/* ============================================================
   LYSINSKI & ASSOCIATES P.C. — Design System v2
   Fraunces + Inter Tight + JetBrains Mono
   Light mode default · Navy reserved for hero dark moments
   ============================================================ */

/* Fonts loaded via <link> in HTML */

/* ── TOKENS ─────────────────────────────────────────────────── */
:root {
  /* Color */
  --canvas:       #FAF8F4;
  --paper:        #FFFFFF;
  --ink:          #0B1F3A;
  --ink-2:        #1D3A66;
  --ink-mute:     rgba(11,31,58,0.78);
  --ink-light:    rgba(11,31,58,0.62);
  --gold:         #8B6F1F;          /* WCAG AA accessible: 4.51:1 on cream */
  --gold-deep:    #6F5419;          /* Even darker: 5.85:1 for emphasis */
  --gold-bright:  #B8963E;          /* Original bright tone — for non-text decorative use only */
  --gold-light:   #D4B563;
  --rule:         rgba(11,31,58,0.08);
  --rule-gold:    rgba(184,150,62,0.25);

  /* Type */
  --font-serif:   'Fraunces','Iowan Old Style',Georgia,serif;
  --font-sans:    'Inter Tight','Inter',-apple-system,system-ui,sans-serif;
  --font-mono:    'JetBrains Mono','Courier New',monospace;

  /* Scale */
  --t-display:    clamp(3.5rem, 8vw, 7rem);
  --t-monumental: clamp(5rem, 12vw, 11rem);
  --t-display-2:  clamp(2.25rem, 5vw, 4rem);
  --t-h2:         clamp(2rem, 3.4vw, 2.875rem);
  --t-h3:         clamp(1.375rem, 2.2vw, 1.75rem);
  --t-body:       1.1875rem;
  --t-body-lg:    1.3125rem;
  --t-body-sm:    1.0625rem;
  --t-eyebrow:    0.78rem;
  --t-micro:      0.82rem;

  /* Space */
  --sp-1: 0.5rem; --sp-2: 1rem; --sp-3: 1.5rem;
  --sp-4: 2rem;   --sp-6: 3rem; --sp-8: 4rem; --sp-12: 6rem;

  /* Motion */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --dur-fast: 200ms; --dur-mid: 400ms; --dur-slow: 700ms;

  /* Misc */
  --radius: 4px;
  --container: 1280px;
}

/* ── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:var(--font-sans);
  font-size:var(--t-body);
  line-height:1.65;
  color:#0B1F3A;color:var(--ink);
  background-color:#FAF8F4;background:var(--canvas);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%;}
button{cursor:pointer;border:none;background:none;font:inherit;color:inherit;}
a{color:inherit;}

/* ── UTILITIES ──────────────────────────────────────────────── */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--sp-4);}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(20px);transition:opacity var(--dur-mid) var(--ease-out), transform var(--dur-mid) var(--ease-out);}
.reveal.is-visible{opacity:1;transform:none;}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:0.01ms!important;transition-duration:0.01ms!important;}
  .reveal{opacity:1;transform:none;}
}

/* ── HEADER ─────────────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(250,248,244,0.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--rule);
}
.site-header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:200px;gap:var(--sp-2);
}
.wordmark{
  font-family:var(--font-serif);
  font-size:0.95rem;font-weight:400;
  letter-spacing:0.08em;text-transform:uppercase;
  color:var(--ink);text-decoration:none;
  display:flex;flex-direction:row;align-items:center;gap:0.85rem;
}
.wordmark-sub{
  font-family:var(--font-sans);font-size:0.58rem;
  letter-spacing:0.22em;color:var(--gold);font-weight:500;
}
.header-right{display:flex;align-items:center;gap:var(--sp-2);}
.header-cta{
  font-family:var(--font-sans);font-size:0.875rem;font-weight:600;
  letter-spacing:0.06em;padding:0.75rem 1.25rem;
  border:1.5px solid var(--ink);border-radius:var(--radius);
  color:var(--ink);text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;
  min-height:44px;
  transition:background var(--dur-fast), color var(--dur-fast);
}
.header-cta:hover{background:var(--ink);color:var(--canvas);}
.nav-toggle {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px;
  min-width: 44px;
  height: 44px;
  min-height: 44px;
  padding: 8px;
  background: transparent;
  border: 0;
  cursor: pointer;
}
.nav-toggle span{
  display:block;width:24px;height:1.5px;background:var(--ink);
  transition:transform var(--dur-fast), opacity var(--dur-fast);
}
.nav-toggle.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.nav-toggle.is-open span:nth-child(2){opacity:0;}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

/* Full-screen nav overlay */
.nav-overlay{
  position:fixed;inset:0;z-index:99;
  background:var(--ink);
  display:flex;flex-direction:column;justify-content:flex-start;align-items:center;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity var(--dur-mid) var(--ease-out),visibility var(--dur-mid);
  overflow-y:auto;
  padding:var(--sp-4) 0 var(--sp-8);
}
.nav-overlay.is-open{opacity:1;visibility:visible;pointer-events:all;}
.nav-overlay-links{display:flex;flex-direction:column;gap:0.9rem;text-align:center;margin:0 auto;width:100%;max-width:520px;}
.nav-overlay-links a{
  font-family:var(--font-serif);
  font-size:clamp(1.5rem,3vw,2.5rem);
  font-weight:300;color:var(--canvas);
  text-decoration:none;letter-spacing:-0.01em;
  transition:color var(--dur-fast);
  line-height:1.2;
}
.nav-overlay-links a:hover{color:var(--gold-light);}
.nav-overlay-close{
  position:absolute;top:var(--sp-4);right:var(--sp-4);
  font-size:1.5rem;color:var(--canvas);opacity:0.5;
  background:none;border:none;cursor:pointer;
}

/* ── HERO ────────────────────────────────────────────────────── */
.hero{
  min-height:calc(100vh - 60px);
  background-color:#FAF8F4;background:var(--canvas);
  display:flex;flex-direction:column;justify-content:space-between;
  padding:var(--sp-6) 0 0;
  position:relative;overflow:hidden;
}
.hero-editorial-zone{
  display:grid;
  grid-template-columns:1fr 340px;
  gap:var(--sp-4);
  align-items:start;
  padding:0 var(--sp-4);
  max-width:var(--container);margin:0 auto;width:100%;
}
.hero-editorial{display:flex;flex-direction:column;gap:var(--sp-3);}
.hero-eyebrow{
  font-family:var(--font-sans);
  font-size:var(--t-eyebrow);
  font-weight:600;letter-spacing:0.2em;
  text-transform:uppercase;color:#B8963E;color:var(--gold);
}
.hero-headline{
  color:#0B1F3A;
  font-family:var(--font-serif);
  font-variation-settings:"opsz" 144,"SOFT" 100,"WONK" 1;
  font-size:var(--t-display);
  font-weight:300;line-height:0.95;
  letter-spacing:-0.02em;color:var(--ink);
  max-width:9ch;
}
.hero-headline em,.hero-headline-accent{
  font-style:italic;font-weight:400;
  color:var(--gold);
  font-feature-settings:"swsh" 1,"ss01" 1;
}
.hero-sub{
  font-family:var(--font-sans);
  font-size:var(--t-body-lg);
  color:rgba(11,31,58,0.78);
  line-height:1.6;max-width:46ch;
}

/* Tech credential card */
.tc-key{color:var(--gold-light);}
.tc-val{color:rgba(250,248,244,0.85);}
.tc-str{color:#9EC8B9;}
.tc-bool{color:#B39DDB;}
.tc-num{color:#FFB347;}
.tc-comment{color:rgba(250,248,244,0.3);font-style:italic;}

/* Intake zone */
.intake-zone{
  background-color:#FAF8F4;background:var(--canvas);
  border-top:1px solid var(--rule-gold);
  padding:var(--sp-4) var(--sp-4) var(--sp-6);
  max-width:var(--container);margin:0 auto;width:100%;
}
.intake-prompt{
  font-family:var(--font-serif);
  font-size:1.35rem;font-weight:400;
  color:var(--ink);margin-bottom:var(--sp-3);
}
.intake-cards{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0.65rem;
  margin-bottom:var(--sp-2);
}
.intake-card{
  border:1px solid var(--rule-gold);
  border-radius:var(--radius);
  padding:1.1rem 1rem;
  min-height:110px;
  display:flex;flex-direction:column;gap:0.4rem;
  background:var(--paper);
  cursor:pointer;
  text-align:left;
  transition:border-color var(--dur-fast), box-shadow var(--dur-fast), transform var(--dur-fast);
  animation:cardFadeIn var(--dur-mid) var(--ease-out) both;
}
.intake-card:hover{
  border-color:var(--gold);
  box-shadow:0 4px 20px rgba(184,150,62,0.12);
  transform:translateY(-2px);
}
.intake-card:nth-child(1){animation-delay:200ms;}
.intake-card:nth-child(2){animation-delay:260ms;}
.intake-card:nth-child(3){animation-delay:320ms;}
.intake-card:nth-child(4){animation-delay:380ms;}
.intake-card:nth-child(5){animation-delay:440ms;}
.intake-card:nth-child(6){animation-delay:500ms;}
.intake-card:nth-child(7){animation-delay:560ms;}
.intake-card-num{
  font-family:var(--font-mono);font-size:0.65rem;
  color:var(--gold-deep);font-weight:500;letter-spacing:0.05em;
}
.intake-card-title{
  font-family:var(--font-serif);font-size:1rem;
  font-weight:400;color:var(--ink);line-height:1.25;
}
.intake-card-sub{
  font-size:0.75rem;color:var(--ink-light);
  line-height:1.4;margin-top:auto;
}
.intake-card.is-selected{
  background:var(--ink);border-color:var(--ink);
}
.intake-card.is-selected .intake-card-title,
.intake-card.is-selected .intake-card-num{color:var(--gold-light);}
.intake-card.is-selected .intake-card-sub{color:rgba(250,248,244,0.55);}
.intake-card.is-fading{
  opacity:0;transform:translateY(12px);
  transition:opacity 200ms, transform 200ms;
}

@keyframes cardFadeIn{
  from{opacity:0;transform:translateY(14px);}
  to{opacity:1;transform:none;}
}

.intake-q2-view{
  animation:fadeSlideIn 280ms var(--ease-out) both;
}
@keyframes fadeSlideIn{
  from{opacity:0;transform:translateY(10px);}
  to{opacity:1;transform:none;}
}
.intake-q2-label{
  font-family:var(--font-serif);font-size:1.25rem;
  color:var(--ink);margin-bottom:var(--sp-2);
}
.intake-q2-options{display:flex;flex-wrap:wrap;gap:0.5rem;margin-bottom:var(--sp-2);}
.intake-q2-btn{
  font-family:var(--font-sans);font-size:0.82rem;font-weight:500;
  border:1px solid var(--rule);border-radius:var(--radius);
  padding:0.65rem 1.1rem;background:var(--paper);
  cursor:pointer;text-align:left;
  transition:border-color var(--dur-fast), background var(--dur-fast);
  display:flex;flex-direction:column;gap:0.2rem;
}
.intake-q2-btn:hover{border-color:var(--gold);background:rgba(184,150,62,0.04);}
.intake-q2-btn.is-selected{border-color:var(--ink);background:var(--ink);color:var(--canvas);}
.intake-q2-btn-sub{font-size:0.72rem;color:var(--ink-light);font-weight:400;}
.intake-q2-btn.is-selected .intake-q2-btn-sub{color:rgba(250,248,244,0.5);}
.intake-back{
  font-family:var(--font-sans);font-size:0.75rem;font-weight:500;
  letter-spacing:0.06em;color:var(--gold);
  background:none;border:none;cursor:pointer;
  padding:0.4rem 0;
  transition:opacity var(--dur-fast);
  display:inline-flex;align-items:center;gap:0.3rem;
}
.intake-back:hover{opacity:0.7;}
.intake-input-field{
  width:100%;max-width:420px;
  font-family:var(--font-sans);font-size:0.95rem;
  border:1px solid var(--rule);border-radius:var(--radius);
  padding:0.75rem 1rem;background:var(--paper);
  color:var(--ink);
  transition:border-color var(--dur-fast);
  margin-bottom:0.65rem;
}
.intake-input-field:focus{outline: 2px solid var(--gold); outline-offset: 2px;border-color:var(--gold);}
.intake-input-field::placeholder{color:var(--ink-light);}
.intake-disclaimer{
  font-size:0.7rem;color:var(--ink-light);
  margin-top:var(--sp-2);line-height:1.5;
  max-width:56ch;
}
.intake-success{
  animation:fadeSlideIn 300ms var(--ease-out) both;
  padding:var(--sp-2) 0;
}
.intake-success-check{font-size:2rem;color:var(--gold);margin-bottom:var(--sp-2);}
.intake-success-name{
  font-family:var(--font-serif);font-size:1.75rem;
  font-style:italic;font-weight:400;color:var(--ink);
  margin-bottom:0.5rem;
}
.intake-success-sub{font-size:0.95rem;color:var(--ink-mute);line-height:1.6;}
.intake-success-sig{
  margin-top:var(--sp-2);
  font-family:var(--font-serif);font-style:italic;
  font-size:1.1rem;color:var(--gold);
}

/* Scroll cue */
.scroll-cue{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:0.35rem;
  opacity:0;animation:scrollCueIn 600ms 1.2s var(--ease-out) forwards;
}
.scroll-cue-line{
  width:1px;height:40px;background:var(--gold);
  animation:scrollPulse 1.5s 1.8s ease-in-out infinite;
}
.scroll-cue-text{
  font-family:var(--font-mono);font-size:0.6rem;
  letter-spacing:0.15em;color:var(--gold);opacity:0.6;
}
@keyframes scrollCueIn{to{opacity:1;}}
@keyframes scrollPulse{
  0%,100%{transform:scaleY(1);opacity:0.6;}
  50%{transform:scaleY(1.4);opacity:1;}
}
.scroll-cue.is-hidden{opacity:0;pointer-events:none;transition:opacity 400ms;}

/* ── TRUST BAND ─────────────────────────────────────────────── */
.trust-band{
  background:var(--ink);
  padding:0.85rem var(--sp-4);
  overflow:hidden;
}
.trust-band-inner{
  display:flex;align-items:center;gap:var(--sp-3);
  flex-wrap:wrap;max-width:var(--container);margin:0 auto;
}
.trust-label{
  font-family:var(--font-mono);font-size:0.65rem;
  color:var(--gold-light);letter-spacing:0.12em;
  text-transform:uppercase;flex-shrink:0;
}
.trust-items{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;}
.trust-item{
  font-family:var(--font-sans);font-size:0.72rem;
  font-weight:500;letter-spacing:0.06em;
  color:rgba(250,248,244,0.65);
}
.trust-item.is-gold{color:var(--gold-light);}
.trust-sep{color:rgba(250,248,244,0.2);}
.trust-response{
  margin-left:auto;
  font-family:var(--font-sans);font-size:0.7rem;
  color:rgba(250,248,244,0.65);flex-shrink:0;
}

/* ── SIGNATURE SCROLL MOMENT ─────────────────────────────────── */
.signature-scroll{
  background:var(--ink);
  display:flex;flex-direction:column;
  justify-content:flex-start;
  padding:var(--sp-2) var(--sp-4) var(--sp-5);
  overflow:hidden;
  position:relative;
}
.sig-numerals{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:1rem;
  max-width:var(--container);margin:0 auto;width:100%;
  align-items:start;
}
.sig-numeral{
  display:flex;flex-direction:column;gap:0.35rem;
  opacity:0;transform:translateY(40px);
  transition:opacity 600ms var(--ease-out), transform 600ms var(--ease-out);
  min-width:0;overflow:visible;
}
.sig-numeral.is-revealed{opacity:1;transform:none;}
.sig-num{
  font-family:var(--font-serif);
  font-variation-settings:"opsz" 144,"SOFT" 100;
  font-size:clamp(2.8rem,5.5vw,var(--t-monumental));
  font-weight:200;line-height:0.9;
  color:var(--gold-light);
  display:block;
  overflow:visible;
}
.sig-unit{
  font-family:var(--font-serif);
  font-style:italic;font-weight:300;
  font-size:clamp(0.72rem,1.3vw,1rem);
  color:rgba(250,248,244,0.7);
  white-space:normal;
  word-break:normal;
  hyphens:auto;
}
.sig-detail{
  font-size:0.65rem;color:rgba(250,248,244,0.65);
  font-family:var(--font-sans);letter-spacing:0.06em;
  margin-top:0.2rem;line-height:1.4;
}
.sig-closing{
  max-width:var(--container);margin:var(--sp-5) auto 0;width:100%;
  opacity:0;transform:translateY(20px);
  transition:opacity 700ms 200ms var(--ease-out), transform 700ms 200ms var(--ease-out);
}
.sig-closing.is-revealed{opacity:1;transform:none;}
.sig-closing-text{
  font-family:var(--font-serif);
  font-style:italic;font-weight:300;
  font-size:1.5rem;color:var(--gold-light);
  letter-spacing:-0.01em;
}

/* ── ASYMMETRIC PRACTICE AREAS ──────────────────────────────── */
.practices-section{
  background:var(--canvas);
  padding:var(--sp-8) var(--sp-4);
}
.practices-header{margin-bottom:var(--sp-6);}
.section-eyebrow{
  font-family:var(--font-mono);font-size:0.65rem;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--gold);margin-bottom:0.6rem;
}
.section-title{
  font-family:var(--font-serif);
  font-size:var(--t-display-2);
  font-weight:300;color:var(--ink);
  line-height:1.1;letter-spacing:-0.01em;
}
.practices-split{
  display:grid;
  grid-template-columns:3fr 2fr;
  gap:var(--sp-3);
  align-items:start;
}
.practices-volume{display:flex;flex-direction:column;gap:var(--sp-3);}
.vol-card{
  background:var(--paper);
  border:1px solid var(--rule);
  border-radius:var(--radius);
  padding:var(--sp-4);
  text-decoration:none;
  display:block;
  transition:box-shadow var(--dur-fast), border-color var(--dur-fast);
  position:relative;overflow:hidden;
}
.vol-card::before{
  content:'';position:absolute;top:0;left:0;
  width:3px;height:100%;background:var(--gold);
  transform:scaleY(0);transform-origin:top;
  transition:transform var(--dur-mid) var(--ease-out);
}
.vol-card:hover{box-shadow:0 8px 40px rgba(0,0,0,0.06);border-color:var(--rule-gold);}
.vol-card:hover::before{transform:scaleY(1);}
.vol-card-label{
  font-family:var(--font-mono);font-size:0.65rem;
  color:var(--gold);letter-spacing:0.1em;
  text-transform:uppercase;margin-bottom:0.75rem;
}
.vol-card-title{
  font-family:var(--font-serif);
  font-size:1.75rem;font-weight:400;
  color:var(--ink);line-height:1.15;
  margin-bottom:0.75rem;
}
.vol-card-price{
  display:inline-block;
  font-family:var(--font-mono);font-size:0.78rem;
  color:var(--gold);border:1px solid var(--rule-gold);
  padding:0.25rem 0.65rem;border-radius:2px;
  margin-bottom:var(--sp-2);
}
.vol-card-desc{font-size:1rem;color:var(--ink-mute);line-height:1.65;margin-bottom:var(--sp-2);}
.vol-card-detail{font-size:0.9375rem;color:var(--ink-light);line-height:1.6;}
.vol-card-cta{
  margin-top:var(--sp-2);
  font-family:var(--font-sans);font-size:0.78rem;font-weight:600;
  letter-spacing:0.06em;color:var(--ink);
  display:inline-flex;align-items:center;gap:0.4rem;
  transition:color var(--dur-fast);
}
.vol-card:hover .vol-card-cta{color:var(--gold);}

.practices-specialty{display:flex;flex-direction:column;gap:0.75rem;}
.spec-tile{
  background:var(--paper);border:1px solid var(--rule);
  border-radius:var(--radius);padding:var(--sp-2) var(--sp-3);
  text-decoration:none;display:block;
  transition:border-color var(--dur-fast), box-shadow var(--dur-fast);
  overflow:hidden;
}
.spec-tile:hover{border-color:var(--rule-gold);box-shadow:0 4px 16px rgba(0,0,0,0.05);}
.spec-tile-header{display:flex;align-items:center;justify-content:space-between;}
.spec-tile-title{
  font-family:var(--font-serif);font-size:1.1rem;
  font-weight:400;color:var(--ink);
}
.spec-tile-arrow{color:var(--gold);opacity:0;transition:opacity var(--dur-fast), transform var(--dur-fast);}
.spec-tile:hover .spec-tile-arrow{opacity:1;transform:translateX(4px);}
.spec-tile-sub{
  font-size:0.9375rem;color:var(--ink-light);
  margin-top:0.4rem;line-height:1.5;
  max-height:0;overflow:hidden;
  transition:max-height 300ms var(--ease-out);
}
.spec-tile:hover .spec-tile-sub{max-height:60px;}
.vol-divider{
  display:none;
  height:1px;background:var(--rule-gold);margin:var(--sp-2) 0;
}

/* ── INSIGHTS — FROM THE PRACTICE ───────────────────────────── */
.insights-section{
  background:var(--paper);
  padding:var(--sp-8) var(--sp-4);
  border-top:1px solid var(--rule);
}
.insights-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--sp-3);margin-top:var(--sp-6);
}
.insight-card{
  border:1px solid var(--rule);border-radius:var(--radius);
  padding:var(--sp-3);background:var(--canvas);
  text-decoration:none;display:block;
  transition:box-shadow var(--dur-fast), border-color var(--dur-fast), transform var(--dur-fast);
}
.insight-card:hover{
  box-shadow:0 6px 28px rgba(0,0,0,0.06);
  border-color:var(--rule-gold);
  transform:translateY(-3px);
}
.insight-meta{
  font-family:var(--font-mono);font-size:0.65rem;
  letter-spacing:0.1em;color:var(--gold);
  margin-bottom:0.75rem;
}
.insight-title{
  font-family:var(--font-serif);font-size:1.1rem;
  font-weight:400;color:var(--ink);line-height:1.4;
  margin-bottom:0.75rem;
}
.insight-summary{font-size:0.83rem;color:var(--ink-mute);line-height:1.65;}
.insight-read-more{
  display:inline-block;margin-top:var(--sp-2);
  font-size:0.75rem;font-weight:600;
  letter-spacing:0.06em;color:var(--ink);
  transition:color var(--dur-fast);
}
.insight-card:hover .insight-read-more{color:var(--gold);}

/* ── FAQ ─────────────────────────────────────────────────────── */
.faq-section{
  background:var(--canvas);
  padding:var(--sp-8) var(--sp-4);
  border-top:1px solid var(--rule);
}
.faq-list{border-top:1px solid var(--rule);margin-top:var(--sp-6);}
.faq-item{border-bottom:1px solid var(--rule);}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;
  padding:1.25rem 0;gap:var(--sp-2);
  font-family:var(--font-serif);font-size:1.05rem;
  font-weight:400;color:var(--ink);
  background:none;border:none;text-align:left;cursor:pointer;
}
.faq-q::after{
  content:'+';font-size:1.25rem;color:var(--gold);
  flex-shrink:0;line-height:1;
  transition:transform var(--dur-fast);
}
.faq-item.is-open .faq-q::after{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height 350ms var(--ease-out);}
.faq-item.is-open .faq-a{max-height:600px;}
.faq-answer{
  padding:0 var(--sp-8) 1.25rem 0;
  font-size:1.0625rem;line-height:1.75;color:var(--ink-mute);
}

/* ── VOICES — TESTIMONIALS ───────────────────────────────────── */
.voices-section{
  background:var(--paper);
  padding:var(--sp-8) var(--sp-4);
  border-top:1px solid var(--rule);
}
.voices-grid{
  display:flex;flex-direction:column;
  gap:var(--sp-6);margin-top:var(--sp-6);
}
.pull-quote{
  display:grid;grid-template-columns:3rem 1fr;gap:var(--sp-3);
  align-items:start;
}
.pull-quote-mark{
  font-family:var(--font-serif);
  font-size:5rem;line-height:0.7;
  color:var(--rule-gold);font-weight:700;
  user-select:none;
}
.pull-quote-text{
  font-family:var(--font-serif);
  font-size:clamp(1.25rem,2.5vw,1.75rem);
  font-weight:300;font-style:italic;
  color:var(--ink);line-height:1.45;
}
.pull-quote-attr{
  margin-top:var(--sp-2);
  font-family:var(--font-mono);font-size:0.7rem;
  color:var(--gold);letter-spacing:0.1em;
}
.voices-disclaimer{
  margin-top:var(--sp-4);font-size:0.75rem;
  color:var(--ink-light);line-height:1.5;
}

/* ── LOGO COMPARISON ─────────────────────────────────────────── */









/* ── FINAL CTA ──────────────────────────────────────────────── */
.final-cta{
  background:var(--canvas);
  padding:var(--sp-8) var(--sp-4);
  border-top:1px solid var(--rule);
  text-align:center;
}
.final-cta-eyebrow{
  font-family:var(--font-mono);font-size:0.65rem;
  color:var(--gold);letter-spacing:0.18em;text-transform:uppercase;
  margin-bottom:var(--sp-2);
}
.final-cta-headline{
  font-family:var(--font-serif);
  font-size:var(--t-display-2);
  font-weight:300;color:var(--ink);
  line-height:1.1;margin-bottom:var(--sp-3);
}
.final-cta-phone{
  font-family:var(--font-serif);
  font-size:clamp(2.5rem,5vw,4rem);
  font-weight:300;color:var(--ink);
  text-decoration:none;
  display:block;margin-bottom:var(--sp-3);
  letter-spacing:-0.02em;
  transition:color var(--dur-fast);
}
.final-cta-phone:hover{color:var(--gold);}
.final-cta-btn{
  font-family:var(--font-sans);font-size:0.9rem;font-weight:600;
  letter-spacing:0.06em;padding:1rem 2.5rem;
  background:var(--ink);color:var(--canvas);
  border:none;border-radius:var(--radius);
  cursor:pointer;text-decoration:none;display:inline-block;
  transition:background var(--dur-fast);
}
.final-cta-btn:hover{background:var(--gold);}
.final-cta-micro{
  margin-top:var(--sp-2);font-size:0.75rem;color:var(--ink-light);
}

/* ── FOOTER ─────────────────────────────────────────────────── */
.site-footer{
  background:var(--ink);
  padding:var(--sp-8) var(--sp-4) var(--sp-4);
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:var(--sp-6);margin-bottom:var(--sp-6);
}
.footer-wordmark{
  font-family:var(--font-serif);
  font-size:0.9rem;font-weight:400;
  letter-spacing:0.08em;text-transform:uppercase;
  color:rgba(250,248,244,0.7);margin-bottom:0.75rem;
  display:block;
}
.footer-tagline{
  font-size:0.8rem;font-style:italic;
  font-family:var(--font-serif);
  color:rgba(250,248,244,0.65);margin-bottom:var(--sp-2);
}
.footer-contact{
  font-size:0.8rem;color:rgba(250,248,244,0.65);line-height:1.65;
}
.footer-contact a{color:rgba(250,248,244,0.85);text-decoration:none;}
.footer-col-title{
  font-family:var(--font-mono);font-size:0.6rem;
  letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gold-light);margin-bottom:var(--sp-2);
}
.footer-links{display:flex;flex-direction:column;gap:0.65rem;}
.footer-links a{
  font-size:0.82rem;color:rgba(250,248,244,0.5);
  text-decoration:none;transition:color var(--dur-fast);
}
.footer-links a:hover{color:rgba(250,248,244,0.9);}
.footer-disclaimer{
  border-top:1px solid rgba(250,248,244,0.06);
  padding-top:var(--sp-4);
  font-size:0.72rem;line-height:1.7;
  color:rgba(250,248,244,0.65);
}

/* ── MODAL INTAKE (nav CTA + practice page CTAs) ────────────── */
.intake-modal{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity var(--dur-mid);
}
.intake-modal.is-open{opacity:1;pointer-events:all;}
.intake-backdrop{
  position:absolute;inset:0;background:rgba(11,31,58,0.65);
  backdrop-filter:blur(4px);
}
.intake-panel{
  position:relative;z-index:1;
  background:var(--paper);border-radius:var(--radius);
  padding:var(--sp-4);max-width:560px;width:90%;
  max-height:90vh;overflow-y:auto;
  box-shadow:0 24px 80px rgba(0,0,0,0.25);
}
.intake-close{
  position:absolute;top:var(--sp-2);right:var(--sp-2);
  font-size:1.5rem;color:var(--ink-light);
  background:none;border:none;cursor:pointer;line-height:1;
}
.intake-header{margin-bottom:var(--sp-3);}
.intake-headline{
  font-family:var(--font-serif);font-size:1.5rem;
  font-weight:400;color:var(--ink);margin-bottom:0.5rem;
}
.intake-sub{font-size:0.88rem;color:var(--ink-mute);line-height:1.6;}
.intake-modal .intake-disclaimer{
  background:rgba(11,31,58,0.04);
  border-left:2px solid var(--gold);
  padding:0.65rem var(--sp-2);
  border-radius:0 var(--radius) var(--radius) 0;
  font-size:0.75rem;color:var(--ink-mute);
  margin-bottom:var(--sp-2);
}
.modal-q{font-family:var(--font-serif);font-size:1.15rem;color:var(--ink);margin-bottom:var(--sp-2);}
.modal-options{display:flex;flex-direction:column;gap:0.4rem;}
.modal-option{
  border:1px solid var(--rule);border-radius:var(--radius);
  padding:0.7rem var(--sp-2);background:var(--canvas);
  cursor:pointer;text-align:left;font-size:0.88rem;
  transition:border-color var(--dur-fast), background var(--dur-fast);
  display:flex;flex-direction:column;gap:0.15rem;
}
.modal-option:hover{border-color:var(--gold);background:rgba(184,150,62,0.04);}
.modal-option.is-selected{border-color:var(--ink);background:var(--ink);color:var(--canvas);}
.modal-option-sub{font-size:0.75rem;color:var(--ink-light);}
.modal-option.is-selected .modal-option-sub{color:rgba(250,248,244,0.5);}
.intake-progress{display:flex;gap:4px;margin-bottom:var(--sp-2);}
.intake-dot{width:20px;height:3px;border-radius:2px;background:var(--rule);}
.intake-dot.is-active{background:var(--gold);}
.intake-dot.is-done{background:var(--ink);}
.intake-nav{display:flex;justify-content:space-between;align-items:center;margin-top:var(--sp-2);}
.modal-label{font-size:0.8rem;color:var(--ink-mute);margin-bottom:0.3rem;display:block;}
.modal-input{
  width:100%;font-size:0.9rem;font-family:var(--font-sans);
  border:1px solid var(--rule);border-radius:var(--radius);
  padding:0.7rem var(--sp-2);background:var(--canvas);
  color:var(--ink);margin-bottom:0.65rem;
  transition:border-color var(--dur-fast);
}
.modal-input:focus{outline: 2px solid var(--gold); outline-offset: 2px;border-color:var(--gold);}
.btn-primary{
  font-family:var(--font-sans);font-size:1rem;font-weight:600;
  letter-spacing:0.04em;padding:0.875rem 1.75rem;
  background:var(--ink);color:var(--canvas);border:none;
  border-radius:var(--radius);cursor:pointer;
  transition:background var(--dur-fast);
}
.btn-primary:hover{background:var(--gold);}
.btn-ghost{
  font-family:var(--font-sans);font-size:0.9375rem;font-weight:500;
  padding:0.75rem 1.3rem;background:none;
  border:1px solid var(--rule);color:var(--ink-mute);
  border-radius:var(--radius);cursor:pointer;
  transition:border-color var(--dur-fast), color var(--dur-fast);
}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink);}
/* ── HEADER PHONE — v6 readability ─────────────────────────────────────── */
.header-phone{
  font-family:var(--font-mono);
  font-size:1.0625rem;
  font-weight:500;
  color:var(--ink);
  letter-spacing:0.02em;
  white-space:nowrap;
  padding:0.5rem 0.75rem;
  text-decoration:none;
}
@media(max-width:768px){
  .header-phone{
    font-size:1rem;
    padding:0.625rem 0.5rem;
  }
}



/* ── WORDMARK LOGO MARK — v6 identity ──────────────────────────────────── */
.wordmark{display:flex;align-items:center;gap:1.5rem;text-decoration:none;}
.wordmark-mark{height:200px;width:auto;display:block;flex-shrink:0;}
.wordmark-text{display:flex;flex-direction:column;gap:2px;}
@media(max-width:768px){
  .wordmark-mark{height:154px;}
}
/* ── FOOTER LOGO MARK ────────────────────────────────────────────────────── */
.footer-brand{display:flex;align-items:center;gap:0.6rem;margin-bottom:0.4rem;}
.footer-brand-mark{height:36px;width:auto;display:block;opacity:0.85;}

/* ── MOBILE ─────────────────────────────────────────────────── */
@media(max-width:1100px){
  .site-header-inner{height:172px;}
  .hero-editorial-zone{grid-template-columns:1fr;}
  .practices-split{grid-template-columns:1fr;}
  .vol-divider{display:block;}
  
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  .intake-cards{grid-template-columns:repeat(2,1fr);}
  .sig-numerals{
    grid-template-columns:repeat(2,1fr);gap:var(--sp-4);
  }
  .sig-num{font-size:clamp(4rem,18vw,7rem);}
  .insights-grid{grid-template-columns:1fr;}
  
  .pull-quote{grid-template-columns:2rem 1fr;}
  .pull-quote-mark{font-size:3.5rem;}
}
@media(max-width:480px){
  .intake-cards{grid-template-columns:1fr;}
  
  .footer-grid{grid-template-columns:1fr;}
  .trust-response{display:none;}
}

/* Focus states — accessibility */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}

/* WCAG-compliant visually-hidden utility (v23 — added for hero intake labels) */
.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* WCAG-compliant skip-to-content link (v25 — accessibility) */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--ink);
  color: var(--paper);
  padding: 0.75rem 1.25rem;
  text-decoration: none;
  font-weight: 600;
  z-index: 9999;
  border-bottom-right-radius: 0.25rem;
  transform: translateY(-100%);
  transition: transform 0.15s ease-out;
}
.skip-link:focus {
  transform: translateY(0);
  outline: 3px solid var(--gold);
  outline-offset: 2px;
}

/* ── INTENT ROUTER (v5.2) ──────────────────────────────────────────────── */
.intent-router{
  background:var(--canvas);
  padding:3rem 1.25rem 3.5rem;
  border-top:1px solid rgba(11,31,58,0.08);
  border-bottom:1px solid rgba(11,31,58,0.08);
}
.intent-router-inner{
  max-width:1200px;
  margin:0 auto;
}
.intent-router-heading{
  font-family:var(--font-serif);
  font-size:clamp(1.6rem, 3vw, 2.2rem);
  font-weight:600;
  color:var(--ink);
  text-align:center;
  margin:0 0 0.5rem 0;
  line-height:1.2;
}
.intent-router-sub{
  text-align:center;
  color:var(--ink-light);
  margin:0 0 2rem 0;
  font-size:1rem;
}
.intent-router-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1rem;
}
@media (max-width: 900px){
  .intent-router-grid{ grid-template-columns:repeat(2, 1fr); }
}
@media (max-width: 480px){
  .intent-router-grid{ grid-template-columns:1fr; }
}
.intent-card{
  display:flex;
  flex-direction:column;
  gap:0.5rem;
  padding:1.5rem 1.25rem;
  background:var(--paper);
  border:1px solid rgba(11,31,58,0.12);
  border-radius:8px;
  text-decoration:none;
  color:var(--ink);
  transition:transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
  min-height:160px;
}
.intent-card:hover, .intent-card:focus-visible{
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(11,31,58,0.08);
  border-color:var(--gold);
}
.intent-card:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:2px;
}
.intent-card-icon{
  font-size:1.75rem;
  line-height:1;
}
.intent-card-title{
  font-family:var(--font-serif);
  font-size:1.15rem;
  font-weight:600;
  color:var(--ink);
}
.intent-card-sub{
  font-size:0.85rem;
  color:var(--ink-light);
  flex-grow:1;
  line-height:1.45;
}
.intent-card-cta{
  font-size:0.85rem;
  font-weight:600;
  color:var(--gold);
  margin-top:0.25rem;
}
@media (prefers-reduced-motion: reduce){
  .intent-card{ transition:none; }
  .intent-card:hover, .intent-card:focus-visible{ transform:none; }
}


/* ─────────────────────────────────────────────────────────
   SEV3-45 PARTIAL: Utility classes extracted from repeated inline styles.
   Generated 2026-05-11. Replaced 9,155 inline-style attributes.
   ───────────────────────────────────────────────────────── */
.u-body{font-size:1.0625rem;line-height:1.7;color:var(--ink);margin-bottom:1.25rem;}
.u-card-link{display:block;padding:1rem 1.25rem;background:var(--paper);border:1px solid rgba(11,31,58,0.15);border-radius:6px;text-decoration:none;color:var(--ink);font-size:0.92rem;font-weight:500;min-height:44px;}
.u-readable-width{max-width:46rem;}
.u-sep-bottom{margin-bottom:1.25rem;border-bottom:1px solid var(--rule);padding-bottom:1.25rem;}
.u-faq-q{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:1.25rem;color:var(--ink);cursor:pointer;list-style:none;}
.u-body-after{font-size:1.0625rem;line-height:1.7;color:var(--ink);margin-top:1rem;}
.u-section-title{font-family:var(--font-serif);font-style:italic;font-weight:300;font-size:clamp(1.75rem,3.5vw,2.5rem);color:var(--ink);margin-bottom:var(--sp-4);}
.u-link-gold{color:var(--gold);text-decoration:underline;font-weight:500;}
.u-section-canvas{padding:var(--sp-8) 0;background:var(--canvas);}
.u-section-pad{padding:var(--sp-8) 0;}
.u-container-center{max-width:980px;margin:0 auto;text-align:center;}
.u-eyebrow{font-size:0.78rem;font-weight:700;text-transform:uppercase;letter-spacing:0.18em;color:var(--gold);margin:0 0 0.5rem 0;}
.u-cta-title{font-family:var(--font-serif);font-size:1.4rem;color:var(--ink);margin:0 0 1.5rem 0;font-weight:400;}
.u-grid-cta{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:0.85rem;max-width:880px;margin:0 auto;}

/* Round-2 utility extractions */
.u-cta-gradient{background:linear-gradient(135deg, rgba(212,184,106,0.05), rgba(11,31,58,0.03));border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:2.5rem 1rem;}
.u-author-card{background:var(--paper);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:2rem 1rem;}
.u-author-flex{max-width:880px;display:flex;gap:1.25rem;align-items:flex-start;flex-wrap:wrap;}
.u-author-avatar{flex:0 0 auto;width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--gold-light) 0%,#B8956A 100%);display:flex;align-items:center;justify-content:center;color:var(--ink);font-family:var(--font-serif);font-weight:600;font-size:1.5rem;}
.u-author-body{flex:1 1 280px;}
.u-author-name{font-family:var(--font-serif);font-size:1.15rem;font-weight:600;color:var(--ink);margin:0 0 0.4rem 0;}
.u-author-bio{font-size:0.95rem;line-height:1.65;color:rgba(11,31,58,0.82);margin:0 0 0.6rem 0;}
.u-author-note{margin:0;font-size:0.9rem;}
.u-italic-mt{margin-top:0.5rem;font-style:italic;}
.u-hero-pad{padding:var(--sp-12) 0 var(--sp-8);background:linear-gradient(180deg,var(--canvas) 0%,var(--canvas) 100%);}
.u-readable-wide{max-width:62rem;}
.u-mono-eyebrow{font-family:var(--font-mono);font-size:0.78rem;letter-spacing:0.22em;color:var(--gold);font-weight:500;text-transform:uppercase;margin-bottom:1rem;}




/* ── v5.2.6l HERO PRACTICES (BIGDOT) — 3 balanced lines, large gold-dot separators ── */
.hero-practices { margin: 1.4rem 0 1.75rem 0; }
.hp-line { margin: 0; line-height: 1.55; white-space: nowrap; }
.hp-line + .hp-line { margin-top: 0.3rem; }
.hp-item {
  font-family: var(--font-sans);
  font-weight: 600;
  text-transform: uppercase;
  color: var(--ink);
  font-size: 1.05rem;
  letter-spacing: 0.18em;
}
.hp-dot {
  display: inline-block;
  color: var(--gold, #b89556);
  font-weight: 400;
  font-size: 1.6rem;
  opacity: 1;
  line-height: 1;
  position: relative;
  top: 0.05em;
  vertical-align: middle;
}
.hp-l1 .hp-dot { margin: 0 2.0em; }
.hp-l2 .hp-dot { margin: 0 1.4em; }
.hp-l3 .hp-dot { margin: 0 0.2em; }
.hp-l3 .hp-item { letter-spacing: 0.11em; }

@media (max-width: 768px) {
  .hero-practices { margin: 1.1rem 0 1.4rem 0; }
  .hp-line + .hp-line { margin-top: 0.2rem; }
  .hp-item { font-size: 0.62rem; letter-spacing: 0.08em; line-height: 1.5; }
  .hp-dot { font-size: 0.95rem; top: 0.08em; }
  .hp-l1 .hp-dot { margin: 0 1.0em; }
  .hp-l2 .hp-dot { margin: 0 0.65em; }
  .hp-l3 .hp-dot { margin: 0 0.1em; }
  .hp-l3 .hp-item { letter-spacing: 0.05em; }
}
@media (max-width: 380px) {
  .hp-item { font-size: 0.56rem; }
  .hp-dot { font-size: 0.85rem; }
  .hp-l1 .hp-dot { margin: 0 0.8em; }
  .hp-l2 .hp-dot { margin: 0 0.5em; }
  .hp-l3 .hp-dot { margin: 0 0.05em; }
}
@media (max-width: 768px) { .header-cta { display: none !important; } }
/* ── END v5.2.6l BIGDOT ── */

/* ── v5.2.6m TRIAGE MODAL ────────────────────────────────── */
.lys-triage {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  font-family: var(--font-sans, system-ui, -apple-system, sans-serif);
}
.lys-triage.is-open { display: flex; }
.lys-triage-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(11, 31, 58, 0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.lys-triage-panel {
  position: relative;
  background: var(--paper, #FFFFFF);
  color: var(--ink, #0B1F3A);
  border-radius: 6px;
  padding: 2.25rem 2rem 2rem;
  max-width: 540px;
  width: 100%;
  max-height: calc(100vh - 3rem);
  overflow-y: auto;
  box-shadow: 0 20px 50px rgba(11, 31, 58, 0.35);
  border-top: 4px solid var(--gold, #b89556);
}
.lys-triage-close {
  position: absolute;
  top: 0.4rem;
  right: 0.6rem;
  background: transparent;
  border: 0;
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
  color: var(--ink-mute, #4d5d72);
  padding: 0.3rem 0.6rem;
  border-radius: 4px;
}
.lys-triage-close:hover { background: rgba(11,31,58,0.05); }
.lys-triage-close:focus { outline: 2px solid var(--gold, #b89556); }

.lys-triage-header { margin-bottom: 1.25rem; }
.lys-triage-eyebrow {
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--gold, #b89556);
  margin: 0 0 0.5rem 0;
}
.lys-triage-title {
  font-family: var(--font-serif, 'Fraunces', serif);
  font-size: 1.65rem;
  font-weight: 600;
  line-height: 1.2;
  margin: 0 0 0.75rem 0;
  color: var(--ink, #0B1F3A);
}
.lys-triage-sub {
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--ink-mute, #4d5d72);
  margin: 0;
}

.lys-triage-form { display: block; }
.lys-triage-field { margin-bottom: 1rem; }
.lys-triage-field label,
.lys-triage-field-inline label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--ink, #0B1F3A);
  margin-bottom: 0.35rem;
}
.lys-triage-field input[type="text"],
.lys-triage-field input[type="email"],
.lys-triage-field input[type="tel"],
.lys-triage-field select,
.lys-triage-field textarea {
  width: 100%;
  padding: 0.65rem 0.85rem;
  font-size: 1rem;
  font-family: inherit;
  border: 1px solid #cdd4dd;
  border-radius: 4px;
  background: #fff;
  color: var(--ink, #0B1F3A);
  box-sizing: border-box;
}
.lys-triage-field input:focus,
.lys-triage-field select:focus,
.lys-triage-field textarea:focus {
  outline: none;
  border-color: var(--gold, #b89556);
  box-shadow: 0 0 0 3px rgba(184, 149, 86, 0.18);
}
.lys-triage-field textarea { resize: vertical; min-height: 80px; }
.lys-triage-hint, .lys-triage-hint-inline {
  font-size: 0.75rem;
  color: var(--ink-mute, #4d5d72);
}
.lys-triage-hint { display: block; margin-top: 0.3rem; }
.lys-triage-hint-inline { font-weight: 400; font-style: italic; }
.lys-req { color: var(--gold, #b89556); }

.lys-triage-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.9rem; }
@media (max-width: 480px) {
  .lys-triage-row { grid-template-columns: 1fr; gap: 0; }
}

.lys-triage-field-inline {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  margin-bottom: 0.9rem;
}
.lys-triage-field-inline input[type="checkbox"] {
  margin-top: 0.25rem;
  flex: 0 0 auto;
  width: 1.05rem;
  height: 1.05rem;
}
.lys-triage-field-inline label {
  margin: 0;
  font-size: 0.85rem;
  font-weight: 400;
  line-height: 1.45;
  color: var(--ink-mute, #4d5d72);
}

.lys-triage-actions {
  display: flex;
  gap: 0.75rem;
  margin-top: 1.25rem;
  align-items: center;
}
.lys-triage-submit {
  background: var(--ink, #0B1F3A);
  color: var(--paper, #FFFFFF);
  border: 0;
  padding: 0.85rem 1.6rem;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  border-radius: 4px;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s;
}
.lys-triage-submit:hover:not(:disabled) { background: #1a2f4d; }
.lys-triage-submit:disabled { opacity: 0.6; cursor: wait; }
.lys-triage-submit:focus { outline: 2px solid var(--gold, #b89556); outline-offset: 2px; }
.lys-triage-cancel {
  background: transparent;
  color: var(--ink-mute, #4d5d72);
  border: 0;
  font-size: 0.9rem;
  cursor: pointer;
  padding: 0.6rem 0.8rem;
  font-family: inherit;
}
.lys-triage-cancel:hover { color: var(--ink, #0B1F3A); }

.lys-triage-status {
  margin-top: 1rem;
  font-size: 0.9rem;
  line-height: 1.4;
  min-height: 1.2rem;
}
.lys-triage-status.is-error { color: #a83232; }
.lys-triage-status.is-success { color: #2c6c41; }

body.triage-modal-open { overflow: hidden; }
body.triage-modal-open #lys-sticky-cta { display: none !important; }

@media (max-width: 768px) {
  .lys-triage { padding: 0; align-items: flex-end; }
  .lys-triage-panel {
    border-radius: 12px 12px 0 0;
    max-height: 92vh;
    padding: 2rem 1.25rem 1.25rem;
  }
  .lys-triage-title { font-size: 1.35rem; }
}
/* ── END v5.2.6m TRIAGE MODAL ────────────────────────────── */

/* ───────────────────────────────────────────────────────────────────────
   v5.2.6n D45 — noscript fallback for triage modal
   When JS is disabled, hide every triage-trigger control and show a fallback
   strip with Adam's phone + email at the top of the page.
   ─────────────────────────────────────────────────────────────────────── */
.no-js [data-triage-trigger] { display: none !important; }
.no-js .lys-noscript-fallback {
  position: relative;
  z-index: 50;
  background: var(--ink, #0B1F3A);
  color: var(--paper, #FAF8F4);
  padding: 0.9rem 1.25rem;
  text-align: center;
  font-size: 0.95rem;
  line-height: 1.5;
}
.no-js .lys-noscript-fallback a {
  color: var(--gold, #D4B86A);
  text-decoration: underline;
  font-weight: 600;
}
.lys-noscript-fallback { display: none; }
.no-js .lys-noscript-fallback { display: block; }

/* ── HEADER 4-LINE WORDMARK STACK (v02) ─────────────────────────────────── */
.wordmark-text{display:flex;flex-direction:column;gap:4px;line-height:1.25;}
.wordmark-line1{
  font-family:var(--font-serif);
  font-size:2.0rem;font-weight:400;
  letter-spacing:0.03em;text-transform:none;
  color:var(--ink);
  line-height:1.15;
}
.wordmark-line2{
  font-family:var(--font-sans);font-size:0.85rem;
  letter-spacing:0.22em;color:var(--gold);font-weight:500;
  text-transform:uppercase;
}
.wordmark-line3, .wordmark-line4{
  font-family:var(--font-sans);font-size:1.15rem;font-weight:500;
  letter-spacing:0.03em;text-transform:none;
  color:var(--ink);text-decoration:none;
  transition:color var(--dur-fast);
}
.wordmark-line3:hover, .wordmark-line4:hover{color:var(--gold);}
.wordmark-line3{font-style:italic;}

/* ── PC HEADER 2-COL LAYOUT (v07.1) — header-brand-block: wordmark LEFT, contact-row RIGHT ───── */
.header-brand-block{
  display: flex;
  align-items: center;
  gap: 2.5rem;
  flex: 1 1 auto;
  min-width: 0;
}
@media(min-width:769px){
  .header-brand-block{
    flex-direction: row;
    align-items: center;
  }
  /* Wordmark-text inside <a class="wordmark"> stacks line1+line2 vertically */
  .wordmark-text{
    display: flex !important;
    flex-direction: column;
    gap: 0.15rem;
    align-items: flex-start;
  }
  .wordmark-line1{
    text-align: left;
    font-size: 2.0rem !important;
    line-height: 1.15;
    margin: 0;
  }
  .wordmark-line2{
    text-align: left;
    font-size: 0.85rem !important;
    line-height: 1.4;
    margin: 0;
  }
  /* Contact-row: flex column, phone on top, email below */
  .wordmark-contact-row{
    display: flex !important;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.15rem;
    margin: 0;
    padding: 0;
  }
  /* Phone — matches firm name size + serif */
  .wordmark-contact-row .wordmark-line4{
    font-family: var(--font-serif) !important;
    font-size: 2.0rem !important;
    font-weight: 400 !important;
    font-style: normal !important;
    letter-spacing: 0.03em;
    line-height: 1.15;
    color: var(--ink) !important;
    margin: 0;
    white-space: nowrap;
    text-decoration: none;
  }
  /* Email — directly below phone, GOLD */
  .wordmark-contact-row .wordmark-line3{
    font-family: var(--font-sans) !important;
    font-size: 1.0rem !important;
    font-style: normal !important;
    font-weight: 500;
    color: var(--gold) !important;
    line-height: 1.4;
    margin: 0;
    white-space: nowrap;
    letter-spacing: 0.02em;
    text-decoration: none;
  }
  .wordmark-contact-row .wordmark-line3:hover{ color: var(--gold-light) !important; }
  .wordmark-contact-row .wordmark-line4:hover{ color: var(--gold) !important; }
}
@media(min-width:769px) and (max-width:1100px){
  /* Tablet: smaller phone match to firm name */
  .header-brand-block{ gap: 1.5rem; }
  .wordmark-line1{ font-size: 1.6rem !important; }
  .wordmark-contact-row .wordmark-line4{ font-size: 1.6rem !important; }
  .wordmark-line2{ font-size: 0.78rem !important; }
  .wordmark-contact-row .wordmark-line3{ font-size: 0.92rem !important; }
}
@media(max-width:1100px){
  .wordmark-line1{font-size:1.7rem;}
  .wordmark-line3, .wordmark-line4{font-size:1.0rem;}
}
/* (legacy v02 mobile rules removed in v06 — replaced by mobile stack block below) */
/* (legacy v02 480px rules removed in v06) */

/* ── PRACTICE GRID 4x2 (v02) — replaces old .hero-practices hp-l1/l2/l3 lines ──── */
.practice-grid-v2{
  margin: 1.4rem 0 1.75rem 0;
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  row-gap: 0.5rem;
  column-gap: 0.6rem;
  max-width: 580px;
}
.practice-grid-v2 a.pg-item{
  font-family: var(--font-sans);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 1.0rem;
  color: var(--ink);
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--dur-fast);
}
.practice-grid-v2 a.pg-item:hover{color:var(--gold);}
.practice-grid-v2 a.pg-item.pg-left{text-align:right;}
.practice-grid-v2 a.pg-item.pg-right{text-align:left;}
.practice-grid-v2 .pg-dot{
  color: var(--gold, #b89556);
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1;
  align-self: center;
  justify-self: center;
}
@media(max-width:768px){
  .practice-grid-v2{column-gap:0.4rem;row-gap:0.35rem;max-width:none;}
  .practice-grid-v2 a.pg-item{font-size:0.7rem;letter-spacing:0.09em;}
  .practice-grid-v2 .pg-dot{font-size:1rem;}
}

/* ── SLIMMER BLUE BANNER + SCROLL CUE (v02) ────────────────────────────── */
.signature-scroll{
  min-height: auto;
  padding: var(--sp-2) var(--sp-4) var(--sp-5);
  margin: 0 var(--sp-3);
  border-radius: 8px;
}
@media(max-width:768px){
  .signature-scroll{margin:0 var(--sp-2);padding:var(--sp-2) var(--sp-3) var(--sp-4);}
}
.sig-closing{margin-top: var(--sp-5);}
.banner-scroll-cue{
  display:flex;justify-content:center;align-items:center;
  margin: 1.5rem auto 0;
  max-width: var(--container);
  color: rgba(250,248,244,0.7);
  font-family: var(--font-sans);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  gap: 0.6rem;
}
.banner-scroll-cue .bsc-label{
  color: rgba(250,248,244,0.7);
}
.banner-scroll-cue .bsc-arrow{
  display:inline-block;
  width: 24px; height: 24px;
  border: 1.5px solid rgba(250,248,244,0.55);
  border-radius: 50%;
  position: relative;
  animation: bannerScrollCueFloat 2.2s ease-in-out infinite;
}
.banner-scroll-cue .bsc-arrow::after{
  content: '';
  position: absolute; left: 50%; top: 32%;
  width: 6px; height: 6px;
  border-right: 1.5px solid rgba(250,248,244,0.85);
  border-bottom: 1.5px solid rgba(250,248,244,0.85);
  transform: translateX(-50%) rotate(45deg);
}
@keyframes bannerScrollCueFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(4px); }
}
@media (prefers-reduced-motion: reduce) {
  .banner-scroll-cue .bsc-arrow { animation: none; }
}

/* ── NAV OVERLAY — header offset (v02) ─────────────────────────────────── */
/* Don't cover the header when open */
.nav-overlay{
  top: 200px;                /* desktop header height */
  inset: 200px 0 0 0;
}
@media(max-width:1100px){
  .nav-overlay{ top: 172px; inset: 172px 0 0 0; }
}
@media(max-width:768px){
  .nav-overlay{ top: 172px; inset: 172px 0 0 0; }
}


/* ── NAV OVERLAY ORDER (v03) — Adam's specified order, same on both views ───────── */
.nav-overlay-links{display:flex;flex-direction:column;gap:0.9rem;text-align:center;margin:0 auto;width:100%;max-width:520px;}

/* Single canonical order — applies to all viewports */
.nav-overlay-links a[data-link="real-estate"]     { order: 1; }
.nav-overlay-links a[data-link="estate-planning"] { order: 2; }
.nav-overlay-links a[data-link="business-law"]    { order: 3; }
.nav-overlay-links a[data-link="ai-law"]          { order: 4; }
.nav-overlay-links a[data-link="startups"]        { order: 5; }
.nav-overlay-links a[data-link="private-equity"]  { order: 6; }
.nav-overlay-links a[data-link="family-business"] { order: 7; }
.nav-overlay-links a[data-link="general-counsel"] { order: 8; }
.nav-overlay-links a[data-link="zones"]           { order: 9; }
.nav-overlay-links a[data-link="locations"]       { order: 10; }
.nav-overlay-links a[data-link="po-polsku"]       { order: 11; }
.nav-overlay-links a[data-link="contact"]         { order: 12; }

/* Mobile: larger tappable area, scroll-friendly */
@media(max-width:768px){
  .nav-overlay-links a{ font-size: clamp(1.6rem, 6vw, 2.2rem) !important; }
  .nav-overlay-links{ gap: var(--sp-3); padding: var(--sp-4) 0; }
  .nav-overlay{ padding-top: var(--sp-2); justify-content: flex-start; overflow-y:auto; }
}


/* ── MOBILE HEADER STACK (v07.1) — logo top, 3 visual rows ───── */
@media(max-width:768px){
  /* Make brand-block stack vertically, full-width on mobile */
  .header-brand-block{
    flex-direction: column !important;
    align-items: center !important;
    width: 100% !important;
    gap: 0.4rem !important;
  }
  .site-header-inner{
    height: auto !important;
    min-height: 220px;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: var(--sp-2) var(--sp-3);
    gap: 0.4rem;
    position: relative;
  }
  .wordmark{
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.45rem !important;
    text-align: center;
    width: 100%;
  }
  .wordmark-mark{
    height: 130px !important;
    width: auto !important;
    margin: 0 auto;
  }
  /* wordmark-text: flex column with EQUAL gaps between row1/row2/contact-row */
  .wordmark-text{
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: center !important;
    gap: 0.35rem !important;
    width: 100%;
    max-width: 380px;
    margin: 0 auto;
    padding: 0 0.5rem;
    text-align: center;
    box-sizing: border-box;
  }
  .wordmark-line1{
    width: 100%;
    text-align: center !important;
    font-size: 1.4rem !important;
    line-height: 1.2 !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  .wordmark-line2{
    width: 100%;
    text-align: center !important;
    font-size: 0.78rem !important;
    letter-spacing: 0.18em !important;
    line-height: 1.2 !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  /* Contact-row wrapper holds phone (line4) on LEFT and email (line3) on RIGHT */
  .wordmark-contact-row{
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    width: 100%;
    gap: 0.5rem;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.1;
  }
  .wordmark-contact-row .wordmark-line3,
  .wordmark-contact-row .wordmark-line4{
    font-size: 1.0rem !important;
    font-style: normal !important;
    font-weight: 500 !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.2 !important;
    white-space: nowrap;
    flex: 0 0 auto;
  }
  .wordmark-contact-row .wordmark-line4{ text-align: left !important; }
  .wordmark-contact-row .wordmark-line3{ text-align: right !important; }

  /* Position the header-right (5-Min Triage button + hamburger) at the top-right corner */
  .header-right{
    position: absolute;
    top: var(--sp-2);
    right: var(--sp-3);
    gap: var(--sp-1);
  }
  
  .nav-overlay{ top: 260px !important; inset: 260px 0 0 0 !important; }
}

@media(max-width:480px){
  .site-header-inner{ min-height: 200px; }
  .wordmark-mark{ height: 110px !important; }
  .wordmark-line1{ font-size: 1.2rem !important; }
  .wordmark-line2{ font-size: 0.7rem !important; }
  .wordmark-contact-row .wordmark-line3,
  .wordmark-contact-row .wordmark-line4{ font-size: 0.9rem !important; }
  .nav-overlay{ top: 240px !important; inset: 240px 0 0 0 !important; }
}

@media(max-width:380px){
  .wordmark-text{ gap: 0.45rem !important; padding: 0 0.25rem; }
  .wordmark-line1{ font-size: 1.05rem !important; }
  .wordmark-line2{ font-size: 0.62rem !important; letter-spacing: 0.14em !important; }
  .wordmark-contact-row .wordmark-line3,
  .wordmark-contact-row .wordmark-line4{ font-size: 0.82rem !important; }
}

