/* GENERATED by _port.py from creative/mockups/ — edit the mockup, not this file. */
  h2 { font-family: 'Hedvig Letters Serif', serif; font-weight: 400; font-size: clamp(1.9rem, 3.4vw, 2.8rem); line-height: 1.12; }
  .nav-cta { white-space: nowrap; }
  /* ---------- hero (locked v2: split + animatic) ---------- */
  .hero { position: relative; display: flex; flex-direction: column; justify-content: center; min-height: calc(100vh - 58px); overflow: hidden; padding-bottom: 5.5rem;
    background:
      radial-gradient(ellipse at 6% 0%, rgba(199,164,77,0.14) 0%, transparent 52%),
      radial-gradient(ellipse at 96% 10%, rgba(28,43,74,0.07) 0%, transparent 48%),
      radial-gradient(ellipse at 18% 88%, rgba(201,163,107,0.12) 0%, transparent 50%),
      radial-gradient(ellipse at 55% 110%, rgba(216,185,104,0.2) 0%, transparent 55%),
      linear-gradient(180deg, #FAF7F0 0%, var(--cream) 58%, var(--cream-2) 100%); }
  .hero-grid { width: 100%; display: grid; grid-template-columns: 1.05fr 0.92fr; gap: clamp(2.5rem, 5vw, 4.5rem); align-items: center; max-width: 1280px; margin: 0 auto; padding: clamp(2rem, 5vh, 3.5rem) clamp(1.25rem, 3vw, 2.5rem) 2rem; }
  /* scroll cue: serif whisper + cascading chevrons, no chrome */
  .scroll-cue { position: absolute; left: 50%; transform: translateX(-50%); bottom: 1.5rem; display: flex; flex-direction: column; align-items: center; gap: 0.35rem; text-decoration: none; }
  .cue-label { font-family: 'Hedvig Letters Serif', serif; font-style: italic; font-size: 0.95rem; letter-spacing: 0.04em; color: var(--gold-deep); }
  .cue-chevrons path { stroke: var(--navy); animation: cascade 1.8s ease-in-out infinite; transition: stroke .25s; }
  .cue-chevrons path:nth-child(2) { animation-delay: .18s; }
  .cue-chevrons path:nth-child(3) { animation-delay: .36s; }
  .scroll-cue:hover .cue-chevrons path { stroke: var(--gold-deep); }
  @keyframes cascade { 0%, 100% { opacity: 0.12; } 35% { opacity: 0.8; } }
  @media (max-width: 960px) { .hero-grid { grid-template-columns: 1fr; } .panel-col { justify-self: center; width: 100%; max-width: 480px; } }
  .d1 { animation-delay: .05s; } .d2 { animation-delay: .16s; } .d3 { animation-delay: .3s; } .d4 { animation-delay: .44s; } .d5 { animation-delay: .3s; }
  /* pre-header pill: white core, gradient hairline border (gold -> navy) */
  .badge { display: inline-flex; align-items: center; border: 1.5px solid transparent; border-radius: 999px;
    background: linear-gradient(#fff, #fff) padding-box, linear-gradient(100deg, var(--gold) 0%, var(--gold-2) 55%, rgba(28,43,74,0.45) 100%) border-box;
    color: var(--navy); padding: 0.5rem 1.2rem; font-size: 0.88rem; font-weight: 500; letter-spacing: 0; margin-bottom: 1.9rem;
    box-shadow: 0 8px 20px -14px rgba(28,43,74,0.3); }
  h1 { font-family: 'Hedvig Letters Serif', serif; max-width: 14ch; font-size: clamp(2.5rem, 4.8vw, 4.1rem); line-height: 1.1; font-weight: 400; letter-spacing: -0.005em; }
  .rotator { position: relative; display: inline-block; vertical-align: baseline; }
  .rotator .sizer { visibility: hidden; font-style: italic; }
  /* blueprint-draw rotator (locked option 02 from rotator-options.html) */
  .bp-word { position: absolute; left: 0; overflow: visible; }
  /* phones/tablets: blueprint hidden; JS shows the .sizer as a solid cross-fading word */
  @media (max-width: 820px) { .bp-word { display: none; } }
  .bp-word .bp-fill { filter: drop-shadow(0 0 0.5px rgba(28,43,74,0.55)) drop-shadow(0 0 0.4px rgba(28,43,74,0.5)) drop-shadow(0 0 0.6px rgba(28,43,74,0.32)); }
  .subhead { margin-top: 1.4rem; max-width: 42ch; font-size: clamp(1.02rem, 1.6vw, 1.18rem); line-height: 1.55; color: var(--navy-soft); }
  .cta-row { margin-top: 2.2rem; display: flex; flex-wrap: wrap; align-items: center; gap: 0.9rem; }
  .panel-col { display: flex; flex-direction: column; align-items: flex-end; gap: 0.7rem; }
  @media (max-width: 960px) { .panel-col { align-items: center; } }
  .panel { position: relative; width: 100%; max-width: 560px; aspect-ratio: 1 / 1; border-radius: 20px; overflow: hidden;
    background:
      linear-gradient(rgba(28,43,74,0.045) 1px, transparent 1px),
      linear-gradient(90deg, rgba(28,43,74,0.045) 1px, transparent 1px),
      linear-gradient(170deg, #FCFAF4 0%, var(--paper) 55%, #F4EEDF 100%);
    background-size: 34px 34px, 34px 34px, 100% 100%;
    border: 1px solid var(--border);
    box-shadow: 0 40px 80px -40px rgba(28,43,74,0.45), 0 12px 28px -18px rgba(28,43,74,0.25); }
  .caption { font-size: 0.78rem; color: var(--navy-faint); padding-right: 0.3rem; }
  .panel svg.scene { position: absolute; inset: 0; width: 100%; height: 100%; }
  #blueprint path, #blueprint line { stroke-dasharray: 1; stroke-dashoffset: 1; }
  .panel.drawn #blueprint path, .panel.drawn #blueprint line { stroke-dashoffset: 0; }
  #blueprint text { opacity: 0; transition: opacity .6s ease 3.4s; }
  .panel.drawn #blueprint text { opacity: 1; }
  .reveal { position: absolute; inset: 0; clip-path: inset(100% 0 0 0); transition: clip-path 2.6s cubic-bezier(0.45, 0, 0.18, 1); }
  .panel.revealed .reveal { clip-path: inset(0 0 0 0); }
  .horizon-sweep { position: absolute; left: 4%; right: 4%; height: 2.5px; bottom: 0; border-radius: 999px; opacity: 0;
    background: linear-gradient(90deg, transparent, var(--gold) 18%, var(--gold-2) 50%, var(--gold) 82%, transparent);
    box-shadow: 0 0 14px 2px rgba(199,164,77,0.55); }
  .panel.revealed .horizon-sweep { animation: sweep 2.6s cubic-bezier(0.45, 0, 0.18, 1) forwards; }
  @keyframes sweep { 0% { bottom: 0; opacity: 0; } 8% { opacity: 1; } 86% { opacity: 1; } 100% { bottom: 100%; opacity: 0; } }
  .glow-after { position: absolute; inset: 0; opacity: 0; transition: opacity 1.6s ease .8s; pointer-events: none;
    background: radial-gradient(80% 60% at 68% 22%, rgba(216,185,104,0.22) 0%, transparent 60%); }
  .panel.revealed .glow-after { opacity: 1; }
  .panel .fades { transition: opacity .7s ease; }
  .panel.resetting .fades { opacity: 0 !important; }
  .panel.resetting #blueprint path, .panel.resetting #blueprint line { transition: none; }
  .panel:not(.drawn) #blueprint path, .panel:not(.drawn) #blueprint line { transition: none; }
  .panel.drawn #blueprint path, .panel.drawn #blueprint line { transition: stroke-dashoffset .85s cubic-bezier(0.4, 0, 0.3, 1); }
  .panel:not(.revealed) .reveal { transition: none; }
  .ui-row { position: absolute; left: 0; right: 0; bottom: 1.4rem; display: flex; justify-content: center; gap: 0.8rem; z-index: 5; }
  .chip { display: inline-flex; align-items: center; gap: 0.45rem; font-size: 0.92rem; font-weight: 600; color: var(--navy); background: #fff; border: 1.5px solid var(--border); border-radius: 999px; padding: 0.6rem 1.5rem; box-shadow: 0 8px 20px -12px rgba(28,43,74,0.35); transition: background .3s, color .3s, border-color .3s, transform .15s; }
  .chip .dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(28,43,74,0.25); transition: background .3s; }
  .chip.active { background: var(--navy); color: var(--cream); border-color: var(--navy); }
  .chip.active .dot { background: var(--gold-2); }
  .chip.pressed { transform: scale(0.94); }
  .cursor { position: absolute; z-index: 6; width: 26px; height: 26px; opacity: 0; transition: transform 0.85s cubic-bezier(0.45, 0.05, 0.2, 1), opacity .5s ease; pointer-events: none; filter: drop-shadow(0 2px 5px rgba(28,43,74,0.45)); }
  .cursor.visible { opacity: 1; }
  .cursor .ring { position: absolute; left: -6px; top: -6px; width: 36px; height: 36px; border-radius: 50%; border: 2px solid var(--gold); opacity: 0; transform: scale(0.4); }
  .cursor.clicking .ring { animation: ripple .55s ease-out; }
  @keyframes ripple { 0% { opacity: 0.9; transform: scale(0.4); } 100% { opacity: 0; transform: scale(1.5); } }
  /* ---------- 2: empathy beat ---------- */
  .empathy { background: var(--navy); color: var(--cream); overflow: hidden; }
  .empathy-grid { display: grid; grid-template-columns: 1.08fr 0.92fr; gap: clamp(2.5rem, 5vw, 5rem); align-items: center; }
  @media (max-width: 960px) { .empathy-grid { grid-template-columns: 1fr; } .phone-col { margin-top: 2.8rem; } }
  .empathy .empathy-copy p.statement { font-family: 'Hedvig Letters Serif', serif; font-size: clamp(1.7rem, 3.4vw, 2.7rem); line-height: 1.25; max-width: 30ch; margin-top: 0; color: var(--cream); }
  .empathy .statement em { font-style: italic; color: var(--gold-2); }
  .empathy .empathy-copy p.statement-echo { margin-top: 1.3rem; font-family: 'Hedvig Letters Serif', serif; font-style: italic; font-size: clamp(1.1rem, 1.8vw, 1.4rem); line-height: 1.4; color: rgba(248,244,235,0.6); max-width: 40ch; }
  /* curved hand-drawn underline that sketches itself under "never you" */
  .never { position: relative; display: inline-block; color: var(--gold-2); }
  .never-swoosh { position: absolute; left: -3%; bottom: -0.3em; width: 106%; height: 0.4em; overflow: visible; }
  .never-swoosh path { fill: none; stroke: var(--gold); stroke-width: 2.4; stroke-linecap: round; stroke-dasharray: 1; stroke-dashoffset: 1; }
  .never.draw .never-swoosh path { transition: stroke-dashoffset .9s cubic-bezier(0.4, 0, 0.3, 1) .3s; stroke-dashoffset: 0; }
  .empathy .empathy-copy > p { margin-top: 1.6rem; max-width: 58ch; font-size: 1.05rem; line-height: 1.65; color: rgba(248,244,235,0.72); }
  /* ---------- 2b: why us — comparison ---------- */
  .cmp { position: relative; max-width: 1240px; margin: 3.4rem auto 0; display: grid;
    grid-template-columns: minmax(135px, 0.46fr) 1fr 1fr; column-gap: 1.1rem; row-gap: 0; }
  .cmp-bg { position: absolute; z-index: 0; border-radius: 20px; pointer-events: none; }
  .cmp-bg.us { background: linear-gradient(180deg, #213352, var(--navy-3)); border: 1px solid rgba(199,164,77,0.4);
    box-shadow: 0 46px 90px -40px rgba(16,24,42,0.7), 0 16px 38px -26px rgba(28,43,74,0.5); }
  .cmp-bg.us::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; border-radius: 20px 20px 0 0;
    background: linear-gradient(90deg, transparent, var(--gold-2) 22%, var(--gold) 50%, var(--gold-2) 78%, transparent); }
  .cmp-cell { position: relative; z-index: 1; padding: 1.15rem 1.45rem; display: flex; flex-direction: column; justify-content: center;
    opacity: 0; transform: translateY(14px); transition: opacity .6s ease, transform .6s cubic-bezier(0.22,0.61,0.36,1); }
  .cmp.inview .cmp-cell { opacity: 1; transform: none; }
  .cmp-cell.topic, .cmp-cell.them { border-bottom: 1px solid var(--border); }
  .cmp-cell.us { background: var(--navy-3); border-bottom: 1px solid rgba(248,244,235,0.1); }
  .cmp.bgset .cmp-cell.us { background: transparent; }
  .cmp-cell.us.firstus { border-radius: 20px 20px 0 0; }
  .cmp-cell.last { border-bottom: 0; }
  .cmp-cell.us.last { border-radius: 0 0 20px 20px; }
  .cmp-cell.head { padding-top: 1.35rem; padding-bottom: 1.35rem; }
  .cmp-cell.head.them { align-items: center; text-align: center; font-size: 0.78rem; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--navy-faint); }
  .cmp-cell.head.us { flex-direction: row; align-items: center; gap: 0.55rem; }
  .cmp-cell.head.us .hz { font-family: 'Hedvig Letters Serif', serif; font-size: 1.42rem; color: var(--cream); }
  .cmp-cell.head.us .logo { height: 22px; width: auto; display: block; }
  /* topic column */
  .cmp-cell.topic { flex-direction: row; align-items: center; justify-content: flex-start; gap: 0.7rem; }
  .cmp-ico { width: 30px; height: 30px; flex: 0 0 auto; display: grid; place-items: center; }
  .cmp-ico svg { width: 28px; height: 28px; }
  .cmp-tlabel { font-size: 0.74rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--navy); line-height: 1.25; }
  /* answers */
  .cmp-cell p { display: flex; gap: 0.55rem; align-items: flex-start; line-height: 1.46; margin: 0; }
  .cmp-cell.them p { font-size: 1rem; color: rgba(28,43,74,0.82); line-height: 1.5; }
  .cmp-cell.us p { font-size: 1rem; color: var(--cream); font-weight: 500; }
  .cmp-x, .cmp-ck { width: 15px; height: 15px; flex: 0 0 auto; margin-top: 0.18rem; }
  .cmp-x { color: rgba(28,43,74,0.3); }
  .cmp-ck { color: var(--gold-2); }
  @media (max-width: 760px) {
    .cmp { display: block; max-width: 460px; }
    .cmp-bg { display: none; }
    .cmp-cell { padding: 1rem 1.3rem; }
    .cmp-cell.head.them, .cmp-cell.topic.head { display: none; }
    .cmp-cell.head.us { border-radius: 14px 14px 0 0; margin-top: 1.4rem; box-shadow: 0 30px 60px -42px rgba(16,24,42,0.7); }
    .cmp-cell.topic { background: rgba(28,43,74,0.025); margin-top: 1.2rem; border-radius: 12px 12px 0 0; }
    .cmp-cell.topic + .cmp-cell.us + * .cmp-cell.topic { margin-top: 1.4rem; }
    .cmp-cell.us.last { border-radius: 0 0 12px 12px; }
  }
  @media (prefers-reduced-motion: reduce) { .cmp-cell { opacity: 1; transform: none; transition: none; } }
  /* phone animation: sms with a contractor going sideways */
  .phone-col { display: flex; justify-content: center; }
  .phone { position: relative; width: min(300px, 80vw); background: #10192C; border-radius: 46px; padding: 11px;
    transform: rotate(3deg);
    box-shadow: 0 50px 90px -40px rgba(0,0,0,0.65), 0 18px 36px -20px rgba(0,0,0,0.5), inset 0 0 0 2px rgba(248,244,235,0.07);
    animation: phoneFloat 6s ease-in-out infinite; }
  @keyframes phoneFloat { 0%, 100% { transform: rotate(3deg) translateY(0); } 50% { transform: rotate(3deg) translateY(-11px); } }
  .phone-screen { position: relative; height: 580px; background: var(--paper); border-radius: 36px; overflow: hidden; display: flex; flex-direction: column; }
  .phone .island { position: absolute; top: 21px; left: 50%; transform: translateX(-50%); width: 80px; height: 22px; background: #10192C; border-radius: 999px; z-index: 12; }
  .chat-header { position: relative; z-index: 10; display: flex; flex-direction: column; align-items: center; gap: 0.3rem; padding: 3.1rem 0.9rem 0.55rem; background: rgba(251,248,241,0.94); border-bottom: 1px solid rgba(28,43,74,0.1); }
  .chat-header img { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; object-position: 50% 18%; }
  .chat-name { display: inline-flex; align-items: center; gap: 2px; font-size: 0.7rem; font-weight: 500; color: var(--navy); }
  .chat-name svg { opacity: 0.4; }
  .chat-stamp { text-align: center; font-size: 0.6rem; font-weight: 500; color: rgba(28,43,74,0.4); padding: 0.7rem 0 0.1rem; }
  .chat-body { flex: 1; display: flex; flex-direction: column; justify-content: flex-end; gap: 5px; padding: 0.4rem 0.7rem 0.6rem; overflow: hidden; transition: opacity .6s ease; }
  .chat-body.resetting { opacity: 0; }
  .msg { display: none; max-width: 80%; padding: 0.46rem 0.72rem; border-radius: 17px; font-size: 0.82rem; line-height: 1.32; opacity: 0; transform: translateY(12px) scale(0.92); }
  .msg.in { align-self: flex-start; background: #E9E7DF; color: #1a1a1a; border-bottom-left-radius: 5px; transform-origin: bottom left; }
  .msg.out { align-self: flex-end; background: #147EFB; color: #fff; border-bottom-right-radius: 5px; transform-origin: bottom right; }
  .msg.show { display: block; animation: msgPop .42s cubic-bezier(0.18, 0.89, 0.32, 1.18) forwards; }
  @keyframes msgPop { to { opacity: 1; transform: translateY(0) scale(1); } }
  .receipt { align-self: flex-end; font-size: 0.6rem; font-weight: 500; color: rgba(28,43,74,0.45); padding-right: 5px; margin-top: -1px; opacity: 0; transition: opacity .5s ease; }
  .receipt.show { opacity: 1; }
  .typing { align-self: flex-start; display: none; gap: 4px; align-items: center; background: #E9E7DF; border-radius: 17px; border-bottom-left-radius: 5px; padding: 0.55rem 0.7rem; }
  .typing.out-side { align-self: flex-end; background: #147EFB; border-bottom-left-radius: 17px; border-bottom-right-radius: 5px; }
  .typing.on { display: inline-flex; }
  .typing i { width: 6px; height: 6px; border-radius: 50%; background: rgba(28,43,74,0.35); animation: tDot 1.2s ease-in-out infinite; }
  .typing.out-side i { background: rgba(255,255,255,0.75); }
  .typing i:nth-child(2) { animation-delay: .15s; } .typing i:nth-child(3) { animation-delay: .3s; }
  @keyframes tDot { 0%, 60%, 100% { opacity: 0.35; transform: translateY(0); } 30% { opacity: 1; transform: translateY(-3px); } }
  .chat-inputbar { display: flex; align-items: center; margin: 0.3rem 0.7rem 0.85rem; padding: 0.38rem 0.8rem; border: 1px solid rgba(28,43,74,0.16); border-radius: 999px; font-size: 0.74rem; color: rgba(28,43,74,0.35); }
  /* ---------- 3: services (scroll-driven accordion + stage) ---------- */
  .svc-scroll { height: 320vh; }
  .svc-sticky { position: sticky; top: 0; min-height: 100vh; display: flex; flex-direction: column; justify-content: center; padding: 3.5rem 0; }
  .svc-layout { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: clamp(2rem, 4vw, 4rem); align-items: stretch; margin-top: 2.4rem; }
  .acc { display: flex; flex-direction: column; gap: 1rem; justify-content: center; }
  .acc-item { background: #fff; border: 1.5px solid var(--border); border-radius: 16px; padding: 1.4rem 1.7rem; cursor: pointer; transition: border-color .35s, box-shadow .35s; }
  .acc-item.active { border-color: rgba(199,164,77,0.65); box-shadow: 0 26px 50px -34px rgba(28,43,74,0.5); }
  .acc-item h3 { font-family: 'Hedvig Letters Serif', serif; font-weight: 400; font-size: 1.45rem; }
  .acc-body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .55s cubic-bezier(0.22,0.61,0.36,1); }
  .acc-item.active .acc-body { grid-template-rows: 1fr; }
  .acc-body-inner { overflow: hidden; }
  .acc-body p { margin-top: 0.85rem; font-size: 0.98rem; line-height: 1.6; color: var(--navy-soft); }
  .acc-img { display: none; }
  .learn { display: inline-flex; align-items: center; gap: 0.55rem; margin-top: 1rem; margin-bottom: 0.2rem; font-size: 0.8rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold-deep); text-decoration: none; }
  .learn svg { transition: transform .25s; }
  .learn:hover svg { transform: translateX(4px); }
  .svc-stage { position: relative; background: var(--cream-2); border: 1px solid var(--border); border-radius: 24px; min-height: 500px; }
  .svc-stage .frame { position: absolute; inset: clamp(1rem, 1.8vw, 1.5rem); border-radius: 16px; overflow: hidden; }
  .svc-stage .collage { position: absolute; inset: 0; display: grid; grid-template-columns: 1.45fr 1fr; grid-template-rows: 1fr 1fr; gap: 0.6rem; opacity: 0; transition: opacity .7s ease; }
  .svc-stage .collage.active { opacity: 1; }
  .svc-stage .collage img { width: 100%; height: 100%; object-fit: cover; border-radius: 10px; display: block; }
  .svc-stage .collage img.big { grid-row: 1 / 3; border-radius: 12px; }
  @media (max-width: 900px) {
    .svc-scroll { height: auto; }
    .svc-sticky { position: static; min-height: 0; }
    .svc-layout { grid-template-columns: 1fr; }
    .svc-stage { display: none; }
    .acc-item .acc-body { grid-template-rows: 1fr; }
    .acc-item { cursor: default; }
    .acc-img { display: block; margin-top: 1rem; border-radius: 12px; overflow: hidden; aspect-ratio: 16 / 10; }
    .acc-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
  }
  /* ---------- 5: process (blueprint timeline on navy) ---------- */
  .process { background: var(--navy); color: var(--cream); overflow: hidden; }
  .process .kicker { color: var(--gold-2); }
  .steps { position: relative; margin-top: 3.4rem; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
  .steps::before { content: ""; position: absolute; top: 27px; left: 0; width: 100%; height: 1.5px; background: rgba(248,244,235,0.14); }
  .steps .track-fill { position: absolute; top: 27px; left: 0; width: 100%; height: 1.5px; pointer-events: none;
    background: linear-gradient(90deg, var(--gold) 0%, var(--gold-2) 100%); box-shadow: 0 0 14px rgba(216,185,104,0.55);
    transform: scaleX(0); transform-origin: left; }
  .steps.go .track-fill { transition: transform 2.4s cubic-bezier(0.45, 0, 0.18, 1) .1s; transform: scaleX(1); }
  .step { position: relative; }
  .step .station { position: relative; z-index: 2; display: inline-flex; align-items: center; justify-content: center; width: 54px; height: 54px; border-radius: 50%; border: 1.5px solid rgba(216,185,104,0.6); background: var(--navy); opacity: 0; transform: scale(0.55); }
  .step .station svg { stroke: var(--gold-2); fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
  .steps.go .station { transition: opacity .45s ease, transform .55s cubic-bezier(0.34, 1.45, 0.5, 1); opacity: 1; transform: scale(1); }
  .step .step-body { opacity: 0; transform: translateY(16px); }
  .steps.go .step-body { transition: opacity .6s ease, transform .6s cubic-bezier(0.22, 0.61, 0.36, 1); opacity: 1; transform: translateY(0); }
  .steps.go .step:nth-of-type(1) .station { transition-delay: .15s; } .steps.go .step:nth-of-type(1) .step-body { transition-delay: .3s; }
  .steps.go .step:nth-of-type(2) .station { transition-delay: .7s; }  .steps.go .step:nth-of-type(2) .step-body { transition-delay: .85s; }
  .steps.go .step:nth-of-type(3) .station { transition-delay: 1.3s; } .steps.go .step:nth-of-type(3) .step-body { transition-delay: 1.45s; }
  .steps.go .step:nth-of-type(4) .station { transition-delay: 1.9s; } .steps.go .step:nth-of-type(4) .step-body { transition-delay: 2.05s; }
  .step .num { font-family: 'Hedvig Letters Serif', serif; font-size: 2.5rem; color: var(--gold-2); line-height: 1; margin-top: 1.2rem; }
  .step h3 { margin-top: 0.6rem; color: var(--cream); }
  .step .dur { display: inline-block; margin-top: 0.35rem; font-size: 0.78rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gold-2); }
  .step p { margin-top: 0.7rem; font-size: 0.94rem; line-height: 1.55; color: rgba(248,244,235,0.7); max-width: 30ch; }
  .step .seal-line { color: var(--gold-2); }
  @media (max-width: 1020px) { .steps { grid-template-columns: repeat(2, 1fr); row-gap: 2.6rem; } .steps::before, .steps .track-fill { display: none; } }
  @media (max-width: 560px) { .steps { grid-template-columns: 1fr; } }
  @media (prefers-reduced-motion: reduce) {
    .steps .track-fill { transform: scaleX(1); }
    .step .station { opacity: 1; transform: none; }
    .step .step-body { opacity: 1; transform: none; }
  }
  /* ---------- 6b: client portal ("your project, at your fingertips") ---------- */
  .portal { position: relative; overflow: hidden;
    background:
      radial-gradient(120% 80% at 88% 8%, rgba(199,164,77,0.10) 0%, transparent 55%),
      linear-gradient(170deg, var(--paper) 0%, var(--cream) 60%, var(--cream-2) 100%); }
  .portal-grid { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: clamp(2.5rem, 5vw, 5rem); align-items: center; }
  @media (max-width: 980px) { .portal-grid { grid-template-columns: 1fr; gap: 3rem; } }
  .portal h2 { max-width: 16ch; }
  .portal .lede { max-width: 46ch; }
  .portal-feats { margin-top: 2.6rem; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.8rem 1.4rem; max-width: 30rem; }
  @media (max-width: 560px) { .portal-feats { grid-template-columns: repeat(2, 1fr); } }
  .pf { opacity: 0; transform: translateY(14px); }
  .portal.inview .pf { opacity: 1; transform: translateY(0); transition: opacity .55s ease, transform .55s cubic-bezier(0.22,0.61,0.36,1); }
  .portal.inview .pf:nth-child(1){transition-delay:.05s}.portal.inview .pf:nth-child(2){transition-delay:.12s}.portal.inview .pf:nth-child(3){transition-delay:.19s}
  .portal.inview .pf:nth-child(4){transition-delay:.26s}.portal.inview .pf:nth-child(5){transition-delay:.33s}.portal.inview .pf:nth-child(6){transition-delay:.4s}
  .pf .pf-ic { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 11px; background: #fff; border: 1px solid var(--border); box-shadow: 0 8px 18px -12px rgba(28,43,74,0.45); }
  .pf .pf-ic svg { stroke: var(--gold-deep); fill: none; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
  .pf h4 { margin-top: 0.7rem; font-size: 0.96rem; font-weight: 700; color: var(--navy); }
  .pf span { display: block; margin-top: 0.15rem; font-size: 0.82rem; line-height: 1.4; color: var(--navy-soft); }
  /* device cluster */
  .portal-stage { position: relative; min-height: 600px; }
  @media (max-width: 980px) { .portal-stage { min-height: 0; display: flex; justify-content: center; } }
  .pdev { background: #10192C; border-radius: 40px; padding: 9px; box-shadow: 0 50px 90px -40px rgba(28,43,74,0.55), 0 18px 36px -20px rgba(28,43,74,0.3); }
  .pdev .pscreen { background: var(--paper); border-radius: 32px; overflow: hidden; }
  .portal.inview .p-phone { animation: pdevRise 1s cubic-bezier(0.22,0.61,0.36,1) both .15s; }
  .portal.inview .p-laptop { animation: pdevRise 1s cubic-bezier(0.22,0.61,0.36,1) both 0s; }
  @keyframes pdevRise { from { opacity: 0; transform: translateY(34px) rotate(var(--rot,0deg)); } to { opacity: 1; transform: translateY(0) rotate(var(--rot,0deg)); } }
  /* laptop behind, running the desktop app */
  .p-laptop { --rot: 2deg; position: absolute; top: 4px; right: -9%; width: 88%; transform: rotate(2deg); opacity: 0; }
  @media (max-width: 980px) { .p-laptop { display: none; } }
  .p-laptop .lid { background: #0c1424; border-radius: 13px; padding: 8px; box-shadow: 0 50px 90px -42px rgba(28,43,74,0.5), 0 16px 30px -18px rgba(28,43,74,0.3); }
  .p-laptop .pscreen { border-radius: 6px; }
  .p-laptop .base { position: relative; height: 10px; width: 114%; margin: 3px 0 0 -7%; border-radius: 2px 2px 9px 9px;
    background: linear-gradient(180deg, #e4e7ec 0%, #c2c8d2 55%, #a7aeba 100%);
    box-shadow: 0 16px 24px -12px rgba(28,43,74,0.4); }
  .p-laptop .base::before { content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 15%; height: 4px; background: rgba(28,43,74,0.18); border-radius: 0 0 6px 6px; }
  /* the application */
  .app { background: #fff; color: var(--navy); }
  .app-top { display: flex; align-items: center; gap: 12px; padding: 8px 12px; border-bottom: 1px solid var(--border); }
  .app-brand { display: inline-flex; align-items: center; }
  .app-brand img { height: 13px; width: auto; display: block; }
  .app-tabs { display: flex; gap: 13px; margin-left: 6px; font-size: 9.5px; color: var(--navy-soft); }
  .app-tabs span { position: relative; padding-bottom: 9px; margin-bottom: -9px; }
  .app-tabs span.on { color: var(--navy); font-weight: 600; }
  .app-tabs span.on::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 2px; background: var(--gold); border-radius: 2px; }
  .app-right { margin-left: auto; display: flex; align-items: center; gap: 8px; }
  .app-search { width: 92px; height: 18px; border-radius: 999px; background: rgba(28,43,74,0.05); border: 1px solid var(--border); display: flex; align-items: center; padding: 0 8px; gap: 5px; font-size: 8.5px; color: var(--navy-faint); }
  .app-search svg { stroke: var(--navy-faint); fill: none; stroke-width: 2; flex: none; }
  .app-av { width: 20px; height: 20px; border-radius: 50%; background: var(--navy); color: var(--cream); font-size: 8px; font-weight: 700; display: grid; place-items: center; flex: none; }
  .app-toolbar { display: flex; align-items: center; padding: 9px 12px 5px; }
  .app-toolbar h5 { font-size: 12px; font-weight: 700; }
  .app-toolbar .legend { margin-left: 14px; display: flex; gap: 11px; font-size: 8.5px; color: var(--navy-soft); }
  .app-toolbar .legend i { display: inline-block; width: 8px; height: 8px; border-radius: 2px; margin-right: 4px; vertical-align: -1px; }
  .app-month { margin-left: auto; display: flex; align-items: center; gap: 9px; font-size: 9.5px; font-weight: 600; color: var(--navy); }
  .app-month .arw { width: 16px; height: 16px; border-radius: 4px; border: 1px solid var(--border); display: grid; place-items: center; color: var(--navy-soft); }
  .app-month .arw svg { stroke: currentColor; fill: none; stroke-width: 2.4; }
  .app-seg { display: flex; border: 1px solid var(--border); border-radius: 6px; overflow: hidden; font-size: 8.5px; font-weight: 600; }
  .app-seg b { padding: 3px 8px; color: var(--navy-soft); }
  .app-seg b.on { background: var(--navy); color: var(--cream); }
  /* gantt */
  .gantt { padding: 6px 12px 16px; }
  .g-days { display: grid; grid-template-columns: repeat(7, 1fr); border-bottom: 1px solid var(--border); padding-bottom: 6px; }
  .g-days span { text-align: center; font-size: 8.5px; color: var(--navy-faint); }
  .g-days span b { display: block; font-size: 11px; color: var(--navy); font-weight: 600; }
  .g-days span.today b { color: var(--gold-deep); }
  .g-body { position: relative; margin-top: 14px;
    background-image: repeating-linear-gradient(90deg, transparent 0, transparent calc(14.2857% - 1px), rgba(28,43,74,0.07) calc(14.2857% - 1px), rgba(28,43,74,0.07) 14.2857%); }
  .g-today { position: absolute; top: -8px; bottom: 0; width: 0; border-left: 1.5px dashed var(--gold); z-index: 3; }
  .g-today::before { content: "Today"; position: absolute; top: -13px; left: 50%; transform: translateX(-50%); font-size: 7.5px; font-weight: 700; color: var(--gold-deep); white-space: nowrap; }
  .g-row { position: relative; height: 25px; }
  .g-bar { position: absolute; top: 3px; height: 19px; border-radius: 5px; display: flex; align-items: center; gap: 5px; padding: 0 6px; overflow: hidden; }
  .g-bar .g-fill { position: absolute; left: 0; top: 0; bottom: 0; border-radius: 5px 0 0 5px; }
  .g-bar .g-who { position: relative; z-index: 1; flex: none; width: 13px; height: 13px; border-radius: 50%; font-size: 7px; font-weight: 700; display: grid; place-items: center; }
  .g-bar .g-name { position: relative; z-index: 1; font-size: 8.5px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .g-bar .g-pct { position: relative; z-index: 1; margin-left: auto; font-size: 7.5px; font-weight: 700; opacity: 0.85; padding-left: 4px; }
  .g-bar.done { background: #22345A; color: #fff; }
  .g-bar.done .g-who { background: rgba(255,255,255,0.22); color: #fff; }
  .g-bar.active { background: rgba(199,164,77,0.18); color: var(--navy); border: 1px solid rgba(199,164,77,0.55); }
  .g-bar.active .g-fill { background: linear-gradient(90deg, var(--gold), var(--gold-2)); opacity: 0.4; }
  .g-bar.active .g-who { background: var(--gold-deep); color: #fff; }
  .g-bar.next { background: rgba(28,43,74,0.04); border: 1px dashed rgba(28,43,74,0.28); color: var(--navy-soft); }
  .g-bar.next .g-who { background: rgba(28,43,74,0.12); color: var(--navy-soft); }
  .g-mile { position: absolute; top: 6px; width: 12px; height: 12px; background: var(--gold); transform: rotate(45deg); border-radius: 3px; z-index: 2; box-shadow: 0 0 0 3px rgba(199,164,77,0.18); }
  .g-mile-label { position: absolute; top: 3px; font-size: 8px; font-weight: 700; color: var(--gold-deep); white-space: nowrap; }
  /* phone in front */
  .p-phone { --rot: -2deg; position: absolute; left: -1%; top: 58px; width: 260px; transform: rotate(-2deg); opacity: 0; z-index: 2; }
  @media (max-width: 980px) { .p-phone { position: static; transform: none; --rot: 0deg; opacity: 1; } }
  .p-phone .pscreen { height: 540px; display: flex; flex-direction: column; }
  .pp-bar { display: flex; align-items: center; justify-content: space-between; padding: 0.85rem 1rem 0.6rem; }
  .pp-bar .pp-h { display: flex; flex-direction: column; }
  .pp-bar .pp-h b { font-size: 0.82rem; color: var(--navy); }
  .pp-bar .pp-h span { font-size: 0.62rem; color: var(--navy-faint); }
  .pp-bar .pp-av { width: 26px; height: 26px; border-radius: 50%; background: var(--navy); color: var(--cream); font-size: 0.6rem; font-weight: 700; display: grid; place-items: center; }
  .pp-body { flex: 1; overflow: hidden; padding: 0 0.7rem; display: flex; flex-direction: column; gap: 0.6rem; }
  .pcard { background: #fff; border: 1px solid var(--border); border-radius: 14px; padding: 0.75rem 0.8rem; box-shadow: 0 12px 26px -22px rgba(28,43,74,0.5); }
  .pcard-h { display: flex; align-items: center; justify-content: space-between; }
  .pcard-h b { font-size: 0.72rem; color: var(--navy); }
  .pcard-h a { font-size: 0.6rem; font-weight: 600; color: var(--gold-deep); }
  .p-locked { display: inline-flex; align-items: center; gap: 4px; margin-top: 0.5rem; font-size: 0.58rem; font-weight: 700; letter-spacing: 0.03em; color: var(--gold-deep); background: rgba(199,164,77,0.14); border: 1px solid rgba(199,164,77,0.4); border-radius: 999px; padding: 0.18rem 0.5rem; }
  .p-track { margin-top: 0.55rem; height: 4px; border-radius: 999px; background: rgba(28,43,74,0.1); overflow: hidden; }
  .p-track i { display: block; height: 100%; width: 60%; border-radius: 999px; background: linear-gradient(90deg, var(--gold), var(--gold-2)); transform: scaleX(0); transform-origin: left; }
  .portal.inview .p-track i { transform: scaleX(1); transition: transform 1.4s cubic-bezier(0.45,0,0.18,1) .8s; }
  .p-miles { margin-top: 0.45rem; display: flex; justify-content: space-between; font-size: 0.56rem; color: var(--navy-faint); }
  .p-miles span.on { color: var(--navy); font-weight: 700; }
  .p-stats { margin-top: 0.6rem; display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.3rem; }
  .p-stats div { text-align: center; }
  .p-stats b { display: block; font-size: 0.72rem; color: var(--navy); }
  .p-stats span { font-size: 0.5rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--navy-faint); }
  .p-photos { display: grid; grid-template-columns: 1fr 1fr; gap: 5px; margin-top: 0.5rem; }
  .p-photos figure { position: relative; aspect-ratio: 4/3; border-radius: 8px; overflow: hidden; }
  .p-photos img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .p-photos figcaption { position: absolute; left: 4px; bottom: 3px; font-size: 0.48rem; color: #fff; text-shadow: 0 1px 3px rgba(0,0,0,0.6); }
  .p-sched { display: flex; flex-direction: column; gap: 0.4rem; margin-top: 0.5rem; }
  .p-row { display: flex; align-items: center; gap: 0.5rem; font-size: 0.66rem; color: var(--navy); }
  .p-row .dot { width: 13px; height: 13px; border-radius: 50%; border: 1.5px solid var(--gold); display: grid; place-items: center; flex: none; }
  .p-row.done .dot { background: var(--gold); }
  .p-row.done .dot svg { stroke: #fff; }
  .p-row .dot svg { width: 8px; height: 8px; stroke: var(--gold); fill: none; stroke-width: 3; }
  .p-row .when { margin-left: auto; font-size: 0.58rem; color: var(--navy-faint); }
  @media (prefers-reduced-motion: reduce) {
    .portal.inview .pf, .p-phone, .p-laptop { animation: none; opacity: 1; transform: none; }
    .p-phone { transform: rotate(-2deg); } .p-laptop { transform: rotate(2deg); }
    .portal.inview .p-track i { transition: none; transform: scaleX(1); }
  }
  /* ---------- 7: before/after ---------- */
  .ba-tabs { margin-top: 1.8rem; display: flex; flex-wrap: wrap; justify-content: center; gap: 0.6rem; }
  .ba-tab { appearance: none; font: inherit; font-size: 0.9rem; font-weight: 600; cursor: pointer; padding: 0.5rem 1.1rem; border-radius: 999px; border: 1px solid var(--border); background: #fff; color: var(--navy-soft); transition: background .2s, color .2s, border-color .2s; }
  .ba-tab:hover { border-color: var(--gold); color: var(--gold-deep); }
  .ba-tab.active { background: var(--navy); color: var(--cream); border-color: var(--navy); }
  .ba-wrap { margin-top: 1.4rem; display: grid; grid-template-columns: 1fr; gap: 1rem; }
  .ba { position: relative; width: 100%; max-width: 960px; margin: 0 auto; aspect-ratio: 16 / 9; border-radius: 20px; overflow: hidden; border: 1px solid var(--border); box-shadow: 0 40px 80px -44px rgba(28,43,74,0.5); user-select: none; touch-action: none; }
  .ba svg { position: absolute; inset: 0; width: 100%; height: 100%; }
  .ba .after-layer { position: absolute; inset: 0; clip-path: inset(0 0 0 50%); }
  .ba .divider { position: absolute; top: 0; bottom: 0; left: 50%; width: 2.5px; background: #fff; box-shadow: 0 0 12px rgba(28,43,74,0.4); }
  .ba .handle { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 46px; height: 46px; border-radius: 50%; background: #fff; border: 1.5px solid var(--border); box-shadow: 0 10px 24px -10px rgba(28,43,74,0.5); display: grid; place-items: center; cursor: ew-resize; }
  .ba .tag { position: absolute; top: 1rem; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; padding: 0.35rem 0.8rem; border-radius: 999px; }
  .ba .tag.before { left: 1rem; background: rgba(28,43,74,0.75); color: #fff; }
  .ba .tag.after { right: 1rem; background: rgba(199,164,77,0.9); color: var(--navy-3); }
  .ba-note { text-align: center; font-size: 0.85rem; color: var(--navy-faint); }
  /* inline mid-page CTA (after the work) */
  .inline-cta { margin-top: 3rem; display: flex; align-items: center; justify-content: center; gap: 1.4rem; flex-wrap: wrap; }
  .inline-cta .hint { font-size: 0.95rem; color: var(--navy-soft); }
  /* ---------- 8: owner ---------- */
  .owner { background: var(--cream-2); }
  .owner-grid { display: grid; grid-template-columns: 320px 1fr; gap: clamp(2rem, 4vw, 4rem); align-items: center; }
  @media (max-width: 860px) { .owner-grid { grid-template-columns: 1fr; } }
  .portrait { position: relative; width: 100%; max-width: 320px; aspect-ratio: 4 / 5; border-radius: 20px; background: linear-gradient(170deg, #22345A, var(--navy-3)); border: 1px solid var(--border); overflow: hidden; box-shadow: 0 30px 60px -40px rgba(28,43,74,0.5); }
  .portrait img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: top; }
  .owner-copy h2 em { font-style: italic; color: var(--gold-deep); }
  .owner-copy .sig { margin-top: 1.6rem; font-family: 'Hedvig Letters Serif', serif; font-style: italic; font-size: 1.15rem; color: var(--gold-deep); }
  /* ---------- 9: reviews (3-up Google-review cards) ---------- */
  .rev-grid { margin-top: 2.8rem; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; }
  @media (max-width: 940px) { .rev-grid { grid-template-columns: repeat(2, 1fr); } }
  @media (max-width: 620px) { .rev-grid { grid-template-columns: 1fr; } }
  .rev { aspect-ratio: 1 / 1; display: flex; flex-direction: column; background: #fff; border: 1px solid var(--border); border-radius: 18px; padding: 1.6rem 1.55rem; box-shadow: 0 24px 48px -34px rgba(28,43,74,0.4); }
  @media (max-width: 620px) { .rev { aspect-ratio: auto; } }
  .rev-top { display: flex; align-items: center; gap: 0.7rem; }
  .rev-av { flex: none; width: 40px; height: 40px; border-radius: 50%; background: linear-gradient(150deg, var(--navy-2), var(--navy)); color: var(--cream); font-size: 1rem; font-weight: 700; display: grid; place-items: center; }
  .rev-id { display: flex; flex-direction: column; line-height: 1.25; min-width: 0; }
  .rev-id b { font-size: 0.92rem; color: var(--navy); font-weight: 600; }
  .rev-id span { font-size: 0.78rem; color: var(--navy-faint); }
  .rev-g { margin-left: auto; flex: none; }
  .rev .stars { margin-top: 1rem; color: var(--gold); letter-spacing: 0.1em; font-size: 0.95rem; }
  .rev blockquote { margin-top: 0.7rem; font-size: 0.97rem; line-height: 1.58; color: var(--navy); overflow: hidden; display: -webkit-box; -webkit-line-clamp: 6; -webkit-box-orient: vertical; }
  .rev .who { margin-top: auto; padding-top: 1rem; display: flex; align-items: center; justify-content: space-between; gap: 0.8rem; font-size: 0.82rem; color: var(--navy-soft); border-top: 1px solid var(--border); }
  .rev .who .loc { display: inline-flex; align-items: center; gap: 0.35rem; }
  .rev .who .loc svg { stroke: var(--navy-faint); fill: none; stroke-width: 1.8; flex: none; }
  .rev .who a { display: inline-flex; align-items: center; gap: 0.3rem; color: var(--gold-deep); font-weight: 600; text-decoration: none; white-space: nowrap; }
  .rev .who a:hover { text-decoration: underline; }
  /* ---------- 11: FAQ ---------- */
  .faq { background: var(--cream-2); }
  .faq-list { margin-top: 2.4rem; max-width: 820px; display: flex; flex-direction: column; gap: 0.8rem; }
  details { background: #fff; border: 1px solid var(--border); border-radius: 14px; overflow: hidden; }
  summary { list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.2rem 1.4rem; font-weight: 600; font-size: 1rem; }
  summary::-webkit-details-marker { display: none; }
  summary .plus { flex: 0 0 auto; width: 24px; height: 24px; border-radius: 50%; border: 1.5px solid var(--border); display: grid; place-items: center; font-weight: 500; color: var(--gold-deep); transition: transform .25s; }
  details[open] summary .plus { transform: rotate(45deg); }
  details .a { padding: 0 1.4rem 1.3rem; font-size: 0.96rem; line-height: 1.6; color: var(--navy-soft); max-width: 64ch; }
  /* ---------- 12: final CTA + footer ---------- */
  /* light closing section; the navy form card is the page's last dark object before the footer.
     deepening cream + a low gold glow = dusk light before the dark footer */
  /* gold button: opposite of the navy button — navy gradient cross-fades in from the left on hover */
  .foot-links span { color: rgba(248,244,235,0.75); }
  @media (prefers-reduced-motion: reduce) {
    .rise { animation: none; opacity: 1; transform: none; }
    .reveal { transition: none; }
    .horizon-sweep, .cursor { display: none; }
    .cue-chevrons path { animation: none; opacity: 0.6; }
    .never.draw .never-swoosh path { transition: none; }
    .phone { animation: none; }
    .msg { display: block; opacity: 1; transform: none; animation: none; }
    .receipt { opacity: 1; }
    .typing { display: none !important; }
  }