/* ============================================================
   FyrDraft.ai — brand stylesheet
   Cream / rust-orange / high-contrast serif (matches pitch deck)
   ============================================================ */

:root {
  --ink:        #1b1a17;
  --ink-soft:   #3a372f;
  --muted:      #6c665b;
  --cream:      #fbf6e3;
  --cream-2:    #f6eed6;
  --cream-3:    #f1e7c9;
  --white:      #ffffff;
  --rust:       #b5532c;
  --flame:      #e8742a;
  --flame-2:    #f6a34b;
  --line:       rgba(27,26,23,0.12);
  --line-soft:  rgba(27,26,23,0.07);
  --shadow-sm:  0 1px 2px rgba(27,26,23,.06), 0 2px 8px rgba(27,26,23,.05);
  --shadow-md:  0 6px 24px rgba(27,26,23,.10);
  --shadow-lg:  0 18px 50px rgba(27,26,23,.16);
  --radius:     16px;
  --radius-sm:  10px;
  --maxw:       1180px;
  --serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 84px; }
body {
  margin: 0; font-family: var(--sans); color: var(--ink); background: var(--cream);
  line-height: 1.6; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: var(--rust); text-decoration: none; }
a:hover { color: var(--flame); }
h1, h2, h3, h4 { font-family: var(--serif); color: var(--ink); line-height: 1.08; margin: 0 0 .4em; font-weight: 800; }
h2 { font-size: clamp(1.9rem, 3.6vw, 3rem); letter-spacing: -0.01em; }
h3 { font-size: 1.3rem; font-weight: 700; }
p { margin: 0 0 1rem; }
.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

.eyebrow { font-family: var(--sans); font-size: .78rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--rust); margin: 0 0 .9rem; }

.section { padding: 92px 0; position: relative; }
.section--cream2 { background: var(--cream-2); }
.section--white  { background: var(--white); }
.section--ink { background: radial-gradient(120% 120% at 80% 0%, #2a2823 0%, #181712 70%); color: #f3eede; }
.section--ink h2, .section--ink h3 { color: #fdfaf0; }
.section-head { max-width: 760px; margin: 0 0 48px; }
.section-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.section-head p.lead { font-size: 1.12rem; color: var(--muted); margin: 0; }
.section--ink .section-head p.lead { color: #cfc8b6; }

/* ---------- buttons ---------- */
.btn { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--sans); font-weight: 600; font-size: .98rem;
  padding: .8rem 1.4rem; border-radius: 999px; cursor: pointer; border: 1.5px solid transparent;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease; white-space: nowrap; }
.btn-primary { background: var(--flame); color: #fff; box-shadow: 0 6px 18px rgba(232,116,42,.35); }
.btn-primary:hover { background: #d9651d; color:#fff; transform: translateY(-2px); box-shadow: 0 10px 26px rgba(232,116,42,.45); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--ink); color: var(--ink); transform: translateY(-2px); }
.btn-light { background: #fff; color: var(--ink); }
.btn-light:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); color: var(--ink); }
.btn-lg { padding: 1rem 1.8rem; font-size: 1.05rem; }

/* ---------- nav ---------- */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; transition: background .25s ease, box-shadow .25s ease, border-color .25s ease; border-bottom: 1px solid transparent; }
.nav.scrolled { background: rgba(251,246,227,.92); backdrop-filter: blur(10px); box-shadow: var(--shadow-sm); border-bottom-color: var(--line-soft); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.brand { display: flex; align-items: center; gap: .6rem; }
.brand img { width: 40px; height: 40px; object-fit: contain; }
.brand .wordmark { font-family: var(--serif); font-weight: 800; font-size: 1.45rem; letter-spacing: -.01em; color: var(--ink); }
.brand .wordmark span { color: var(--rust); }
.nav-links { display: flex; align-items: center; gap: 1.6rem; }
.nav-links a.navlink { color: var(--ink-soft); font-weight: 500; font-size: .95rem; }
.nav-links a.navlink:hover { color: var(--rust); }
.nav-cta { display: flex; align-items: center; gap: .75rem; }
.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: 8px; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: var(--ink); margin: 5px 0; transition: .25s; }

/* ---------- hero ---------- */
.hero { position: relative; padding: 116px 0 80px; overflow: hidden; }
.hero::before { content:""; position:absolute; inset:0;
  background: radial-gradient(60% 50% at 78% 20%, rgba(246,163,75,.18), transparent 60%), radial-gradient(50% 50% at 10% 90%, rgba(181,83,44,.08), transparent 60%);
  pointer-events:none; }
.hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 48px; align-items: center; position: relative; }
.hero h1 { font-size: clamp(2.6rem, 5.6vw, 4.6rem); letter-spacing: -.02em; margin-bottom: .15em; }
.hero .tagline { font-family: var(--serif); font-weight: 700; color: var(--rust); font-size: clamp(1.5rem, 3.2vw, 2.4rem); margin: 0 0 .6em; }
.hero .sub { font-size: 1.2rem; line-height: 1.55; color: var(--ink-soft); margin-bottom: 1.9rem; }
.hero .eyebrow { font-size: .95rem; letter-spacing: .2em; margin-bottom: 1.2rem; }
.hero-cta { display: flex; gap: .8rem; flex-wrap: wrap; margin-bottom: 2rem; }
.hero-figure { position: relative; }
.hero-figure img, .hero-figure .hero-media { width: 100%; height: auto; display: block; filter: drop-shadow(0 24px 40px rgba(27,26,23,.16)); }

/* video trigger (first-frame thumbnail with play badge) */
.media-trigger { position: relative; display: block; width: 100%; max-width: 500px; margin: 0 auto; padding: 0; border: 0; background: none; cursor: pointer; }
.hero-thumb { width: 100%; aspect-ratio: 1 / 1; height: auto; display: block; object-fit: cover; border-radius: var(--radius); box-shadow: var(--shadow-md); background: var(--cream-2); }
.play-badge { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 76px; height: 76px; border-radius: 50%;
  background: var(--flame); color: #fff; display: grid; place-items: center; box-shadow: 0 10px 30px rgba(232,116,42,.5); transition: transform .18s ease, background .18s ease; }
.play-badge svg { width: 32px; height: 32px; margin-left: 4px; }
.media-trigger:hover .play-badge { transform: translate(-50%, -50%) scale(1.08); background: #d9651d; }
.video-trigger.btn { cursor: pointer; }

/* video lightbox */
.video-modal { position: fixed; inset: 0; z-index: 200; display: none; }
.video-modal.open { display: grid; place-items: center; }
.video-modal__backdrop { position: absolute; inset: 0; background: rgba(20,19,15,.82); backdrop-filter: blur(4px); }
.video-modal__inner { position: relative; z-index: 1; width: min(92vw, 620px); }
.video-modal__video { width: 100%; height: auto; max-height: 84vh; display: block; border-radius: var(--radius); background: #000; box-shadow: var(--shadow-lg); }
.video-modal__close { position: absolute; top: -14px; right: -14px; width: 40px; height: 40px; border-radius: 50%; border: 0; cursor: pointer;
  background: #fff; color: var(--ink); font-size: 1.5rem; line-height: 1; box-shadow: var(--shadow-md); display: grid; place-items: center; }
.video-modal__close:hover { background: var(--flame); color: #fff; }
@media (max-width: 520px) { .video-modal__close { top: -8px; right: 4px; } }
.trust { opacity: .85; line-height: 1.7; }
.trust .label { font-size: .72rem; text-transform: uppercase; letter-spacing: .14em; color: var(--muted); font-weight: 700; margin-right: .7rem; white-space: nowrap; }
.trust .names { font-family: var(--serif); font-weight: 700; color: var(--ink-soft); font-size: .98rem; }

/* ---------- generic two-col ---------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.split.reverse .split-media { order: 2; }
.split-media img { border-radius: var(--radius); box-shadow: var(--shadow-md); border: 1px solid var(--line-soft); background:#fff; }
.split-media.plain img { box-shadow: none; border: none; background: transparent; }

/* ---------- cards ---------- */
.card-grid { display: grid; gap: 22px; }
.cols-2 { grid-template-columns: repeat(2, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.cols-4 { grid-template-columns: repeat(4, 1fr); }
.card { background: var(--white); border: 1px solid var(--line-soft); border-radius: var(--radius); padding: 26px; box-shadow: var(--shadow-sm); transition: transform .18s ease, box-shadow .2s ease; }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.card .ic { width: 44px; height: 44px; border-radius: 11px; display: grid; place-items: center; margin-bottom: 16px; background: linear-gradient(135deg, #fbe0c7, #f6c79b); color: var(--rust); }
.card .ic svg { width: 24px; height: 24px; }
.card h3 { margin-bottom: .35rem; }
.card p { color: var(--muted); margin: 0; font-size: .97rem; }

.callout { margin-top: 34px; text-align: center; border: 1.5px solid var(--flame); background: linear-gradient(180deg, #fff7ee, #fdeedd); border-radius: var(--radius); padding: 22px 26px; font-family: var(--serif); font-size: 1.35rem; font-weight: 700; color: var(--ink); }

/* ---------- feature list ---------- */
.flist { list-style: none; padding: 0; margin: 1.2rem 0 0; display: grid; gap: 14px; }
.flist li { display: flex; gap: .75rem; align-items: flex-start; }
.flist .tick { flex: 0 0 auto; width: 24px; height: 24px; border-radius: 50%; background: var(--flame); color: #fff; display: grid; place-items: center; font-size: 13px; margin-top: 2px; }
.flist b { color: var(--ink); }
.flist span.t { color: var(--muted); }

/* ---------- stats ---------- */
.stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.stat { text-align: center; padding: 8px; }
.stat .big { font-family: var(--serif); font-weight: 800; font-size: clamp(2rem,4vw,2.9rem); color: var(--rust); line-height: 1; }
.stat .lbl { color: var(--muted); font-size: .92rem; margin-top: .5rem; }

/* ---------- testimonials ---------- */
.quotes { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.quote { position: relative; background: #fff; border-radius: var(--radius); padding: 30px 26px 24px; box-shadow: var(--shadow-sm); border: 1px solid var(--line-soft); }
.quote::before { content:"\201C"; position:absolute; top: 2px; left: 18px; font-family: var(--serif); font-size: 4.5rem; color: var(--flame); line-height: 1; }
.quote p { position: relative; margin: 18px 0 16px; color: var(--ink-soft); font-size: 1.02rem; }
.quote .who { color: var(--rust); font-weight: 700; font-size: .9rem; }

/* ---------- footer ---------- */
.footer { background: #14130f; color: #b8b1a1; padding: 54px 0 30px; }
.footer-grid { display:flex; justify-content: space-between; gap: 30px; flex-wrap: wrap; align-items: flex-start; }
.footer .brand .wordmark { color: #fff; }
.footer .brand .wordmark span { color: var(--flame-2); }
.footer p { color: #908a7c; max-width: 38ch; font-size: .95rem; margin-top: .8rem; }
.footer-links { display: flex; gap: 40px; flex-wrap: wrap; }
.footer-col h5 { color:#fff; font-family: var(--sans); font-size: .8rem; text-transform: uppercase; letter-spacing: .12em; margin: 0 0 12px; }
.footer-col a { display:block; color:#b8b1a1; font-size:.93rem; margin-bottom: 8px; }
.footer-col a:hover { color: var(--flame-2); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.08); margin-top: 40px; padding-top: 20px; display:flex; justify-content: space-between; gap:12px; flex-wrap: wrap; font-size: .85rem; color:#7c7668; }

/* ---------- pill / badge ---------- */
.pill { display:inline-flex; align-items:center; gap:.5rem; background:#fff; border:1px solid var(--line); color:var(--rust); font-weight:600; font-size:.82rem; padding:.4rem .85rem; border-radius:999px; box-shadow:var(--shadow-sm); }
.pill .dot { width:8px; height:8px; border-radius:50%; background:var(--flame); box-shadow:0 0 0 4px rgba(232,116,42,.18); }

/* ---------- how it works steps ---------- */
.steps { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.step { background:#fff; border:1px solid var(--line-soft); border-radius:var(--radius); padding:28px 26px; position:relative; box-shadow:var(--shadow-sm); }
.step .stepnum { font-family:var(--serif); font-weight:800; font-size:1rem; color:#fff; background:var(--flame); width:38px; height:38px; border-radius:50%; display:grid; place-items:center; margin-bottom:16px; }
.step h3 { margin-bottom:.4rem; }
.step p { color:var(--muted); margin:0; font-size:.96rem; }

/* ---------- use-case cards ---------- */
.use-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.use { background:#fff; border:1px solid var(--line-soft); border-radius:var(--radius); padding:26px; box-shadow:var(--shadow-sm); transition:transform .18s ease, box-shadow .2s; }
.use:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.use .ic { width:46px; height:46px; border-radius:12px; display:grid; place-items:center; margin-bottom:16px; background:linear-gradient(135deg,#fbe0c7,#f6c79b); color:var(--rust); }
.use .ic svg { width:24px; height:24px; }
.use h3 { font-size:1.18rem; margin-bottom:.4rem; }
.use p { color:var(--muted); margin:0; font-size:.96rem; }
.use .q { display:block; font-style:italic; color:var(--rust); font-size:.9rem; margin-top:.7rem; font-family:var(--serif); }

/* ---------- audience ---------- */
.aud-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.aud { border-radius:var(--radius); padding:28px; border:1px solid var(--line-soft); background:var(--cream); }
.aud h3 { font-size:1.15rem; margin-bottom:.4rem; }
.aud p { color:var(--muted); margin:0; font-size:.95rem; }

/* ---------- FAQ ---------- */
.faq { max-width:820px; margin:0 auto; display:grid; gap:14px; }
.faq details { background:#fff; border:1px solid var(--line-soft); border-radius:var(--radius-sm); padding:4px 22px; box-shadow:var(--shadow-sm); }
.faq summary { cursor:pointer; list-style:none; padding:18px 0; font-family:var(--serif); font-weight:700; font-size:1.08rem; color:var(--ink); display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:"+"; font-family:var(--sans); font-weight:400; font-size:1.6rem; color:var(--flame); transition:transform .2s; line-height:1; }
.faq details[open] summary::after { transform:rotate(45deg); }
.faq details p { color:var(--muted); margin:0 0 18px; font-size:.98rem; }

/* ---------- early access band ---------- */
.band { background:linear-gradient(135deg,#e8742a,#c0451a); color:#fff; border-radius:calc(var(--radius)*1.4); padding:54px 40px; text-align:center; box-shadow:var(--shadow-lg); }
.band h2 { color:#fff; max-width:20ch; margin:0 auto .4em; }
.band p { color:#ffe9d6; font-size:1.12rem; max-width:54ch; margin:0 auto 1.6rem; }
.band .btn-light { background:#fff; color:var(--rust); }
.band .btn-ghost { color:#fff; border-color:rgba(255,255,255,.5); }
.band .btn-ghost:hover { border-color:#fff; color:#fff; background:rgba(255,255,255,.1); }

/* ---------- auth pages ---------- */
.auth-wrap { min-height:100vh; display:grid; grid-template-columns:1.05fr .95fr; }
.auth-aside { background:radial-gradient(120% 120% at 80% 0%, #2a2823 0%, #181712 70%); color:#f3eede; padding:56px; display:flex; flex-direction:column; justify-content:space-between; position:relative; overflow:hidden; }
.auth-aside::before { content:""; position:absolute; inset:0; background:radial-gradient(50% 50% at 75% 25%, rgba(246,163,75,.18), transparent 60%); }
.auth-aside .brand .wordmark { color:#fff; }
.auth-aside .a-body { position:relative; z-index:1; max-width:460px; }
.auth-aside h2 { color:#fff; font-size:clamp(1.8rem,2.6vw,2.5rem); margin-bottom:.6rem; }
.auth-aside p { color:#cfc8b6; font-size:1.05rem; }
.auth-aside .a-list { list-style:none; padding:0; margin:24px 0 0; display:grid; gap:14px; position:relative; z-index:1; }
.auth-aside .a-list li { display:flex; gap:.7rem; align-items:flex-start; color:#e8e2d3; font-size:.98rem; }
.auth-aside .a-list .tick { flex:0 0 auto; width:22px; height:22px; border-radius:50%; background:var(--flame); color:#fff; display:grid; place-items:center; font-size:12px; margin-top:2px; }
.auth-aside .a-quote { position:relative; z-index:1; border-left:3px solid var(--flame); padding-left:16px; color:#cfc8b6; font-style:italic; font-family:var(--serif); }

.auth-main { display:grid; place-items:center; padding:48px 24px; background:var(--cream); }
.auth-card { width:100%; max-width:430px; }
.auth-card .back { font-size:.9rem; color:var(--muted); display:inline-flex; gap:.4rem; align-items:center; margin-bottom:28px; }
.auth-card h1 { font-size:2rem; margin-bottom:.3rem; }
.auth-card .sub { color:var(--muted); margin-bottom:26px; }

.sso { width:100%; display:flex; align-items:center; justify-content:center; gap:.6rem; padding:.85rem 1rem; border-radius:10px; border:1.5px solid var(--line); background:#fff; font-weight:600; font-size:.98rem; color:var(--ink); cursor:pointer; transition:.15s; text-decoration:none; }
.sso:hover { border-color:var(--ink); transform:translateY(-1px); color:var(--ink); }
.sso img, .sso svg { width:20px; height:20px; flex:0 0 20px; }
.or { display:flex; align-items:center; gap:14px; color:var(--muted); font-size:.85rem; margin:20px 0; }
.or::before, .or::after { content:""; flex:1; height:1px; background:var(--line); }

form.f { display:grid; gap:16px; }
.field { display:grid; gap:6px; }
.field label { font-size:.86rem; font-weight:600; color:var(--ink-soft); }
.field label .req { color:var(--flame); }
.field input, .field select, .field textarea { font-family:var(--sans); font-size:.98rem; padding:.78rem .9rem; border:1.5px solid var(--line); border-radius:10px; background:#fff; color:var(--ink); width:100%; transition:border-color .15s, box-shadow .15s; }
.field textarea { resize:vertical; min-height:96px; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--flame); box-shadow:0 0 0 3px rgba(232,116,42,.15); }
.form-row2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.f .btn-primary { width:100%; justify-content:center; padding:.9rem; font-size:1rem; }
.f .hint, .auth-card .alt { font-size:.9rem; color:var(--muted); }
.f .checkline { display:flex; gap:.6rem; align-items:flex-start; font-size:.86rem; color:var(--muted); }
.f .checkline input { width:auto; margin-top:3px; flex:0 0 auto; }
/* ============================================================
   RESPONSIVE  (re-added — tablet & mobile reflow)
   ============================================================ */

/* ---- Tablet / small laptop ---- */
@media (max-width: 960px) {
  .section { padding: 68px 0; }
  .hero { padding-top: 96px; }
  .hero-grid { grid-template-columns: 1fr; gap: 32px; }
  .split { grid-template-columns: 1fr; gap: 36px; }
  .auth-wrap { grid-template-columns: 1fr; }
  .auth-aside { display: none; }
  .cols-4, .stats { grid-template-columns: repeat(2, 1fr); }
  .cols-3, .steps, .use-grid, .aud-grid, .quotes { grid-template-columns: repeat(2, 1fr); }

  /* Mobile nav */
  .nav-toggle { display: inline-block; }
  .nav-links {
    position: absolute; top: 72px; left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: 0;
    background: rgba(251,246,227,.98); backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--line-soft);
    box-shadow: var(--shadow-sm);
    padding: 8px 24px 20px;
    max-height: 0; overflow: hidden; opacity: 0; pointer-events: none;
    transition: max-height .28s ease, opacity .2s ease;
  }
  .nav-links.open { max-height: 80vh; opacity: 1; pointer-events: auto; }
  .nav-links a.navlink { padding: 14px 0; border-bottom: 1px solid var(--line-soft); font-size: 1rem; }
  .nav-cta { flex-direction: column; align-items: stretch; gap: .6rem; margin-top: 14px; width: 100%; }
  .nav-cta .btn { width: 100%; justify-content: center; }
  .nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2) { opacity: 0; }
  .nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
}

/* ---- Phone ---- */
@media (max-width: 640px) {
  .section { padding: 56px 0; }
  .container { padding: 0 18px; }
  .cols-2, .cols-3, .cols-4,
  .stats, .quotes, .steps, .use-grid, .aud-grid,
  .form-row2 { grid-template-columns: 1fr; }
  .section-head p.lead { font-size: 1.04rem; }
  .names { font-size: .82rem; line-height: 1.7; }
}

/* ============================================================
   HOW IT WORKS — hill journey diagram + key steps
   ============================================================ */
.how-intake { max-width:380px; margin:8px auto 2px; text-align:center; }
.how-bubble { display:inline-block; background:#fff; border:1.5px solid var(--flame-2); border-radius:18px 18px 18px 5px; padding:12px 18px; font-family:var(--serif); font-size:1.04rem; color:var(--ink); box-shadow:var(--shadow-sm); }
.how-intake-sub { margin-top:9px; font-size:1rem; color:var(--muted); }
.how-intake-arrow { color:var(--flame); font-size:1.7rem; line-height:1; margin-top:2px; }

.how-fig { margin-top:6px; }
.how-fig svg { width:100%; max-width:760px; height:auto; display:block; margin:0 auto; }

/* SVG label classes */
.how-svg-t  { font-family:var(--sans); font-weight:700; font-size:15px; fill:var(--ink); }
.how-svg-tg { font-family:var(--serif); font-weight:700; font-size:15px; fill:var(--ink); }
.how-svg-th { font-family:var(--sans); font-weight:800; font-size:15px; fill:var(--rust); }
.how-svg-d  { font-family:var(--sans); font-size:13px; fill:#6f6757; }
.how-svg-loop { font-family:var(--sans); font-weight:700; font-size:13px; fill:#9a6f46; }
.how-svg-callh { font-family:var(--sans); font-weight:800; font-size:13px; fill:var(--rust); }
.how-svg-call  { font-family:var(--sans); font-size:12.5px; fill:#3c3a33; }
.how-svg-callw { font-family:var(--sans); font-size:12.5px; fill:#8a5a36; }

/* golden climber: travels the path, grows + brightens */
.how-climber { offset-path:path('M100 228 C175 222 238 208 300 194 C360 184 410 174 470 160 C 410 112 360 114 300 194 C360 184 410 174 470 160 C540 142 600 128 655 112'); animation:howClimb 9.5s ease-in-out infinite; }
.how-climber-grow { animation:howGrow 9.5s ease-in-out infinite; }
.how-climber-halo { animation:howHalo 9.5s ease-in-out infinite; }
@keyframes howClimb { from { offset-distance:0%; } to { offset-distance:100%; } }
@keyframes howGrow { 0%{transform:scale(.9);} 40%{transform:scale(1.3);} 62%{transform:scale(1.85);} 100%{transform:scale(2.6);} }
@keyframes howHalo { 0%{opacity:.12;} 55%{opacity:.34;} 100%{opacity:.55;} }

/* key steps below */
.how-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:26px; margin-top:30px; }
.how-step h3 { display:flex; align-items:center; gap:9px; font-size:1.04rem; margin:0 0 .45rem; }
.how-step h3 .n { flex:0 0 26px; width:26px; height:26px; border-radius:50%; background:var(--flame); color:#fff; font-family:var(--sans); font-weight:700; font-size:.85rem; display:inline-flex; align-items:center; justify-content:center; }
.how-step:nth-child(3) h3 .n { background:var(--rust); }
.how-step:nth-child(4) h3 .n { background:#4e8a52; }
.how-step p { margin:0; color:var(--muted); font-size:.93rem; line-height:1.55; }

@media (max-width:860px) {
  .how-fig { overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .how-fig svg { min-width:580px; }
  .how-steps { grid-template-columns:1fr 1fr; gap:22px; }
}
@media (max-width:560px) { .how-steps { grid-template-columns:1fr; } }
@media (prefers-reduced-motion: reduce) {
  .how-climber { offset-distance:50%; animation:none; }
  .how-climber-grow { animation:none; transform:scale(1.6); }
  .how-climber-halo { animation:none; opacity:.35; }
}

/* For-attorneys section: copy + reallocation graphic */
.att-top { display:grid; grid-template-columns:1.05fr .95fr; gap:44px; align-items:center; margin-bottom:46px; }
.att-fig svg { width:100%; max-width:460px; height:auto; display:block; margin:0 auto; }
.att-cap { margin:12px 0 0; font-size:.92rem; color:var(--muted); line-height:1.5; max-width:460px; }
@media (max-width:860px) { .att-top { grid-template-columns:1fr; gap:26px; } }

.att-fig-title { font-family:var(--sans); font-size:.78rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--rust); margin:0 0 12px; text-align:center; }
