/* ============================================================
   Dental OS by FwdDeploy — shared design system
   Hybrid: clinical emerald base + editorial serif + tasteful motion
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* warm ivory paper + near-black ink — "The Operator" editorial palette */
  --bg:#eef2f3; --paper:#f8fbfb; --surface:#e4ecee; --card:#f8fbfb;
  --ink:#0f1517; --ink-soft:#46525a; --ink-faint:#7b878d;
  --primary:#0c7f8f; --primary-deep:#085f6d; --primary-tint:#ddeef0; --primary-glow:rgba(12,127,143,.16);
  --signal:#d96f47; --signal-tint:#f6e3d8;
  --blue:#3f6ad8; --rose:#d9534f;
  --border:#d6e0e2; --border-strong:#bccdd1;
  --hair:#ccd8da;
  --serif:'Fraunces',Georgia,serif; --sans:'Inter',-apple-system,system-ui,sans-serif;
  --mono:'IBM Plex Mono','SFMono-Regular',ui-monospace,Menlo,monospace;
  --shadow:0 1px 2px rgba(15,21,23,.05),0 14px 34px -18px rgba(15,21,23,.22);
  --shadow-lift:0 28px 64px -24px rgba(15,21,23,.38);
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-out:cubic-bezier(.23,1,.32,1); --ease-in-out:cubic-bezier(.77,0,.175,1);
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap{max-width:1280px;margin:0 auto;padding:0 28px}
.narrow{max-width:880px}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:-.02em;text-wrap:balance}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
/* huashu craft polish — low-specificity :where() guards so they don't fight existing rules */
:where(h1,h2,h3){text-wrap:balance}
:where(p.lede,.lede){text-wrap:pretty}
.eyebrow{font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--primary-deep)}
.muted{color:var(--ink-soft)}
/* editorial hairline + mono micro-labels */
.hr{height:1px;background:var(--hair);border:0;margin:0}
.mono-label{font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint)}

/* buttons — chunky high-contrast statement pills, arrow slides on hover */
.btn{display:inline-flex;align-items:center;gap:.55rem;border-radius:999px;font-weight:600;font-size:.95rem;padding:.95rem 1.7rem;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);cursor:pointer;border:1.5px solid transparent;font-family:var(--sans);letter-spacing:-.005em;overflow:hidden}
.btn:active{transform:scale(.97)}
.btn span{display:inline-block;transition:transform .3s var(--ease)}
.btn:hover span{transform:translateX(5px)}
.btn-primary{background:var(--ink);color:var(--paper);box-shadow:0 4px 0 0 var(--primary-deep)}
.btn-primary:hover{background:#000;transform:translateY(-2px);box-shadow:0 6px 0 0 var(--primary-deep),var(--shadow-lift)}
.btn-emerald{background:var(--primary);color:var(--paper);box-shadow:0 4px 0 0 var(--primary-deep)}
.btn-emerald:hover{background:var(--primary-deep);transform:translateY(-2px);box-shadow:0 6px 0 0 #06424c,var(--shadow-lift)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink);border-radius:999px}
.btn-ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}
/* Emil: gate movement-hovers behind real pointers so touch taps don't stick */
@media (hover:none){
  .btn-primary:hover,.btn-emerald:hover,.btn-ghost:hover,.btn:hover span,.card:hover,.pcard:hover,.pcard:hover .vis img,.showitem:hover .shotwrap,.pcard:hover .more span{transform:none}
}
.btn-lg{padding:1.1rem 2.15rem;font-size:1.04rem}

/* nav */
header{position:sticky;top:0;z-index:50;background:rgba(238,242,243,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--hair)}
nav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:72px}
.brand{justify-self:start}
.navlinks{justify-self:center}
.navcta{justify-self:end;display:flex;align-items:center;gap:.7rem}
/* bespoke wordmark: "Dental·OS" — Fraunces + emerald operator dot + mono ·OS */
.brand{display:inline-flex;align-items:center;letter-spacing:-.01em;text-decoration:none;position:relative}
.brand .wm-txt{display:flex;flex-direction:column;align-items:center;line-height:1.04}
.brand .wm-row{display:flex;align-items:baseline}
.brand .wm{font-family:var(--serif);font-weight:600;font-size:1.85rem;color:var(--ink);letter-spacing:-.02em}
.brand .wm-tooth{display:inline-block;width:1.04rem;height:1.34rem;margin:0 -.05rem 0 .3rem;color:var(--primary);align-self:center;position:relative;top:.05rem;transition:color .2s}
.brand .wm-tooth svg{width:100%;height:100%;display:block;fill:currentColor}
.brand .wm-os{font-family:var(--mono);font-weight:600;font-size:1.5rem;color:var(--ink);letter-spacing:.01em}
.brand .wm-tag{font-family:var(--mono);font-weight:500;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-top:4px;text-align:center}
.brand:hover .wm-tooth{color:var(--primary-deep)}
/* legacy box logo kept harmless if any old markup references it */
.logo{display:none}
.navlinks{display:flex;align-items:center;gap:1.7rem;font-family:var(--mono);font-size:.76rem;letter-spacing:.04em;color:var(--ink-soft);font-weight:500;text-transform:uppercase}
.navlinks a{transition:color .2s}.navlinks a:hover{color:var(--primary-deep)}
.navlinks a.active{color:var(--primary-deep)}
.navcta{display:flex;align-items:center;gap:1rem}

/* header buttons — Emil micro-interactions (hero CTA keeps .btn-primary untouched) */
.btn-login{display:inline-flex;align-items:center;white-space:nowrap;font-family:var(--sans);font-weight:600;font-size:.85rem;padding:.52rem 1.05rem;border:1.5px solid var(--hair);border-radius:999px;color:var(--ink);background:transparent;cursor:pointer;transition:background .16s var(--ease-out),border-color .16s var(--ease-out),transform .14s var(--ease-out)}
.btn-login:active{transform:scale(.97)}
.btn-nav{white-space:nowrap;padding:.58rem 1.2rem;font-size:.85rem;background:var(--ink);color:var(--paper);box-shadow:none;border-color:transparent}
.btn-nav:hover{box-shadow:none;transform:none}
/* gate hover states behind real pointers so touch taps don't stick */
@media (hover:hover) and (pointer:fine){
  .btn-login:hover{background:var(--surface);border-color:var(--ink-faint)}
  .btn-nav:hover{background:#000}
}

/* Under 880px: brand + CTAs on one row. Product nav stays reachable via homepage cards + footer. */
@media(max-width:880px){
  nav{grid-template-columns:auto auto;justify-content:space-between}
  .navlinks{display:none}
  .navcta{gap:.5rem}
  .btn-login,.btn-nav{padding-top:.7rem;padding-bottom:.7rem;min-height:44px}
}
/* Compact the header so brand + both CTAs fit one row on phones. */
@media(max-width:560px){
  .btn-login{padding-left:.8rem;padding-right:.8rem;font-size:.8rem}
  .btn-nav{padding-left:.85rem;padding-right:.85rem;font-size:.8rem}
  .brand .wm{font-size:1.55rem}
  .brand .wm-os{font-size:1.25rem}
  .brand .wm-tooth{width:.9rem;height:1.16rem}
}
@media(max-width:360px){.brand .wm-tag{display:none}}

/* generic section */
section{padding:clamp(40px,6vw,60px) 0}
.sec-head{max-width:720px;margin-bottom:36px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(2.1rem,4vw,3.15rem);margin-top:14px}
.sec-head p{color:var(--ink-soft);font-size:1.08rem;margin-top:16px}
/* big numbered section marker */
.sec-no{font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.18em;color:var(--primary-deep);display:inline-flex;align-items:center;gap:.6rem}
.sec-no::before{content:"";width:30px;height:1.5px;background:var(--primary)}
.band{background:var(--surface);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
/* dark "ink" block for editorial rhythm */
.band-ink{background:var(--ink);color:#e4ecee}
.band-ink h1,.band-ink h2,.band-ink h3{color:var(--paper)}.band-ink .muted,.band-ink p{color:#b8b2a3}.band-ink .eyebrow{color:#5ad0ac}.band-ink .sec-no{color:#5ad0ac}.band-ink .mono-label{color:#9c9686}.band-ink .hr{background:rgba(255,255,255,.12)}

/* hero (home + product) */
.hero{position:relative;padding:clamp(48px,6vw,64px) 0 clamp(40px,5vw,56px);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;background:
  radial-gradient(60% 50% at 82% 14%,var(--primary-glow),transparent 70%),
  radial-gradient(42% 42% at 4% 0%,rgba(201,138,43,.07),transparent 70%)}
.hero-grid{position:absolute;inset:0;z-index:-1;opacity:.55;
  background-image:linear-gradient(var(--hair) 1px,transparent 1px),linear-gradient(90deg,var(--hair) 1px,transparent 1px);
  background-size:36px 36px;mask:radial-gradient(72% 62% at 72% 8%,#000,transparent 78%)}
.hero-inner{display:grid;grid-template-columns:1.08fr .92fr;gap:52px;align-items:center}
@media(max-width:940px){.hero-inner{grid-template-columns:1fr;gap:36px}}
.hero h1{font-size:clamp(2.5rem,5.6vw,4.3rem);margin-top:20px}
.hero h1 em{font-style:italic;color:var(--primary-deep)}
.hero .lede{font-size:1.16rem;color:var(--ink-soft);margin-top:24px;max-width:44ch;text-wrap:pretty}
.hero-cta{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.hero-meta{margin-top:28px;display:flex;flex-wrap:wrap;gap:9px 20px;font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:var(--ink-faint);font-weight:500;text-transform:uppercase}
.hero-meta span{display:inline-flex;align-items:center;gap:.45rem}
.dot{width:7px;height:7px;border-radius:50%;background:var(--primary);flex:0 0 auto}

/* ---- LIVE-ROTATING HERO HEADLINE (mask-up roll) ---- */
.rotator{position:relative;display:block;min-height:3.4em;overflow:hidden;font-weight:600;line-height:1.04}
.rotator .rline{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;opacity:0;transform:translateY(1.15em);
  transition:transform .72s cubic-bezier(.16,1,.3,1),opacity .55s ease;will-change:opacity,transform}
.rotator .rline.is-active{opacity:1;transform:translateY(0)}
.rotator .rline.is-out{opacity:0;transform:translateY(-.95em);
  transition:transform .5s cubic-bezier(.4,0,.2,1),opacity .34s ease}
.rotator .r2{display:block;font-style:italic;color:var(--primary-deep)}
.aitag-hero{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--primary-deep)}
.aitag-hero::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}
@media(prefers-reduced-motion:reduce){
  /* static first line, no auto-rotate, no transition */
  .rotator{min-height:0}
  .rotator .rline{position:static;opacity:1;transform:none;filter:none;transition:none}
  .rotator .rline:not(:first-child){display:none}
}

/* cards & grids */
.grid{display:grid;gap:18px}
.g4{grid-template-columns:repeat(4,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g2{grid-template-columns:repeat(2,1fr)}
@media(max-width:1000px){.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:880px){.g3,.g2{grid-template-columns:1fr}.g4{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:26px;transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease)}
.card:hover{transform:translateY(-5px);border-color:var(--primary);box-shadow:var(--shadow-lift)}
.card .ic{width:44px;height:44px;border-radius:12px;background:var(--primary-tint);color:var(--primary-deep);display:grid;place-items:center;margin-bottom:16px;font-size:1.2rem}
.card h3{font-size:1.22rem;font-weight:600}
.card p{color:var(--ink-soft);font-size:.94rem;margin-top:8px}
.feat-no{font-family:var(--serif);font-size:.85rem;color:var(--primary);font-weight:600}
/* product card (homepage) */
.pcard{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--border);border-radius:18px;padding:0;overflow:hidden;transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease)}
.pcard:hover{transform:translateY(-6px);border-color:var(--primary);box-shadow:var(--shadow-lift)}
.pcard .vis{height:210px;border-bottom:1px solid var(--border);position:relative;overflow:hidden;background:#0a4d3f}
.pcard .vis img{display:block;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .35s var(--ease)}
.pcard:hover .vis img{transform:scale(1.025)}
.pcard .body{padding:24px;display:flex;flex-direction:column;flex:1}
.pcard h3{font-size:1.3rem;font-weight:600}
.pcard .kic{font-size:1.4rem;margin-bottom:6px}
.pcard p{color:var(--ink-soft);font-size:.93rem;margin-top:8px;flex:1}
.pcard .more{margin-top:16px;font-family:var(--mono);font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--primary-deep);font-size:.74rem;display:inline-flex;gap:.45rem;align-items:center}
.pcard:hover .more span{transform:translateX(5px)}.pcard .more span{transition:transform .25s}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:30px}.split .flip{order:-1}}
.ulist{list-style:none;margin-top:20px;display:grid;gap:13px}
.ulist li{display:flex;gap:11px;align-items:flex-start;font-size:1rem;color:var(--ink-soft)}
.ulist li b{color:var(--ink);font-weight:600}
.check{flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:var(--primary-tint);color:var(--primary-deep);display:grid;place-items:center;font-size:.75rem;margin-top:2px}

/* stat / impact */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:760px){.stats{grid-template-columns:1fr}}
.stat{background:var(--card);border:1px solid var(--border);border-radius:15px;padding:26px}
.stat .big{font-family:var(--serif);font-size:3rem;color:var(--ink);line-height:1}
.stat p{color:var(--ink-soft);font-size:.92rem;margin-top:10px}
.band-ink .stat{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12)}
.band-ink .stat .big{color:#5ad0ac}

/* ---- bespoke mock frames ---- */
.frame{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}
.frame-top{display:flex;align-items:center;gap:.5rem;padding:11px 15px;border-bottom:1px solid var(--border);background:linear-gradient(var(--card),var(--surface));font-size:.74rem;color:var(--ink-faint)}
.pip{width:9px;height:9px;border-radius:50%}.pip.r{background:#e6837d}.pip.y{background:#e8c06a}.pip.g{background:#7cc69a}
.urlbar{margin-left:8px;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:3px 10px;flex:1;max-width:320px;color:var(--ink-faint)}

/* google search result mock */
.serp{padding:16px;display:grid;gap:12px;background:#fff}
.serp .q{display:flex;align-items:center;gap:8px;border:1px solid var(--border-strong);border-radius:999px;padding:8px 14px;color:var(--ink-soft);font-size:.85rem}
.serp .res{padding:10px 12px;border-radius:10px}
.serp .res.top{background:var(--primary-tint);border:1px solid #bfe6da}
.serp .res .site{font-size:.72rem;color:var(--ink-faint)}
.serp .res .title{color:var(--blue);font-weight:600;font-size:.98rem;margin-top:2px}
.serp .res .desc{font-size:.8rem;color:var(--ink-soft);margin-top:3px}
.serp .res .stars{color:var(--signal);font-size:.78rem;margin-top:4px}
.rank{font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--primary-deep);background:#fff;border:1px solid #bfe6da;padding:2px 8px;border-radius:999px;float:right}

/* map mock */
.map{position:relative;height:230px;background:
  radial-gradient(circle at 30% 40%,#eef4f0,#e3ece8);overflow:hidden}
.map .road{position:absolute;background:#fff;opacity:.8}
.map .pin{position:absolute;transform:translate(-50%,-100%);font-size:1.3rem;filter:drop-shadow(0 4px 4px rgba(0,0,0,.15))}
.map .pin.you{font-size:2rem;color:var(--primary)}
.map .lbl{position:absolute;background:#fff;border:1px solid var(--border);border-radius:8px;padding:5px 9px;font-size:.72rem;font-weight:600;box-shadow:var(--shadow);transform:translate(-50%,-160%)}

/* reel / post grid */
.reels{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:14px}
.reel{aspect-ratio:9/16;border-radius:11px;position:relative;overflow:hidden;display:grid;place-items:end;padding:10px;color:#fff;font-size:.7rem;font-weight:600}
.reel::after{content:"▶";position:absolute;top:8px;right:9px;font-size:.7rem;opacity:.85}
.reel .views{position:relative;z-index:1;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.reel.r1{background:linear-gradient(160deg,#13b48f,#0a6f5a)}.reel.r2{background:linear-gradient(160deg,#3f6ad8,#27408f)}.reel.r3{background:linear-gradient(160deg,#d98a3f,#a85e1c)}
.reel.r4{background:linear-gradient(160deg,#c0497e,#7e2b50)}.reel.r5{background:linear-gradient(160deg,#5b56c9,#322e84)}.reel.r6{background:linear-gradient(160deg,#2bb1c9,#1c6f80)}

/* ad creative mock */
.ad{border:1px solid var(--border);border-radius:13px;overflow:hidden;background:#fff}
.ad .head{display:flex;align-items:center;gap:9px;padding:11px 13px}
.ad .head .av{width:34px;height:34px;border-radius:50%;background:var(--primary-tint);color:var(--primary-deep);display:grid;place-items:center;font-weight:700;font-size:.8rem}
.ad .head .name{font-weight:600;font-size:.86rem}.ad .head .spon{font-size:.7rem;color:var(--ink-faint)}
.ad .pic{height:130px;background:linear-gradient(135deg,var(--primary-tint),#cdebe1);display:grid;place-items:center;color:var(--primary-deep);font-family:var(--serif);font-size:1.1rem}
.ad .cta{display:flex;align-items:center;justify-content:space-between;padding:11px 13px;background:var(--surface);font-size:.82rem}
.ad .cta b{color:var(--ink)}
.ad .cta .book{background:var(--primary);color:#fff;padding:5px 12px;border-radius:7px;font-weight:600;font-size:.78rem}

/* CRM dashboard mock */
.dash{display:grid;grid-template-columns:140px 1fr;min-height:260px}
.dash .side{background:var(--surface);border-right:1px solid var(--border);padding:14px;font-size:.8rem;color:var(--ink-soft);display:grid;gap:8px;align-content:start}
.dash .side .it{padding:7px 10px;border-radius:8px;display:flex;gap:8px;align-items:center}
.dash .side .it.on{background:var(--primary-tint);color:var(--primary-deep);font-weight:600}
.dash .main{padding:16px;display:grid;gap:11px;background:#fff}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.kpi{border:1px solid var(--border);border-radius:10px;padding:11px}
.kpi .n{font-family:var(--serif);font-size:1.5rem;color:var(--ink)}.kpi .l{font-size:.68rem;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em}
.drow{display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:9px;padding:9px 11px;font-size:.82rem}
.drow .av{width:26px;height:26px;border-radius:7px;background:var(--primary-tint);color:var(--primary-deep);display:grid;place-items:center;font-weight:600;font-size:.72rem}
.drow .tag{margin-left:auto;font-size:.66rem;font-weight:600;padding:3px 9px;border-radius:999px}
.tag-green{background:var(--primary-tint);color:var(--primary-deep)}.tag-amber{background:var(--signal-tint);color:var(--signal)}.tag-blue{background:#e8eefb;color:var(--blue)}

/* enquiry form */
.enq{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:36px;box-shadow:var(--shadow);max-width:560px}
.enq h3{font-size:1.6rem}
.enq .sub{color:var(--ink-soft);margin-top:8px;font-size:.96rem}
.field{margin-top:16px}
.field label{display:block;font-size:.8rem;font-weight:600;color:var(--ink-soft);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--border-strong);border-radius:11px;padding:.8rem 1rem;font-family:var(--sans);font-size:.95rem;color:var(--ink);background:var(--bg);transition:border-color .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.field textarea{min-height:96px;resize:vertical}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.frow{grid-template-columns:1fr}}
.enq .note{font-size:.78rem;color:var(--ink-faint);margin-top:14px;text-align:center}

/* demo CTA (replaces pricing) */
.demo-card{background:var(--ink);color:#e4ecee;border-radius:24px;padding:clamp(28px,4vw,44px);text-align:center;position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.demo-card::before{content:"";position:absolute;inset:0;background:radial-gradient(55% 65% at 82% 0%,rgba(12,127,143,.22),transparent 70%),radial-gradient(40% 50% at 8% 100%,rgba(201,138,43,.1),transparent 70%)}
.demo-card h2{color:var(--paper);font-size:clamp(2.1rem,4.4vw,3.2rem);position:relative}
.demo-card p{color:#bcd6cc;font-size:1.12rem;max-width:52ch;margin:16px auto 0;position:relative}
.demo-points{display:flex;gap:10px 26px;justify-content:center;flex-wrap:wrap;margin-top:24px;position:relative;font-size:.88rem;color:#cfe6dd;font-weight:500}
.demo-points span{display:inline-flex;gap:.5rem;align-items:center}
.demo-points .dot{background:#5ad0ac}

/* product page hero visual */
.phero{position:relative;overflow:hidden}

/* breadcrumb */
.crumb{font-size:.8rem;color:var(--ink-faint);margin-bottom:6px}.crumb a:hover{color:var(--primary-deep)}

/* footer */
footer{background:var(--ink);color:#b8b2a3;padding:48px 0 32px;font-size:.88rem}
footer .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px}
@media(max-width:780px){footer .cols{grid-template-columns:1fr 1fr}}
footer h4{color:var(--paper);font-family:var(--mono);font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.16em;margin-bottom:16px}
footer a{display:block;color:#b8b2a3;margin-bottom:9px;transition:color .2s}footer a:hover{color:#5ad0ac}
footer .brand .wm,footer .brand .wm-os{color:var(--paper)}
footer .brand .wm-tag{color:#7b878d;border-color:rgba(255,255,255,.14)}
footer .fbot{margin-top:44px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#7b878d;font-family:var(--mono);font-size:.72rem;letter-spacing:.03em}

/* ===== Bold About Us (editorial manifesto) ===== */
.about{position:relative}
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:start}
@media(max-width:880px){.about-grid{grid-template-columns:1fr;gap:32px}}
.about .quote{font-family:var(--serif);font-weight:500;font-size:clamp(1.7rem,3vw,2.5rem);line-height:1.12;letter-spacing:-.02em;text-wrap:balance}
.about .quote em{font-style:italic;color:#5ad0ac}
.about .lead-in{font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:#5ad0ac;margin-bottom:18px;display:flex;align-items:center;gap:.6rem}
.about .lead-in::before{content:"";width:30px;height:1.5px;background:#5ad0ac}
.about p{color:#b8b2a3;font-size:1.06rem;margin-top:20px;max-width:60ch;text-wrap:pretty}
.about p strong{color:var(--paper);font-weight:600}
.beliefs{list-style:none;margin-top:32px;display:grid;gap:0;border-top:1px solid rgba(255,255,255,.12)}
.beliefs li{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:baseline;padding:20px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.beliefs .n{font-family:var(--mono);font-size:.74rem;color:#5ad0ac;letter-spacing:.1em}
.beliefs b{font-family:var(--serif);font-weight:500;font-size:1.22rem;color:var(--paper);display:block;margin-bottom:5px}
.beliefs span.d{color:#b8b2a3;font-size:.96rem;line-height:1.55}
.about-sig{margin-top:28px;font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;color:#7b878d}

/* motion */
[data-rev]{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-rev].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  [data-rev]{opacity:1;transform:none;transition:none}
  .btn:hover,.card:hover,.pcard:hover,.stat:hover,.price:hover{transform:none}
  .btn:active,.btn-login:active,.btn-nav:active{transform:none}
  html{scroll-behavior:auto}
}

/* ---- AI-first chip + call/voice mock (added) ---- */
.aitag{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--mono);font-size:.62rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--primary-deep);background:var(--primary-tint);border:1px solid #b6dccd;padding:3px 9px;border-radius:999px}
.aitag::before{content:"✦";font-size:.7rem}
.aitag.light{color:#5ad0ac;background:rgba(90,208,172,.12);border-color:rgba(90,208,172,.3)}
.grp-head{display:flex;align-items:baseline;gap:.7rem;margin:8px 0 20px;border-top:1px solid var(--hair);padding-top:18px}
.grp-head .e{font-family:var(--serif);font-size:1.55rem;color:var(--ink);font-weight:500}
.grp-head .l{font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}
/* incoming call mock */
.call{display:flex;align-items:center;gap:12px;padding:13px 15px;border-bottom:1px solid var(--border);background:linear-gradient(var(--card),var(--surface))}
.call .ring{width:38px;height:38px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:1.1rem;box-shadow:0 0 0 0 var(--primary-glow);animation:callpulse 2s infinite}
@keyframes callpulse{0%{box-shadow:0 0 0 0 rgba(12,127,143,.35)}70%{box-shadow:0 0 0 10px rgba(12,127,143,0)}100%{box-shadow:0 0 0 0 rgba(12,127,143,0)}}
.call .who b{font-size:.9rem}.call .who span{font-size:.74rem;color:var(--ink-faint);display:block}
.call .live{margin-left:auto;font-size:.66rem;font-weight:700;color:var(--primary-deep);background:var(--primary-tint);padding:3px 9px;border-radius:999px}
@media(prefers-reduced-motion:reduce){.call .ring{animation:none}}

/* ---- real product screenshots ---- */
.frame img,.shotframe img{display:block;width:100%}
.shotframe{border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);background:#fff}
.shotframe .bar{display:flex;align-items:center;gap:.5rem;padding:9px 14px;border-bottom:1px solid var(--border);background:linear-gradient(var(--card),var(--surface));font-size:.72rem;color:var(--ink-faint)}
.showcase{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:8px}
@media(max-width:880px){.showcase{grid-template-columns:1fr}}
.showitem .cap{margin-top:14px}
.showitem .cap h3{font-size:1.15rem;font-weight:600}
.showitem .cap p{color:var(--ink-soft);font-size:.92rem;margin-top:5px}
.showitem .cap .aitag{margin-bottom:8px}
.shotwrap{transition:transform .4s var(--ease),box-shadow .4s}
.showitem:hover .shotwrap{transform:translateY(-5px);box-shadow:var(--shadow-lift)}

/* uniform, polished crop for the showcase screenshots (hero stays full) */
.showitem .shotframe img{height:300px;object-fit:cover;object-position:top center}
@media(max-width:880px){.showitem .shotframe img{height:240px}}

/* ============ LIVE ANIMATIONS ============ */
/* generic sequential reveal (driven by live.js) */
[data-step]{opacity:0;transform:translateY(9px) scale(.985);transition:opacity .45s var(--ease),transform .45s var(--ease)}
[data-step].show{opacity:1;transform:none}

/* chat conversation bubbles (call transcript + WhatsApp) */
.convo{padding:14px;display:grid;gap:9px;background:#fff;min-height:172px;align-content:start}
.bub{max-width:84%;padding:9px 12px;font-size:.84rem;line-height:1.42;border-radius:14px;position:relative}
.bub .t{display:block;font-size:.62rem;margin-top:5px;opacity:.65;font-weight:600;letter-spacing:.02em}
.bub.caller{justify-self:start;background:var(--surface);border:1px solid var(--border);border-bottom-left-radius:4px;color:var(--ink)}
.bub.ai{justify-self:end;background:var(--primary-tint);border:1px solid #bfe6da;border-bottom-right-radius:4px;color:#0c5c49}
.bub.ai .t{color:var(--primary-deep)}
/* typing indicator */
.typing{justify-self:start;display:inline-flex;gap:4px;align-items:center;padding:11px 14px;background:var(--surface);border:1px solid var(--border);border-radius:14px;border-bottom-left-radius:4px}
.typing.ai{justify-self:end;background:var(--primary-tint);border-color:#bfe6da;border-bottom-right-radius:4px;border-bottom-left-radius:14px}
.typing i{width:6px;height:6px;border-radius:50%;background:var(--ink-faint);animation:td 1.2s infinite}
.typing.ai i{background:var(--primary)}
.typing i:nth-child(2){animation-delay:.18s}.typing i:nth-child(3){animation-delay:.36s}
@keyframes td{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}

/* live ring that turns "connecting" -> "live" */
.call .ring.answered{background:var(--primary);animation:callpulse 2s infinite}

/* ===== Local SEO live search demo ===== */
.searchdemo{position:relative}
.gsearch{display:flex;align-items:center;gap:9px;padding:11px 14px;border-bottom:1px solid var(--border);background:#fff}
.gsearch .gicon{font-size:.95rem;opacity:.6}
.gsearch .gtype{font-size:.92rem;color:var(--ink);white-space:nowrap;overflow:hidden}
.gsearch .gcaret{display:inline-block;width:2px;height:1.05em;background:var(--primary);margin-left:1px;vertical-align:-2px;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.gmap{position:relative;height:188px;overflow:hidden;background:#e7ece3}
.gmap iframe{width:100%;height:100%;border:0;filter:saturate(1.02)}
.gmap .mpin{position:absolute;left:50%;top:46%;transform:translate(-50%,-100%);font-size:1.9rem;filter:drop-shadow(0 4px 5px rgba(0,0,0,.28));z-index:2}
.gmap .mpin::after{content:"";position:absolute;left:50%;bottom:-3px;transform:translateX(-50%);width:14px;height:14px;border-radius:50%;background:var(--primary-glow);box-shadow:0 0 0 0 rgba(12,127,143,.45);animation:mppulse 2s infinite}
@keyframes mppulse{0%{box-shadow:0 0 0 0 rgba(12,127,143,.4)}70%{box-shadow:0 0 0 16px rgba(12,127,143,0)}100%{box-shadow:0 0 0 0 rgba(12,127,143,0)}}
.gmap .mlbl{position:absolute;left:50%;top:46%;transform:translate(-50%,-225%);background:#fff;border:1px solid var(--border);border-radius:8px;padding:4px 9px;font-size:.7rem;font-weight:600;box-shadow:var(--shadow);white-space:nowrap;z-index:2}
.gres{padding:12px 14px 14px;display:grid;gap:9px;background:#fff}
.gres .gcard{padding:9px 11px;border:1px solid var(--border);border-radius:11px;background:#fff;transition:opacity .5s var(--ease),transform .5s var(--ease)}
.gres .gcard .rk{font-size:.66rem;font-weight:700;color:var(--primary-deep);letter-spacing:.04em}
.gres .gcard .nm{font-weight:600;font-size:.92rem;margin-top:2px;color:var(--blue)}
.gres .gcard .mt{font-size:.76rem;color:var(--ink-soft);margin-top:3px}
.gres .gcard .mt .st{color:var(--signal)}
.gres .gcard.top{background:var(--primary-tint);border-color:#9ed9c8;box-shadow:0 6px 18px -10px rgba(12,127,143,.5)}
/* map + results hidden until the query is typed */
.searchdemo .gmap,.searchdemo .gres{opacity:0;transform:translateY(12px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.searchdemo.show .gmap,.searchdemo.show .gres{opacity:1;transform:none}
.searchdemo.show .gres .gcard.top{animation:rise2top .7s var(--ease) both}
@keyframes rise2top{0%{transform:translateY(34px);opacity:0}60%{transform:translateY(-4px)}100%{transform:none;opacity:1}}

/* counters (ads / social metrics) */
.count-up{font-variant-numeric:tabular-nums}

/* honor reduced motion across all live bits */
@media(prefers-reduced-motion:reduce){
  [data-step]{opacity:1;transform:none;transition:none}
  .searchdemo .gmap,.searchdemo .gres{opacity:1;transform:none}
  .gmap .mpin::after,.typing i,.gsearch .gcaret,.searchdemo.show .gres .gcard.top{animation:none}
}

/* ===== rendered product videos in a true iPhone bezel (island baked into video) ===== */
.vphone{position:relative;width:306px;max-width:80vw;margin:0 auto;border-radius:54px;padding:13px;
  background:linear-gradient(155deg,#23262b,#0a0c0e 55%,#1a1d22);
  box-shadow:0 40px 80px -30px rgba(8,12,10,.75),0 6px 18px rgba(8,12,10,.35),inset 0 0 0 2px rgba(255,255,255,.05);}
.vphone video{display:block;width:100%;height:auto;aspect-ratio:1080/2340;border-radius:42px;background:#0c1f1a}
.vland{position:relative;border-radius:16px;overflow:hidden;background:#f5f6f6;box-shadow:0 28px 56px -34px rgba(20,19,15,.30),0 3px 12px rgba(20,19,15,.07);border:1px solid var(--hair,rgba(20,19,15,.1))}
.vland .vbar{display:flex;align-items:center;gap:7px;padding:11px 16px;background:#f8f9f9;border-bottom:1px solid #ececec}
.vland .vbar .vu{margin-left:10px;font-family:var(--mono);font-size:.72rem;color:var(--ink-faint);letter-spacing:.02em}
.vland video{display:block;width:100%;height:auto;aspect-ratio:16/10}
.hero-vis{position:relative}
@media(min-width:941px){.hero-vis{transform:translateX(22px)}}
/* dashboard-screen embeds on product pages */
.dashgrid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:8px}
@media(max-width:900px){.dashgrid{grid-template-columns:1fr}}
.dashshot{border:1px solid var(--hair,#e6e2d6);border-radius:14px;overflow:hidden;background:#fff;box-shadow:0 24px 50px -28px rgba(20,19,15,.4);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.dashshot .bar{display:flex;align-items:center;gap:.5rem;padding:9px 14px;border-bottom:1px solid #ececec;background:#f7f8f8;font-size:.72rem;color:var(--ink-faint)}
.dashshot .bar .urlbar{margin-left:8px}
.dashshot img{display:block;width:100%;height:auto;filter:brightness(.965);transition:filter .4s var(--ease),transform .5s var(--ease)}
@media (hover:hover) and (pointer:fine){
  .dashshot{cursor:pointer}
  .dashshot:hover{transform:translateY(-8px);box-shadow:0 46px 82px -34px rgba(12,127,143,.5),0 12px 26px -18px rgba(20,19,15,.32)}
  .dashshot:hover img{filter:brightness(1.06) saturate(1.05);transform:scale(1.015)}
}
.dashcap{margin-top:13px;font-family:var(--mono);font-size:.72rem;color:var(--ink-faint);letter-spacing:.02em;display:flex;align-items:center;gap:8px}
.dashcap .lvdot{width:7px;height:7px;border-radius:50%;background:var(--primary)}
/* Website-template preview (rendered PNGs already include browser chrome) */
.sitepreview{border-radius:16px;overflow:hidden;border:1px solid var(--hair,#e6e2d6);box-shadow:0 24px 50px -28px rgba(20,19,15,.4)}
.sitepreview img{display:block;width:100%;height:auto}
.vcap{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:18px;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.02em;color:var(--ink-faint)}
@media(max-width:880px){.vphone{width:270px}}

/* ============ DEMO-REQUEST MODAL ============ */
.dosm-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(20,19,15,.55);backdrop-filter:blur(5px);opacity:0;transition:opacity .22s var(--ease)}
.dosm-overlay[hidden]{display:none}
.dosm-overlay.dosm-show{opacity:1}
.dosm-card{position:relative;width:100%;max-width:540px;max-height:92vh;overflow:auto;background:var(--paper);border:1px solid var(--hair);border-radius:22px;padding:38px 36px 30px;box-shadow:0 40px 90px -30px rgba(20,19,15,.6);transform:translateY(10px) scale(.97);transition:transform .24s var(--ease)}
.dosm-overlay.dosm-show .dosm-card{transform:none}
.dosm-x{position:absolute;top:16px;right:18px;width:38px;height:38px;border-radius:50%;border:1px solid var(--border);background:var(--card);color:var(--ink-soft);font-size:1.4rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .2s var(--ease),transform .15s var(--ease)}
.dosm-x:hover{background:var(--surface)}.dosm-x:active{transform:scale(.94)}
.dosm-inner h3{font-family:var(--serif);font-size:1.7rem;margin-top:10px}
.dosm-sub{color:var(--ink-soft);margin-top:8px;font-size:.96rem}
.dosm-form{margin-top:20px;display:flex;flex-direction:column;gap:14px}
.dosm-form .field{display:flex;flex-direction:column;gap:6px}
.dosm-form label{font-family:var(--mono);font-size:.66rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}
.dosm-form label i{color:var(--primary-deep);font-style:normal}
.dosm-opt-tag{text-transform:none;letter-spacing:0;color:var(--ink-faint);font-family:var(--sans);font-size:.78rem}
.dosm-form input,.dosm-form textarea{width:100%;font-family:var(--sans);font-size:.95rem;color:var(--ink);background:var(--card);border:1.5px solid var(--border);border-radius:11px;padding:12px 14px;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.dosm-form input:focus,.dosm-form textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.dosm-form textarea{resize:vertical;min-height:78px;line-height:1.5}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.frow{grid-template-columns:1fr}}
/* multi-select */
.dosm-ms{position:relative}
.dosm-ms-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;font-family:var(--sans);font-size:.95rem;color:var(--ink-faint);background:var(--card);border:1.5px solid var(--border);border-radius:11px;padding:12px 14px;cursor:pointer;transition:border-color .2s var(--ease)}
.dosm-ms-btn.has{color:var(--ink)}
.dosm-ms-btn.open{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.dosm-ms-caret{transition:transform .2s var(--ease);color:var(--ink-faint)}
.dosm-ms-btn.open .dosm-ms-caret{transform:rotate(180deg)}
.dosm-ms-panel{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:5;background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lift);padding:6px;display:flex;flex-direction:column}
.dosm-ms-panel[hidden]{display:none}
.dosm-opt{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:9px;cursor:pointer;font-size:.95rem;color:var(--ink);transition:background .15s var(--ease)}
.dosm-opt:hover{background:var(--surface)}
.dosm-opt input{position:absolute;opacity:0;width:0;height:0}
.dosm-check{width:20px;height:20px;border:1.5px solid var(--border-strong);border-radius:6px;flex:0 0 auto;display:grid;place-items:center;transition:background .15s var(--ease),border-color .15s var(--ease)}
.dosm-opt input:checked + .dosm-check{background:var(--primary);border-color:var(--primary)}
.dosm-opt input:checked + .dosm-check::after{content:"✓";color:#fff;font-size:.8rem;font-weight:700}
.dosm-note{font-family:var(--mono);font-size:.66rem;letter-spacing:.04em;color:var(--ink-faint);text-align:center;margin-top:10px}
.dosm-err{color:var(--rose);font-size:.86rem;font-weight:500;margin-top:2px}
@media(prefers-reduced-motion:reduce){.dosm-overlay,.dosm-card,.dosm-x,.dosm-ms-caret{transition:none}.dosm-card{transform:none}}
/* 6 nav items — tighten to fit */
header .navlinks{gap:1.05rem;font-size:.72rem}
@media(max-width:1180px){header .navlinks{gap:.8rem;font-size:.68rem}}
