/* DilloLex - shared styles (navy-authority theme) */
/* Fonts: self-hosted Source Serif 4 + Inter (woff2, latin + latin-ext). */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/inter-400-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/inter-400.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/inter-500-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/inter-500.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/inter-600-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/inter-600.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/inter-700-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/inter-700.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/sourceserif4-500-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/sourceserif4-500.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/sourceserif4-600-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/sourceserif4-600.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/sourceserif4-700-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Source Serif 4';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/sourceserif4-700.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}

@font-face{font-family:'Century Supra';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/century-supra-regular.woff') format('woff')}
@font-face{font-family:'Century Supra';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/century-supra-bold.woff') format('woff')}
@font-face{font-family:'Century Supra';font-style:italic;font-weight:400;font-display:swap;src:url('fonts/century-supra-italic.woff') format('woff')}
@font-face{font-family:'Century Supra';font-style:italic;font-weight:700;font-display:swap;src:url('fonts/century-supra-bolditalic.woff') format('woff')}
@font-face{font-family:'Valkyrie OT B';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/valkyrie-b-regular.woff2') format('woff2')}
@font-face{font-family:'Valkyrie OT B';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/valkyrie-b-bold.woff2') format('woff2')}
@font-face{font-family:'Valkyrie OT B';font-style:italic;font-weight:400;font-display:swap;src:url('fonts/valkyrie-b-italic.woff2') format('woff2')}
@font-face{font-family:'Valkyrie OT B';font-style:italic;font-weight:700;font-display:swap;src:url('fonts/valkyrie-b-bolditalic.woff2') format('woff2')}

:root{
  color-scheme:light; /* light-only design: keep native form controls, scrollbars & dropdowns light even on a dark-mode OS */

  /* ---- Ink (existing; keep) ---- */
  --ink:#0F1B30; --navy-2:#1E2C44; --slate:#2A3A57; --body:#475569; --muted-strong:#52617a;

  /* ---- Ground + surfaces (existing; keep hues) ---- */
  --bg:#F6F8FC; --bg2:#E8EEF6; --bg-warm:#F6EFE4; --card:#ffffff;
  --line:#D5DEEC;
  --line-strong:#C2CEE0;

  /* ---- Brass (existing; keep, scarce) ---- */
  --brass:#B07D3C; --brass-deep:#946429;

  /* ---- Teal: promoted to the signature accent ---- */
  --teal:#0A8C86;
  --teal-deep:#097a74;
  --teal-strong:#066B66;
  --teal-tint:#E6F4F3;
  --teal-line:#BFE0DD;

  /* ---- Radius ---- */
  --r:18px;
  --r-card:14px;
  --r-sm:8px;

  /* ---- Elevation ramp (2-step: resting / raised) ---- */
  --shadow-xs:0 1px 2px rgba(15,27,48,.05);
  --shadow:0 1px 2px rgba(15,27,48,.06), 0 4px 14px -6px rgba(15,27,48,.14);
  --shadow-md:0 2px 6px rgba(15,27,48,.08), 0 16px 32px -16px rgba(15,27,48,.22);
  --shadow-lg:0 24px 60px -24px rgba(15,27,48,.42);

  /* ---- Focus ring (single source; teal) ---- */
  --ring:0 0 0 3px rgba(10,140,134,.30);

  /* ---- Type scale ---- */
  --fs-display:clamp(2.3rem,4.6vw,3.4rem);
  --fs-data:clamp(1.8rem,3vw,2.4rem);
  --tracking-eyebrow:.13em;

  --maxw:1140px; --r-old:18px; --shell:#B07D3C;
  --grad:linear-gradient(135deg,#13243F 0%,#0F1B30 100%);
  --grad-brass:linear-gradient(135deg,#B07D3C 0%,#946429 100%);
  --grad-warm:linear-gradient(135deg,#B07D3C 0%,#946429 100%);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth; scroll-padding-top:84px}
body{margin:0; font-family:"Inter",system-ui,sans-serif; color:var(--body); background:var(--bg); line-height:1.65; -webkit-font-smoothing:antialiased; font-size:17px}
h1,h2,h3,h4{font-family:"Century Supra","Source Serif 4",Georgia,serif; line-height:1.12; font-weight:700; letter-spacing:-.015em; margin:0 0 .4em; color:var(--ink)}
h1{font-size:clamp(2.3rem,4.6vw,3.4rem)}
h2{font-size:clamp(1.8rem,3.4vw,2.5rem)}
h3{font-size:1.26rem; letter-spacing:-.01em}
p{margin:0 0 1rem}
main p,main li,main .lead,main blockquote,.prose,.prose p,.prose li{font-family:"Valkyrie OT B",Georgia,serif}
a{color:var(--teal-strong); text-decoration:none; font-weight:500}
a:hover{color:var(--brass-deep)}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}
.narrow{max-width:840px}
section{padding:84px 0; position:relative}
.eyebrow{display:inline-block; text-transform:uppercase; letter-spacing:var(--tracking-eyebrow); font-size:.76rem; font-weight:700; color:var(--teal-strong); background:var(--teal-tint); padding:6px 13px; border-radius:var(--r-sm); margin-bottom:18px}
/* status chips: honest capability tiers (Live / Rolling out / Roadmap) */
.st{display:inline-flex; align-items:center; gap:6px; font-size:.68rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; padding:4px 10px; border-radius:999px; border:1px solid transparent; line-height:1; vertical-align:middle}
.st::before{content:""; width:6px; height:6px; border-radius:50%; background:currentColor}
.st.live{color:var(--teal-strong); background:var(--teal-tint); border-color:rgba(10,140,134,.25)}
.st.pilot{color:var(--brass-deep); background:#F7EFE4; border-color:rgba(176,125,60,.3)}
.st.soon{color:var(--muted-strong); background:#EEF2F7; border-color:#E0E7F0}
.card .st{margin-bottom:13px}
.frow .st{margin-left:10px; vertical-align:middle}
.lead{font-size:1.2rem; color:var(--muted-strong); max-width:62ch}
.sub-lead{font-size:1.02rem; color:var(--brass); font-weight:600; max-width:60ch; margin:-6px 0 26px}
.center{text-align:center; max-width:760px; margin:0 auto 50px}
.center .lead{margin-left:auto;margin-right:auto}
.gt{color:var(--ink); box-shadow:inset 0 -.16em 0 rgba(176,125,60,.35)}

/* skip link + focus */
.skip-link{position:absolute; left:-9999px; top:0; background:var(--ink); color:#fff!important; padding:10px 18px; z-index:100; border-radius:0 0 8px 0}
.skip-link:focus{left:0}
.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0}
:where(a,button,summary,input,textarea,select,[tabindex]):focus-visible{outline:3px solid var(--teal); outline-offset:3px; border-radius:6px}
.dark :focus-visible,.band :focus-visible{outline-color:#fff}

/* sections */
.alt{background:var(--bg2)}
.warm{background:var(--bg-warm)}
.dark{background:var(--grad); color:#fff; overflow:hidden}
.dark h1,.dark h2,.dark h3,.dark h4{color:#fff}
.dark p{color:#cdd7e6}
.dark .eyebrow{color:#fff; background:rgba(255,255,255,.14)}
.band{background:var(--ink); color:#fff; text-align:center; overflow:hidden}
.band h2{color:#fff}
.band p{color:#cdd7e6; max-width:60ch; margin:0 auto 26px}

/* buttons */
.btn{display:inline-block; background:var(--ink); color:#fff!important; font-weight:600; padding:14px 28px; border-radius:10px; border:2px solid var(--ink); transition:.18s; cursor:pointer; box-shadow:0 10px 22px -14px rgba(15,27,48,.7)}
.btn:hover{transform:translateY(-2px); background:var(--brass); border-color:var(--brass); color:#fff!important}
.btn.ghost{background:#fff; color:var(--ink)!important; border-color:var(--line); box-shadow:none}
.btn.ghost:hover{border-color:var(--ink); color:var(--ink)!important; background:#fff}
.btn.light{background:#fff; color:var(--ink)!important; border-color:#fff; box-shadow:0 10px 30px -14px rgba(0,0,0,.4)}
.btn.light:hover{color:var(--brass-deep)!important}
.btn.sm{padding:10px 20px; font-size:.95rem}
.btn-link{font-weight:600; display:inline-flex; align-items:center; gap:6px}
.cta-row{display:flex; gap:20px; flex-wrap:wrap; align-items:center}

/* header */
header{position:sticky; top:0; z-index:50; background:rgba(255,255,255,.88); backdrop-filter:blur(12px); border-bottom:1px solid var(--line)}
.nav{display:flex; align-items:center; justify-content:space-between; height:70px}
.brand{display:flex; align-items:center; gap:11px; font-family:"Source Serif 4"; font-weight:700; font-size:1.32rem; color:var(--ink)}
.brand:hover{color:var(--ink)}
.brand .dot{color:var(--brass)}
.brand-logo{height:36px; width:auto; display:block}
.foot-logo{height:26px; width:auto; vertical-align:-8px; background:#fff; border-radius:7px; padding:3px; box-sizing:content-box}
.navlinks{display:flex; align-items:center; gap:24px}
.navlinks a{color:var(--ink); font-weight:500; font-size:.96rem}
.navlinks a:hover{color:var(--brass-deep)}
.navlinks a.active{color:var(--teal-strong)}
.menu-btn{display:none; place-items:center; min-width:44px; min-height:44px; background:none; border:0; font-size:1.6rem; cursor:pointer; color:var(--ink)}

/* page hero (interior) */
.page-hero{padding:74px 0 54px; background:var(--bg2); border-bottom:1px solid var(--line); position:relative; overflow:hidden}
.page-hero .lead{margin-bottom:0}

/* home hero */
.hero{padding:72px 0 60px; overflow:hidden; position:relative}
.hero-grid{display:grid; grid-template-columns:1.08fr .92fr; gap:48px; align-items:center; position:relative}
.hero .lead{margin-bottom:28px}
.hero-art{display:flex; justify-content:center}

.kpis{display:flex; gap:14px; flex-wrap:wrap; margin-top:42px; position:relative}
.kpi{background:var(--card); border:1px solid var(--line); border-radius:var(--r-card); padding:18px 20px; flex:1; min-width:150px; box-shadow:var(--shadow)}
.kpi b{font-family:"Source Serif 4"; font-size:1.35rem; display:block; color:var(--ink)}
.kpi span{font-size:.85rem; color:var(--body)}

/* trust strip */
.trust{display:flex; gap:12px; flex-wrap:wrap; margin-top:24px}
.trust .pill{display:inline-flex; align-items:center; gap:7px; background:#fff; border:1px solid var(--line); border-radius:8px; padding:8px 14px; font-size:.85rem; font-weight:600; color:var(--ink)}
.trust .pill::before{content:""; width:7px; height:7px; border-radius:50%; background:var(--teal)}
.cta-note{font-size:.86rem; color:var(--body); margin:14px 0 0}

/* grids & cards */
.grid{display:grid; gap:22px}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--card); border:1px solid var(--line); border-radius:var(--r-card); padding:30px; box-shadow:var(--shadow); transition:transform .18s ease, box-shadow .18s, border-color .12s}
.card:hover{transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:var(--line-strong)}
.card.linked{border-left:3px solid transparent}
.card.linked:hover{border-left-color:var(--teal)}
.card.dk{background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.16)}
.card.dk:hover{transform:translateY(-3px); background:rgba(255,255,255,.1)}
.card.dk h3{color:#fff}.card.dk p{color:#cdd7e6}
/* Docket-tab rule under section eyebrows/headers (decorative; not sole indicator) */
.page-hero{position:relative}
.page-hero .wrap::after,
.center.docket::after{
  content:""; display:block; height:2px; width:100%; margin-top:22px;
  background:linear-gradient(to right, var(--teal) 0 44px, var(--line) 44px);
}

/* Data-fig: load-bearing serif numbers with tabular figures + teal underscore */
.data-fig{font-family:"Source Serif 4",Georgia,serif; font-weight:700; line-height:1;
  font-size:var(--fs-data); color:var(--ink); font-variant-numeric:tabular-nums lining-nums;
  display:inline-block; padding-bottom:4px;
  background:linear-gradient(var(--teal),var(--teal)) 0 100%/2.2ch 2px no-repeat}

/* Header CTA lift */
.nav .btn.sm{box-shadow:var(--shadow)}
.nav .btn.sm:hover{box-shadow:var(--shadow-md)}

/* Moat sub-bar under header (desktop only) */
.moat-bar{background:var(--bg); border-bottom:1px solid var(--line); text-align:center; padding:5px 0; font-size:.78rem; font-weight:600; color:var(--teal-strong); letter-spacing:.01em; display:none}
@media(min-width:700px){.moat-bar{display:block}}

.card .ic{width:46px;height:46px;border-radius:11px;background:var(--ink);display:grid;place-items:center;margin-bottom:18px;color:#fff;box-shadow:0 8px 18px -10px rgba(15,27,48,.6)}
.card:nth-child(2n) .ic{background:var(--grad-brass); box-shadow:0 8px 18px -10px rgba(176,125,60,.6)}
.dlx-ic{display:block; width:56px; height:56px; margin-bottom:16px}
.card.dk .ic{background:rgba(255,255,255,.14); box-shadow:none}
.card .ic svg{width:23px; height:23px; stroke:#fff; fill:none; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round}
.card h3{margin-bottom:.35em}
.card p{margin:0; font-size:.98rem; color:var(--body)}

/* media / images */
.media{border-radius:var(--r); overflow:hidden; position:relative; background:var(--grad); min-height:300px; box-shadow:var(--shadow-lg)}
.media img{width:100%; height:100%; object-fit:cover; display:block; position:relative; z-index:1; min-height:300px; aspect-ratio:11/6}
.media .fb{position:absolute; inset:0; display:grid; place-items:center; z-index:0}
.media .fb svg{width:38%; opacity:.85}

/* steps */
.steps{display:grid; gap:18px}
.step{display:grid; grid-template-columns:auto 1fr; gap:22px; align-items:start; background:var(--card); border:1px solid var(--line); border-radius:16px; padding:26px 28px; transition:.2s}
.step:hover{box-shadow:var(--shadow-md)}
.step .num{width:46px;height:46px;border-radius:12px;background:var(--ink);color:#fff;font-family:"Source Serif 4";font-weight:700;display:grid;place-items:center;font-size:1.12rem}
.step:nth-child(2n) .num{background:var(--grad-brass)}
.step h3{margin-bottom:.2em}
.step p{margin:0; font-size:.98rem}

/* feature rows */
.frow{display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; margin-bottom:56px}
.frow:nth-child(even) .ftext{order:2}
.frow .fart{border-radius:var(--r); padding:40px; min-height:200px; display:flex; align-items:center; justify-content:center; background:var(--bg2); border:1px solid var(--line)}
.frow .fart svg{width:84px; stroke:var(--ink); fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round}
.frow:nth-child(even) .fart svg{stroke:var(--brass)}
.frow .fart .dlx-fart{width:112px; height:112px}
.frow h3{font-size:1.55rem}

/* checklist */
.checklist{list-style:none; padding:0; margin:0}
.checklist li{padding:10px 0 10px 34px; position:relative; color:var(--ink)}
.checklist li::before{content:"✓"; position:absolute; left:0; top:9px; width:22px;height:22px;border-radius:50%;background:var(--teal-tint);color:var(--teal-deep);display:grid;place-items:center;font-size:.8rem;font-weight:700}

/* comparison grid */
.compare-wrap{overflow-x:auto; -webkit-overflow-scrolling:touch; width:100%; max-width:100%}
.compare{width:100%; min-width:640px; border-collapse:collapse; background:var(--card); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-md); font-size:.96rem}
.compare th,.compare td{padding:15px 18px; text-align:left; border-bottom:1px solid var(--line)}
.compare thead th{font-family:"Source Serif 4"; background:var(--bg2); color:var(--ink); font-size:.95rem}
.compare thead th.us{background:var(--ink); color:#fff}
.compare td.us{background:rgba(15,27,48,.03); font-weight:600; color:var(--ink)}
.compare tbody th{font-family:"Inter"; font-weight:600; color:var(--ink); background:#fff}
.compare tr:last-child th,.compare tr:last-child td{border-bottom:0}
.compare .yes{color:var(--teal-deep); font-weight:700}
.compare .no{color:#52617a}

/* dial (static cards) */
.dial{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:8px}
.dial .lvl{background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.16); border-radius:14px; padding:22px}
.dial .lvl h3{font-size:1.02rem; margin-bottom:.3em; color:#fff}
.dial .lvl p{font-size:.88rem; margin:0; color:#cdd7e6}
.dial .tag{font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:#fff; font-weight:700; background:rgba(176,125,60,.45); padding:3px 9px; border-radius:6px}

/* table */
.tbl{width:100%; border-collapse:collapse; background:var(--card); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; font-size:.98rem; box-shadow:var(--shadow-md)}
.tbl th,.tbl td{text-align:left; padding:15px 20px; border-bottom:1px solid var(--line)}
.tbl th{font-family:"Source Serif 4"; background:var(--bg2); color:var(--ink)}
.tbl tr:last-child td{border-bottom:0}

/* pricing tiers */
.tiers{display:grid; grid-template-columns:repeat(2,1fr); gap:26px; align-items:stretch}
.tier{background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:34px; display:flex; flex-direction:column; position:relative; box-shadow:var(--shadow)}
.tier.feature{border:2px solid var(--ink)}
.tier .pill{position:absolute; top:-14px; left:34px; background:var(--ink); color:#fff; font-size:.74rem; font-weight:700; padding:6px 15px; border-radius:6px; letter-spacing:.04em}
.tier h3{font-size:1.45rem}
.tier .price{font-family:"Source Serif 4"; font-size:1.05rem; color:var(--brass-deep); margin:.2em 0 1em; font-weight:600}
.tier ul{list-style:none; padding:0; margin:0 0 26px; flex:1}
.tier li{padding:9px 0 9px 30px; position:relative; font-size:.97rem; color:var(--ink); border-bottom:1px solid #eef3f8}
.tier li::before{content:"✓"; position:absolute; left:4px; color:var(--teal-deep); font-weight:700}
.note-box{background:#fff; border:1px solid var(--line); border-left:4px solid var(--brass); border-radius:var(--r-card); padding:20px 24px; font-size:.96rem; margin-top:26px; box-shadow:var(--shadow)}
/* Recommended tier: teal top accent bar */
.tier.feature::before{content:""; display:block; height:4px; background:var(--teal); border-radius:var(--r) var(--r) 0 0; position:absolute; top:-2px; left:-2px; right:-2px}

/* faq */
details{background:var(--card); border:1px solid var(--line); border-radius:12px; padding:4px 24px; margin-bottom:12px; transition:.2s}
details[open]{box-shadow:var(--shadow-md); border-color:var(--line-strong)}
summary{cursor:pointer; font-weight:600; font-family:"Source Serif 4"; font-size:1.05rem; padding:18px 0; list-style:none; display:flex; justify-content:space-between; gap:16px; align-items:center; color:var(--ink)}
summary::-webkit-details-marker{display:none}
summary::after{content:"+"; color:var(--brass); font-size:1.6rem; font-weight:400; flex:none}
details[open] summary::after{content:"-"}
details p{padding:0 0 20px; font-size:.98rem; margin:0; color:var(--body)}

/* contact */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:44px; align-items:start}
form{display:grid; gap:14px}
label{font-size:.85rem; font-weight:600; color:var(--ink); margin-bottom:-8px}
input,textarea,select{font-family:inherit; font-size:1rem; padding:13px 15px; border:1px solid var(--line); border-radius:10px; background:#fff; color:var(--ink); width:100%}
input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--teal); outline-offset:2px; border-color:var(--teal); box-shadow:var(--ring)}
.contact-grid .card{box-shadow:var(--shadow-md)}

/* prose */
.prose p{font-size:1.06rem; color:var(--body)}
.prose h3{margin-top:1.7em; color:var(--ink)}

/* footer */
footer{background:#0B1322; color:#9fb0c4; padding:60px 0 40px; font-size:.92rem}
footer h3{color:#fff; font-family:"Source Serif 4"; font-size:1.05rem; margin:0 0 12px}
.foot-grid{display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:34px; margin-bottom:36px}
footer a{color:#c6d4e3}
footer address{font-style:normal; color:#b3c1d2; line-height:1.8}
.disclaimer{border-top:1px solid #1c2940; padding-top:26px; font-size:.8rem; color:#8a9bb0; line-height:1.7}

/* ===== interactions ===== */
.scroll-progress{position:fixed; top:0; left:0; height:4px; width:100%; transform:scaleX(0); transform-origin:0 50%; background:var(--brass); z-index:90; transition:transform .08s linear}
.reveal{opacity:0; transform:translateY(20px); transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1; transform:none}
.sticky-cta{position:fixed; left:50%; bottom:18px; transform:translate(-50%,140%); width:min(820px,calc(100% - 32px)); background:var(--ink); color:#fff; border-radius:14px; padding:14px 18px; display:flex; align-items:center; justify-content:space-between; gap:16px; box-shadow:0 20px 50px -16px rgba(0,0,0,.55); z-index:80; transition:transform .35s cubic-bezier(.2,.8,.2,1); font-size:.95rem}
.sticky-cta.show{transform:translate(-50%,0)}
.sticky-cta strong{color:#fff}
.sticky-actions{display:flex; align-items:center; gap:10px; flex:none}
.sticky-x{background:none; border:0; color:#9fb0c4; font-size:1.5rem; line-height:1; cursor:pointer; padding:0 4px}
.sticky-x:hover{color:#fff}

/* renamer demo */
.demo{max-width:880px; margin:0 auto}
.demo-chips{display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:22px}
.chip{font-family:"Inter",monospace; font-size:.95rem; background:#fff; border:1px solid var(--line); color:#475569; padding:10px 16px; border-radius:8px; cursor:pointer; transition:.18s; box-shadow:0 4px 10px -8px rgba(15,27,48,.3)}
.chip:hover{border-color:var(--ink); color:var(--ink); transform:translateY(-2px)}
.chip.active{background:var(--ink); color:#fff; border-color:var(--ink)}
.demo-stage{background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:30px; box-shadow:var(--shadow); text-align:center}
.demo-controls{display:flex; justify-content:center; margin-bottom:14px}
.demo-pause{background:#fff; border:1px solid var(--line); color:var(--body); border-radius:999px; padding:5px 14px; font-size:.82rem; font-weight:600; cursor:pointer}
.demo-pause:hover{border-color:var(--ink); color:var(--ink)}
.demo-row{display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; font-size:1.1rem}
.demo-raw{font-family:monospace; color:#475569}
.demo-arrow{color:var(--brass); font-weight:700; font-size:1.4rem}
.demo-clean{font-family:"Source Serif 4",Georgia,serif; font-weight:700; color:var(--ink); font-size:1.22rem; min-height:1.4em; word-break:break-word; overflow-wrap:break-word}
.demo-clean::after{content:"▍"; color:var(--teal); animation:blink 1s steps(2) infinite}
.demo-meta{margin-top:16px; font-size:.9rem; color:var(--body); display:flex; align-items:center; gap:8px; justify-content:center; flex-wrap:wrap}
.demo-type{color:var(--teal-deep); font-weight:600}
.demo-dot{color:#cbd5e1}
.demo-badge{background:var(--teal-tint); color:var(--teal-deep); font-weight:600; padding:3px 10px; border-radius:6px; font-size:.8rem}
@keyframes blink{50%{opacity:0}}

/* interactive dial */
.dial-i{margin-top:34px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.16); border-radius:var(--r); padding:24px}
.dial-seg{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:22px}
.dial-seg button{flex:1; min-width:130px; background:rgba(255,255,255,.08); color:#fff; border:1px solid rgba(255,255,255,.2); padding:11px 12px; border-radius:9px; font-family:"Source Serif 4",Georgia,serif; font-weight:600; font-size:.92rem; cursor:pointer; transition:.18s}
.dial-seg button:hover{background:rgba(255,255,255,.16)}
.dial-seg button.active{background:#fff; color:var(--ink)}
.dial-diagram{display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; margin-bottom:14px}
.dchip{display:inline-flex; align-items:center; gap:7px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.22); border-radius:8px; padding:8px 14px; font-weight:600; color:#fff; font-size:.92rem}
.dchip svg{width:17px; height:17px; stroke:#fff; fill:none; stroke-width:1.7}
.dflow{font-family:"Source Serif 4",Georgia,serif; font-weight:700; color:#fff; letter-spacing:.01em; transition:.2s}
.dial-diagram.cut .cloud{opacity:.35}
.dial-diagram.cut .dflow{color:#e7c9a3}
.dial-what{color:#cdd7e6; margin:0; text-align:center; font-size:1rem; min-height:3em}

/* roi calculator */
.roi-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:44px; align-items:center}
.roi-controls{margin-top:22px; display:grid; gap:6px}
.roi-controls label{display:flex; justify-content:space-between; align-items:center; font-weight:600; color:var(--ink); font-size:.95rem; margin:14px 0 0}
.roi-controls output{font-family:"Source Serif 4",Georgia,serif; color:var(--teal-strong); background:var(--teal-tint); padding:2px 12px; border-radius:6px; font-size:.95rem}
.roi-controls input[type=range]{-webkit-appearance:none; appearance:none; width:100%; height:8px; border-radius:999px; background:#dfeaf3; outline:none; padding:0}
.roi-controls input[type=range]::-webkit-slider-thumb{-webkit-appearance:none; width:24px; height:24px; border-radius:50%; background:var(--ink); cursor:pointer; box-shadow:0 4px 10px -4px rgba(15,27,48,.7); border:3px solid #fff}
.roi-controls input[type=range]::-moz-range-thumb{width:22px; height:22px; border-radius:50%; background:var(--ink); cursor:pointer; border:3px solid #fff}
.roi-controls input[type=range]:focus-visible{outline:3px solid var(--teal); outline-offset:4px}
.roi-controls input[type=range]:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 4px rgba(10,140,134,.5)}
.roi-controls input[type=range]:focus-visible::-moz-range-thumb{box-shadow:0 0 0 4px rgba(10,140,134,.5)}
.roi-result{background:var(--ink); color:#fff; border-radius:var(--r); padding:36px; text-align:center; box-shadow:var(--shadow-lg)}
.roi-num{font-family:"Source Serif 4",Georgia,serif; font-weight:700; line-height:1; color:#fff}
.roi-num span{font-size:clamp(3rem,8vw,4.4rem); color:#fff}
.roi-num small{display:block; font-size:1.05rem; color:#cdd7e6; font-weight:500; margin-top:6px}
.roi-note{color:#cdd7e6; margin:18px 0 24px; min-height:3em}
.roi-result .btn{background:#fff; color:var(--ink)!important; border-color:#fff}
.roi-result .btn:hover{background:var(--brass); color:#fff!important; border-color:var(--brass)}

@media(prefers-reduced-motion:reduce){
  .demo-clean::after{animation:none}
  .scroll-progress{transition:none}
  .sticky-cta{transition:none}
  .reveal{transition:none}
  .card{transition:none; transform:none}
  .data-fig{background:none; padding-bottom:0}
}

@media(max-width:880px){
  .roi-grid{grid-template-columns:1fr}
  .roi-result .btn{display:block; text-align:center}
  .sticky-cta{flex-direction:column; gap:10px; text-align:center; bottom:10px}
  .sticky-actions{justify-content:center; width:100%}
  .hero-grid,.g3,.g2,.tiers,.contact-grid,.frow{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .dial{grid-template-columns:1fr 1fr}
  .frow:nth-child(even) .ftext{order:0}
  .hero-art{order:-1}
  .navlinks{position:fixed; inset:70px 0 auto 0; background:#fff; flex-direction:column; align-items:flex-start; gap:0; padding:8px 24px 22px; border-bottom:1px solid var(--line); display:none; box-shadow:var(--shadow)}
  .navlinks.open{display:flex}
  .navlinks a{padding:14px 0; width:100%; border-bottom:1px solid var(--line)}
  .navlinks .btn{margin-top:10px}
  .menu-btn{display:grid}
  section{padding:60px 0}
  .demo-clean{font-size:1.05rem}
  .kpis{flex-direction:column}
  .compare{min-width:480px; font-size:.9rem}
  .compare th,.compare td{padding:11px 12px}
  .compare thead th:first-child,.compare tbody th{position:sticky; left:0; z-index:1}
  .compare thead th:first-child{background:var(--bg2)}
  .compare tbody th{background:#fff; box-shadow:1px 0 0 var(--line)}
  .compare-wrap{box-shadow:inset -14px 0 11px -11px rgba(15,27,48,.13)}
}
@media(max-width:420px){
  .dial-seg button{min-width:0; flex:1 1 45%}
  .foot-grid{grid-template-columns:1fr}
  .dial{grid-template-columns:1fr}
}
/* comfortable tap targets on touch devices (>=44px) */
@media(pointer:coarse){
  .btn-link{min-height:44px}
  .chip{padding:13px 18px}
  .demo-pause{min-height:44px}
  .dial-seg button{min-height:44px}
  .sticky-x{min-width:44px; min-height:44px; display:inline-grid; place-items:center; padding:0}
}
