
  :root{
    --burgundy:#722334;
    --burgundy-deep:#5a1a28;
    --burgundy-glow:rgba(114,35,52,.18);
    --cream:#F1EADB;
    --cream-2:#E8DFCB;
    --cream-3:#DCD2BC;
    --stone:#8C8579;
    --stone-2:#B6AFA0;
    --ink:#1F1A1A;
    --ink-soft:#3a3030;
    --brass:#B8975A;
    --line:rgba(31,26,26,.16);
    --line-soft:rgba(31,26,26,.08);
    --serif:"Crimson Pro", Georgia, serif;
    --sans:"Work Sans","Helvetica Neue",Arial,sans-serif;
    --mono:"Work Sans","Helvetica Neue",Arial,sans-serif;
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    background:var(--cream);
    color:var(--ink);
    font-family:var(--sans);
    font-size:15px;
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}

  /* ---------- Top bar ---------- */
  .topbar{
    position:fixed;top:0;left:0;right:0;z-index:80;
    display:flex;align-items:center;justify-content:space-between;
    padding:18px 40px;
    background:rgba(241,234,219,.78);
    backdrop-filter:saturate(140%) blur(14px);
    -webkit-backdrop-filter:saturate(140%) blur(14px);
    border-bottom:1px solid transparent;
    transition:border-color .25s ease, padding .25s ease, background .25s ease;
  }
  .topbar.scrolled{
    border-bottom-color:var(--line);
    padding:12px 40px;
    background:rgba(241,234,219,.92);
  }
  .topbar .lockup{display:flex;align-items:center;gap:14px}
  .topbar .disc{
    width:34px;height:34px;border-radius:50%;
    background:var(--burgundy);color:var(--cream);
    font-family:var(--serif);font-weight:700;font-size:15px;
    display:flex;align-items:center;justify-content:center;
    letter-spacing:-.02em;
  }
  .topbar .name{
    font-family:var(--serif);font-weight:700;font-size:18px;
    letter-spacing:-.005em;line-height:1;
  }
  .topbar .name span{
    display:block;font-family:var(--mono);font-size:8.5px;
    letter-spacing:.18em;text-transform:uppercase;color:var(--stone);
    font-weight:400;margin-top:3px;
  }
  .topbar nav{display:flex;align-items:center;gap:32px}
  .topbar nav a{
    font-family:var(--sans);font-weight:700;font-size:11px;
    letter-spacing:.16em;text-transform:uppercase;
    color:var(--ink);position:relative;transition:color .2s;
  }
  .topbar nav a::after{
    content:"";position:absolute;left:0;right:0;bottom:-6px;
    height:1px;background:var(--burgundy);
    transform:scaleX(0);transform-origin:left;
    transition:transform .35s cubic-bezier(.6,.2,.2,1);
  }
  .topbar nav a:hover::after{transform:scaleX(1)}
  .topbar nav a:hover{color:var(--burgundy)}
  .topbar .cta{
    background:var(--burgundy);color:var(--cream);
    padding:10px 18px;font-family:var(--sans);font-weight:700;
    font-size:11px;letter-spacing:.14em;text-transform:uppercase;
    transition:background .2s, transform .2s;
  }
  .topbar .cta:hover{background:var(--burgundy-deep);transform:translateY(-1px)}
  .topbar .menu-btn{display:none;background:none;border:0;cursor:pointer;color:var(--ink);font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
  @media (max-width:880px){
    .topbar nav{display:none}
    .topbar .menu-btn{display:inline-block}
    .topbar{padding:14px 22px}
    .topbar.scrolled{padding:10px 22px}
  }

  /* ---------- Hero ---------- */
  .hero{padding:160px 56px 80px;position:relative;overflow:hidden}
  .hero .grid-bg{
    position:absolute;inset:0;pointer-events:none;
    background-image:
      linear-gradient(var(--line-soft) 1px, transparent 1px),
      linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
    background-size:80px 80px;
    mask-image:radial-gradient(ellipse at 50% 30%, black 30%, transparent 75%);
    -webkit-mask-image:radial-gradient(ellipse at 50% 30%, black 30%, transparent 75%);
    opacity:.7;
  }
  .hero .eyebrow{
    font-family:var(--mono);font-size:11px;
    letter-spacing:.16em;text-transform:uppercase;color:var(--stone);
    display:flex;align-items:center;gap:14px;margin-bottom:42px;position:relative;
  }
  .hero .eyebrow .bar{display:inline-block;width:28px;height:1px;background:var(--ink)}
  .hero .eyebrow .flag{display:inline-flex;align-items:center;gap:6px;color:var(--burgundy);font-weight:500}
  .hero .eyebrow .flag svg{width:14px;height:10px}
  .hero h1{
    font-family:var(--serif);font-weight:700;
    font-size:clamp(56px, 10vw, 168px);
    line-height:.92;letter-spacing:-.025em;margin:0;color:var(--ink);position:relative;
  }
  .hero h1 .word{display:inline-block;overflow:hidden;vertical-align:top}
  .hero h1 .word span{display:inline-block;transform:translateY(110%);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
  .hero h1 .word:nth-child(1) span{animation-delay:.1s}
  .hero h1 .word:nth-child(2) span{animation-delay:.18s}
  .hero h1 .word:nth-child(3) span{animation-delay:.26s}
  .hero h1 .word:nth-child(4) span{animation-delay:.34s}
  .hero h1 .word:nth-child(5) span{animation-delay:.42s}
  .hero h1 .word:nth-child(6) span{animation-delay:.5s}
  .hero h1 .accent{color:var(--burgundy);text-transform:uppercase;font-weight:700}
  @keyframes rise{0%{transform:translateY(110%)}100%{transform:translateY(0)}}
  .hero .lede{
    display:grid;grid-template-columns:1fr 1fr;gap:64px;margin-top:64px;align-items:end;
    opacity:0;transform:translateY(16px);
    animation:fadeUp .9s cubic-bezier(.2,.7,.2,1) forwards;animation-delay:.7s;position:relative;
  }
  @keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
  .hero .lede p{
    font-family:var(--serif);font-size:23px;line-height:1.4;
    color:var(--ink);max-width:34ch;margin:0;
  }
  .hero .meta{
    font-family:var(--mono);font-size:11px;letter-spacing:.08em;
    text-transform:uppercase;color:var(--stone);
    display:flex;flex-direction:column;gap:8px;text-align:right;
  }
  .hero .meta b{color:var(--ink);font-weight:500}
  .hero .actions{
    display:flex;gap:18px;margin-top:56px;flex-wrap:wrap;
    opacity:0;animation:fadeUp .9s cubic-bezier(.2,.7,.2,1) forwards;
    animation-delay:.85s;position:relative;
  }
  .btn-primary{
    background:var(--burgundy);color:var(--cream);
    padding:16px 28px;font-family:var(--sans);font-weight:700;
    font-size:12px;letter-spacing:.18em;text-transform:uppercase;
    display:inline-flex;align-items:center;gap:14px;
    transition:background .25s, transform .25s, gap .25s;
    position:relative;overflow:hidden;
  }
  .btn-primary::after{
    content:"";position:absolute;inset:0;
    background:linear-gradient(120deg, transparent 30%, rgba(241,234,219,.18) 50%, transparent 70%);
    transform:translateX(-100%);transition:transform .6s;
  }
  .btn-primary:hover::after{transform:translateX(100%)}
  .btn-primary:hover{background:var(--burgundy-deep);gap:20px}
  .btn-primary .arrow{font-family:var(--mono);font-weight:500}
  .btn-ghost{
    border:1px solid var(--ink);color:var(--ink);
    padding:16px 28px;font-family:var(--sans);font-weight:700;
    font-size:12px;letter-spacing:.18em;text-transform:uppercase;
    display:inline-flex;align-items:center;gap:14px;
    transition:background .25s, color .25s, gap .25s;
  }
  .btn-ghost:hover{background:var(--ink);color:var(--cream);gap:20px}
  .hero .scroll-cue{
    position:absolute;bottom:24px;right:56px;
    font-family:var(--mono);font-size:10px;letter-spacing:.18em;
    text-transform:uppercase;color:var(--stone);
    display:flex;align-items:center;gap:10px;
  }
  .hero .scroll-cue .line{
    width:1px;height:48px;background:var(--stone);position:relative;overflow:hidden;
  }
  .hero .scroll-cue .line::after{
    content:"";position:absolute;top:-48px;left:0;width:1px;height:48px;
    background:var(--burgundy);animation:cue 2.2s ease-in-out infinite;
  }
  @keyframes cue{0%{top:-48px}50%{top:48px}100%{top:48px}}

  /* ---------- Marquee ---------- */
  .marquee{
    border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
    overflow:hidden;background:var(--cream);position:relative;
  }
  .marquee .track{
    display:flex;gap:64px;padding:18px 0;
    animation:slide 22s linear infinite;white-space:nowrap;
    will-change:transform;
  }
  .marquee:hover .track{animation-play-state:paused}
  .marquee .track span{
    font-family:var(--mono);font-size:11px;letter-spacing:.18em;
    text-transform:uppercase;color:var(--ink);
    display:inline-flex;align-items:center;gap:18px;
  }
  .marquee .track span .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--burgundy)}
  .marquee .track span .brass{color:var(--brass);font-weight:500}
  @keyframes slide{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
  @media (prefers-reduced-motion: reduce){
    .marquee .track{animation-duration:60s}
  }

  /* ---------- Sections ---------- */
  section.sec{padding:120px 56px;border-bottom:1px solid var(--line);position:relative}
  .frame{max-width:1320px;margin:0 auto}
  .sec-head{display:grid;grid-template-columns:220px 1fr;gap:56px;margin-bottom:64px;align-items:start}
  .sec-no{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone)}
  .sec-no .marker{color:var(--burgundy);display:block;margin-bottom:8px}
  .sec-title{font-family:var(--serif);font-weight:700;font-size:clamp(36px,5vw,64px);line-height:1;letter-spacing:-.015em;margin:0 0 18px}
  .sec-title .accent{color:var(--burgundy);text-transform:uppercase}
  .sec-deck{font-family:var(--serif);font-size:21px;line-height:1.4;max-width:46ch;margin:0;font-weight:400;color:var(--ink-soft)}
  @media (max-width:880px){
    .sec-head{grid-template-columns:1fr;gap:18px}
    section.sec{padding:80px 22px}
    .hero{padding:130px 22px 60px}
  }

  /* Reveal */
  .reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:translateY(0)}
  .reveal.d1{transition-delay:.08s}
  .reveal.d2{transition-delay:.16s}
  .reveal.d3{transition-delay:.24s}
  .reveal.d4{transition-delay:.32s}
  .reveal.d5{transition-delay:.40s}

  /* ---------- Materials ---------- */
  .materials{display:grid;grid-template-columns:repeat(12,1fr);gap:0;border-top:1px solid var(--ink)}
  .mat{
    grid-column:span 4;padding:36px 32px 40px;
    border-right:1px solid var(--line);border-bottom:1px solid var(--ink);
    position:relative;overflow:hidden;cursor:pointer;transition:background .4s ease;
  }
  .mat:nth-child(3n){border-right:none}
  .mat:hover{background:var(--cream-2)}
  .mat .num{
    font-family:var(--mono);font-size:11px;letter-spacing:.14em;
    text-transform:uppercase;color:var(--stone);
    display:flex;justify-content:space-between;align-items:center;margin-bottom:64px;
  }
  .mat .num .arrow{color:var(--burgundy);transition:transform .35s cubic-bezier(.6,.2,.2,1);display:inline-block}
  .mat:hover .num .arrow{transform:translate(4px,-4px)}
  .mat h3{font-family:var(--serif);font-weight:700;font-size:42px;line-height:1;letter-spacing:-.01em;margin:0 0 18px;transition:color .3s}
  .mat:hover h3{color:var(--burgundy)}
  .mat p{font-family:var(--serif);font-size:17px;line-height:1.45;color:var(--ink);max-width:32ch;margin:0 0 28px}
  .mat .tex{
    height:180px;width:100%;background:var(--cream-2);margin-top:20px;
    position:relative;overflow:hidden;border:1px solid var(--line);
    box-shadow:inset 0 0 0 0 rgba(31,26,26,0);
    transition:box-shadow .35s;
  }
  .mat:hover .tex{box-shadow:inset 0 0 0 2px rgba(31,26,26,.1)}
  .mat .tex svg{position:absolute;inset:0;width:100%;height:100%;display:block}
  .mat .tex::after{
    content:"";position:absolute;inset:0;
    background:linear-gradient(105deg, transparent 40%, rgba(255,255,255,.22) 50%, transparent 60%);
    transform:translateX(-100%);transition:transform .9s cubic-bezier(.4,.2,.2,1);
  }
  .mat:hover .tex::after{transform:translateX(100%)}
  @media (max-width:980px){
    .mat{grid-column:span 6}
    .mat:nth-child(3n){border-right:1px solid var(--line)}
    .mat:nth-child(2n){border-right:none}
  }
  @media (max-width:640px){.mat{grid-column:span 12;border-right:none!important}}

  /* ---------- Stats ---------- */
  .stats-band{background:var(--ink);color:var(--cream);padding:96px 56px;border-bottom:1px solid var(--ink);position:relative;overflow:hidden}
  .stats-band::before{
    content:"";position:absolute;inset:0;
    background:
      repeating-linear-gradient(0deg, transparent 0 80px, rgba(241,234,219,.04) 80px 81px),
      repeating-linear-gradient(90deg, transparent 0 80px, rgba(241,234,219,.04) 80px 81px);
    pointer-events:none;
  }
  .stats-band .frame{position:relative}
  .stats-band .label{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone-2);margin-bottom:48px;display:flex;gap:14px;align-items:center}
  .stats-band .label .bar{display:inline-block;width:28px;height:1px;background:var(--stone-2)}
  .stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid rgba(241,234,219,.18)}
  .stat{padding:48px 32px 40px;border-right:1px solid rgba(241,234,219,.18);border-bottom:1px solid rgba(241,234,219,.18)}
  .stat:last-child{border-right:none}
  .stat .num{font-family:var(--serif);font-weight:700;font-size:clamp(64px, 7vw, 104px);line-height:.95;letter-spacing:-.025em;color:var(--cream)}
  .stat .num .unit{color:var(--brass);font-size:.45em;font-weight:500;vertical-align:top;margin-left:6px}
  .stat .cap{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone-2);margin-top:18px}
  @media (max-width:980px){.stats-grid{grid-template-columns:1fr 1fr}.stat:nth-child(2){border-right:none}}
  @media (max-width:640px){.stats-grid{grid-template-columns:1fr}.stat{border-right:none}}

  /* ---------- Why ---------- */
  .why{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
  .why .left{position:sticky;top:120px}
  .why .left .pull{font-family:var(--serif);font-weight:700;font-size:clamp(36px,4.4vw,56px);line-height:1.02;letter-spacing:-.015em;margin:0 0 28px}
  .why .left .pull .accent{color:var(--burgundy);text-transform:uppercase}
  .why .left .desc{font-family:var(--serif);font-size:19px;line-height:1.5;color:var(--ink);max-width:42ch;margin:0 0 32px}
  .why .pillars{display:flex;flex-direction:column;border-top:1px solid var(--ink)}
  .pillar{
    padding:28px 0;border-bottom:1px solid var(--line);
    display:grid;grid-template-columns:60px 1fr;gap:24px;align-items:start;
    transition:padding .4s, background .4s;cursor:pointer;
  }
  .pillar:hover{padding-left:14px;background:linear-gradient(90deg, rgba(114,35,52,.04), transparent 80%)}
  .pillar .ord{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--burgundy);padding-top:6px}
  .pillar h4{font-family:var(--serif);font-weight:700;font-size:24px;line-height:1.2;margin:0 0 8px;letter-spacing:-.005em}
  .pillar p{font-family:var(--serif);font-size:17px;line-height:1.45;color:var(--ink-soft);margin:0;max-width:42ch}
  @media (max-width:880px){.why{grid-template-columns:1fr;gap:48px}.why .left{position:static}}

  /* ---------- Process ---------- */
  .process{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--ink)}
  .step{padding:40px 28px 44px;border-right:1px solid var(--line);border-bottom:1px solid var(--ink);position:relative;transition:background .35s}
  .step:last-child{border-right:none}
  .step:hover{background:var(--cream-2)}
  .step .ord{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);margin-bottom:48px}
  .step .ord b{color:var(--burgundy);font-weight:500}
  .step h4{font-family:var(--serif);font-weight:700;font-size:28px;line-height:1.05;letter-spacing:-.005em;margin:0 0 14px}
  .step p{font-family:var(--serif);font-size:16px;line-height:1.45;color:var(--ink-soft);margin:0;max-width:28ch}
  @media (max-width:880px){.process{grid-template-columns:1fr 1fr}.step:nth-child(2){border-right:none}}
  @media (max-width:560px){.process{grid-template-columns:1fr}.step{border-right:none}}

  /* ---------- Reviews ---------- */
  .quotes{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
  .quote{
    grid-column:span 6;border:1px solid var(--line);padding:36px 32px 28px;
    background:var(--cream);position:relative;
    transition:transform .35s, border-color .35s, box-shadow .35s;
  }
  .quote:hover{transform:translateY(-4px);border-color:var(--burgundy);box-shadow:0 24px 40px -28px rgba(31,26,26,.25)}
  .quote .mark{font-family:var(--serif);font-weight:700;font-size:64px;line-height:.5;color:var(--burgundy);position:absolute;top:36px;left:32px}
  .quote p{font-family:var(--serif);font-size:18px;line-height:1.5;color:var(--ink);margin:36px 0 24px;padding-left:48px}
  .quote .who{
    border-top:1px solid var(--line);padding-top:16px;
    display:flex;justify-content:space-between;align-items:center;
    font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);
  }
  .quote .who b{color:var(--ink);font-family:var(--serif);font-size:14px;letter-spacing:0;text-transform:none;font-weight:700}

  .quote .photo-btn{
    display:inline-flex;align-items:center;gap:10px;
    margin:0 0 22px 48px;padding:9px 14px;
    background:transparent;border:1px solid var(--line);
    color:var(--ink);cursor:pointer;
    font-family:var(--mono);font-size:10px;font-weight:700;
    letter-spacing:.16em;text-transform:uppercase;
    transition:background .2s, color .2s, border-color .2s;
  }
  .quote .photo-btn svg{width:14px;height:14px;flex-shrink:0}
  .quote .photo-btn:hover{
    background:var(--burgundy);color:var(--cream);border-color:var(--burgundy);
  }
  @media (max-width:880px){.quote{grid-column:span 12}}

  /* ---------- Lightbox ---------- */
  .lightbox{
    position:fixed;inset:0;z-index:100;
    background:rgba(31,26,26,.92);
    display:flex;align-items:center;justify-content:center;
    padding:64px 80px;
    opacity:0;visibility:hidden;
    transition:opacity .35s ease, visibility .35s ease;
  }
  .lightbox.is-open{opacity:1;visibility:visible}
  .lightbox-stage{
    max-width:100%;max-height:100%;
    display:flex;align-items:center;justify-content:center;
    transform:translateY(12px);
    transition:transform .45s cubic-bezier(.2,.7,.2,1);
  }
  .lightbox.is-open .lightbox-stage{transform:translateY(0)}
  .lightbox-stage img{
    max-width:100%;max-height:80vh;
    object-fit:contain;
    border:1px solid rgba(241,234,219,.15);
    background:var(--cream);
  }
  .lightbox-close{
    position:absolute;top:22px;right:26px;
    width:44px;height:44px;border:0;background:none;cursor:pointer;
    display:flex;align-items:center;justify-content:center;color:var(--cream);
    transition:color .2s;
  }
  .lightbox-close span{
    position:absolute;width:26px;height:1.5px;background:var(--cream);
    transition:background .2s;
  }
  .lightbox-close span:first-child{transform:rotate(45deg)}
  .lightbox-close span:last-child{transform:rotate(-45deg)}
  .lightbox-close:hover span{background:var(--brass)}

  .lightbox-nav{
    position:absolute;top:50%;transform:translateY(-50%);
    width:52px;height:52px;border:1px solid rgba(241,234,219,.35);
    background:transparent;color:var(--cream);cursor:pointer;
    font-size:20px;font-family:var(--serif);
    display:flex;align-items:center;justify-content:center;
    transition:background .2s, border-color .2s, color .2s;
  }
  .lightbox-nav.prev{left:24px}
  .lightbox-nav.next{right:24px}
  .lightbox-nav:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}

  .lightbox-meta{
    position:absolute;bottom:24px;left:0;right:0;
    display:flex;justify-content:center;align-items:center;gap:18px;
    font-family:var(--mono);font-size:10px;letter-spacing:.18em;
    text-transform:uppercase;color:var(--cream);
  }
  .lightbox-counter{color:var(--brass);font-weight:700}
  .lightbox-credit{opacity:.65}

  @media (max-width:680px){
    .lightbox{padding:60px 14px}
    .lightbox-nav{width:42px;height:42px}
    .lightbox-nav.prev{left:8px}
    .lightbox-nav.next{right:8px}
    .lightbox-stage img{max-height:70vh}
  }

  /* ---------- Repair ---------- */
  .repair{background:var(--burgundy);color:var(--cream);border-bottom:1px solid var(--burgundy-deep);position:relative;overflow:hidden}
  .repair::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 30%, rgba(241,234,219,.06), transparent 50%);pointer-events:none}
  .repair .sec-no{color:rgba(241,234,219,.6)}
  .repair .sec-no .marker{color:var(--brass)}
  .repair .sec-title{color:var(--cream)}
  .repair .sec-title .accent{color:var(--brass)}
  .repair .sec-deck{color:rgba(241,234,219,.85)}
  .repair .sec-head{margin-bottom:48px}
  .repair .row{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end}
  .repair .pitch{font-family:var(--serif);font-size:21px;line-height:1.5;color:var(--cream);margin:0;max-width:42ch}
  .repair .actions{display:flex;gap:18px;flex-wrap:wrap;justify-content:flex-end}
  .repair .btn-primary{background:var(--cream);color:var(--burgundy)}
  .repair .btn-primary:hover{background:#fff}
  .repair .btn-ghost{border-color:var(--cream);color:var(--cream)}
  .repair .btn-ghost:hover{background:var(--cream);color:var(--burgundy)}
  @media (max-width:880px){.repair .row{grid-template-columns:1fr;gap:32px}.repair .actions{justify-content:flex-start}}

  /* ---------- Service area (constellation) ---------- */
  .constellation-wrap{
    margin-top:8px;
  }
  .constellation{
    position:relative;
    aspect-ratio:8/6;
    background:
      radial-gradient(circle at 50% 50%, var(--cream) 0%, var(--cream-2) 100%);
    border:1px solid var(--ink);
    overflow:hidden;
  }
  .constellation .lines{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
  .constellation .ring{fill:none;stroke:rgba(31,26,26,.18);stroke-width:1;stroke-dasharray:2 6}
  .constellation .ring-label{
    font-family:var(--sans);font-weight:600;font-size:9px;
    letter-spacing:.18em;fill:var(--stone);text-transform:uppercase;
  }
  .constellation .connector{stroke:rgba(31,26,26,.14);stroke-width:1;stroke-dasharray:1 3;fill:none}
  .constellation .compass{
    font-family:var(--serif);font-weight:700;font-size:18px;letter-spacing:.08em;
    fill:var(--stone);text-anchor:middle;dominant-baseline:middle;
  }
  .constellation .city-dot{fill:var(--burgundy);transition:r .35s cubic-bezier(.2,.7,.2,1)}
  .constellation .city{
    position:absolute;transform:translate(-50%,-50%);
    display:flex;flex-direction:column;gap:2px;align-items:center;
    padding:6px 10px;background:var(--cream);
    transition:transform .35s cubic-bezier(.2,.7,.2,1), color .25s;
    cursor:pointer;white-space:nowrap;
  }
  .constellation .city .name{
    font-family:var(--serif);font-weight:700;font-size:19px;
    line-height:1;letter-spacing:-.01em;color:var(--ink);
  }
  .constellation .city .tag{
    font-family:var(--sans);font-weight:600;font-size:9px;
    letter-spacing:.14em;text-transform:uppercase;color:var(--stone);
  }
  .constellation .city:hover{transform:translate(-50%,calc(-50% - 6px))}
  .constellation .city:hover .name{color:var(--burgundy)}

  .constellation .akron{
    background:var(--burgundy);
    color:var(--cream);
    padding:18px 26px;
    box-shadow:0 30px 50px -28px rgba(31,26,26,.55);
  }
  .constellation .akron .name{font-size:40px;color:var(--cream);line-height:.9;letter-spacing:-.02em}
  .constellation .akron .tag{color:rgba(241,234,219,.75);margin-top:6px}
  .constellation .akron:hover{transform:translate(-50%,-50%)}
  .constellation .akron:hover .name{color:var(--cream)}

  .constellation .center-pulse{
    fill:none;stroke:var(--burgundy);stroke-width:1.5;opacity:.5;
    animation:pulseRing 3.5s ease-out infinite;
  }
  @keyframes pulseRing{
    0%{r:14;opacity:.6}
    100%{r:120;opacity:0}
  }

  .area-meta{
    margin-top:48px;
    display:grid;grid-template-columns:repeat(3,1fr) auto;gap:48px;
    align-items:center;border-top:1px solid var(--line);padding-top:36px;
  }
  .area-meta .stat-line .v{
    font-family:var(--serif);font-weight:700;font-size:36px;line-height:1;letter-spacing:-.02em;
  }
  .area-meta .stat-line .v .accent{color:var(--burgundy)}
  .area-meta .stat-line .l{
    font-family:var(--sans);font-weight:600;font-size:10px;letter-spacing:.14em;
    text-transform:uppercase;color:var(--stone);margin-top:10px;
  }
  .area-meta .ask{
    font-family:var(--serif);font-size:18px;line-height:1.45;
    color:var(--ink-soft);max-width:34ch;
  }
  .area-meta .ask a{color:var(--burgundy);font-weight:500}

  @media (max-width:980px){
    .constellation{aspect-ratio:1/1}
    .constellation .city .name{font-size:15px}
    .constellation .akron .name{font-size:30px}
    .area-meta{grid-template-columns:1fr 1fr;gap:28px}
  }
  @media (max-width:640px){
    .constellation{aspect-ratio:4/5}
    .constellation .city{padding:3px 6px}
    .constellation .city .name{font-size:13px}
    .constellation .city .tag{font-size:8px;letter-spacing:.1em}
    .constellation .akron{padding:12px 18px}
    .constellation .akron .name{font-size:22px}
    .area-meta{grid-template-columns:1fr}
  }

  /* ---------- CTA ---------- */
  .cta-band{padding:140px 56px;text-align:left;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
  .cta-band h2{font-family:var(--serif);font-weight:700;font-size:clamp(48px,8vw,128px);line-height:.95;letter-spacing:-.025em;margin:0 0 32px;max-width:14ch}
  .cta-band h2 .accent{color:var(--burgundy);text-transform:uppercase}
  .cta-band p{font-family:var(--serif);font-size:22px;line-height:1.4;margin:0 0 40px;max-width:36ch;color:var(--ink-soft)}
  .cta-band .actions{display:flex;gap:18px;flex-wrap:wrap}

  /* ---------- Footer ---------- */
  footer{background:var(--ink);color:var(--cream);padding:80px 56px 36px}
  footer .frame{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px}
  footer h5{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--stone-2);margin:0 0 22px;font-weight:400}
  footer .brand .lockup{display:flex;align-items:center;gap:14px;margin-bottom:18px}
  footer .brand .disc{
    width:42px;height:42px;border-radius:50%;background:var(--cream);color:var(--burgundy);
    font-family:var(--serif);font-weight:700;font-size:18px;
    display:flex;align-items:center;justify-content:center;
  }
  footer .brand .name{font-family:var(--serif);font-weight:700;font-size:22px;line-height:1}
  footer .brand .name span{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone-2);font-weight:400;margin-top:4px}
  footer .brand p{font-family:var(--serif);font-size:17px;line-height:1.45;color:rgba(241,234,219,.75);margin:0;max-width:34ch}
  footer ul{list-style:none;padding:0;margin:0}
  footer li{padding:8px 0}
  footer li a{font-family:var(--sans);font-size:14px;color:rgba(241,234,219,.78);transition:color .2s}
  footer li a:hover{color:var(--cream)}
  footer .contact .line{font-family:var(--serif);font-size:17px;line-height:1.5;color:rgba(241,234,219,.85);margin-bottom:10px}
  footer .contact .line b{color:var(--cream);font-weight:700}
  footer .contact .phone{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--cream);display:block;margin:14px 0 6px}
  footer .bottom{
    margin-top:64px;padding-top:24px;border-top:1px solid rgba(241,234,219,.18);
    display:flex;justify-content:space-between;align-items:center;
    font-family:var(--mono);font-size:10px;letter-spacing:.14em;
    text-transform:uppercase;color:var(--stone-2);flex-wrap:wrap;gap:18px;
  }
  footer .bottom .flag{display:inline-flex;align-items:center;gap:8px;color:var(--cream)}
  footer .bottom .flag svg{width:16px;height:11px}
  @media (max-width:880px){
    footer .frame{grid-template-columns:1fr 1fr;gap:32px}
    footer{padding:60px 22px 30px}
  }
  @media (max-width:560px){footer .frame{grid-template-columns:1fr}}

  /* ---------- Sticky Call CTA ---------- */
  .phone-cta{
    position:fixed;bottom:24px;right:24px;z-index:70;
    background:var(--burgundy);color:var(--cream);
    border-radius:14px;padding:14px 22px;
    display:inline-flex;align-items:center;gap:14px;
    box-shadow:0 22px 36px -22px rgba(31,26,26,.55), 0 4px 14px -8px rgba(31,26,26,.25);
    transform:translateY(140%);opacity:0;
    transition:transform .55s cubic-bezier(.2,.7,.2,1), opacity .55s, background .25s, box-shadow .25s;
    text-decoration:none;
  }
  .phone-cta.in{transform:translateY(0);opacity:1}
  .phone-cta:hover{background:var(--burgundy-deep);box-shadow:0 26px 42px -22px rgba(31,26,26,.65), 0 6px 18px -8px rgba(31,26,26,.35)}
  .phone-cta .icon{
    width:36px;height:36px;border-radius:10px;
    background:rgba(241,234,219,.14);
    display:flex;align-items:center;justify-content:center;color:var(--cream);flex-shrink:0;
  }
  .phone-cta .icon svg{width:18px;height:18px;display:block}
  .phone-cta .copy{display:flex;flex-direction:column;line-height:1;gap:3px}
  .phone-cta .copy .big{
    font-family:var(--sans);font-weight:700;font-size:13px;
    letter-spacing:.02em;color:var(--cream);
  }
  .phone-cta .copy .small{
    font-family:var(--sans);font-weight:500;font-size:11px;
    letter-spacing:.04em;color:rgba(241,234,219,.78);
  }
  @media (max-width:560px){
    .phone-cta{right:14px;bottom:14px;padding:12px 16px;gap:10px}
    .phone-cta .icon{width:32px;height:32px}
    .phone-cta .copy .big{font-size:12px}
    .phone-cta .copy .small{font-size:10.5px}
  }80%,100%{box-shadow:0 0 0 14px rgba(184,151,90,0)}}


  /* Refined small-label treatment: replaces ex-monospace look with tracked Work Sans */
  .sec-no, .marquee .track span, .stats-band .label,
  .stat .cap, .pillar .ord, .step .ord, .step .ord b,
  .quote .who, .area .list .city .tag,
  footer h5, footer .bottom,
  .topbar .name span, .topbar nav a, .topbar .cta, .topbar .menu-btn,
  .hero .eyebrow, .hero .meta, .hero .scroll-cue,
  .mat .num, .btn-primary, .btn-ghost,
  .stat .num .unit, .phone-cta .small{
    font-family:var(--sans)!important;
    font-feature-settings:"ss01" on, "cv11" on;
  }
  .sec-no, .stats-band .label, .stat .cap, .pillar .ord, .step .ord,
  .quote .who, .area .list .city .tag, footer h5, footer .bottom,
  .topbar .name span, .hero .eyebrow, .hero .meta, .hero .scroll-cue,
  .mat .num{
    font-weight:600;letter-spacing:.12em;
  }
  .marquee .track span{font-weight:600;letter-spacing:.10em}
  .stats-band .label{letter-spacing:.14em}
  .topbar .name span{letter-spacing:.14em;font-weight:500}

  /* SVG text on the map should also use sans */
  /* Handled inline below by find/replace */


  /* ===== Sub-page hero ===== */
  .page-hero{
    padding:160px 56px 80px;
    border-bottom:1px solid var(--line);
    background:var(--cream);
    position:relative;
    overflow:hidden;
  }
  .page-hero .grid-bg{
    position:absolute;inset:0;pointer-events:none;
    background-image:
      linear-gradient(var(--line-soft) 1px, transparent 1px),
      linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
    background-size:80px 80px;
    mask-image:radial-gradient(ellipse at 50% 30%, black 30%, transparent 75%);
    -webkit-mask-image:radial-gradient(ellipse at 50% 30%, black 30%, transparent 75%);
    opacity:.7;
  }
  .page-hero .crumb{
    font-family:var(--sans);font-weight:600;font-size:11px;
    letter-spacing:.14em;text-transform:uppercase;color:var(--stone);
    display:flex;align-items:center;gap:12px;margin-bottom:36px;position:relative;
  }
  .page-hero .crumb a{color:var(--stone);transition:color .2s}
  .page-hero .crumb a:hover{color:var(--burgundy)}
  .page-hero .crumb .sep{color:var(--line);font-weight:400}
  .page-hero h1{
    font-family:var(--serif);font-weight:700;
    font-size:clamp(56px,9vw,128px);
    line-height:.92;letter-spacing:-.025em;margin:0;
    color:var(--ink);position:relative;
  }
  .page-hero h1 .accent{color:var(--burgundy);text-transform:uppercase}
  .page-hero .lede{
    margin-top:48px;position:relative;
    display:grid;grid-template-columns:1fr 1fr;gap:64px;
    align-items:end;
  }
  .page-hero .lede p{
    font-family:var(--serif);font-size:22px;line-height:1.4;
    color:var(--ink);max-width:42ch;margin:0;
  }
  .page-hero .meta{
    font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.14em;
    text-transform:uppercase;color:var(--stone);
    display:flex;flex-direction:column;gap:8px;text-align:right;
  }
  .page-hero .meta b{color:var(--ink);font-weight:600}
  @media (max-width:880px){
    .page-hero{padding:130px 22px 56px}
    .page-hero .lede{grid-template-columns:1fr;gap:24px}
    .page-hero .meta{text-align:left}
  }

  /* ===== Generic content section ===== */
  .content-section{padding:96px 56px;border-bottom:1px solid var(--line)}
  .content-section .frame{max-width:1320px;margin:0 auto}
  .twocol{display:grid;grid-template-columns:220px 1fr;gap:56px;align-items:start}
  .twocol h2{
    font-family:var(--serif);font-weight:700;
    font-size:clamp(32px,4.5vw,56px);
    line-height:1.02;letter-spacing:-.015em;margin:0 0 24px;
  }
  .twocol h2 .accent{color:var(--burgundy);text-transform:uppercase}
  .twocol p{
    font-family:var(--serif);font-size:19px;line-height:1.5;
    color:var(--ink);margin:0 0 18px;max-width:60ch;
  }
  .twocol p:last-child{margin-bottom:0}
  .twocol .lbl{
    font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.14em;
    text-transform:uppercase;color:var(--stone);
  }
  .twocol .lbl .marker{color:var(--burgundy);display:block;margin-bottom:8px}
  @media (max-width:880px){.twocol{grid-template-columns:1fr;gap:18px}.content-section{padding:64px 22px}}

  /* spec table */
  .specs{margin-top:36px;border-top:1px solid var(--ink)}
  .specs .row{
    display:grid;grid-template-columns:220px 1fr;gap:24px;
    padding:18px 0;border-bottom:1px solid var(--line);align-items:baseline;
  }
  .specs .row .k{
    font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.14em;
    text-transform:uppercase;color:var(--stone);
  }
  .specs .row .v{font-family:var(--serif);font-size:18px;line-height:1.4}
  .specs .row .v b{color:var(--burgundy);font-weight:700}
  @media (max-width:780px){.specs .row{grid-template-columns:1fr;gap:6px}}

  /* slab swatch large */
  .slab{
    margin-top:48px;
    aspect-ratio:16/7;width:100%;background:var(--cream-2);
    position:relative;overflow:hidden;border:1px solid var(--ink);
  }
  .slab svg{position:absolute;inset:0;width:100%;height:100%;display:block}
  .slab .stamp{
    position:absolute;bottom:14px;left:14px;
    font-family:var(--sans);font-weight:600;font-size:10px;letter-spacing:.18em;
    text-transform:uppercase;color:var(--ink);
    background:rgba(241,234,219,.92);padding:6px 10px;
  }

  /* cross-link cards */
  .also{display:grid;grid-template-columns:repeat(var(--cols,4),1fr);gap:0;border-top:1px solid var(--ink)}
  .also a{
    padding:28px 24px 32px;border-right:1px solid var(--line);
    border-bottom:1px solid var(--ink);background:var(--cream);
    transition:background .35s, padding .35s;display:block;
  }
  .also a:last-child{border-right:none}
  .also a:hover{background:var(--cream-2);padding-left:34px}
  .also a .lbl{
    font-family:var(--sans);font-weight:600;font-size:10px;letter-spacing:.14em;
    text-transform:uppercase;color:var(--burgundy);margin-bottom:16px;display:flex;justify-content:space-between
  }
  .also a h4{font-family:var(--serif);font-weight:700;font-size:26px;line-height:1;letter-spacing:-.01em;margin:0 0 8px}
  .also a p{font-family:var(--serif);font-size:15px;line-height:1.4;color:var(--ink-soft);margin:0;max-width:24ch}
  @media (max-width:1100px){.also{grid-template-columns:repeat(3,1fr)!important}}
  @media (max-width:780px){.also{grid-template-columns:1fr 1fr!important}.also a:nth-child(2n){border-right:none}}
  @media (max-width:560px){.also{grid-template-columns:1fr!important}.also a{border-right:none!important}}

  /* form */
  .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:36px;max-width:760px}
  .form-grid label{display:flex;flex-direction:column;gap:8px}
  .form-grid label.full{grid-column:span 2}
  .form-grid .lab{
    font-family:var(--sans);font-weight:600;font-size:10px;letter-spacing:.14em;
    text-transform:uppercase;color:var(--stone);
  }
  .form-grid input, .form-grid select, .form-grid textarea{
    font-family:var(--serif);font-size:18px;color:var(--ink);
    background:var(--cream);border:none;border-bottom:1px solid var(--ink);
    padding:8px 0;outline:none;width:100%;
    transition:border-color .25s;
  }
  .form-grid input:focus, .form-grid select:focus, .form-grid textarea:focus{border-bottom-color:var(--burgundy)}
  .form-grid textarea{min-height:120px;resize:vertical}
  .form-grid .actions{grid-column:span 2;margin-top:12px;display:flex;gap:18px;flex-wrap:wrap;align-items:center}
  .form-grid .actions .note{font-family:var(--sans);font-size:12px;color:var(--stone)}
  @media (max-width:680px){.form-grid{grid-template-columns:1fr}.form-grid label.full{grid-column:span 1}.form-grid .actions{grid-column:span 1}}

  /* team grid */
  .team{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--ink);margin-top:36px}
  .team .m{padding:28px 24px 32px;border-right:1px solid var(--line);border-bottom:1px solid var(--ink);background:var(--cream)}
  .team .m:last-child{border-right:none}
  .team .m .disc{
    width:54px;height:54px;border-radius:50%;background:var(--burgundy);color:var(--cream);
    display:flex;align-items:center;justify-content:center;
    font-family:var(--serif);font-weight:700;font-size:22px;letter-spacing:-.02em;margin-bottom:24px;
  }
  .team .m h4{font-family:var(--serif);font-weight:700;font-size:26px;line-height:1.05;margin:0 0 6px;letter-spacing:-.01em}
  .team .m .role{font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--burgundy);margin-bottom:14px}
  .team .m p{font-family:var(--serif);font-size:16px;line-height:1.45;color:var(--ink-soft);margin:0;max-width:28ch}
  @media (max-width:880px){.team{grid-template-columns:1fr}.team .m{border-right:none}}

  /* ---------- Mobile nav overlay ---------- */
  .mobile-nav{
    position:fixed;inset:0;z-index:90;
    background:var(--cream);
    transform:translateY(-100%);
    transition:transform .55s cubic-bezier(.7,.05,.2,1);
    overflow-y:auto;
    visibility:hidden;
  }
  .mobile-nav.is-open{transform:translateY(0);visibility:visible}
  .mobile-nav::before{
    content:"";position:absolute;inset:0;
    background-image:
      linear-gradient(rgba(31,26,26,.04) 1px, transparent 1px),
      linear-gradient(90deg, rgba(31,26,26,.04) 1px, transparent 1px);
    background-size:48px 48px;
    pointer-events:none;
  }
  .mobile-nav-close{
    position:absolute;top:18px;right:22px;z-index:2;
    width:44px;height:44px;border:0;background:none;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    color:var(--ink);
  }
  .mobile-nav-close span{
    position:absolute;width:24px;height:1.5px;background:var(--ink);
    transition:background .2s;
  }
  .mobile-nav-close span:first-child{transform:rotate(45deg)}
  .mobile-nav-close span:last-child{transform:rotate(-45deg)}
  .mobile-nav-close:hover span{background:var(--burgundy)}

  .mobile-nav-inner{
    position:relative;z-index:1;
    padding:96px 32px 48px;
    max-width:520px;margin:0 auto;
    display:flex;flex-direction:column;gap:36px;
    min-height:100%;
  }
  .mobile-nav-group{display:flex;flex-direction:column}
  .mobile-nav-label{
    font-family:var(--mono);font-size:10px;font-weight:700;
    letter-spacing:.22em;text-transform:uppercase;color:var(--stone);
    padding-bottom:14px;margin-bottom:8px;
    border-bottom:1px solid var(--line-soft);
  }
  .mobile-nav-group a{
    font-family:var(--serif);font-weight:500;font-size:32px;
    letter-spacing:-.01em;line-height:1.15;color:var(--ink);
    padding:14px 0;
    display:flex;align-items:baseline;gap:18px;
    border-bottom:1px solid var(--line-soft);
    transition:color .2s, padding-left .25s ease;
    opacity:0;transform:translateY(14px);
  }
  .mobile-nav-group a .num{
    font-family:var(--mono);font-size:10px;font-weight:700;
    letter-spacing:.14em;color:var(--brass);
    flex-shrink:0;min-width:24px;
  }
  .mobile-nav-group a:hover,.mobile-nav-group a:active{
    color:var(--burgundy);padding-left:8px;
  }
  .mobile-nav.is-open .mobile-nav-group a{
    opacity:1;transform:translateY(0);
    transition:opacity .5s ease, transform .5s cubic-bezier(.2,.7,.2,1), color .2s, padding-left .25s ease;
  }
  .mobile-nav.is-open .mobile-nav-group:nth-child(1) a:nth-child(2){transition-delay:.12s}
  .mobile-nav.is-open .mobile-nav-group:nth-child(1) a:nth-child(3){transition-delay:.17s}
  .mobile-nav.is-open .mobile-nav-group:nth-child(1) a:nth-child(4){transition-delay:.22s}
  .mobile-nav.is-open .mobile-nav-group:nth-child(1) a:nth-child(5){transition-delay:.27s}
  .mobile-nav.is-open .mobile-nav-group:nth-child(2) a:nth-child(2){transition-delay:.32s}
  .mobile-nav.is-open .mobile-nav-group:nth-child(2) a:nth-child(3){transition-delay:.37s}
  .mobile-nav.is-open .mobile-nav-group:nth-child(2) a:nth-child(4){transition-delay:.42s}

  .mobile-nav-cta{
    background:var(--burgundy);color:var(--cream);
    padding:18px 22px;
    font-family:var(--sans);font-weight:700;font-size:12px;
    letter-spacing:.16em;text-transform:uppercase;
    display:flex;align-items:center;justify-content:space-between;
    transition:background .2s, transform .2s;
    opacity:0;transform:translateY(14px);
  }
  .mobile-nav-cta span{font-size:18px}
  .mobile-nav-cta:hover{background:var(--burgundy-deep)}
  .mobile-nav.is-open .mobile-nav-cta{
    opacity:1;transform:translateY(0);
    transition:opacity .5s ease .5s, transform .5s cubic-bezier(.2,.7,.2,1) .5s, background .2s;
  }

  .mobile-nav-foot{
    margin-top:auto;padding-top:28px;
    display:flex;flex-direction:column;gap:6px;
    font-family:var(--mono);font-size:11px;
    letter-spacing:.08em;color:var(--stone);
    border-top:1px solid var(--line-soft);
    opacity:0;
  }
  .mobile-nav-foot a{color:var(--ink);font-weight:700}
  .mobile-nav.is-open .mobile-nav-foot{
    opacity:1;transition:opacity .5s ease .65s;
  }

  /* ---------- Quote form: honeypot ---------- */
  .form-grid .hp-field{
    position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden;
  }

  /* ---------- Sketch tab toggle ---------- */
  .sketch-toggle{
    margin-top:32px;display:flex;flex-wrap:wrap;align-items:center;gap:10px;
    border-bottom:1px solid var(--line);padding-bottom:14px;
  }
  .sketch-toggle .opt{
    background:transparent;border:1px solid var(--line);color:var(--ink);
    font-family:var(--sans);font-weight:600;font-size:13px;letter-spacing:.02em;
    padding:9px 16px;cursor:pointer;transition:background .2s, color .2s, border-color .2s;
  }
  .sketch-toggle .opt:hover{border-color:var(--burgundy);color:var(--burgundy)}
  .sketch-toggle .opt.is-active{background:var(--burgundy);color:var(--cream);border-color:var(--burgundy)}
  .sketch-toggle-note{
    font-family:var(--sans);font-size:12px;color:var(--stone);margin-left:auto;
  }

  /* ---------- Kitchen planner ---------- */
  .planner-wrap{margin-top:24px;max-width:100%;overflow:hidden}
  .planner-intro p{
    font-family:var(--sans);font-size:14px;line-height:1.55;color:var(--ink-soft);
    background:var(--cream-2);border-left:3px solid var(--burgundy);
    padding:14px 18px;margin:0 0 16px;
  }
  .planner-intro kbd{
    font-family:var(--mono);font-size:11px;background:var(--cream);
    border:1px solid var(--line);padding:1px 6px;border-radius:3px;
  }
  .planner{
    display:grid;grid-template-columns:200px minmax(0,1fr);gap:18px;
    background:var(--cream-2);border:1px solid var(--line);padding:18px;
    max-width:100%;
  }
  .planner-palette{display:flex;flex-direction:column;gap:14px}
  .palette-group{display:flex;flex-direction:column;gap:6px}
  .palette-label{
    font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
    color:var(--stone);padding-bottom:2px;
  }
  .palette-item{
    background:var(--cream);border:1px solid var(--line);color:var(--ink);
    font-family:var(--sans);font-weight:600;font-size:13px;
    padding:8px 12px;cursor:pointer;text-align:left;
    transition:background .15s, border-color .15s, color .15s;
  }
  .palette-item:hover{background:#fff;border-color:var(--burgundy);color:var(--burgundy)}
  .palette-item.subtle{
    background:transparent;color:var(--stone);font-weight:500;font-size:12px;
  }
  .palette-item.subtle:hover{color:var(--burgundy);background:var(--cream)}
  .planner-stage{display:flex;flex-direction:column;gap:10px;min-width:0;max-width:100%;overflow:hidden}
  .canvas-container{max-width:100% !important}
  #plannerCanvas{
    background:#fff;border:1px solid var(--line);
    max-width:100%;display:block;touch-action:none;
  }
  .planner-summary{
    font-family:var(--mono);font-size:12px;color:var(--ink-soft);
    background:var(--cream);border:1px solid var(--line-soft);
    padding:10px 14px;white-space:pre-wrap;min-height:42px;
  }

  @media (max-width:900px){
    .planner{grid-template-columns:1fr}
    .planner-palette{flex-direction:row;flex-wrap:wrap;gap:10px}
    .palette-group{flex-direction:row;flex-wrap:wrap;align-items:center;gap:6px}
    .palette-label{width:100%}
  }
