/* ===========================
   Service Detail Styles (svc)
   =========================== */

/* --- Design tokens --- */
:root{
  --svc-primary:#10459c;
  --svc-accent:#ff9800;
  --svc-text:#0e1328;
  --svc-muted:#5f6b85;
  --svc-stroke:#e6edff;
  --svc-card:#ffffff;
  --svc-bg:#f7fbff;
  --svc-shadow:0 12px 36px rgba(16,69,156,.08);
  --svc-radius:16px;
}

/* --- Breadcrumb --- */
.svc-breadcrumb{ background:#fff; border-bottom:1px solid #eef2ff; }
.svc-breadcrumb .container{ padding:10px 0; }
.svc-breadcrumb ol{ list-style:none; margin:0; padding:0; display:flex; gap:8px; flex-wrap:wrap; }
.svc-breadcrumb a{ color:var(--svc-primary); text-decoration:none; }
.svc-breadcrumb li:not(:last-child)::after{ content:"›"; color:#9aa6c0; margin-left:6px; }

/* --- Page canvas (soft wash) --- */
.svc-wrap{
  background:
    radial-gradient(1100px 420px at 10% -10%, #eef4ff 14%, transparent 60%),
    radial-gradient(900px 360px at 110% -20%, #f5f9ff 18%, transparent 70%),
    var(--svc-bg);
  padding: 24px 0 60px;
}

/* Ensure sticky is not broken by overflow on ancestors */
.svc-wrap,
.svc-wrap .container,
.svc-layout,
.svc-right{ overflow:visible; }

/* --- Top-level 2-column layout (left content + right sticky form) --- */
.svc-layout{
  display:grid;
  grid-template-columns: minmax(0,1fr) 380px;  /* left flexible, right fixed */
  gap: 28px;
  align-items: start;
}


@media (max-width: 1024px){
  .svc-layout{ grid-template-columns: 1fr; }
}

/* --- Hero card --- */
.svc-hero-block{
  position:relative;
  
  padding: 18px 18px 12px;
  display:flex; align-items:flex-start; gap:16px;
  margin-bottom: 8px;
}
.svc-hero-text h1{
  font-size: 2.2rem; color: var(--svc-primary);
  letter-spacing:.2px; margin: 4px 0 8px;
}
.badge{
  display:inline-block; font-size:.8rem; padding:4px 25px; border-radius:8px;
  margin-left:.5rem; background:#fff3e0; color:#d97706; border:1px solid #ffe2b8;
}
.lead{ color:var(--svc-muted); margin:0 0 10px; }
.rating{ display:flex; align-items:center; gap:10px; color:#2b3a66; margin:6px 0 2px; }
.stars{ color:#ffb400; letter-spacing:2px; font-size:1rem; }
.svc-hero-art{ margin-left:auto; opacity:.75; filter: drop-shadow(0 6px 18px rgba(16,69,156,.12)); }
@media (max-width: 540px){ .svc-hero-art{ display:none; } }

/* --- Reusable card --- */
.svc-card{
  background:#fff; border:1px solid var(--svc-stroke);
  border-radius: var(--svc-radius);
  padding: 18px;
  box-shadow: var(--svc-shadow);
}
.svc-left > .svc-card + .svc-card{ margin-top: 12px; }

/* --- Checklists / bullets with green ticks --- */
.svc-list{ list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.svc-list li{ position:relative; padding-left:22px; color:#2c3958; }
.svc-list li::before{
  content:""; position:absolute; left:0; top:6px; width:14px; height:14px; border-radius:5px;
  background:linear-gradient(135deg,#43e97b,#38f9d7);
  -webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="white" d="M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.5z"/></svg>') center/14px 14px no-repeat;
          mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="white" d="M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.5z"/></svg>') center/14px 14px no-repeat;
}

/* --- Chips --- */
.chips{ display:flex; flex-wrap:wrap; gap:8px; }
.chip{
  background: #a3aaf342; border:1px solid var(--svc-stroke);
  padding:8px 12px; border-radius:999px; font-size:.82rem; color:#2c3958;
}

/* --- Timeline --- */
.timeline{ list-style:none; margin:0; padding:0; display:grid; gap:12px; }
.timeline li{ display:grid; grid-template-columns: 36px 1fr; align-items:start; gap:10px; }
.t-icon{
  width:36px; height:36px; border-radius:999px; display:grid; place-items:center;
  background:#eef4ff; color:var(--svc-primary); border:1px solid #dfe6ff; font-size:18px;
}
.t-body strong{ color:#1a2644; display:block; margin-bottom:2px; }
.t-body p{ color:var(--svc-muted); margin:0; }

/* --- FAQ (accordion style) --- */
.faq{ border:1px solid var(--svc-stroke); border-radius:12px; padding:10px 12px; margin:8px 0; background:#fff; }
.faq > summary{ list-style:none; cursor:pointer; font-weight:600; color:#1b2645; outline:none; }
.faq > summary::-webkit-details-marker{ display:none; }
.faq[open] > summary{ color:var(--svc-primary); }
.faq__body{ margin-top:8px; color:#48567a; }

/* --- Mini why + CTA --- */
.svc-why{
  background:#fff; border:1px solid var(--svc-stroke); border-radius:var(--svc-radius);
  padding:16px; box-shadow:var(--svc-shadow); margin-top:12px;
  display:flex; gap:10px; flex-wrap:wrap; align-items:center;
}
.why-pill{
  background:#fff; border:1px solid var(--svc-stroke);
  padding:8px 12px; border-radius:999px; font-size:.92rem;
  box-shadow:0 6px 18px rgba(16,69,156,.06);
}
.svc-cta-btn{ margin-left:auto; }

/* --- Buttons & fields --- */
.btn{ display:inline-block; padding:12px 16px; border-radius:10px; font-weight:600; border:2px solid transparent; cursor:pointer; text-decoration:none; }
.btn-block{ width:100%; }
.btn-primary{ background: #ff8823; color:#fff; }
.btn-primary:hover{ background:#0d3f8d; }
.btn-outline{ border-color: var(--svc-primary); color: var(--svc-primary); background:transparent; }
.btn-outline:hover{ background: var(--svc-primary); color:#fff; }
.svc-wa{ display:inline-block; margin-top:10px; font-size:.95rem; color:#0b8f35; text-decoration:none; }

.field{ margin-bottom:10px; }
.field input, .field select, .field textarea{
  width:100%; border:1px solid #dfe6ff; background:#fff; border-radius:10px;
  padding:10px 12px; font: inherit; color:#233056; outline:none;
}
.field input:focus, .field select:focus, .field textarea:focus{
  border-color:#b9ccff; box-shadow:0 0 0 3px rgba(16,69,156,.08);
}

/* --- LEFT: two independent vertical stacks (no grid gaps) --- */
.svc-left-cols{
  display:flex;
  gap:18px;
  align-items:flex-start;
}
.svc-lcol,
.svc-rcol{
  display:flex;
  flex-direction:column;
  gap:18px;
}
.svc-lcol{ flex: 1.12; }   /* wider like the mock */
.svc-rcol{ flex: 0.88; }

/* Make why-box match cards visually when inside left stacks */
.svc-left-cols .svc-why{
  box-shadow: var(--svc-shadow);
  border-radius: var(--svc-radius);
  border: 1px solid var(--svc-stroke);
  background:#fff;
}

/* --- RIGHT: sticky form --- */
.svc-right{ min-width:0; }
.svc-sticky{
  position: sticky;
  top: 92px;      /* adjust if your header height differs */
  z-index: 2;
}
@media (max-width: 1024px){
  .svc-sticky{ position: static; }
  .svc-layout{ gap: 20px; }
}

/* --- Mobile polish --- */
@media (max-width: 992px){
  .svc-left-cols{ flex-direction:column; gap:14px; }
}
@media (max-width: 767px){
  .svc-hero-text h1{ font-size:1.7rem; }
  .svc-card, .svc-hero-block{ border-radius:14px; }
}

.btn-primary {
    background: #ff8823;
    color: #fff;
}
