/* AideaMaker design system. Palette + tokens per the North Star spec.
   Self-hosted-friendly system font stack (no external CDN; CSP font-src 'self'). */
:root{
  --ink:#0B1B2B; --brand-700:#0E3A5C; --brand-600:#14598C; --spark:#18C2E6; --warm:#FF8A3D;
  --paper:#FFFFFF; --mist:#F4F7FA; --line:#E2E8F0; --slate:#5B6B7B;
  --success:#1E9E6A; --warn:#E0A100; --danger:#D14343;
  --ink-soft:#13283b;
  --fs-h1:clamp(2rem,1.2rem + 3vw,3.25rem); --fs-h2:clamp(1.5rem,1.1rem + 1.6vw,2.1rem);
  --sans:'Sora',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --body:'Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SFMono-Regular',Menlo,Consolas,monospace;
  --radius:16px; --radius-sm:10px; --shadow:0 14px 40px -18px rgba(11,27,43,.28);
  --wrap:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);
  line-height:1.6;-webkit-font-smoothing:antialiased;font-size:17px}
h1,h2,h3,h4{font-family:var(--sans);line-height:1.15;color:var(--ink);margin:0 0 .5em;font-weight:700;letter-spacing:-.01em}
h1{font-size:var(--fs-h1)} h2{font-size:var(--fs-h2)} h3{font-size:1.2rem}
p{margin:0 0 1rem;max-width:68ch}
a{color:var(--brand-600);text-decoration:none}
a:hover{text-decoration:underline}
img,svg{max-width:100%}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:.6rem 1rem;z-index:200}
.skip:focus{left:8px;top:8px}
:focus-visible{outline:3px solid var(--spark);outline-offset:2px;border-radius:4px}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(16px,4vw,32px)}
.narrow{max-width:840px;margin:0 auto}
.center{text-align:center}
.mt{margin-top:1.5rem}

/* ---- brand wordmark (lightbulb-dot i) ---- */
.brand{display:inline-flex;align-items:flex-end;font-family:var(--sans);font-weight:800;
  font-size:1.5rem;letter-spacing:-.02em;color:var(--ink);line-height:1;gap:0}
.brand-a{color:var(--brand-600)}
.brand-i{position:relative;display:inline-flex;flex-direction:column;align-items:center;width:.46em;margin:0 .01em}
.brand-i-stem{display:block;width:.16em;height:.62em;border-radius:.08em;background:var(--brand-600)}
.brand-i .bulb{width:.62em;height:auto;margin-bottom:.06em}
.brand-rest{color:var(--ink)}
.foot-logo .brand,.foot-logo .brand-rest{color:#fff}
.foot-logo .brand-a{color:var(--spark)}

.bulb .bulb-glass{fill:none;stroke:var(--spark);stroke-width:2}
.bulb .bulb-fil{fill:none;stroke:var(--spark);stroke-width:1.4}
.bulb .bulb-base{fill:var(--slate)}
.bulb .bulb-glow circle{fill:var(--warm);opacity:0;filter:blur(3px)}
.bulb.ada .bulb-glass,.bulb.launch .bulb-glass{stroke:var(--spark)}
.head-logo:hover .bulb .bulb-glass,.brand:hover .bulb .bulb-glass{fill:var(--spark);fill-opacity:.18}
.head-logo:hover .bulb .bulb-glow circle{opacity:.5}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-family:var(--sans);
  font-weight:600;font-size:1rem;padding:.85em 1.5em;border-radius:var(--radius-sm);cursor:pointer;
  border:1.5px solid transparent;transition:transform .12s ease,box-shadow .12s ease,background .12s;text-decoration:none}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--brand-600);color:#fff;box-shadow:0 2px 0 var(--spark)}
.btn-primary:hover{background:var(--brand-700);box-shadow:0 4px 0 var(--spark)}
.btn-ghost{background:transparent;color:var(--brand-600);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--brand-600)}
.btn-ghost-light{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost-light:hover{background:rgba(255,255,255,.16)}
.btn.full{width:100%}

/* ---- header ---- */
.site-head{position:sticky;top:0;z-index:80;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.head-inner{display:flex;align-items:center;justify-content:space-between;min-height:68px;gap:1rem}
.site-nav{display:flex;align-items:center;gap:1.4rem}
.site-nav a{color:var(--ink);font-weight:500;font-size:.97rem}
.site-nav a:hover{color:var(--brand-600);text-decoration:none}
.site-nav .nav-cta{color:#fff}
.navtoggle,.navburger{display:none}
.navburger{flex-direction:column;gap:5px;width:42px;height:42px;justify-content:center;align-items:center;cursor:pointer;border-radius:8px}
.navburger span{width:22px;height:2px;background:var(--ink);border-radius:2px}

/* ---- sections ---- */
.sec{padding:clamp(72px,9vw,128px) 0}
.sec.alt{background:var(--mist)}
/* Scroll-reveal: opt-in via the js-reveal class added by reveal.js, so content is
   never hidden if JS fails. Reduced-motion users get no animation. */
.js-reveal [data-reveal]{opacity:0;transform:translateY(26px);
  transition:opacity .7s cubic-bezier(.16,.84,.44,1),transform .7s cubic-bezier(.16,.84,.44,1)}
.js-reveal [data-reveal].is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .js-reveal [data-reveal]{opacity:1!important;transform:none!important;transition:none!important}}
.sec-title{font-size:var(--fs-h2);margin-bottom:.4em}
.sec-title.center{text-align:center}
.sec-intro{color:var(--slate);max-width:60ch;margin:0 0 2rem}
.sec-intro.center{margin-left:auto;margin-right:auto;text-align:center}
.kicker{font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  font-size:.8rem;color:var(--brand-600);margin:0 0 .8rem}
.lede{font-size:1.18rem;color:var(--slate);max-width:60ch}
.textlink{font-weight:600}

.page-hero{padding:clamp(48px,6vw,80px) 0 0;background:var(--mist)}
.page-hero.tall{padding-bottom:60px}
.page-hero h1{margin-bottom:.3em}
.page-hero .lede{margin:0 auto}

/* ---- hero ---- */
.hero{background:linear-gradient(180deg,var(--mist),var(--paper));padding:clamp(40px,5vw,72px) 0}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,56px);align-items:center}
.hero-grid.hero-solo{grid-template-columns:1fr;max-width:780px}
.hero-copy h1{margin-bottom:.4em}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin:1.6rem 0}
.center-cta{justify-content:center}

/* ---- trust chips ---- */
.trustchips{list-style:none;display:flex;flex-wrap:wrap;gap:.6rem 1.2rem;padding:0;margin:1.2rem 0 0}
.trustchips li{display:flex;align-items:center;gap:.4rem;font-size:.9rem;color:var(--slate);font-weight:500}
.trustchips .chk{width:16px;height:16px;fill:var(--success);flex:none}

/* ---- grids & cards ---- */
.grid{display:grid;gap:1.2rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;
  transition:box-shadow .15s ease,transform .15s ease}
.card:hover{box-shadow:var(--shadow)}
a.card:hover{text-decoration:none;transform:translateY(-2px)}
.card-link{color:var(--brand-600);font-weight:600;font-size:.95rem;display:inline-block;margin-top:.6rem}
.tag{display:inline-block;background:var(--mist);color:var(--brand-700);font-size:.72rem;font-weight:600;
  padding:.18em .6em;border-radius:99px;margin-right:.3em}

.sol-card .sol-ico{width:44px;height:44px;border-radius:11px;background:var(--mist);display:grid;place-items:center;margin-bottom:.9rem}
.sol-ico .ico{width:24px;height:24px;color:var(--brand-600)}
.sol-outcome{font-weight:600;color:var(--ink);margin:.2rem 0 .8rem}
.sol-ex{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}
.sol-ex li{font-size:.9rem;color:var(--slate)}
.ind-card h3,.ind-deep h2{margin-bottom:.3rem}
.ind-deep .ticks{margin:.8rem 0}
.extra-card h3{font-size:1.05rem}
.extra-card p{font-size:.9rem;color:var(--slate);margin:0}

.ticks{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.55rem}
.ticks li{position:relative;padding-left:1.6rem;color:var(--ink)}
.ticks li::before{content:"";position:absolute;left:0;top:.45em;width:.7rem;height:.7rem;border-radius:50%;
  background:var(--spark);box-shadow:0 0 0 3px rgba(24,194,230,.18)}
.ticks.big li{font-size:1.05rem}

/* ---- vs table ---- */
.vs-table{max-width:760px;margin:0 auto;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--paper)}
.vs-head,.vs-row{display:grid;grid-template-columns:1fr 1fr}
.vs-head{font-family:var(--sans);font-weight:700;background:var(--ink);color:#fff}
.vs-head span{padding:.9rem 1.1rem}
.vs-head .vs-good{background:var(--brand-700)}
.vs-row span{padding:.9rem 1.1rem;border-top:1px solid var(--line);font-size:.97rem}
.vs-row .vs-bad{color:var(--slate)}
.vs-row .vs-good{background:rgba(24,194,230,.06);color:var(--ink);font-weight:500}

/* ---- pillars ---- */
.pillars{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.pillars-2{grid-template-columns:repeat(2,1fr)}
.pillar{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem}
.pillar-no{font-family:var(--mono);color:var(--spark);font-weight:700;font-size:.85rem}
.pillar h3{font-size:1.05rem;margin:.4rem 0 .3rem}
.pillar p{font-size:.92rem;color:var(--slate);margin:0}

/* ---- how mini & steps ---- */
.how-mini{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;padding:0;margin:1.5rem 0}
.how-mini li{display:flex;align-items:center;gap:.5rem;background:var(--paper);border:1px solid var(--line);
  border-radius:99px;padding:.5rem 1rem;font-weight:600;font-family:var(--sans)}
.how-n,.step-n{display:grid;place-items:center;width:1.7rem;height:1.7rem;border-radius:50%;background:var(--brand-600);color:#fff;font-size:.85rem;flex:none}
.steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1.1rem}
.step{display:flex;gap:1rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem}
.step h3{margin:.1rem 0 .3rem}
.step p{margin:0;color:var(--slate)}
.scope-note{margin-top:1.5rem;padding:1rem 1.2rem;background:rgba(24,194,230,.08);border-left:3px solid var(--spark);border-radius:8px;font-weight:500}

/* ---- comparison / pricing ---- */
.cmp-table{width:100%;border-collapse:collapse;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.cmp-table th,.cmp-table td{padding:.8rem 1rem;text-align:left;border-top:1px solid var(--line);font-size:.95rem}
.cmp-table .cmp-head{background:var(--ink);color:#fff}
.cmp-table .cmp-head th,.cmp-table .cmp-head td{color:#fff;border:0;font-family:var(--sans)}
.cmp-table td:last-child{background:rgba(24,194,230,.06);font-weight:600}
.price-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:1.2rem;align-items:stretch}
.price-grid > .card{flex:1 1 320px;max-width:380px}
.price-card .price{font-family:var(--sans);font-size:2rem;font-weight:800;color:var(--brand-700)}
.price-card.featured{border-color:var(--brand-600);box-shadow:var(--shadow);position:relative}
.price-card.featured::before{content:"Most popular";position:absolute;top:-12px;right:16px;background:var(--brand-600);color:#fff;font-size:.72rem;font-weight:700;padding:.2em .7em;border-radius:99px}
.price-time{color:var(--slate);font-weight:600;margin-bottom:.5rem}
.price-blurb{color:var(--slate)}
.price-card .ticks{margin:1rem 0 1.3rem}
.price-custom{display:flex;flex-direction:column;justify-content:center;background:var(--mist);border:1px solid var(--line)}
.price-custom h3{color:var(--brand-700)}
.price-custom p{color:var(--slate)}
.price-note{color:var(--slate);margin-top:1.4rem;font-size:.95rem}
.layers{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.layer{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem}
.layer h3{font-size:1.05rem;margin-bottom:.3rem}
.layer p{margin:0;color:var(--slate);font-size:.93rem}
.principles{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}
.principle{padding:1.2rem;border:1px solid var(--line);border-radius:var(--radius)}
.principle h3{font-size:1.05rem;color:var(--brand-700)}
.principle p{margin:0;color:var(--slate);font-size:.93rem}

/* ---- calculator ---- */
.calc{display:grid;gap:1.2rem}
.calc-inputs{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.calc-inputs label{display:flex;flex-direction:column;gap:.35rem;font-weight:600;font-size:.9rem}
.calc-inputs input[type=number],.calc-inputs input[type=range]{padding:.5rem;border:1px solid var(--line);border-radius:8px;font:inherit}
.calc-out{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-end;padding-top:.5rem;border-top:1px solid var(--line)}
.calc-big{display:flex;flex-direction:column}
.calc-big span{font-family:var(--sans);font-size:2rem;font-weight:800;color:var(--success)}
.calc-big small{color:var(--slate)}
.calc-payback{flex:1;min-width:200px}
.calc-bar{height:10px;background:var(--mist);border-radius:99px;overflow:hidden;margin-top:.4rem}
.calc-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--brand-600),var(--spark))}
.calc-caveat{font-size:.82rem;color:var(--slate);margin:0}

/* ---- FAQ ---- */
.faq{display:flex;flex-direction:column;gap:.7rem}
.faq-item{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:0 1.2rem}
.faq-item summary{cursor:pointer;font-family:var(--sans);font-weight:600;padding:1.1rem 0;list-style:none;display:flex;justify-content:space-between;gap:1rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--brand-600);font-size:1.3rem;line-height:1}
.faq-item[open] summary::after{content:"–"}
.faq-a{padding-bottom:1.1rem;color:var(--slate)}
.faq-a p{margin:0}

/* ---- spine / values / prose ---- */
.spine{font-family:var(--sans);font-size:1.3rem;line-height:1.5;border-left:4px solid var(--spark);
  padding:.4rem 0 .4rem 1.4rem;margin:0;color:var(--ink)}
.big-body{font-size:1.1rem;color:var(--ink-soft)}
.value-card h3{color:var(--brand-700)}
.prose h1{font-size:var(--fs-h1);margin-top:0}
.prose h2{margin-top:2rem}
.prose p,.prose li{color:var(--ink-soft)}
.prose ul{padding-left:1.2rem}
.legal p,.legal li{font-size:.97rem}

/* ---- legal pages (terms / privacy): readable, on-brand document ---- */
.legal-hero .lede a{color:var(--brand-600);font-weight:600}
.legal-doc{background:var(--paper,#fff);border:1px solid var(--line);border-radius:18px;
  padding:clamp(1.4rem,4vw,2.8rem);box-shadow:var(--shadow-sm,0 1px 3px rgba(11,27,43,.06))}
.legal-doc>h1:first-child{display:none}            /* the hero already shows the title */
.legal-doc>p:first-of-type{background:rgba(24,194,230,.07);border-left:3px solid var(--spark);
  border-radius:6px;padding:.7rem 1rem;font-size:.9rem;color:var(--ink-70);margin:0 0 1.6rem;font-style:normal}
.legal-doc>p:first-of-type em{font-style:normal;color:var(--ink-70)}
.legal-doc h2{font-size:1.16rem;font-weight:800;letter-spacing:-.01em;margin:2.1rem 0 .6rem;
  padding-top:1.5rem;border-top:1px solid var(--line);color:var(--brand-700)}
.legal-doc h2:first-of-type{border-top:0;padding-top:.2rem}
.legal-doc p,.legal-doc li{color:var(--ink-70);line-height:1.7;font-size:.96rem}
.legal-doc ul{padding-left:1.2rem;margin:.6rem 0}
.legal-doc li{margin:.35rem 0}
.legal-doc strong{color:var(--ink)}
.legal-foot{display:flex;flex-wrap:wrap;align-items:center;gap:1rem 1.4rem;justify-content:space-between;
  margin-top:1.6rem;padding:1.3rem 1.5rem;background:var(--ink);color:#fff;border-radius:16px}
.legal-foot p{margin:0;color:rgba(255,255,255,.82);font-size:.92rem;line-height:1.5;max-width:40rem}
.legal-foot .btn{flex:none}
.honesty-note{margin-top:1.5rem;color:var(--slate);font-style:italic;text-align:center}

/* ---- portfolio ---- */
.port-frame{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--line);margin-bottom:1rem}
.port-badge{position:absolute;top:10px;left:10px;background:var(--ink);color:#fff;font-size:.7rem;font-weight:700;padding:.2em .6em;border-radius:99px;z-index:2}
.port-mock{height:150px;background:linear-gradient(135deg,var(--brand-700),var(--ink) 60%,var(--brand-600))}

/* ---- contact form ---- */
.contact-form{display:flex;flex-direction:column;gap:1rem}
.contact-form label{display:flex;flex-direction:column;gap:.35rem;font-weight:600;font-size:.92rem}
.contact-form input,.contact-form select,.contact-form textarea{padding:.7rem .8rem;border:1px solid var(--line);border-radius:10px;font:inherit;background:var(--paper)}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{border-color:var(--spark);outline:none;box-shadow:0 0 0 3px rgba(24,194,230,.18)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field-hp{position:absolute;left:-9999px}
.next-note{font-size:.86rem;color:var(--slate);margin:0}
.form-success{text-align:center;padding:2.5rem}
.success-tick{width:56px;height:56px;border-radius:50%;background:var(--success);color:#fff;font-size:1.8rem;display:grid;place-items:center;margin:0 auto 1rem}

/* ---- cta band ---- */
.quote-why{border-left:5px solid var(--spark,#18C2E6);background:linear-gradient(180deg,var(--mist,#f1f6fb),#fff);
  padding:clamp(28px,4vw,44px)}
.quote-why h2{font-size:var(--fs-h2);margin:0 0 .5em}
.quote-why p{font-size:1.05rem;line-height:1.65;margin:0 0 1.3em;max-width:62ch}

/* ---- build-plan report page ---- */
.report-loading{text-align:center;padding:3rem 1rem}
.report-spinner{width:44px;height:44px;border-radius:50%;border:4px solid var(--mist,#eef3f8);
  border-top-color:var(--brand-600);margin:0 auto 1.2rem;animation:report-spin .8s linear infinite}
@keyframes report-spin{to{transform:rotate(360deg)}}
.report-status{font-weight:600;color:var(--ink)}
.report-body>:first-child{margin-top:0}
.report-body h2{margin-top:1.7em}.report-body h3{margin-top:1.25em}
.report-email-card{text-align:center;margin-top:2rem;background:linear-gradient(180deg,var(--mist,#f1f6fb),#fff)}
.report-email-form{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;margin-top:.7rem}
.report-email-form input{padding:.7rem .9rem;border:1px solid var(--line);border-radius:10px;min-width:240px;font-size:1rem}
.report-email-note{font-size:.85rem;margin:.7rem 0 0}

/* ---- hero demo slideshow (stack the cards, slow crossfade every 4s) ---- */
.c3-demo-col{position:relative}
.c3-demo-slides{display:grid}
.c3-demo-slides .c3-float-chip{z-index:5}
.c3-demo-slide{grid-area:1/1;position:relative;opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity 1.1s ease,visibility 1.1s ease}
.c3-demo-slide.is-active{opacity:1;visibility:visible;pointer-events:auto}
@media (prefers-reduced-motion:reduce){.c3-demo-slide{transition:none}}
/* position dots */
.c3-demo-dots{position:relative;z-index:6;display:flex;justify-content:center;gap:9px;margin-top:34px}
.c3-demo-dots:empty{display:none}
.c3-demo-dot{width:9px;height:9px;padding:0;border:0;border-radius:50%;cursor:pointer;
  background:rgba(11,27,43,.18);transition:background .2s,transform .2s}
.c3-demo-dot:hover{background:rgba(11,27,43,.34)}
.c3-demo-dot.is-on{background:linear-gradient(90deg,var(--spark),var(--violet));transform:scale(1.3)}
@media (prefers-reduced-motion:reduce){.report-spinner{animation:none}}

.cta-band{background:var(--ink);color:#fff}
.cta-band h2,.cta-band .lede{color:#fff}
.cta-band .lede{opacity:.85;margin-left:auto;margin-right:auto}

/* ---- footer ---- */
.site-foot{background:var(--ink);color:#cdd9e4;padding:3.5rem 0 1.5rem}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem}
.site-foot h4{color:#fff;font-size:.95rem;margin-bottom:.8rem}
.site-foot a{display:block;color:#cdd9e4;padding:.25rem 0;font-size:.93rem}
.site-foot a:hover{color:#fff}
.foot-brand p{color:#94a6b6;font-size:.92rem;margin-top:.6rem}
.foot-base{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:2.5rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,.1);font-size:.85rem;color:#94a6b6}

/* ---- responsive ---- */
@media (max-width:960px){
  .grid-3,.grid-4,.pillars{grid-template-columns:repeat(2,1fr)}
  .price-grid,.principles{grid-template-columns:1fr}
  .hero-grid{grid-template-columns:1fr}
  .hero-finder{order:-1}
}
@media (max-width:760px){
  .navburger{display:flex}
  .site-nav{position:fixed;inset:68px 0 auto 0;background:var(--paper);flex-direction:column;align-items:stretch;
    gap:0;padding:1rem;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .25s;box-shadow:var(--shadow)}
  .site-nav a{padding:.9rem .4rem;border-bottom:1px solid var(--line)}
  .navtoggle:checked ~ .site-nav{transform:translateY(0)}
  .nav-cta{margin-top:.6rem;text-align:center}
  .grid-3,.grid-4,.grid-2,.pillars,.pillars-2,.layers,.calc-inputs,.frow,.foot-grid{grid-template-columns:1fr}
  .vs-head span,.vs-row span{padding:.7rem .8rem;font-size:.9rem}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* ============================================================
   Home page — Conversion Punch (c3) design
   All rules scoped to unique c3-* class names so they cannot
   bleed onto any other page. Global token conflicts resolved
   by mapping onto existing :root values below.
   ============================================================ */
:root{
  --violet:#7C5CFC;
  --ink-70:rgba(11,27,43,.70);--ink-55:rgba(11,27,43,.55);
  --c3-line:rgba(11,27,43,.10);
  --shadow-sm:0 2px 8px rgba(11,27,43,.06);
  --shadow-md:0 12px 32px rgba(11,27,43,.10);
  --shadow-lg:0 30px 70px rgba(11,27,43,.18);
}
/* gradient text utility */
.c3-grad{background:linear-gradient(100deg,var(--brand-600) 8%,var(--spark) 52%,var(--violet) 96%);
  -webkit-background-clip:text;background-clip:text;color:transparent}
/* section eyebrow */
.c3-eyebrow{font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-600)}
/* orange CTA buttons (home-only) */
.c3-btn-primary{display:inline-flex;align-items:center;gap:9px;font-size:16px;font-weight:700;line-height:1;
  padding:16px 26px;border-radius:14px;cursor:pointer;border:0;color:#fff;
  background:linear-gradient(120deg,var(--warm),#ff6b2c);
  box-shadow:0 12px 28px rgba(255,107,44,.38);
  transition:transform .15s ease,box-shadow .15s ease;white-space:nowrap;text-decoration:none}
.c3-btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(255,107,44,.48);text-decoration:none;color:#fff}
.c3-btn-ghost{display:inline-flex;align-items:center;gap:9px;font-size:16px;font-weight:700;line-height:1;
  padding:16px 26px;border-radius:14px;cursor:pointer;
  color:var(--ink);background:#fff;border:1.5px solid var(--c3-line);box-shadow:var(--shadow-sm);
  transition:transform .15s ease,border-color .15s;white-space:nowrap;text-decoration:none}
.c3-btn-ghost:hover{transform:translateY(-3px);border-color:rgba(11,27,43,.22);text-decoration:none}
.c3-btn-light{display:inline-flex;align-items:center;gap:9px;font-size:16px;font-weight:700;line-height:1;
  padding:16px 26px;border-radius:14px;cursor:pointer;border:0;
  color:var(--ink);background:#fff;box-shadow:0 12px 28px rgba(11,27,43,.22);
  transition:transform .15s ease;white-space:nowrap;text-decoration:none}
.c3-btn-light:hover{transform:translateY(-3px);text-decoration:none}
.c3-btn-ghost-light{display:inline-flex;align-items:center;gap:9px;font-size:16px;font-weight:700;line-height:1;
  padding:16px 26px;border-radius:14px;cursor:pointer;
  color:#fff;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.3);
  transition:transform .15s ease,background .15s;white-space:nowrap;text-decoration:none}
.c3-btn-ghost-light:hover{background:rgba(255,255,255,.22);transform:translateY(-3px);text-decoration:none;color:#fff}
.c3-arrow{font-size:18px;line-height:1;display:inline-block;transition:transform .15s}
.c3-btn-primary:hover .c3-arrow,.c3-btn-ghost:hover .c3-arrow,
.c3-btn-light:hover .c3-arrow,.c3-btn-ghost-light:hover .c3-arrow{transform:translateX(3px)}

/* ---- Hero ---- */
.c3-hero{position:relative;overflow:hidden;padding:60px 0 84px}
.c3-hero-bg{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(1100px 520px at 78% -8%,rgba(124,92,252,.16),transparent 60%),
    radial-gradient(900px 480px at 8% 8%,rgba(24,194,230,.16),transparent 58%),
    linear-gradient(180deg,#fbfdff,#f1f6fb 70%,#eef4fa);}
.c3-blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.5;z-index:0}
.c3-hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.04fr .96fr;gap:54px;align-items:center}
.c3-hero-flag{display:inline-flex;align-items:center;gap:9px;
  background:rgba(35,201,138,.12);color:#0a7a52;border:1px solid rgba(35,201,138,.3);
  font-size:13px;font-weight:700;letter-spacing:.01em;
  padding:7px 14px;border-radius:30px;margin-bottom:18px}
.c3-hero h1{font-size:60px;line-height:1.02;letter-spacing:-.03em;font-weight:800;margin:0;color:var(--ink)}
.c3-lede{font-size:20px;color:var(--ink-70);margin:22px 0 0;max-width:540px;line-height:1.55}
.c3-hero-cta{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap;align-items:center}
.c3-reassure{font-size:13.5px;font-weight:600;color:var(--ink-55);max-width:170px;line-height:1.35}

/* HVAC demo card */
.c3-demo-wrap{position:relative}
.hvac-card{background:#fff;border-radius:24px;box-shadow:var(--shadow-lg);border:1px solid rgba(11,27,43,.06);overflow:hidden}
.hvac-card-head{display:flex;align-items:center;gap:10px;padding:15px 18px;
  background:linear-gradient(110deg,var(--ink),#123150);color:#fff}
.c3-traffic{display:flex;gap:7px;margin-right:6px}
.c3-traffic i{width:11px;height:11px;border-radius:50%;display:block}
.hvac-card-head .c3-title{font-size:13.5px;font-weight:700;letter-spacing:.01em}
.c3-badge-live{margin-left:auto;display:inline-flex;align-items:center;gap:7px;
  font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  background:rgba(255,255,255,.14);padding:6px 11px;border-radius:20px}
.c3-pulse{width:8px;height:8px;border-radius:50%;background:#5bf0a5;
  box-shadow:0 0 0 0 rgba(91,240,165,.7);animation:c3-pulse 2s infinite}
@keyframes c3-pulse{0%{box-shadow:0 0 0 0 rgba(91,240,165,.6)}70%{box-shadow:0 0 0 10px rgba(91,240,165,0)}100%{box-shadow:0 0 0 0 rgba(91,240,165,0)}}
.hvac-card-body{padding:22px 20px 24px;background:linear-gradient(180deg,#fff,#fafcff)}
.hvac-step-label{font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-55);margin-bottom:9px}
.hvac-bubble{display:inline-block;padding:13px 16px;border-radius:16px;font-size:14.5px;line-height:1.5;max-width:88%}
.hvac-bubble.user{background:linear-gradient(120deg,var(--brand-600),#1c6ea8);color:#fff;
  border-bottom-right-radius:5px;box-shadow:0 6px 16px rgba(20,89,140,.22)}
.hvac-row-user{display:flex;justify-content:flex-end;margin-bottom:18px}
.hvac-row-ada{display:flex;gap:11px;align-items:flex-start;margin-bottom:8px}
.hvac-av{flex:0 0 auto;width:36px;height:36px;border-radius:11px;
  background:linear-gradient(135deg,var(--spark),var(--violet));
  display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(124,92,252,.3)}
.hvac-bubble.ada{background:var(--mist);color:var(--ink);border:1px solid var(--c3-line);border-bottom-left-radius:5px}
.hvac-bubble.ada b{font-weight:700}
.hvac-quote-card{margin-top:13px;margin-left:47px;border:1px solid var(--c3-line);
  border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm);background:#fff;
  animation:c3-rise .6s .2s both}
@keyframes c3-rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.hvac-quote-top{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;
  background:linear-gradient(110deg,rgba(24,194,230,.12),rgba(124,92,252,.12));
  border-bottom:1px solid var(--c3-line)}
.hvac-qt-label{font-size:12px;font-weight:700;color:var(--brand-600);letter-spacing:.02em}
.hvac-qt-tag{font-size:11px;font-weight:700;color:#0a7a52;background:rgba(91,240,165,.22);padding:4px 9px;border-radius:20px}
.hvac-qrows{padding:6px 15px 4px}
.hvac-qrow{display:flex;justify-content:space-between;align-items:center;padding:9px 0;
  border-bottom:1px dashed var(--c3-line);font-size:13.5px}
.hvac-qrow:last-child{border-bottom:0}
.hvac-qrow .k{color:var(--ink-70)}.hvac-qrow .v{font-weight:700}
.hvac-quote-total{display:flex;justify-content:space-between;align-items:center;
  padding:13px 15px;background:var(--ink);color:#fff}
.hvac-quote-total .tk{font-size:13px;font-weight:600;opacity:.8}
.hvac-quote-total .tv{font-size:16px;font-weight:800;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:8px}
.hvac-demo-foot{display:flex;align-items:center;gap:8px;margin-top:16px;padding-top:14px;
  border-top:1px solid var(--c3-line);font-size:12.5px;color:var(--ink-55);font-weight:600}
.c3-float-chip{position:absolute;z-index:3;background:#fff;border-radius:14px;padding:11px 15px;
  box-shadow:var(--shadow-md);display:flex;align-items:center;gap:11px;border:1px solid rgba(11,27,43,.05)}
.c3-float-chip .ico{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.c3-float-chip .fc-k{font-size:11px;color:var(--ink-55);font-weight:700;text-transform:uppercase;letter-spacing:.05em;line-height:1.2}
.c3-float-chip .fc-v{font-size:15px;font-weight:800;line-height:1.2}
.c3-chip-a{top:-22px;right:-14px;animation:c3-bob 5s ease-in-out infinite}
.c3-chip-b{bottom:-20px;left:-26px;animation:c3-bob 6s ease-in-out .6s infinite}
@keyframes c3-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* ---- Credibility band ---- */
.c3-cred{background:var(--ink);color:#fff}
.c3-cred-inner{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:stretch}
.c3-cred-item{flex:1 1 0;min-width:170px;display:flex;align-items:center;gap:13px;padding:22px;position:relative}
.c3-cred-item+.c3-cred-item::before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:1px;background:rgba(255,255,255,.13)}
.c3-cred-ico{width:38px;height:38px;border-radius:11px;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08)}
.c3-cred-k{font-size:14.5px;font-weight:800;letter-spacing:-.01em;line-height:1.2}
.c3-cred-s{font-size:12px;color:rgba(255,255,255,.6);font-weight:600;margin-top:2px;line-height:1.25}

/* ---- Section scaffolding ---- */
.c3-sec-pad{padding:118px 0}
.c3-sec-head{max-width:700px;margin:0 auto 50px;text-align:center}
.c3-sec-head h2{font-size:42px;line-height:1.08;letter-spacing:-.025em;font-weight:800;margin:14px 0 0}
.c3-sec-head p{font-size:18.5px;color:var(--ink-70);margin-top:16px;line-height:1.55;max-width:none}

/* ---- Proof / Outcomes ---- */
.c3-outcomes{background:var(--ink);color:#fff;overflow:hidden}
.c3-outcomes .c3-sec-head h2{color:#fff}
.c3-outcomes .c3-sec-head p{color:rgba(255,255,255,.72)}
.c3-outcomes .c3-eyebrow{color:var(--spark)}
.c3-oc-live{display:flex;align-items:center;justify-content:center;gap:11px;max-width:720px;margin:-18px auto 36px;
  text-align:center;font-size:14.5px;font-weight:600;line-height:1.5;color:rgba(255,255,255,.86);
  background:rgba(91,240,165,.08);border:1px solid rgba(91,240,165,.22);border-radius:14px;padding:13px 22px}
.c3-oc-live-dot{flex:none;width:9px;height:9px;border-radius:50%;background:#5bf0a5;
  box-shadow:0 0 0 0 rgba(91,240,165,.6);animation:c3-pulse 2s infinite}
.c3-oc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.c3-oc{position:relative;border-radius:22px;padding:28px 28px 26px;overflow:hidden;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10);
  transition:transform .2s ease,border-color .2s ease}
.c3-oc:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.26)}
.c3-oc .c3-accent-bar{position:absolute;top:0;left:0;right:0;height:5px}
.c3-oc-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.c3-oc-ico{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.c3-oc-ind{font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.c3-oc h3{font-size:20px;font-weight:800;letter-spacing:-.01em;margin-top:3px;line-height:1.15;color:#fff;margin-bottom:0}
.c3-oc p{font-size:14.5px;color:rgba(255,255,255,.74);line-height:1.55;margin:0}
.c3-oc-metric{display:flex;align-items:baseline;gap:10px;margin:16px 0 2px}
.c3-oc-metric .num{font-size:38px;font-weight:800;letter-spacing:-.03em;line-height:1}
.c3-oc-metric .unit{font-size:13.5px;font-weight:700;color:rgba(255,255,255,.62);max-width:150px;line-height:1.25}
.c3-oc .c3-win{display:inline-flex;align-items:center;gap:9px;margin-top:16px;font-size:13.5px;font-weight:800;padding:8px 14px;border-radius:30px}
/* outcome color variants */
.c3-oc-re .c3-accent-bar{background:linear-gradient(90deg,var(--spark),#39d6ee)}
.c3-oc-re .c3-oc-ico{background:rgba(24,194,230,.16)}.c3-oc-re .c3-oc-ind{color:var(--spark)}
.c3-oc-re .num{color:#7fe3f5}.c3-oc-re .c3-win{background:rgba(24,194,230,.16);color:#9fe9f6}
.c3-oc-co .c3-accent-bar{background:linear-gradient(90deg,var(--warm),#ffb066)}
.c3-oc-co .c3-oc-ico{background:rgba(255,138,61,.18)}.c3-oc-co .c3-oc-ind{color:var(--warm)}
.c3-oc-co .num{color:#ffc18a}.c3-oc-co .c3-win{background:rgba(255,138,61,.18);color:#ffd0a8}
.c3-oc-hv .c3-accent-bar{background:linear-gradient(90deg,var(--violet),#9d86ff)}
.c3-oc-hv .c3-oc-ico{background:rgba(124,92,252,.20)}.c3-oc-hv .c3-oc-ind{color:#b3a2ff}
.c3-oc-hv .num{color:#c3b4ff}.c3-oc-hv .c3-win{background:rgba(124,92,252,.20);color:#cabeff}
.c3-oc-of .c3-accent-bar{background:linear-gradient(90deg,#5bf0a5,#27c98a)}
.c3-oc-of .c3-oc-ico{background:rgba(91,240,165,.16)}.c3-oc-of .c3-oc-ind{color:#5bf0a5}
.c3-oc-of .num{color:#86f5c2}.c3-oc-of .c3-win{background:rgba(91,240,165,.16);color:#a6f5cd}
.c3-oc-note{text-align:center;margin-top:34px;font-size:13.5px;color:rgba(255,255,255,.5);font-weight:600}

/* ---- Contrast / why custom ---- */
.c3-contrast{background:linear-gradient(180deg,#fff,#f6f9fc);border-top:1px solid var(--line)}
.c3-vs-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:0;align-items:stretch;margin-top:8px}
.c3-vs-card{padding:34px 32px;border-radius:22px}
.c3-vs-them{background:#fff;border:1.5px solid var(--c3-line);box-shadow:var(--shadow-sm)}
.c3-vs-us{background:linear-gradient(160deg,var(--ink),#11314f);color:#fff;box-shadow:var(--shadow-lg);transform:translateY(-10px)}
.c3-vs-tag{font-size:12.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}
.c3-vs-them .c3-vs-tag{color:var(--ink-55)}.c3-vs-us .c3-vs-tag{color:var(--spark)}
.c3-vs-card h3{font-size:23px;font-weight:800;margin:8px 0 20px;letter-spacing:-.01em}
.c3-vs-them h3{color:var(--ink)}.c3-vs-us h3{color:#fff}
.c3-vs-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.c3-vs-list li{display:flex;gap:12px;font-size:15.5px;line-height:1.45;align-items:flex-start}
.c3-vs-list .mk{flex:0 0 auto;width:24px;height:24px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;font-weight:900;font-size:14px;margin-top:1px}
.c3-vs-them .mk{background:rgba(11,27,43,.06);color:var(--ink-55)}
.c3-vs-them li{color:var(--ink-70)}
.c3-vs-us .mk{background:linear-gradient(135deg,var(--spark),var(--violet));color:#fff}
.c3-vs-mid{display:flex;align-items:center;justify-content:center;padding:0 18px}
.c3-vs-orb{width:62px;height:62px;border-radius:50%;background:#fff;border:1.5px solid var(--c3-line);
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;color:var(--ink-55);box-shadow:var(--shadow-md)}

/* ---- Pays for itself ---- */
.c3-pays{background:linear-gradient(180deg,#fff,#f6f9fc)}
.c3-pays-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.c3-pays-copy h2{font-size:40px;line-height:1.08;letter-spacing:-.025em;font-weight:800;margin:14px 0 0;color:var(--ink)}
.c3-pays-copy p{font-size:18px;color:var(--ink-70);margin-top:18px;line-height:1.6;max-width:none}
.c3-pays-stats{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}
.c3-pays-stat{flex:1;min-width:130px;background:#fff;border-radius:16px;padding:18px;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.c3-pays-stat .n{font-size:30px;font-weight:800;letter-spacing:-.02em;
  background:linear-gradient(120deg,var(--brand-600),var(--violet));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.c3-pays-stat .l{font-size:13.5px;color:var(--ink-70);font-weight:600;margin-top:4px;line-height:1.35}
.c3-pays-cta{margin-top:30px}
.c3-pays-visual{background:#fff;border-radius:24px;padding:30px 30px 26px;box-shadow:var(--shadow-lg);border:1px solid rgba(11,27,43,.06)}
.c3-pays-visual h4{font-size:16px;font-weight:800;letter-spacing:-.01em;margin:0 0 4px;color:var(--ink)}
.c3-pays-visual .sub{font-size:13.5px;color:var(--ink-55);font-weight:600;margin-bottom:10px}
.c3-pays-legend{display:flex;gap:20px;margin-top:16px;flex-wrap:wrap}
.c3-pays-legend span{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--ink-70)}
.c3-lk{width:14px;height:14px;border-radius:5px;display:inline-block}

/* ---- Ada section ---- */
.c3-ada{position:relative;overflow:hidden}
.c3-ada-bg{position:absolute;inset:0;z-index:0;background:linear-gradient(125deg,#0e2a47,var(--brand-600) 48%,#0e2a47)}
.c3-ada-bg::after{content:"";position:absolute;inset:0;
  background:radial-gradient(680px 320px at 12% 18%,rgba(24,194,230,.34),transparent 60%),
    radial-gradient(620px 340px at 88% 86%,rgba(124,92,252,.34),transparent 60%)}
.c3-ada-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.c3-ada-copy .c3-eyebrow{color:var(--spark)}
.c3-ada-copy h2{font-size:42px;line-height:1.08;letter-spacing:-.025em;font-weight:800;color:#fff;margin:14px 0 0}
.c3-ada-copy p{font-size:18.5px;color:rgba(255,255,255,.82);margin-top:18px;line-height:1.6;max-width:480px}
.c3-ada-cta{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.c3-ada-bul{list-style:none;padding:0;margin:26px 0 0;display:flex;flex-direction:column;gap:11px}
.c3-ada-bul li{display:flex;gap:11px;align-items:center;font-size:15.5px;font-weight:600;color:rgba(255,255,255,.9)}
.c3-ada-bul .tick{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.16);
  display:flex;align-items:center;justify-content:center;flex:0 0 auto;font-weight:900;font-size:12px;color:#5bf0a5}
/* glass card wrapping the real finder widget */
.c3-ada-finder{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);
  border-radius:24px;padding:6px;backdrop-filter:blur(8px);box-shadow:var(--shadow-lg)}
.c3-ada-finder .finder{border-radius:18px;height:min(920px,80vh);border:0}
/* offline fallback column */
.c3-ada-offline{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);
  border-radius:24px;padding:36px 30px;text-align:center;backdrop-filter:blur(8px)}
.c3-ada-offline p{color:rgba(255,255,255,.82);margin-bottom:24px;font-size:16px;line-height:1.6}

/* ---- Final CTA ---- */
.c3-final{padding:90px 0}
.c3-final-card{position:relative;overflow:hidden;border-radius:30px;
  background:linear-gradient(125deg,var(--brand-600),#1573b0 46%,var(--violet));
  padding:62px 56px;text-align:center;box-shadow:var(--shadow-lg)}
.c3-final-card::before{content:"";position:absolute;inset:0;
  background:radial-gradient(560px 300px at 84% 8%,rgba(24,194,230,.5),transparent 60%)}
.c3-final-card>*{position:relative;z-index:2}
.c3-final-card .c3-eyebrow{color:#bfe9f6}
.c3-final-card h2{font-size:46px;line-height:1.06;letter-spacing:-.03em;font-weight:800;color:#fff;max-width:780px;margin:12px auto 0}
.c3-final-card p{font-size:19px;color:rgba(255,255,255,.9);margin:20px auto 0;max-width:560px;line-height:1.55}
.c3-final-cta{display:flex;gap:14px;justify-content:center;margin-top:32px;flex-wrap:wrap}
.c3-final-sub{margin-top:22px;font-size:14.5px;color:rgba(255,255,255,.86);font-weight:600;
  display:flex;gap:22px;justify-content:center;flex-wrap:wrap}
.c3-final-sub span{display:inline-flex;align-items:center;gap:8px}

/* ---- Home responsive ---- */
@media(max-width:980px){
  .c3-hero-grid{grid-template-columns:1fr;gap:46px}
  .c3-hero h1{font-size:48px}
  .c3-cred-inner{flex-wrap:wrap}
  .c3-cred-item{flex:1 1 40%;min-width:200px}
  .c3-cred-item+.c3-cred-item::before{display:none}
  .c3-oc-grid{grid-template-columns:1fr}
  .c3-vs-grid{grid-template-columns:1fr;gap:18px}
  .c3-vs-us{transform:none}
  .c3-vs-mid{padding:6px 0}.c3-vs-orb{transform:rotate(90deg)}
  .c3-pays-grid{grid-template-columns:1fr;gap:40px}
  .c3-ada-inner{grid-template-columns:1fr;gap:40px}
  .c3-ada-finder .finder{height:70vh}
}
@media(max-width:680px){
  .c3-hero{padding:38px 0 64px}
  .c3-hero h1{font-size:37px}
  .c3-lede{font-size:17.5px}
  .c3-sec-pad{padding:60px 0}
  .c3-sec-head h2,.c3-pays-copy h2,.c3-ada-copy h2{font-size:31px}
  .c3-cred-item{flex:1 1 100%}
  .c3-final-card{padding:44px 26px}
  .c3-final-card h2{font-size:32px}
  .c3-float-chip{display:none}
  .c3-pays-stats{flex-direction:column}
  .c3-hero-cta,.c3-ada-cta,.c3-final-cta,.c3-pays-cta{flex-direction:column;align-items:stretch}
  .c3-btn-primary,.c3-btn-ghost,.c3-btn-light,.c3-btn-ghost-light{justify-content:center;width:100%}
  .c3-reassure{max-width:none;text-align:center}
}

/* ============================================================
   Marketing redesign — interior pages lifted toward the c3
   "gold standard" home. All additive; scoped to new class names
   plus a few targeted overrides on .page-hero. CSS-only.
   ============================================================ */
:root{
  --mint:#5bf0a5;
  /* shared accent cycle (win=cyan, do=violet, run=orange, of=mint) */
  --acc-win:var(--spark); --acc-do:var(--violet); --acc-run:var(--warm); --acc-of:var(--mint);
}

/* ---- shared eyebrow ---- */
.eyebrow{display:inline-block;font-family:var(--sans);font-size:13px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--brand-600);margin:0 0 .55rem}
.eyebrow.acc-text{color:var(--accent,var(--brand-600))}

/* per-band/per-card accent variable. Set --accent once; children consume it. */
.acc-win{--accent:var(--acc-win)} .acc-do{--accent:var(--acc-do)}
.acc-run{--accent:var(--acc-run)} .acc-of{--accent:var(--acc-of)}
.band-win{--accent:var(--acc-win)} .band-do{--accent:var(--acc-do)} .band-run{--accent:var(--acc-run)}

/* ---- soft radial hero (replaces flat mist on interior pages) ---- */
.page-hero.hero-soft{position:relative;overflow:hidden;background:
  radial-gradient(1000px 480px at 80% -12%,rgba(124,92,252,.14),transparent 60%),
  radial-gradient(820px 440px at 6% 4%,rgba(24,194,230,.16),transparent 58%),
  linear-gradient(180deg,#fbfdff,#f1f6fb 72%,#eef4fa);
  padding:clamp(56px,7vw,92px) 0 clamp(40px,5vw,64px);border-bottom:1px solid var(--line)}
.page-hero.hero-soft .wrap{position:relative;z-index:2}
.page-hero.hero-soft h1{margin-bottom:.3em;letter-spacing:-.025em}

/* ---- band heads (themed section intros) ---- */
.band-head{max-width:720px;margin:0 0 2.2rem}
.sec .band-head{text-align:left}
.band-head .sec-title.center{text-align:center}
.band-intro{font-size:1.12rem;color:var(--slate);max-width:60ch;margin:.2rem 0 0}

/* ---- theme bands on /what-we-build ---- */
.theme-band{position:relative}
/* tinted gradient header strip + accent left-border on each band head */
.theme-band .band-head{position:relative;padding:1.1rem 1.3rem;border-left:5px solid var(--accent);
  border-radius:0 var(--radius) var(--radius) 0;
  background:linear-gradient(100deg,color-mix(in srgb,var(--accent) 12%,transparent),transparent 70%)}
.theme-band .band-head h2{margin:.15rem 0 .35rem}
.theme-band .band-intro{margin-bottom:0}

/* ---- themed solution cards (recolor the icon chip by theme) ---- */
.sol-card{position:relative;overflow:hidden}
.sol-card .sol-ico{background:color-mix(in srgb,var(--accent) 14%,#fff);transition:background .15s}
.sol-card .sol-ico .ico{color:var(--accent)}
.sol-card .tag{background:color-mix(in srgb,var(--accent) 12%,var(--mist));color:var(--ink-soft)}
.sol-win{--accent:var(--acc-win)} .sol-do{--accent:var(--acc-do)} .sol-run{--accent:var(--acc-run)}
.sol-card::after{content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:var(--accent);opacity:0;transition:opacity .15s}
.sol-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.sol-card:hover::after{opacity:1}

/* ---- accent bar + chip shared by industry/benefit cards ---- */
.acc-bar{position:absolute;top:0;left:0;bottom:0;width:5px;background:var(--accent);border-radius:6px 0 0 6px}
.ib-head{display:flex;gap:.85rem;align-items:flex-start;margin-bottom:.9rem}
.ib-ico{flex:0 0 auto;width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:color-mix(in srgb,var(--accent) 16%,#fff)}
.ib-ico .ico{width:24px;height:24px;color:var(--accent);stroke-width:1.8}
.ib-head h3{margin:.1rem 0 .15rem;font-size:1.12rem}
.ib-tag,.ind-tag{margin:0;color:var(--slate);font-size:.92rem;font-weight:500}

/* ---- industries: deep grid + more grid ---- */
.ind-benefit,.ind-deep{position:relative;padding-left:1.6rem;overflow:hidden}
.ind-benefit .ticks,.ind-deep .ticks{margin-top:.4rem}
.ind-benefit:hover,.ind-deep:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:color-mix(in srgb,var(--accent) 35%,var(--line))}
.deep-grid .ind-deep .card-link{color:var(--accent)}
.deep-grid .ind-deep .ticks li::before{background:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent)}
.more-grid .ind-benefit .ticks li::before{background:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent)}

/* ---- How it works: CSS-only timeline ---- */
.timeline{list-style:none;position:relative;margin:1rem 0 0;padding:0}
.tl-spine{position:absolute;top:8px;bottom:8px;left:23px;width:4px;border-radius:4px;
  background:linear-gradient(180deg,var(--spark),var(--violet) 52%,var(--warm));z-index:0}
.tl-step{position:relative;display:grid;grid-template-columns:48px 1fr;gap:1rem;
  padding:0 0 1.6rem;align-items:start}
.tl-step:last-child{padding-bottom:0}
.tl-node{position:relative;z-index:2;width:48px;height:48px;border-radius:50%;
  display:grid;place-items:center;background:linear-gradient(135deg,var(--brand-600),var(--violet));
  color:#fff;box-shadow:0 6px 18px rgba(124,92,252,.3),0 0 0 5px #fff}
.tl-num{font-family:var(--sans);font-weight:800;font-size:1.05rem;line-height:1}
.tl-card{display:flex;gap:1rem;align-items:flex-start;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);padding:1.25rem 1.4rem;transition:box-shadow .15s ease,transform .15s ease}
.tl-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.tl-ico{flex:0 0 auto;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;
  background:rgba(24,194,230,.12)}
.tl-ico .ico{width:22px;height:22px;color:var(--brand-600);stroke-width:1.8}
.tl-kicker{display:block;font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--violet);margin-bottom:.15rem}
.tl-body h3{margin:0 0 .25rem}
.tl-body p{margin:0;color:var(--slate)}
/* desktop: alternating left/right cards around a centered spine.
   Explicit grid-column placement (no direction:rtl) — robust + LTR text. */
@media(min-width:861px){
  .timeline{padding:0}
  .tl-spine{left:50%;transform:translateX(-2px)}
  .tl-step{grid-template-columns:1fr 56px 1fr;gap:0;padding-bottom:2rem;align-items:center}
  .tl-node{grid-column:2;grid-row:1;justify-self:center}
  .tl-step:nth-child(odd) .tl-card{grid-column:1;grid-row:1;margin-right:1.4rem}
  .tl-step:nth-child(even) .tl-card{grid-column:3;grid-row:1;margin-left:1.4rem}
}
.reassure-band{display:flex;gap:.9rem;align-items:center;margin-top:2rem;padding:1.1rem 1.3rem;
  border-radius:var(--radius);border:1px solid color-mix(in srgb,var(--spark) 30%,var(--line));
  background:linear-gradient(110deg,rgba(24,194,230,.10),rgba(124,92,252,.08))}
.reassure-band p{margin:0;font-weight:600;color:var(--ink)}
.reassure-ico{flex:0 0 auto;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  background:#fff;color:#0a7a52;box-shadow:var(--shadow-sm)}
.reassure-ico svg{width:22px;height:22px}

/* ---- Industry detail: per-industry accent ---- */
.ind-detail .ind-hero{background:
  radial-gradient(900px 460px at 82% -14%,color-mix(in srgb,var(--ind-accent) 22%,transparent),transparent 60%),
  radial-gradient(760px 420px at 4% 6%,color-mix(in srgb,var(--ind-accent) 16%,transparent),transparent 58%),
  linear-gradient(180deg,#fbfdff,#f1f6fb 72%,#eef4fa)}
.ind-kicker{display:inline-flex;align-items:center;gap:.55rem;color:color-mix(in srgb,var(--ind-accent) 72%,var(--ink));
  text-transform:none;letter-spacing:0;font-size:.95rem}
.ik-ico{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;
  background:color-mix(in srgb,var(--ind-accent) 18%,#fff)}
.ik-ico .ico{width:18px;height:18px;color:color-mix(in srgb,var(--ind-accent) 80%,var(--ink));stroke-width:1.9}
.ind-detail .ind-ticks li::before{background:var(--ind-accent);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--ind-accent) 20%,transparent)}
.ind-detail .ind-h2{position:relative}
.ind-detail .demo.ind-demo{border:1px solid color-mix(in srgb,var(--ind-accent) 40%,var(--line));
  box-shadow:0 18px 50px -22px color-mix(in srgb,var(--ind-accent) 55%,transparent)}
.ind-detail .ind-demo .demo-head{background:color-mix(in srgb,var(--ind-accent) 14%,var(--ink));
  border-bottom:2px solid var(--ind-accent)}
.ind-detail .ind-demo .live-dot{background:var(--ind-accent)}

/* ---- Home: outcome tiles become demo links ---- */
.c3-oc-link{display:flex;flex-direction:column;text-decoration:none;color:inherit}
.c3-oc-link:hover{text-decoration:none}
.c3-oc-try{display:inline-flex;align-items:center;gap:7px;margin-top:14px;
  font-size:13px;font-weight:800;color:rgba(255,255,255,.92);
  opacity:.75;transition:opacity .15s,transform .15s}
.c3-oc-link:hover .c3-oc-try{opacity:1;transform:translateX(2px)}

/* ---- Pricing polish ---- */
.lift{transition:box-shadow .15s ease,transform .15s ease}
.lift:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.quote-why.lift{position:relative}
.layers-chip .layer{position:relative;padding-left:3.2rem;border-left:4px solid var(--accent)}
.layer-chip{position:absolute;left:1rem;top:1.2rem;width:1.7rem;height:1.7rem;border-radius:9px;
  display:grid;place-items:center;font-family:var(--sans);font-weight:800;font-size:.9rem;
  color:#fff;background:var(--accent)}
.price-card,.price-custom{position:relative;overflow:hidden}
.acc-top{position:absolute;top:0;left:0;right:0;height:5px}
.acc-top-win .acc-top{background:linear-gradient(90deg,var(--spark),#39d6ee)}
.acc-top-violet .acc-top{background:linear-gradient(90deg,var(--violet),#9d86ff)}

/* ---- responsive: theme bands + grids ---- */
@media(max-width:860px){
  .deep-grid,.more-grid{grid-template-columns:1fr}
  .theme-band .band-head::before{display:none}
}
@media(max-width:960px){
  .more-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .more-grid{grid-template-columns:1fr}
}
