/* ===================================================================
   StitchMedic — style.css
   =================================================================== */
:root{
  --brown:#3E2A1E;
  --brown-deep:#2A1C13;
  --amber:#D4A017;
  --amber-bright:#E8B424;
  --cream:#F7F1E8;
  --cream-2:#EFE6D6;
  --charcoal:#1F1B18;
  --green:#2E7D32;
  --white:#fff;
  --muted:#6E6156;
  --line:rgba(62,42,30,.12);
  --shadow-sm:0 2px 10px rgba(31,27,24,.06);
  --shadow-md:0 12px 34px rgba(31,27,24,.10);
  --shadow-lg:0 24px 60px rgba(31,27,24,.16);
  --r:14px;
  --r-lg:20px;
  --maxw:1180px;
  --head:'Poppins','Montserrat','Helvetica Neue',Arial,sans-serif;
  --body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:92px}
body{
  margin:0;font-family:var(--body);color:var(--charcoal);
  background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--head);line-height:1.12;margin:0 0 .5em;letter-spacing:-.015em;font-weight:700}
h2{font-size:clamp(1.8rem,3.6vw,2.9rem);color:var(--brown)}
h3{font-size:1.25rem;color:var(--brown)}
p{margin:0 0 1.1em}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,44px)}
.amber-text{color:var(--amber)}
.eyebrow{font-family:var(--head);font-weight:700;font-size:.8rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--amber);margin:0 0 .8em}
.eyebrow.light{color:var(--amber-bright)}
.section{padding:clamp(64px,9vw,120px) 0;position:relative}
.section-head{max-width:760px;margin:0 auto clamp(38px,5vw,60px);text-align:center}
.section-sub{color:var(--muted);font-size:1.08rem}
.lead-line{font-size:1.1rem}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--head);font-weight:600;font-size:.98rem;
  padding:.85em 1.5em;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
  text-align:center;line-height:1.15;
}
.btn-lg{font-size:1.05rem;padding:1em 1.8em}
.btn-block{width:100%}
.btn-amber{background:var(--amber);color:var(--brown-deep);box-shadow:0 8px 22px rgba(212,160,23,.32)}
.btn-amber:hover{background:var(--amber-bright);transform:translateY(-2px);box-shadow:0 14px 30px rgba(212,160,23,.42)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;transform:translateY(-2px)}

/* ---------- DEMO RIBBON ---------- */
.demo-ribbon{
  position:fixed;top:20px;left:-58px;transform:rotate(-45deg);z-index:1200;
  background:var(--green);color:#fff;font-family:var(--head);font-weight:700;
  font-size:.62rem;letter-spacing:.09em;padding:6px 64px;box-shadow:0 4px 14px rgba(0,0,0,.28);
  pointer-events:none;
}

/* ---------- HEADER ---------- */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(247,241,232,.82);
  backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line);
  transition:box-shadow .25s ease,background .25s ease}
.site-header.scrolled{box-shadow:var(--shadow-sm);background:rgba(247,241,232,.96)}
.header-inner{display:flex;align-items:center;gap:1.5rem;height:72px}
.logo{display:flex;align-items:center;gap:.55rem}
.logo-img{height:36px;width:auto;display:block}
.logo-footer .logo-img{height:44px}
.logo-mark{flex:none;filter:drop-shadow(0 3px 6px rgba(62,42,30,.18))}
.logo-word{font-family:var(--head);font-weight:800;font-size:1.32rem;color:var(--brown);letter-spacing:-.02em}
.logo-word-accent{color:var(--amber)}
.site-nav{display:flex;gap:1.7rem;margin-left:auto}
.site-nav a{font-family:var(--head);font-weight:600;font-size:.95rem;color:var(--brown);
  position:relative;display:inline-flex;align-items:center;min-height:44px;padding:.2em 0;transition:color .18s}
.site-nav a::after{content:"";position:absolute;left:0;bottom:9px;width:0;height:2px;
  background:var(--amber);transition:width .22s ease}
.site-nav a:hover{color:var(--amber)}
.site-nav a:hover::after{width:100%}
.btn-call-header{margin-left:0}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;
  cursor:pointer;padding:8px;margin-left:auto}
.nav-toggle span{width:26px;height:2.5px;background:var(--brown);border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.mobile-nav{display:none;flex-direction:column;gap:.4rem;padding:0 clamp(20px,5vw,44px) 18px}
.mobile-nav a{font-family:var(--head);font-weight:600;padding:.75em 0;
  border-bottom:1px solid var(--line);color:var(--brown)}
.mobile-nav a.btn{border-bottom:0;margin-top:.6rem}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:min(92vh,760px);display:flex;align-items:center;
  overflow:hidden;color:#fff}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  transform:scale(1.04)}
.hero-overlay{position:absolute;inset:0;z-index:1;background:
  linear-gradient(90deg,rgba(20,15,10,.92) 0%,rgba(20,15,10,.82) 34%,rgba(20,15,10,.5) 62%,rgba(20,15,10,.28) 100%),
  linear-gradient(0deg,rgba(20,15,10,.6),rgba(20,15,10,0) 55%)}
.hero-inner{position:relative;z-index:2;padding-top:60px;padding-bottom:60px}
.hero-content{max-width:660px}
.hero-eyebrow{font-family:var(--head);font-weight:700;font-size:.82rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--amber-bright);margin:0 0 1em}
.hero-title{font-size:clamp(2.15rem,5.2vw,3.9rem);font-weight:800;color:#fff;
  margin-bottom:.5em;text-shadow:0 2px 24px rgba(0,0,0,.35)}
.hero-sub{font-size:clamp(1rem,1.5vw,1.18rem);color:rgba(255,255,255,.92);max-width:600px;margin-bottom:1.8em}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:1.4em}
.hero-microcopy{font-size:.95rem;color:rgba(255,255,255,.82);max-width:560px;margin:0}
.hero-microcopy strong{color:var(--amber-bright)}

/* ---------- TRUST BAR ---------- */
.trust-bar{background:var(--brown);color:#fff;position:relative;z-index:3}
.trust-inner{display:grid;grid-template-columns:repeat(5,1fr);gap:1.4rem;
  padding-top:34px;padding-bottom:34px}
.trust-item{display:flex;gap:.7rem;align-items:flex-start}
.trust-ico{font-size:1.5rem;line-height:1;flex:none}
.trust-item strong{display:block;font-family:var(--head);font-size:.98rem;margin-bottom:.15em}
.trust-item span{font-size:.82rem;color:rgba(255,255,255,.72);line-height:1.4}

/* ---------- SPLIT LAYOUT ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,68px);align-items:center}
.split-media{position:relative}
.split-media img{width:100%;height:100%;object-fit:cover;border-radius:var(--r-lg);box-shadow:var(--shadow-lg)}
.media-badge{position:absolute;bottom:18px;left:18px;background:var(--amber);color:var(--brown-deep);
  font-family:var(--head);font-weight:700;font-size:.85rem;padding:.55em 1em;border-radius:999px;
  box-shadow:var(--shadow-md)}
.split-text p{color:var(--muted)}
.split-text strong{color:var(--charcoal)}

/* ---------- OFFBRAND CHIPS ---------- */
.offbrand-sec{background:var(--cream)}
.chip-grid{list-style:none;padding:0;margin:0 0 1.5em;display:flex;flex-wrap:wrap;gap:.55rem}
.chip-grid li{font-family:var(--head);font-weight:600;font-size:.86rem;color:var(--brown);
  background:#fff;border:1px solid var(--line);padding:.5em .95em;border-radius:999px;
  box-shadow:var(--shadow-sm);transition:transform .16s,border-color .16s,color .16s}
.chip-grid li:hover{transform:translateY(-2px);border-color:var(--amber);color:var(--amber)}
.chip-grid .chip-any{background:var(--brown);color:#fff;border-color:var(--brown)}
.chip-grid .chip-any:hover{color:var(--amber-bright)}

/* ---------- DOWNTIME ---------- */
.downtime-sec{color:#fff;overflow:hidden}
.downtime-bg{position:absolute;inset:0;background:url("img/detail.jpg") center/cover no-repeat}
.downtime-overlay{position:absolute;inset:0;background:linear-gradient(120deg,rgba(31,27,24,.95),rgba(42,28,19,.86))}
.downtime-inner{position:relative;z-index:2;text-align:center;max-width:960px}
.light-h{color:#fff}
.downtime-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(30px,5vw,56px);
  align-items:center;text-align:left;margin-top:2.2rem}
.downtime-copy p{color:rgba(255,255,255,.85)}
.downtime-copy strong{color:var(--amber-bright)}
.stat-callout{background:linear-gradient(160deg,var(--amber-bright),var(--amber));
  color:var(--brown-deep);border-radius:var(--r-lg);padding:2.4rem 1.6rem;text-align:center;
  box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:.35rem}
.stat-label{font-family:var(--head);font-weight:600;font-size:.95rem;opacity:.85}
.stat-number{font-family:var(--head);font-weight:800;font-size:clamp(2.4rem,6vw,3.6rem);line-height:1}
.stat-unit{font-family:var(--head);font-weight:600;font-size:1rem;opacity:.9}

/* ---------- HUMAN / STEPS ---------- */
.human-sec{background:var(--cream)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:clamp(38px,5vw,58px)}
.step-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2rem 1.6rem;
  box-shadow:var(--shadow-sm);position:relative;transition:transform .2s,box-shadow .2s}
.step-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;
  border-radius:50%;background:var(--amber);color:var(--brown-deep);font-family:var(--head);
  font-weight:800;font-size:1.4rem;margin-bottom:1rem;box-shadow:0 6px 16px rgba(212,160,23,.3)}
.step-card p{color:var(--muted);margin:0}
.center-cta{text-align:center;margin-top:clamp(34px,4vw,50px)}

/* ---------- 3 WAYS ---------- */
.ways-sec{background:var(--cream)}
.ways-kicker{font-family:var(--head);font-weight:700;font-size:1.05rem;color:var(--brown);margin:.4rem 0 0}
.ways-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:stretch}
.way-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2rem;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;position:relative;
  transition:transform .2s,box-shadow .2s,border-color .2s}
.way-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:rgba(212,160,23,.4)}
.way-ico{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;
  border-radius:14px;background:var(--cream);font-size:1.7rem;margin-bottom:1rem}
.way-card p{color:var(--muted);margin:0 0 1rem;font-size:.96rem}
.way-bestfor{color:var(--charcoal);font-size:.92rem}
.way-bestfor-label{display:inline-block;font-family:var(--head);font-weight:700;font-size:.72rem;
  letter-spacing:.1em;text-transform:uppercase;color:#8A6410;margin-right:.35em}
.way-fineprint{font-size:.82rem;color:var(--muted);font-style:italic}
.way-card .btn{margin-top:auto}
.way-card-featured{background:linear-gradient(170deg,#fff,#fffaf0);border:2.5px solid var(--amber);
  box-shadow:var(--shadow-lg)}
.way-flag{position:absolute;top:-15px;left:50%;transform:translateX(-50%);background:var(--amber);
  color:var(--brown-deep);font-family:var(--head);font-weight:700;font-size:.72rem;letter-spacing:.1em;
  text-transform:uppercase;padding:.4em 1.1em;border-radius:999px;box-shadow:var(--shadow-md);white-space:nowrap}
.ways-trustline{text-align:center;margin:clamp(34px,4vw,50px) auto 0;max-width:760px;
  font-family:var(--head);font-weight:700;font-size:clamp(1.1rem,2vw,1.35rem);color:var(--brown)}

/* ---------- SERVICES ---------- */
.services-sec{background:var(--cream-2)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.service-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2rem;
  box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s,border-color .2s}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:rgba(212,160,23,.4)}
.service-ico{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;
  border-radius:14px;background:var(--cream);font-size:1.7rem;margin-bottom:1rem}
.service-card p{color:var(--muted);margin:0;font-size:.96rem}
.service-card-cta{background:var(--brown);color:#fff;display:flex;flex-direction:column;
  justify-content:center;align-items:flex-start;gap:.4rem}
.service-card-cta h3{color:#fff}
.service-card-cta p{color:rgba(255,255,255,.8);margin-bottom:.6rem}

/* ---------- LINEUP ---------- */
.lineup-sec{background:var(--cream)}
.cover-list{list-style:none;padding:0;margin:0 0 1.2em;display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.cover-list li{position:relative;padding-left:1.6em;font-size:.96rem;color:var(--brown);font-weight:500}
.cover-list li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:800}

/* ---------- COMPARISON ---------- */
.compare-sec{background:var(--cream-2)}
.compare-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:stretch}
.compare-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2.1rem 1.8rem;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.compare-card h3{margin-bottom:.7em}
.compare-card p{color:var(--muted);font-size:.96rem}
.compare-verdict{margin-top:auto;font-weight:600;font-size:.92rem;padding-top:1rem;border-top:1px solid var(--line)}
.compare-verdict.con{color:#a24a2e}
.compare-verdict.pro{color:var(--green)}
.compare-win{background:linear-gradient(170deg,#fff,#fffaf0);border:2.5px solid var(--amber);
  box-shadow:var(--shadow-lg);position:relative;transform:translateY(-8px)}
.compare-win h3{color:var(--brown)}
.win-flag{position:absolute;top:-15px;left:50%;transform:translateX(-50%);background:var(--amber);
  color:var(--brown-deep);font-family:var(--head);font-weight:700;font-size:.72rem;letter-spacing:.1em;
  text-transform:uppercase;padding:.4em 1.1em;border-radius:999px;box-shadow:var(--shadow-md);white-space:nowrap}
.compare-win p strong{color:var(--brown)}

/* ---------- TESTIMONIALS ---------- */
.testi-sec{background:var(--brown);color:#fff}
.testi-sec h2{color:#fff}
.placeholder-note{font-size:.82rem;color:rgba(255,255,255,.6);font-style:italic;margin-top:.4rem}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.testi-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r);padding:2rem;margin:0;transition:transform .2s,background .2s}
.testi-card:hover{transform:translateY(-4px);background:rgba(255,255,255,.08)}
.stars{color:var(--amber-bright);font-size:1.15rem;letter-spacing:.12em;margin-bottom:1rem}
.testi-card blockquote{margin:0 0 1.2rem;font-size:1rem;line-height:1.65;color:rgba(255,255,255,.92)}
.testi-card figcaption{font-size:.85rem;color:rgba(255,255,255,.55)}
.testi-card .ph{font-style:italic}

/* ---------- FINAL CTA + FORM ---------- */
.finalcta-sec{background:linear-gradient(160deg,var(--brown-deep),var(--brown));color:#fff}
.finalcta-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,64px);align-items:start}
.finalcta-text p{color:rgba(255,255,255,.85)}
.finalcta-or{font-size:.92rem;margin-top:1.4rem}
.finalcta-or a{color:var(--amber-bright);font-weight:600}
.quote-form{background:#fff;border-radius:var(--r-lg);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow-lg)}
.quote-form h3{color:var(--brown);margin-bottom:1.2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.quote-form label{display:block;font-family:var(--head);font-weight:600;font-size:.82rem;
  color:var(--brown);margin-bottom:1rem}
.quote-form input,.quote-form textarea{width:100%;margin-top:.35rem;padding:.75em .9em;
  font-family:var(--body);font-size:.95rem;color:var(--charcoal);background:var(--cream);
  border:1.5px solid var(--line);border-radius:10px;transition:border-color .18s,box-shadow .18s}
.quote-form input:focus,.quote-form textarea:focus{outline:none;border-color:var(--amber);
  box-shadow:0 0 0 3px rgba(212,160,23,.16);background:#fff}
.quote-form textarea{resize:vertical}
.form-note{font-size:.8rem;color:var(--muted);text-align:center;margin:1rem 0 0}
.form-note.success{color:var(--green);font-weight:600}

/* ---------- FAQ ---------- */
.faq-sec{background:var(--cream)}
.faq-wrap{max-width:840px}
.faq-list{display:flex;flex-direction:column;gap:.8rem}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow .2s}
.faq-item[open]{box-shadow:var(--shadow-md)}
.faq-item summary{list-style:none;cursor:pointer;padding:1.25rem 1.5rem;font-family:var(--head);
  font-weight:600;font-size:1.05rem;color:var(--brown);display:flex;align-items:center;
  justify-content:space-between;gap:1rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.6rem;font-weight:400;color:var(--amber);
  flex:none;transition:transform .25s;line-height:1}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{margin:0;padding:0 1.5rem 1.4rem;color:var(--muted)}
.faq-footer{text-align:center;margin-top:2.4rem;font-family:var(--head);font-weight:600;color:var(--brown)}
.faq-footer a{color:var(--amber);text-decoration:underline;text-underline-offset:3px}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--brown-deep);color:#fff;padding-top:clamp(48px,6vw,72px)}
.footer-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:2rem;padding-bottom:2.4rem}
.logo-footer .logo-word{color:#fff}
.footer-tag{color:var(--amber-bright);font-family:var(--head);font-weight:600;margin:.9rem 0 0}
.footer-contact{display:flex;flex-direction:column;gap:.5rem;text-align:right}
.footer-contact a{color:rgba(255,255,255,.9);font-weight:500;transition:color .18s}
.footer-contact a:hover{color:var(--amber-bright)}
.footer-phone{font-family:var(--head);font-weight:700;font-size:1.15rem}
.footer-area{color:rgba(255,255,255,.6);font-size:.88rem;margin:.4rem 0 0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.4rem 0}
.footer-bottom p{margin:0;font-size:.82rem;color:rgba(255,255,255,.5);text-align:center}
.demo-inline{color:var(--amber-bright)}

/* ---------- MOBILE CALL BAR ---------- */
.mobile-call-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1100;
  background:var(--amber);color:var(--brown-deep);font-family:var(--head);font-weight:700;
  font-size:1.05rem;text-align:center;padding:1em;box-shadow:0 -6px 22px rgba(0,0,0,.2)}

/* ---------- REVEAL ANIMATION ---------- */
/* Content is VISIBLE by default. The fade-in only applies once JS adds the
   `.js-anim` class to <html>, so a slow/blocked/early-captured page never
   renders blank. Animation is pure enhancement, not a gate on content. */
.reveal{opacity:1;transform:none}
html.js-anim .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
html.js-anim .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  html.js-anim .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:1000px){
  .trust-inner{grid-template-columns:repeat(2,1fr);gap:1.6rem}
  .services-grid,.compare-grid,.steps,.testi-grid,.ways-grid{grid-template-columns:1fr 1fr}
  .compare-win{transform:none}
}
@media (max-width:860px){
  .site-nav,.btn-call-header{display:none}
  .nav-toggle{display:flex}
  .mobile-nav.open{display:flex}
  .split{grid-template-columns:1fr;gap:2rem}
  .split-reverse .split-media{order:-1}
  .downtime-grid,.finalcta-inner{grid-template-columns:1fr;gap:2rem}
  .hero{min-height:auto;padding:20px 0}
  .hero-overlay{background:linear-gradient(180deg,rgba(42,28,19,.88),rgba(42,28,19,.78))}
}
@media (max-width:640px){
  .trust-inner{grid-template-columns:1fr}
  .services-grid,.compare-grid,.steps,.testi-grid,.ways-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .cover-list{grid-template-columns:1fr}
  .footer-inner{flex-direction:column}
  .footer-contact{text-align:left}
  .hero-cta .btn{width:100%}
  .mobile-call-bar{display:block}
  body{padding-bottom:64px}
  .demo-ribbon{font-size:.55rem;top:16px;left:-62px}
}
