/* EnvMart Services (PrestaShop 9) - fully namespaced to avoid conflicts */
.envm9-mt40{margin-top:40px}
.envm9-layout{
  display:grid;
  grid-template-columns: 280px 1fr 340px;
  gap:24px;
}
@media (max-width: 1200px){
  .envm9-layout{grid-template-columns: 260px 1fr}
  .envm9-right{display:none}
}
@media (max-width: 768px){
  .envm9-layout{grid-template-columns: 1fr}
  .envm9-sidebar{position:relative; top:auto}
  .envm9-right{display:block}
}

.envm9-sidebar,.envm9-right{
  background:#fff;
  border-radius:16px;
  padding:16px;
  box-shadow:0 10px 28px rgba(0,0,0,.05);
}
.envm9-sidebar{position:sticky; top:84px; height:fit-content}
.envm9-title{font-size:18px; font-weight:700; margin-bottom:12px}
.envm9-muted{color:#6b7280; font-size:13px}
.envm9-catlist{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:6px}
.envm9-catitem{border-radius:10px}
.envm9-catlink{
  display:block;
  padding:10px 12px;
  border-radius:10px;
  text-decoration:none;
  color:#111827;
  background:#fff;
}
.envm9-catlink:hover{background:#eef1ff; color:#3342ff}

.envm9-services{display:flex; flex-direction:column; gap:16px}
.envm9-card{
  display:flex;
  gap:16px;
  background:#fff;
  border-radius:18px;
  padding:16px;
  box-shadow:0 10px 28px rgba(0,0,0,.06);
}
.envm9-card-media{text-decoration:none}
.envm9-card-img{
  width:140px; height:140px;
  border-radius:14px;
  background:#f3f4f6;
  background-size:cover;
  background-position:center;
}
.envm9-card-body{flex:1; min-width:0}
.envm9-card-title{font-size:18px; font-weight:800; margin:2px 0 8px}
.envm9-card-titlelink{text-decoration:none; color:#0f172a}
.envm9-card-titlelink:hover{color:#3342ff}
.envm9-card-desc{color:#334155; font-size:14px; max-height:44px; overflow:hidden}
.envm9-meta{display:flex; justify-content:space-between; align-items:center; margin:10px 0 12px}
.envm9-pill{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 10px;
  border-radius:999px;
  background:#f1f5ff;
  color:#3342ff;
  font-weight:700;
  font-size:12px;
}
.envm9-price{font-weight:900; color:#0f172a}
.envm9-actions{display:flex; gap:10px; flex-wrap:wrap}
.envm9-btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px;
  border-radius:12px;
  font-weight:800;
  text-decoration:none;
  cursor:pointer;
  border:1px solid transparent;
}
.envm9-btn-outline{background:#fff; border-color:#e5e7eb; color:#111827}
.envm9-btn-outline:hover{border-color:#c7d2fe; color:#3342ff}
.envm9-btn-primary{background:#3342ff; color:#fff}
.envm9-btn-primary:hover{filter:brightness(.95)}

.envm9-box{background:#fff; border:1px solid #eef2ff; border-radius:16px; padding:16px; margin-bottom:16px}
.envm9-box-title{font-weight:900; margin-bottom:10px}
.envm9-list{margin:0; padding-left:18px}
.envm9-empty{background:#fff; border-radius:16px; padding:18px; box-shadow:0 10px 28px rgba(0,0,0,.04)}

/* Product subscription widget */
.envm9-subbox{
  margin-top:18px;
  border-radius:18px;
  background:#fff;
  border:1px solid #eef2ff;
  padding:16px;
}
.envm9-subbox-head{display:flex; flex-direction:column; gap:6px; margin-bottom:12px}
.envm9-subbox-title{font-weight:900; font-size:16px}
.envm9-subbox-note{color:#6b7280; font-size:13px}
.envm9-subform{display:grid; grid-template-columns: 1fr 1fr; gap:12px}
@media (max-width: 600px){.envm9-subform{grid-template-columns:1fr}}
.envm9-field{display:flex; flex-direction:column; gap:6px}
.envm9-label{font-weight:800; font-size:13px}
.envm9-select,.envm9-input{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid #e5e7eb;
  outline:none;
}
.envm9-select:focus,.envm9-input:focus{border-color:#c7d2fe; box-shadow:0 0 0 4px rgba(51,66,255,.12)}
.envm9-savehint{grid-column:1/-1; color:#6b7280; font-size:12px}

/* Customer dashboard */
.envm9-dashboard{max-width:1200px; margin:30px auto; padding:0 12px}
.envm9-h1{font-size:28px; margin:0 0 6px}
.envm9-dashgrid{display:grid; grid-template-columns: 1fr 1fr; gap:16px; margin-top:16px}
@media (max-width: 900px){.envm9-dashgrid{grid-template-columns:1fr}}
.envm9-panel{
  background:#fff; border-radius:18px; padding:16px;
  box-shadow:0 10px 28px rgba(0,0,0,.05);
}
.envm9-panel-wide{grid-column:1/-1}
.envm9-panel-title{font-weight:900; margin-bottom:10px}
.envm9-table{display:flex; flex-direction:column; gap:8px}
.envm9-tr{display:grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr 1fr; gap:10px; align-items:center; padding:10px; border-radius:12px; border:1px solid #f1f5f9}
.envm9-th{background:#f8fafc; font-weight:900}
@media (max-width: 900px){.envm9-tr{grid-template-columns:1fr; gap:6px}}
.envm9-strong{font-weight:900}
.envm9-visit{border:1px solid #f1f5f9; border-radius:16px; padding:12px; margin-bottom:10px}
.envm9-visit-top{display:flex; justify-content:space-between; align-items:center; margin-bottom:10px}
.envm9-visit-date{font-weight:900}
.envm9-engineer{display:flex; gap:12px; align-items:center}
.envm9-avatar{
  width:56px; height:56px;
  border-radius:50%;
  background:#e5e7eb;
  background-size:cover;
  background-position:center;
  display:flex; align-items:center; justify-content:center;
  font-size:22px;
}
.envm9-avatar-fallback{background:#eef2ff; color:#3342ff}
.envm9-notes{margin-top:8px; color:#334155}

/* Account link */
.envm9-account-link{
  display:flex; align-items:center; gap:10px;
  padding:10px 12px;
  border-radius:14px;
  text-decoration:none;
  background:#fff;
  border:1px solid #eef2ff;
}
.envm9-account-link:hover{border-color:#c7d2fe}
.envm9-account-ico{display:inline-flex; width:28px; height:28px; border-radius:8px; align-items:center; justify-content:center; background:#eef2ff}

/* Calendar modal */
.envm9-modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(15,23,42,.45);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:9999;
}
.envm9-modal{
  width:100%;
  max-width:420px;
  background:#fff;
  border-radius:20px;
  padding:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.2);
}
.envm9-modal-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:12px;
}
.envm9-modal-title{
  font-weight:900;
  font-size:18px;
}
.envm9-modal-close{
  background:none;
  border:none;
  font-size:24px;
  cursor:pointer;
}
.envm9-modal-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:16px;
}