/* ============================================================
   PASTEL DAWN — site components (extends kit.css)
   New surfaces: mobile nav, selected work, pricing, proposal
   wizard, inner-page heroes, case studies, FAQ. Tokens only.
   ============================================================ */

/* ---- prominent logo: large at top, shrinks on scroll (header) + big footer ---- */
.nav-inner{height:120px;transition:height var(--dur-med) var(--ease-out);}
.brand img{height:100px;transition:height var(--dur-med) var(--ease-out);}
.nav.scrolled .nav-inner{height:74px;}
.nav.scrolled .brand img{height:46px;}
.footer-brand img,.footer img{height:90px;margin-bottom:22px;}
@media (max-width:560px){
  .nav-inner{height:84px;}
  .brand img{height:62px;}
  .nav.scrolled .nav-inner{height:68px;}
  .nav.scrolled .brand img{height:42px;}
  .footer-brand img,.footer img{height:64px;}
}

/* ---- shared inner spacing helpers ---- */
.section-tight{padding:84px 0;}
.center{text-align:center;}
.section-head.center{margin-left:auto;margin-right:auto;}
.eyebrow .pip{box-shadow:0 0 14px var(--coral),0 0 4px var(--cream);}

/* ============================================================
   NAV — mobile toggle + menu (kit hides .nav-links < 980)
   ============================================================ */
.nav-toggle{
  display:none;width:44px;height:44px;border:1px solid var(--border-strong);
  background:rgba(20,11,38,0.4);border-radius:var(--r-md);color:var(--fg-1);
  align-items:center;justify-content:center;cursor:pointer;flex:none;
  transition:border-color var(--dur-fast),background var(--dur-fast);
}
.nav-toggle:hover{border-color:rgba(248,151,141,0.6);}
.nav-toggle svg{width:22px;height:22px;}
.nav-toggle .x{display:none;}
.nav-toggle[aria-expanded="true"] .menu{display:none;}
.nav-toggle[aria-expanded="true"] .x{display:block;}

.mobile-menu{
  position:fixed;top:78px;left:0;right:0;z-index:49;
  background:rgba(20,11,38,0.96);backdrop-filter:blur(20px) saturate(1.2);
  border-bottom:1px solid var(--border);
  padding:18px 0 26px;
  transform:translateY(-12px);opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity var(--dur-med) var(--ease-out),transform var(--dur-med) var(--ease-out),visibility var(--dur-med);
}
.mobile-menu.open{opacity:1;visibility:visible;transform:none;pointer-events:auto;}
.mobile-menu a{display:block;font-family:var(--font-display);font-weight:500;font-size:1.35rem;color:var(--fg-1);padding:13px 0;border-bottom:1px solid var(--border);}
.mobile-menu a:last-of-type{border-bottom:none;}
.mobile-menu .btn{margin-top:20px;width:100%;justify-content:center;}
.nav-links a[aria-current="page"]{color:var(--fg-1);}
.nav-links a[aria-current="page"]::after{content:"";display:block;height:2px;border-radius:2px;background:var(--grad-dawn);margin-top:5px;}

/* ============================================================
   INNER-PAGE HERO (services, work, case study, proposal)
   ============================================================ */
.page-hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#140B26 0%,#1A1030 60%,#241636 100%);padding:158px 0 78px;border-bottom:1px solid var(--border);}
.page-hero .glow{position:absolute;left:50%;top:-10%;width:760px;height:760px;max-width:120vw;transform:translateX(-50%);border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(248,151,141,0.22),rgba(252,201,162,0.10) 38%,rgba(40,24,59,0) 68%);
  animation:breathe 11s var(--ease-in-out) infinite;}
.page-hero .wrap{position:relative;z-index:2;}
.page-hero.lefty{text-align:left;}
.page-hero-inner{max-width:820px;}
.page-hero.center .page-hero-inner{margin:0 auto;text-align:center;}
.page-hero h1{font-family:var(--font-display);font-weight:600;font-size:var(--t-h1);line-height:1.05;letter-spacing:-0.02em;color:var(--fg-1);margin:18px 0 20px;text-wrap:balance;}
.page-hero h1 .em{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}
.page-hero .lead{font-size:var(--t-lead);line-height:1.6;color:var(--fg-2);max-width:620px;margin:0;}
.page-hero.center .lead{margin:0 auto;}
.page-hero .hero-actions{margin-top:32px;}

/* Breadcrumb */
.crumb{display:flex;align-items:center;gap:10px;font-size:0.85rem;color:var(--fg-3);flex-wrap:wrap;}
.crumb a{color:var(--fg-3);transition:color var(--dur-fast);}
.crumb a:hover{color:var(--coral);}
.crumb svg{width:14px;height:14px;opacity:0.6;}
.crumb .here{color:var(--fg-2);}
.page-hero.center .crumb{justify-content:center;}

/* ============================================================
   SELECTED WORK — featured flagship + 3-col vertical cards
   ============================================================ */
.work{background:linear-gradient(180deg,#241636 0%,#1A1030 100%);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}

/* Featured flagship */
.work-feature{display:grid;grid-template-columns:1.05fr 0.95fr;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-md);margin-bottom:28px;transition:border-color var(--dur-med),box-shadow var(--dur-med),transform var(--dur-med) var(--ease-out);}
.work-feature:hover{border-color:rgba(248,151,141,0.35);box-shadow:var(--sh-lg);}
.work-feature .shot{position:relative;min-height:420px;background:var(--plum-800);}
.work-feature image-slot,.work-card image-slot{width:100%;height:100%;display:block;}
.work-feature .body{padding:48px 46px;display:flex;flex-direction:column;justify-content:center;}
.flag-badge{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;font-family:var(--font-body);font-weight:600;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-on-light);background:var(--grad-dawn);padding:6px 13px;border-radius:var(--r-pill);margin-bottom:20px;}
.flag-badge svg{width:14px;height:14px;}
.work-feature h3{font-family:var(--font-display);font-weight:600;font-size:1.9rem;line-height:1.12;letter-spacing:-0.015em;color:var(--fg-1);margin:0 0 8px;}
.work-feature .kind{font-size:0.85rem;letter-spacing:0.04em;text-transform:uppercase;color:var(--coral);font-weight:600;margin-bottom:18px;}
.work-feature .desc{font-size:1.0625rem;line-height:1.62;color:var(--fg-2);margin:0 0 26px;max-width:46ch;}
.work-stat{display:flex;align-items:baseline;gap:14px;padding:20px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:26px;}
.work-stat .big{font-family:var(--font-display);font-weight:700;font-size:2.4rem;line-height:1;letter-spacing:-0.02em;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}
.work-stat .label{font-size:0.95rem;line-height:1.45;color:var(--fg-2);}
.work-link{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;font-family:var(--font-display);font-weight:600;font-size:1rem;color:var(--fg-1);transition:gap var(--dur-fast) var(--ease-out),color var(--dur-fast);}
.work-link svg{width:18px;height:18px;color:var(--coral);transition:transform var(--dur-fast) var(--ease-out);}
.work-link:hover{color:var(--coral);}
.work-link:hover svg{transform:translateX(4px);}

/* 3-col vertical grid */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.work-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);transition:transform var(--dur-med) var(--ease-out),border-color var(--dur-med),box-shadow var(--dur-med);}
.work-card:hover{transform:translateY(-6px);border-color:rgba(248,151,141,0.35);box-shadow:var(--sh-lg);}
.work-card .shot{position:relative;aspect-ratio:4/3;background:var(--plum-800);overflow:hidden;}
.work-card .body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1;}
.work-card .kind{font-size:0.75rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--coral);font-weight:600;margin-bottom:10px;}
.work-card h3{font-family:var(--font-display);font-weight:600;font-size:1.2rem;line-height:1.2;color:var(--fg-1);margin:0 0 9px;}
.work-card p{font-size:0.92rem;line-height:1.55;color:var(--fg-2);margin:0 0 18px;}
.work-card .work-link{margin-top:auto;font-size:0.92rem;}
.work-card .work-link svg{width:16px;height:16px;}

/* tag chips */
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px;}
.chip{font-size:0.72rem;font-weight:600;letter-spacing:0.04em;color:var(--fg-2);background:var(--on-glass);border:1px solid var(--border);padding:5px 11px;border-radius:var(--r-pill);}

/* image slots: warm on-brand empty state (slot ships a light-bg default) */
.shot-fallback{display:none;}
image-slot::part(frame){
  background:
    radial-gradient(120% 95% at 30% 0%,rgba(248,151,141,0.16),transparent 58%),
    linear-gradient(150deg,#34204B 0%,#1A1030 100%) !important;
}
image-slot::part(empty){color:var(--fg-2);}
image-slot::part(ring){border-color:var(--border-strong);}

/* ============================================================
   PRICING — support plan cards + starting-price table
   ============================================================ */
.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:64px;}
.plan{position:relative;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:34px 30px 32px;box-shadow:var(--sh-md);transition:transform var(--dur-med) var(--ease-out),border-color var(--dur-med),box-shadow var(--dur-med);}
.plan:hover{transform:translateY(-6px);border-color:rgba(248,151,141,0.32);box-shadow:var(--sh-lg);}
.plan.featured{background:linear-gradient(165deg,#3a2455 0%,#211438 100%);border-color:rgba(248,151,141,0.4);}
.plan-flag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);font-family:var(--font-body);font-weight:600;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-on-light);background:var(--grad-dawn);padding:6px 15px;border-radius:var(--r-pill);box-shadow:var(--sh-glow);white-space:nowrap;}
.plan h3{font-family:var(--font-display);font-weight:600;font-size:1.35rem;color:var(--fg-1);margin:0 0 6px;}
.plan .plan-for{font-size:0.9rem;color:var(--fg-3);line-height:1.5;margin:0 0 22px;min-height:2.7em;}
.plan .price{display:flex;align-items:baseline;gap:4px;margin-bottom:6px;}
.plan .price .amt{font-family:var(--font-display);font-weight:700;font-size:2.9rem;line-height:1;letter-spacing:-0.02em;color:var(--fg-1);}
.plan .price .per{font-size:0.95rem;color:var(--fg-3);}
.plan .price .pre{font-size:0.85rem;color:var(--fg-3);align-self:flex-start;margin-top:4px;}
.plan-sub{font-size:0.85rem;color:var(--fg-3);margin:0 0 24px;}
.plan ul{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:12px;flex:1;}
.plan li{display:flex;align-items:flex-start;gap:11px;font-size:0.94rem;line-height:1.45;color:var(--fg-2);}
.plan li svg{width:17px;height:17px;color:var(--coral);flex:none;margin-top:2px;}
.plan .btn{width:100%;justify-content:center;}

/* starting-price table */
.price-table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-md);}
.price-table-head{padding:28px 36px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;}
.price-table-head h3{font-family:var(--font-display);font-weight:600;font-size:1.4rem;color:var(--fg-1);margin:0 0 4px;}
.price-table-head p{font-size:0.92rem;color:var(--fg-3);margin:0;}
.price-row{display:grid;grid-template-columns:1.4fr 2fr auto;gap:24px;align-items:center;padding:22px 36px;border-bottom:1px solid var(--border);transition:background var(--dur-fast);}
.price-row:last-child{border-bottom:none;}
.price-row:hover{background:rgba(248,151,141,0.05);}
.price-row .svc{font-family:var(--font-display);font-weight:600;font-size:1.08rem;color:var(--fg-1);}
.price-row .note{font-size:0.92rem;color:var(--fg-2);line-height:1.5;}
.price-row .from{display:flex;flex-direction:column;align-items:flex-end;white-space:nowrap;}
.price-row .from .lab{font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--fg-3);}
.price-row .from .val{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--coral);letter-spacing:-0.01em;}
.price-note{text-align:center;color:var(--fg-3);font-size:0.95rem;margin:30px auto 0;max-width:600px;line-height:1.6;}

/* ============================================================
   FEATURE / VALUE GRID (service pages, "why us")
   ============================================================ */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.feat-grid.two{grid-template-columns:repeat(2,1fr);}
.feat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px;box-shadow:var(--sh-sm);transition:transform var(--dur-med) var(--ease-out),border-color var(--dur-med);}
.feat:hover{transform:translateY(-4px);border-color:rgba(248,151,141,0.3);}
.feat-ic{width:46px;height:46px;border-radius:13px;background:rgba(248,151,141,0.14);display:flex;align-items:center;justify-content:center;color:var(--coral);margin-bottom:18px;}
.feat-ic svg{width:22px;height:22px;}
.feat h3{font-family:var(--font-display);font-weight:600;font-size:1.15rem;color:var(--fg-1);margin:0 0 9px;}
.feat p{font-size:0.94rem;line-height:1.58;color:var(--fg-2);margin:0;}

/* split content row (image + text) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.split.flip .split-media{order:2;}
.split-media{position:relative;aspect-ratio:5/4;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border);box-shadow:var(--sh-md);background:var(--plum-800);}
.split-media image-slot{width:100%;height:100%;display:block;}
.split-copy h2{margin-bottom:18px;}
.split-copy .lead{margin-bottom:22px;}
.checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;}
.checklist li{display:flex;align-items:flex-start;gap:13px;font-size:1rem;line-height:1.5;color:var(--fg-1);}
.checklist li svg{width:20px;height:20px;color:var(--coral);flex:none;margin-top:2px;}
.checklist li b{font-weight:600;}
.checklist li span{color:var(--fg-2);font-weight:400;}

/* stat band */
.stat-band{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.stat-cell{text-align:center;padding:32px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);}
.stat-cell .big{font-family:var(--font-display);font-weight:700;font-size:clamp(2.2rem,1.6rem+1.6vw,3rem);line-height:1;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}
.stat-cell .lab{font-size:0.92rem;color:var(--fg-2);margin-top:12px;line-height:1.45;}

/* ============================================================
   FAQ accordion
   ============================================================ */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px;}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:border-color var(--dur-fast);}
.faq-item[open]{border-color:rgba(248,151,141,0.3);}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 26px;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:var(--font-display);font-weight:500;font-size:1.1rem;color:var(--fg-1);}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary .ic{width:22px;height:22px;flex:none;color:var(--coral);transition:transform var(--dur-med) var(--ease-out);}
.faq-item[open] summary .ic{transform:rotate(45deg);}
.faq-item .faq-body{padding:0 26px 24px;font-size:1rem;line-height:1.62;color:var(--fg-2);}
.faq-item .faq-body p{margin:0;}

/* ============================================================
   PROPOSAL WIZARD
   ============================================================ */
.wizard-wrap{max-width:760px;margin:0 auto;}
.wizard{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-xl);box-shadow:var(--sh-lg);overflow:hidden;position:relative;}
.wizard-glow{position:absolute;left:50%;top:-180px;width:520px;height:520px;transform:translateX(-50%);border-radius:50%;pointer-events:none;background:radial-gradient(circle,rgba(248,151,141,0.16),rgba(40,24,59,0) 66%);}

/* progress */
.wiz-progress{position:relative;display:flex;gap:0;padding:24px 36px 0;}
.wiz-step-dot{flex:1;display:flex;flex-direction:column;gap:10px;}
.wiz-step-dot .bar{height:4px;border-radius:2px;background:var(--border);overflow:hidden;}
.wiz-step-dot .bar i{display:block;height:100%;width:0;background:var(--grad-dawn);border-radius:2px;transition:width var(--dur-slow) var(--ease-out);}
.wiz-step-dot.done .bar i,.wiz-step-dot.active .bar i{width:100%;}
.wiz-step-dot.active .bar i{width:100%;}
.wiz-step-dot .lab{font-size:0.78rem;font-weight:600;letter-spacing:0.04em;color:var(--fg-3);transition:color var(--dur-med);padding-right:14px;}
.wiz-step-dot.active .lab,.wiz-step-dot.done .lab{color:var(--fg-1);}

/* step panels */
.wiz-body{padding:34px 40px 12px;position:relative;z-index:1;}
.wiz-step{display:none;animation:wizin var(--dur-med) var(--ease-out);border:0;margin:0;padding:0;min-width:0;}
.wiz-step.active{display:block;}
@keyframes wizin{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}
.wiz-step .step-eyebrow{font-family:var(--font-body);font-weight:600;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--coral);margin-bottom:10px;}
.wiz-step h2{font-family:var(--font-display);font-weight:600;font-size:1.55rem;line-height:1.15;color:var(--fg-1);margin:0 0 6px;letter-spacing:-0.01em;}
.wiz-step .step-help{font-size:0.98rem;color:var(--fg-2);margin:0 0 26px;line-height:1.55;}

/* option cards (radio) */
.opt-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.opt{position:relative;display:flex;align-items:flex-start;gap:14px;padding:20px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-deep);cursor:pointer;transition:border-color var(--dur-fast),background var(--dur-fast),transform var(--dur-fast) var(--ease-out);}
.opt:hover{border-color:rgba(248,151,141,0.45);transform:translateY(-2px);}
.opt input{position:absolute;opacity:0;pointer-events:none;}
.opt .opt-ic{width:42px;height:42px;flex:none;border-radius:11px;background:rgba(248,151,141,0.14);display:flex;align-items:center;justify-content:center;color:var(--coral);transition:background var(--dur-fast);}
.opt .opt-ic svg{width:21px;height:21px;}
.opt .opt-tt{display:block;font-family:var(--font-display);font-weight:600;font-size:1.02rem;color:var(--fg-1);line-height:1.2;margin-bottom:4px;}
.opt .opt-dd{display:block;font-size:0.85rem;color:var(--fg-2);line-height:1.45;}
.opt .opt-check{position:absolute;top:14px;right:14px;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--border-strong);display:flex;align-items:center;justify-content:center;transition:all var(--dur-fast);}
.opt .opt-check svg{width:13px;height:13px;color:var(--fg-on-light);opacity:0;transition:opacity var(--dur-fast);}
.opt input:checked ~ .opt-check{background:var(--grad-dawn);border-color:transparent;}
.opt input:checked ~ .opt-check svg{opacity:1;}
.opt:has(input:checked){border-color:rgba(248,151,141,0.65);background:rgba(248,151,141,0.07);}
.opt:has(input:checked) .opt-ic{background:rgba(248,151,141,0.26);}
.opt input:focus-visible ~ .opt-check{outline:2px solid var(--coral);outline-offset:2px;}

/* budget pills (single col list) */
.opt-grid.one{grid-template-columns:1fr;}
.opt.row{align-items:center;}
.opt.row .opt-tt{margin-bottom:0;}

/* form fields */
.field{margin-bottom:20px;}
.field label{display:block;font-size:0.9rem;font-weight:600;color:var(--fg-1);margin-bottom:8px;}
.field label .req{color:var(--coral);}
.field input,.field textarea,.field select{
  width:100%;font-family:var(--font-body);font-size:1rem;color:var(--fg-1);
  background:var(--bg-deep);border:1px solid var(--border-strong);border-radius:var(--r-md);
  padding:13px 16px;transition:border-color var(--dur-fast),box-shadow var(--dur-fast);
}
.field textarea{resize:vertical;min-height:120px;line-height:1.55;}
.field input::placeholder,.field textarea::placeholder{color:var(--fg-3);}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px rgba(248,151,141,0.18);}
.field.err input,.field.err textarea{border-color:#F0746C;box-shadow:0 0 0 3px rgba(240,116,108,0.2);}
.field .errmsg{display:none;font-size:0.82rem;color:#F8978D;margin-top:7px;}
.field.err .errmsg{display:block;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}

/* review summary */
.review{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:var(--bg-deep);margin-bottom:8px;}
.review-row{display:flex;justify-content:space-between;gap:20px;padding:15px 20px;border-bottom:1px solid var(--border);font-size:0.95rem;}
.review-row:last-child{border-bottom:none;}
.review-row .k{color:var(--fg-3);font-weight:600;}
.review-row .v{color:var(--fg-1);text-align:right;}

/* nav buttons */
.wiz-foot{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:22px 40px 32px;}
.wiz-foot .btn-back{background:transparent;border:none;color:var(--fg-2);font-family:var(--font-body);font-weight:600;font-size:0.95rem;cursor:pointer;display:inline-flex;align-items:center;gap:8px;padding:10px 6px;transition:color var(--dur-fast);}
.wiz-foot .btn-back svg{width:17px;height:17px;}
.wiz-foot .btn-back:hover{color:var(--fg-1);}
.wiz-foot .btn-back:disabled{opacity:0;pointer-events:none;}
.wiz-count{font-size:0.85rem;color:var(--fg-3);font-weight:600;}

/* success */
.wiz-success{display:none;padding:64px 40px 72px;text-align:center;animation:wizin var(--dur-med) var(--ease-out);}
.wiz-success.show{display:block;}
.wiz-success .ok{width:78px;height:78px;border-radius:50%;background:var(--grad-dawn);display:flex;align-items:center;justify-content:center;margin:0 auto 26px;box-shadow:var(--sh-glow);}
.wiz-success .ok svg{width:38px;height:38px;color:var(--fg-on-light);}
.wiz-success h2{font-family:var(--font-display);font-weight:600;font-size:1.8rem;color:var(--fg-1);margin:0 0 12px;}
.wiz-success p{font-size:1.05rem;color:var(--fg-2);max-width:420px;margin:0 auto 28px;line-height:1.6;}

/* contact rail beside the wizard intro */
.contact-rail{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:760px;margin:0 auto 44px;}
.contact-tile{display:flex;align-items:center;gap:14px;padding:18px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);transition:border-color var(--dur-fast),transform var(--dur-fast) var(--ease-out);}
.contact-tile:hover{border-color:rgba(248,151,141,0.35);transform:translateY(-3px);}
.contact-tile .ic{width:40px;height:40px;flex:none;border-radius:11px;background:rgba(248,151,141,0.14);display:flex;align-items:center;justify-content:center;color:var(--coral);}
.contact-tile .ic svg{width:19px;height:19px;}
.contact-tile > span:last-child{display:flex;flex-direction:column;min-width:0;}
.contact-tile .lab{display:block;font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--fg-3);margin-bottom:2px;}
.contact-tile .val{display:block;font-size:0.95rem;color:var(--fg-1);font-weight:600;word-break:break-word;}

/* ============================================================
   CASE STUDY detail
   ============================================================ */
.cs-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:36px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:0;}
.cs-meta .m .lab{font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--fg-3);margin-bottom:8px;}
.cs-meta .m .val{font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--fg-1);line-height:1.35;}
.cs-shot{position:relative;aspect-ratio:16/9;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border);box-shadow:var(--sh-lg);background:var(--plum-800);}
.cs-shot image-slot{width:100%;height:100%;display:block;}
.cs-body{max-width:760px;margin:0 auto;}
.cs-body h2{font-family:var(--font-display);font-weight:600;font-size:1.7rem;color:var(--fg-1);margin:48px 0 16px;letter-spacing:-0.01em;}
.cs-body h2:first-child{margin-top:0;}
.cs-body p{font-size:1.0625rem;line-height:1.7;color:var(--fg-2);margin:0 0 18px;}
.cs-body p strong{color:var(--fg-1);font-weight:600;}
.cs-shot-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.cs-shot-row .cs-shot{aspect-ratio:4/3;}

/* generic two-up gallery slots */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .nav-toggle{display:flex;}
  .nav-cta .btn{display:none;}
  .work-feature{grid-template-columns:1fr;}
  .work-feature .shot{min-height:280px;}
  .work-feature .body{padding:34px 30px;}
  .work-grid{grid-template-columns:1fr 1fr;}
  .plans-grid{grid-template-columns:1fr;max-width:440px;margin-left:auto;margin-right:auto;}
  .feat-grid,.feat-grid.two{grid-template-columns:1fr 1fr;}
  .split{grid-template-columns:1fr;gap:34px;}
  .split.flip .split-media{order:0;}
  .stat-band{grid-template-columns:1fr;gap:16px;}
  .cs-meta{grid-template-columns:1fr 1fr;gap:26px;}
  .contact-rail{grid-template-columns:1fr;max-width:420px;}
}
@media (max-width:620px){
  .work-grid{grid-template-columns:1fr;}
  .feat-grid,.feat-grid.two{grid-template-columns:1fr;}
  .opt-grid{grid-template-columns:1fr;}
  .field-row{grid-template-columns:1fr;}
  .price-row{grid-template-columns:1fr;gap:8px;padding:20px 22px;}
  .price-row .from{align-items:flex-start;margin-top:6px;}
  .price-table-head{padding:22px;}
  .wiz-body{padding:26px 22px 8px;}
  .wiz-progress{padding:20px 22px 0;}
  .wiz-foot{padding:18px 22px 26px;}
  .wiz-step-dot .lab{display:none;}
  .cs-shot-row,.gallery{grid-template-columns:1fr;}
  .cs-meta{grid-template-columns:1fr;}
  .page-hero{padding:128px 0 60px;}
}

/* Real project images dropped into .shot frames (replaces design-tool image-slots) */
.shot{overflow:hidden;}
.shot-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:1;}
.shot-img.contain{object-fit:contain;padding:7%;background:var(--plum-800);}

/* ============================================================
   Peach monochrome to color image treatment
   Project images sit in a warm monochrome peach duotone by default,
   then bloom to full color when their card or figure is hovered.
   ============================================================ */
.shot .shot-img{
  filter:grayscale(1) sepia(0.55) saturate(1.3) hue-rotate(-18deg) brightness(1.02);
  transition:filter var(--dur-slow) var(--ease-out);
}
.work-card:hover .shot-img,
.work-card:focus-within .shot-img,
.work-feature:hover .shot-img,
.work-feature:focus-within .shot-img,
.shot:hover .shot-img{
  filter:none;
}
@media (prefers-reduced-motion: reduce){
  .shot-img{transition:none;}
}

/* ============================================================
   Case-study modal (in-page view of a case-*.html page)
   ============================================================ */
.case-modal{
  position:fixed;
  inset:0;
  z-index:1000;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:clamp(16px,4vw,56px) clamp(12px,4vw,40px);
  background:rgba(10,5,20,0.74);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  overflow-y:auto;
  overscroll-behavior:contain;
  animation:caseModalFade var(--dur-fast) var(--ease-out);
}
@keyframes caseModalFade{from{opacity:0;}to{opacity:1;}}

.case-modal-panel{
  position:relative;
  width:100%;
  max-width:1040px;
  max-height:calc(100vh - clamp(32px,8vw,112px));
  background:var(--bg);
  border:1px solid var(--border-strong);
  border-radius:var(--r-xl);
  box-shadow:var(--sh-lg);
  overflow-y:auto;
  overscroll-behavior:contain;
  outline:none;
  animation:caseModalRise var(--dur-med) var(--ease-out);
}
@keyframes caseModalRise{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:translateY(0);}}

.case-modal-close{
  position:absolute;
  top:16px;
  right:16px;
  z-index:5;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border-radius:var(--r-pill);
  border:1px solid var(--border-strong);
  background:rgba(20,11,38,0.72);
  color:var(--fg-1);
  cursor:pointer;
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out);
}
.case-modal-close:hover{background:var(--grad-dawn);color:var(--fg-on-light);border-color:transparent;}
.case-modal-close:focus-visible{outline:2px solid var(--coral);outline-offset:2px;}
.case-modal-close i,.case-modal-close svg{width:22px;height:22px;}

.case-modal-content{display:block;}

/* The injected case page has a tall hero meant for a full page.
   Tighten it so it does not dominate the modal. */
.case-modal .page-hero{padding:40px 0 36px;}
.case-modal .page-hero .crumb{display:none;}
/* Injected case content must show immediately: the page-level scroll-reveal
   observer only tracks nodes present at load, not the fetched modal content. */
.case-modal .reveal{opacity:1;transform:none;}

.case-modal-loading,
.case-modal-error{
  padding:80px 32px;
  text-align:center;
  color:var(--fg-2);
  font-family:var(--font-body);
}
.case-modal-error a{color:var(--coral);}

@media (max-width:560px){
  .case-modal-panel{border-radius:var(--r-lg);}
  .case-modal .page-hero{padding:32px 0 28px;}
}
@media (prefers-reduced-motion: reduce){
  .case-modal,.case-modal-panel{animation:none;}
  .case-modal-close{transition:none;}
}

/* ============================================================
   Case-study imagery (hero + gallery): natural aspect ratio,
   full color, no peach treatment. Mirrors the old site's
   project gallery (width:100%; height:auto; no forced ratio,
   no cropping). The peach rollover stays on portfolio
   thumbnails (.shot .shot-img) only.
   ============================================================ */
.cs-shot{aspect-ratio:auto;overflow:visible;border:0;box-shadow:none;background:transparent;}
.cs-shot .shot-img{
  position:static;
  width:100%;
  height:auto;
  border-radius:var(--r-xl);
  box-shadow:var(--sh-lg);
  filter:none !important;
}
.gallery{
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:20px;
  align-items:start;
}
.gallery figure{margin:0;aspect-ratio:auto !important;overflow:visible;}
.gallery .shot-img{border-radius:var(--r-lg);box-shadow:var(--sh-md);}
.gallery figcaption,.gallery .cap{
  font-size:0.85rem;color:var(--fg-2);margin-top:8px;line-height:1.45;
}

/* ============================================================
   Nav dropdowns (Services + Contact), restored from the old site
   ============================================================ */
.nav-item.has-dropdown{position:relative;display:flex;align-items:center;}
.nav-drop-toggle{
  display:inline-flex;align-items:center;gap:5px;
  font-family:inherit;font-size:15px;font-weight:500;
  color:var(--fg-2);background:none;border:0;padding:0;cursor:pointer;
  transition:color var(--dur-fast) var(--ease-out);
}
.nav-drop-toggle:hover,
.nav-item.has-dropdown:hover .nav-drop-toggle,
.nav-drop-toggle[aria-expanded="true"]{color:var(--fg-1);}
.nav-drop-toggle .caret{width:15px;height:15px;transition:transform var(--dur-fast) var(--ease-out);}
.nav-item.has-dropdown:hover .caret,
.nav-drop-toggle[aria-expanded="true"] .caret{transform:rotate(180deg);}
/* invisible hover bridge so the menu does not close in the gap below the label */
.nav-item.has-dropdown::after{content:"";position:absolute;top:100%;left:-12px;right:-12px;height:16px;}
.nav-dropdown{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translate(-50%,8px);
  min-width:300px;padding:10px;
  background:rgba(26,16,48,0.98);backdrop-filter:blur(20px) saturate(1.2);
  border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-lg);
  display:flex;flex-direction:column;gap:2px;z-index:60;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out), visibility var(--dur-fast);
}
.nav-item.has-dropdown:hover .nav-dropdown,
.nav-item.has-dropdown:focus-within .nav-dropdown,
.nav-dropdown.open{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,0);}
.nav-dropdown a{
  display:flex;align-items:flex-start;gap:12px;
  padding:10px 12px;border-radius:var(--r-md);
  color:var(--fg-2);font-size:14px;font-weight:500;line-height:1.3;
  transition:background var(--dur-fast), color var(--dur-fast);
}
.nav-dropdown a:hover{background:rgba(248,151,141,0.10);color:var(--fg-1);}
.nav-dropdown a i,.nav-dropdown a svg{width:20px;height:20px;flex:none;margin-top:1px;color:var(--coral);}
.nav-dropdown a span{display:flex;flex-direction:column;gap:2px;}
.nav-dropdown a strong{font-weight:600;color:var(--fg-1);font-size:14px;}
.nav-dropdown a em{font-style:normal;font-size:12.5px;color:var(--fg-2);opacity:0.82;}
.nav-dropdown-contact{min-width:248px;}
.nav-dropdown-contact a{align-items:center;}

/* Mobile menu: grouped service + contact sub-items */
.mobile-menu .mm-label{
  display:block;font-family:var(--font-body);font-weight:700;
  font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--coral);padding:16px 0 4px;
}
.mobile-menu a.mm-sub{
  font-family:var(--font-body);font-size:1.02rem;font-weight:500;
  color:var(--fg-2);padding:9px 0 9px 14px;border-bottom:none;
}
.mobile-menu a.mm-sub:hover{color:var(--fg-1);}

/* ============================================================
   Before / after comparison slider (restored from the old site)
   ============================================================ */
.comparison-slider{position:relative;width:100%;overflow:hidden;border-radius:var(--r-xl);box-shadow:var(--sh-lg);cursor:ew-resize;user-select:none;touch-action:none;}
.comparison-slider img{display:block;width:100%;height:auto;pointer-events:none;}
.comparison-after{position:relative;width:100%;}
.comparison-after img{width:100%;height:auto;display:block;}
.comparison-before{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;clip-path:inset(0 50% 0 0);}
.comparison-before img{width:100%;height:100%;object-fit:cover;object-position:left top;}
.comparison-handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:var(--cream);transform:translateX(-50%);pointer-events:none;box-shadow:0 0 0 1px rgba(0,0,0,0.18);}
.comparison-handle::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:var(--cream);box-shadow:var(--sh-md);}
.comparison-handle::after{content:"\2039\2009\203A";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:17px;font-weight:700;color:var(--plum-900);}
.comparison-label{position:absolute;bottom:14px;padding:6px 12px;border-radius:999px;background:rgba(20,11,38,0.82);backdrop-filter:blur(6px);color:var(--fg-1);font-size:0.74rem;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;pointer-events:none;}
.comparison-label-before{left:14px;}
.comparison-label-after{right:14px;}
.comparison-caption{text-align:center;margin-top:14px;font-size:0.9rem;color:var(--fg-2);}
@media (max-width:560px){
  .comparison-handle::before{width:38px;height:38px;}
  .comparison-label{font-size:0.68rem;padding:5px 10px;}
}

/* ============================================================
   Whole service card clickable (the Explore link covers the card)
   ============================================================ */
.svc-card{position:relative;}
/* Stretched link: the ::after must resolve against .svc-card (the positioned
   ancestor), so the cover link itself must NOT be positioned. */
.svc-card .card-cover::after{content:"";position:absolute;inset:0;z-index:1;}

/* ============================================================
   Pricing toggle: sliding bouncy indicator
   ============================================================ */
.cw-toggle-ind{
  position:absolute;top:6px;bottom:6px;left:0;width:0;
  border-radius:var(--r-pill);background:var(--grad-dawn);
  z-index:0;pointer-events:none;
  transition:left .5s cubic-bezier(.34,1.56,.64,1), width .5s cubic-bezier(.34,1.56,.64,1);
}
.cw-toggle-opt{position:relative;z-index:1;}
@media (prefers-reduced-motion: reduce){
  .cw-toggle-ind{transition:none;}
}

/* ============================================================
   "Whatever you build next" CTA card. Same shape as .work-card,
   the PD mark fills the image slot, and it reads a touch shinier.
   ============================================================ */
.work-cta{text-decoration:none;border-color:rgba(248,151,141,0.4);}
.work-cta:hover{border-color:rgba(248,151,141,0.65);}
.work-cta .shot{
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at 50% 42%, rgba(248,151,141,0.30), rgba(20,11,38,0) 68%),
    linear-gradient(165deg, rgba(248,151,141,0.12), rgba(199,155,180,0.05));
}
.work-cta .cta-glow{
  position:absolute;top:50%;left:50%;width:200px;height:200px;border-radius:50%;
  background:var(--grad-dawn);filter:blur(52px);opacity:0.34;transform:translate(-50%,-50%);
  pointer-events:none;transition:opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out);
}
.work-cta:hover .cta-glow{opacity:0.52;transform:translate(-50%,-50%) scale(1.18);}
.work-cta .cta-mark{position:relative;z-index:1;width:62%;max-width:230px;height:auto;animation:ctaFloat 4.6s ease-in-out infinite;}
.work-cta .cta-mark img{width:100%;height:auto;display:block;object-fit:contain;filter:drop-shadow(0 12px 30px rgba(248,151,141,0.5));}
/* shine sweep across the mark on hover */
.work-cta .shot::after{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(115deg, transparent 35%, rgba(255,255,255,0.22) 50%, transparent 65%);
  transform:translateX(-130%);transition:transform .9s var(--ease-out);
}
.work-cta:hover .shot::after{transform:translateX(130%);}
.work-cta:hover .work-link svg{transform:translateX(4px);}
@keyframes ctaFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
@media (prefers-reduced-motion: reduce){
  .work-cta .cta-mark{animation:none;}
  .work-cta .cta-glow,.work-cta .shot::after{transition:none;}
}

/* ============================================================
   Mobile fixes (nav clearance, hero flow, email sizing)
   ============================================================ */
@media (max-width:760px){
  /* Hero content is taller than a phone viewport, so bottom-aligning it
     pushed the headline under the fixed nav. Flow it from below the nav. */
  .hero{min-height:auto;justify-content:flex-start;padding-top:114px;padding-bottom:56px;}
  .hero-content{padding-top:18px;padding-bottom:24px;}
  /* Drop the build-strip lower so it is not bunched against the CTA buttons. */
  .build-strip-wrap{margin-top:34px;padding-bottom:8px;}
}
@media (max-width:560px){
  .contact-tile .val{font-size:0.84rem;}
}
