/* ============================================================
   Redwater Revenue — editorial "studio" design system (shared)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=Inter:wght@300;400;500&family=Playfair+Display:ital,wght@1,500;1,600;1,700&display=swap');

:root {
  --cream:#FDF9F3; --cream-2:#F6EFE4; --paper:#FFFFFF; --ink:#1A1814; --ink-2:#3A352E;
  --muted:#6B645C; --muted-2:#A39A8E; --line:#E7DECF; --line-2:#EFE8DB;
  --red:#FF1F1F; --orange:#FF8A00; --gold:#B8860B; --green:#16A34A;
  --grad:linear-gradient(120deg,#FF1F1F,#FF8A00 55%,#B8860B);
  --fd:'Plus Jakarta Sans',system-ui,sans-serif; --fb:'Inter',system-ui,sans-serif;
  --fs:'Playfair Display',Georgia,serif; --sm:cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--cream);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
::selection{background:rgba(255,138,0,.22)}
h1,h2,h3{font-family:var(--fd);font-weight:600;letter-spacing:-.025em;line-height:1.02}
.serif{font-family:var(--fs);font-weight:600;font-style:italic;letter-spacing:0}
.wrap{max-width:1240px;margin:0 auto;padding:0 40px}
.lbl{font-family:var(--fd);font-size:11.5px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-2)}
.ink-grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
@media(max-width:720px){.wrap{padding:0 22px}}

/* utility bar — green pulse */
.topbar{border-bottom:1px solid var(--line);background:var(--cream)}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.topbar .lbl{font-size:10.5px;display:inline-flex;align-items:center;gap:9px}
.dot-live{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(22,163,74,.55);animation:pulseG 2.2s infinite}
@keyframes pulseG{0%{box-shadow:0 0 0 0 rgba(22,163,74,.55)}70%{box-shadow:0 0 0 8px rgba(22,163,74,0)}100%{box-shadow:0 0 0 0 rgba(22,163,74,0)}}
@media(max-width:640px){.topbar .right{display:none}}

/* nav */
nav{position:sticky;top:0;z-index:50;background:rgba(253,249,243,.82);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s}
nav.stuck{border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:76px}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--fd);font-weight:600;font-size:18.5px;letter-spacing:-.02em}
.logo .mk{width:30px;height:30px;border-radius:8px;background:var(--grad);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--fd);font-weight:800;font-size:13px;letter-spacing:-1px}
.logo b{font-weight:600}
.nav-mid{display:flex;gap:34px}
.nav-mid a{font-family:var(--fd);font-size:14.5px;font-weight:500;color:var(--ink-2);transition:color .2s}
.nav-mid a:hover,.nav-mid a.active{color:var(--ink)}
.nav-cta{font-family:var(--fd);font-size:14px;font-weight:600;padding:11px 20px;border-radius:100px;background:var(--ink);color:var(--cream);transition:background .2s,transform .2s}
.nav-cta:hover{transform:translateY(-1px)}
@media(max-width:860px){.nav-mid{display:none}}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--fd);font-weight:600;font-size:15px;padding:15px 26px;border-radius:100px;cursor:pointer;border:1px solid transparent;transition:transform .2s var(--sm),background .2s,border-color .2s}
.btn .a{transition:transform .2s var(--sm)}
.btn:hover .a{transform:translateX(4px)}
.btn-ink{background:var(--ink);color:var(--cream)}
.btn-ink:hover{transform:translateY(-2px)}
.btn-line{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-line:hover{border-color:var(--ink)}

/* reveal */
.r{opacity:0;transform:translateY(20px);transition:opacity .8s var(--sm),transform .8s var(--sm)}
.r.on{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}.d4{transition-delay:.28s}

/* hero */
.hero{padding:92px 0 64px;position:relative}
.hero .eyebrow{margin-bottom:30px;display:flex;align-items:center;gap:14px}
.hero .eyebrow::after{content:'';height:1px;width:80px;background:var(--line)}
.hero h1{font-size:clamp(46px,8vw,104px);font-weight:600;max-width:1100px;letter-spacing:-.04em}
.hero h1 .serif{font-size:.98em}
.hero .sub{font-family:var(--fb);font-weight:300;font-size:clamp(17px,1.7vw,21px);color:var(--ink-2);max-width:560px;margin:34px 0 0;line-height:1.5}
.hero-cta{display:flex;gap:13px;margin-top:40px;flex-wrap:wrap}

/* page hero (sub-pages) */
.phero{padding:74px 0 18px;position:relative}
.phero .eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.phero .eyebrow::after{content:'';height:1px;width:80px;background:var(--line)}
.phero h1{font-size:clamp(40px,6vw,76px);letter-spacing:-.04em;max-width:900px}
.phero .sub{font-family:var(--fb);font-weight:300;font-size:clamp(17px,1.8vw,20px);color:var(--muted);max-width:600px;margin-top:24px;line-height:1.5}

/* marquee — colorize all on hover, never pause */
.marquee-sec{padding:40px 0 8px}
.marquee-sec .lbl{display:block;text-align:center;margin-bottom:28px}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;gap:58px;width:max-content;align-items:center;animation:scroll 40s linear infinite}
.marquee-track img{height:28px;width:auto;filter:grayscale(1) opacity(.42);transition:filter .45s var(--sm)}
.marquee:hover .marquee-track img{filter:grayscale(0) opacity(1)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* section heads */
section.blk{padding:92px 0}
.sec-tag{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.sec-tag::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--orange)}
.sec-h{font-size:clamp(34px,5vw,60px);font-weight:600;letter-spacing:-.035em;max-width:820px}
.sec-lead{font-family:var(--fb);font-weight:300;font-size:18px;color:var(--muted);max-width:580px;margin-top:22px;line-height:1.55}

/* spec cards */
.specs{margin-top:56px;border-top:1px solid var(--line)}
.spec{display:grid;grid-template-columns:90px 1fr 1.1fr 170px;gap:30px;align-items:start;padding:38px 0;border-bottom:1px solid var(--line);transition:background .3s}
.spec:hover{background:var(--cream-2)}
.spec .idx{font-family:var(--fd);font-size:14px;color:var(--muted-2);padding-top:6px}
.spec .kicker{font-family:var(--fd);font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);margin-bottom:12px}
.spec h3{font-size:27px;font-weight:600;letter-spacing:-.02em}
.spec p{font-family:var(--fb);font-weight:300;font-size:15.5px;color:var(--ink-2);line-height:1.6}
.spec .go{font-family:var(--fd);font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:8px;padding-top:6px;transition:gap .2s;white-space:nowrap}
.spec:hover .go{gap:12px}
@media(max-width:900px){.spec{grid-template-columns:1fr;gap:10px;padding:30px 0}.spec .idx{display:none}.spec .go{margin-top:8px}}

/* work gallery tiles */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
@media(max-width:900px){.gallery{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.gallery{grid-template-columns:1fr}}
.tile{display:block;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--paper);transition:transform .35s var(--sm),box-shadow .35s var(--sm)}
.tile:hover{transform:translateY(-5px);box-shadow:0 30px 60px -34px rgba(40,30,15,.4)}
.tile .shot{aspect-ratio:4/3;position:relative;background:linear-gradient(150deg,#2a2622,#14110d);display:flex;align-items:center;justify-content:center;overflow:hidden}
.tile .shot::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 70% 18%,rgba(255,138,0,.2),transparent 55%)}
.tile .shot .ph{position:relative;z-index:2;font-family:var(--fd);font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.tile .shot .big{position:absolute;left:22px;bottom:16px;z-index:2;font-family:var(--fs);font-style:italic;font-size:40px;color:rgba(255,255,255,.18)}
.tile .meta{padding:20px 22px 22px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.tile .meta .k{font-family:var(--fd);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2)}
.tile .meta h3{font-size:18px;font-weight:600;margin-top:7px;letter-spacing:-.01em}
.tile .meta .arr{font-family:var(--fd);color:var(--muted-2);transition:transform .2s,color .2s}
.tile:hover .meta .arr{transform:translateX(4px);color:var(--orange)}
.gallery-cta{margin-top:40px;display:flex;justify-content:center}

/* roadmap squiggle */
.roadmap{position:relative;padding:96px 0}
.road-stage{position:relative;max-width:920px;margin:56px auto 0}
.road-svg{position:absolute;inset:0;pointer-events:none}
@media(max-width:820px){.road-svg{display:none}}
.road-line-bg{stroke:var(--line);stroke-width:2;stroke-dasharray:9 11;fill:none}
.road-line-fg{stroke:url(#rgrad);stroke-width:3;stroke-linecap:round;fill:none}
.road-items{display:flex;flex-direction:column}
.road-item{position:relative;min-height:300px;display:flex;align-items:center}
.road-item .node{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;background:var(--cream);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;z-index:3;transition:border-color .4s}
.road-item .node span{width:14px;height:14px;border-radius:50%;background:var(--muted-2);box-shadow:0 0 0 rgba(255,40,0,0);transition:background .45s var(--sm),box-shadow .45s var(--sm)}
.road-card{width:40%;padding:30px;border-radius:18px;background:var(--paper);border:1px solid var(--line);box-shadow:0 18px 44px -30px rgba(40,30,15,.4);transition:box-shadow .45s var(--sm),border-color .45s var(--sm),background .45s var(--sm)}
.road-card:hover{box-shadow:0 28px 60px -30px rgba(40,30,15,.45);border-color:var(--muted-2)}
/* lit state — glows reddish-orange as the squiggle reaches each step */
.road-item.lit .node{border-color:rgba(255,70,20,.5)}
.road-item.lit .node span{background:var(--red);box-shadow:0 0 20px rgba(255,45,0,.75)}
.road-item.lit .road-card{border-color:rgba(255,70,20,.55);box-shadow:0 0 0 1px rgba(255,70,20,.18),0 26px 60px -28px rgba(255,90,0,.55);background:linear-gradient(180deg,rgba(255,138,0,.06),rgba(255,255,255,0) 62%)}
.road-item.right{justify-content:flex-end}
.road-item.left{justify-content:flex-start}
.road-card .rn{font-family:var(--fs);font-style:italic;font-size:52px;line-height:1;color:var(--line);margin-bottom:8px}
.road-card .kicker{font-family:var(--fd);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--orange);margin-bottom:8px}
.road-card h3{font-size:22px;margin-bottom:10px}
.road-card p{font-family:var(--fb);font-weight:300;font-size:14.5px;color:var(--ink-2);line-height:1.6}
.road-rail{display:none}
@media(max-width:820px){
  .road-stage{max-width:520px}
  .road-items{padding-left:30px;position:relative}
  /* one continuous thin line down the left, through every node */
  .road-items::before{content:'';position:absolute;left:18px;top:14px;bottom:14px;width:2px;background:var(--grad);border-radius:2px;opacity:.85}
  .road-item{min-height:auto;margin-bottom:26px}
  .road-item.right,.road-item.left{justify-content:flex-start}
  .road-card{width:100%}
  .road-item .node{left:-30px;top:28px;transform:none;width:38px;height:38px}
  .road-item .node span{width:13px;height:13px}
}

/* founders */
.founders{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:52px;border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--paper)}
@media(max-width:720px){.founders{grid-template-columns:1fr}}
.fr{padding:44px;border-right:1px solid var(--line)}
.fr:last-child{border-right:none}
@media(max-width:720px){.fr{border-right:none;border-bottom:1px solid var(--line)}.fr:last-child{border-bottom:none}}
.fr .av{width:60px;height:60px;border-radius:14px;object-fit:cover;background:var(--cream-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:700;font-size:20px;color:var(--ink);margin-bottom:24px}
.fr h3{font-size:22px;font-weight:600}
.fr .role{font-family:var(--fd);font-size:13px;font-weight:600;color:var(--orange);margin:6px 0 16px}
.fr p{font-family:var(--fb);font-weight:300;font-size:15px;color:var(--ink-2);line-height:1.65}
.fr .editme{color:var(--muted-2);font-style:italic}

/* generic content blocks for sub-pages */
.cols{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:48px}
@media(max-width:760px){.cols{grid-template-columns:1fr}}
.card{padding:34px;border:1px solid var(--line);border-radius:18px;background:var(--paper)}
.card .kicker{font-family:var(--fd);font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);margin-bottom:12px}
.card h3{font-size:23px;font-weight:600;letter-spacing:-.02em;margin-bottom:12px}
.card p{font-family:var(--fb);font-weight:300;font-size:15.5px;color:var(--ink-2);line-height:1.65}
.card ul{list-style:none;margin:18px 0 0;padding:0}
.card li{font-family:var(--fb);font-weight:300;font-size:14.5px;color:var(--ink-2);padding:9px 0 9px 22px;position:relative;border-top:1px solid var(--line-2)}
.card li:first-child{border-top:none}
.card li::before{content:'';position:absolute;left:0;top:16px;width:8px;height:8px;border-radius:2px;background:var(--grad)}

/* split row (image + text) */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;margin-top:40px}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:24px}}
.split .frame{border:1px solid var(--line);border-radius:18px;overflow:hidden;aspect-ratio:16/11;background:linear-gradient(150deg,#2a2622,#14110d);position:relative;display:flex;align-items:center;justify-content:center}
.split .frame::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 70% 16%,rgba(255,138,0,.2),transparent 55%)}
.split .frame .ph{position:relative;z-index:2;font-family:var(--fd);font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5)}

/* Wired-in proof screenshots: fill the frame, crop from the top-left so the app sidebar stays visible */
.tile .shot:has(img),.split .frame:has(img){background:#fff}
.tile .shot:has(img)::after,.split .frame:has(img)::after{display:none}
.tile .shot img,.split .frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:left top;display:block}

/* audit page: what you get + agenda timeline + cal embed */
.audit-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;margin-top:48px}
@media(max-width:820px){.audit-grid{grid-template-columns:1fr}}
.audit-card{padding:30px;border:1px solid var(--line);border-radius:16px;background:var(--paper)}
.audit-card .n{font-family:var(--fs);font-style:italic;font-size:34px;color:var(--muted-2);margin-bottom:14px}
.audit-card h3{font-size:19px;margin-bottom:10px}
.audit-card p{font-family:var(--fb);font-weight:300;font-size:14.5px;color:var(--ink-2);line-height:1.6}
.agenda{margin-top:44px;border-top:1px solid var(--line)}
.agenda .row{display:grid;grid-template-columns:150px 1fr;gap:30px;padding:26px 0;border-bottom:1px solid var(--line)}
.agenda .row .t{font-family:var(--fd);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--orange)}
.agenda .row h3{font-size:20px;margin-bottom:6px}
.agenda .row p{font-family:var(--fb);font-weight:300;font-size:15px;color:var(--ink-2);line-height:1.6}
@media(max-width:680px){.agenda .row{grid-template-columns:1fr;gap:6px}}
.cal-embed{margin-top:44px;border:1px dashed var(--line);border-radius:20px;background:var(--cream-2);padding:64px 40px;text-align:center}
.cal-embed .mark{width:46px;height:46px;border-radius:12px;background:var(--grad);margin:0 auto 18px;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--fd);font-weight:700}
.cal-embed h3{font-size:24px;margin-bottom:10px}
.cal-embed p{font-family:var(--fb);font-weight:300;font-size:15.5px;color:var(--muted);max-width:460px;margin:0 auto 24px}
.dur-pill{display:inline-flex;align-items:center;gap:9px;font-family:var(--fd);font-size:13px;font-weight:600;color:var(--ink-2);padding:8px 16px;background:var(--paper);border:1px solid var(--line);border-radius:100px}

/* faq */
.faq{margin-top:44px;border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line);padding:22px 0}
.faq summary{font-family:var(--fd);font-size:18px;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';color:var(--muted-2);font-weight:400;font-size:22px;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{font-family:var(--fb);font-weight:300;font-size:15px;color:var(--ink-2);line-height:1.65;margin-top:14px;max-width:760px}

/* end cta band */
.endcta{text-align:center;padding:104px 0}
.endcta h2{font-size:clamp(36px,5.5vw,72px);font-weight:600;letter-spacing:-.04em;max-width:900px;margin:0 auto}
.endcta p{font-family:var(--fb);font-weight:300;font-size:19px;color:var(--muted);max-width:480px;margin:24px auto 36px}

/* footer */
footer{border-top:1px solid var(--line);padding:56px 0 44px}
.foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:30px;align-items:flex-start}
.foot .about{max-width:280px}
.foot .about p{font-family:var(--fb);font-weight:300;font-size:13.5px;color:var(--muted);margin-top:14px;line-height:1.6}
.foot .col h5{font-family:var(--fd);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-bottom:14px}
.foot .col a{display:block;font-size:14px;color:var(--ink-2);margin-bottom:9px}
.foot .col a:hover{color:var(--orange)}
.foot-bot{margin-top:46px;padding-top:22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:var(--muted-2)}

/* typed inputs: keep at 16px so iOS does not auto-zoom on focus */
input,textarea,select{font-size:16px}

/* never let the audit CTA wrap onto two lines */
.nav-cta{white-space:nowrap}

/* mobile nav: drop the wordmark so the RR mark + CTA fit cleanly */
@media(max-width:560px){
  .nav-inner{height:64px}
  .logo{font-size:0;gap:0}
  .logo .mk{font-size:13px}
  .nav-cta{font-size:13px;padding:10px 16px}
  .topbar .lbl{font-size:9.5px}
}

/* book-audit mobile polish */
@media(max-width:600px){
  .cal-embed{padding:42px 22px}
  .phero .hero-cta{gap:14px}
  .dur-pill{font-size:12px}
}
