/* ═══════════════════════════════════════════════════════════════════════
   THE FAULKNER FIRM — Master Design System 2025
   A Wealth Preservation & Business Law Firm · Clearwater, FL
   Palette: Navy var(--navy) · Deep var(--navy-deep) · Gold var(--gold) · Blue #0A74CC
   Type: Abril Fatface (display) · Poppins (UI) · Radley (body)
   ═══════════════════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-size:16px}
:root{
  --navy:#151444;--navy-deep:#0a0b22;--navy-mid:#1c1a5e;
  --blue:#0A74CC;--blue-light:#3a94e0;
  --gold:#c9a84c;--gold-lt:#e8c97a;--gold-dk:#a08030;
  --white:#ffffff;--warm:#fdfbf8;--cream:#f5f0e8;--cream-dk:#ede5d6;
  --g50:#f9f9f7;--g100:#f2f2ef;--g200:#e4e4df;--g300:#c8c8c0;
  --g400:#aaaaaa;--g500:#8c8c84;--g700:#4a4a44;--g900:#1a1a16;
  --text:#252520;--muted:#68685e;
  --max-w:1360px;--nav-h:76px;
  --ease:cubic-bezier(.22,1,.36,1);
  --shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 16px rgba(0,0,0,.10),0 2px 6px rgba(0,0,0,.06);
  --shadow-lg:0 12px 40px rgba(0,0,0,.14),0 4px 16px rgba(0,0,0,.08);
  --shadow-xl:0 24px 64px rgba(0,0,0,.18),0 8px 24px rgba(0,0,0,.10);
  --banner-offset:42px;
  --g600:#6a6a62;
  --off-white:#fafaf8;
}
body{font-family:'Radley',Georgia,serif;font-size:17px;line-height:1.78;color:var(--text);background:var(--white);overflow-x:hidden}
h1,h2,h3{font-family:'Abril Fatface',Georgia,serif;font-weight:400;line-height:1.08;letter-spacing:-.02em;color:var(--navy)}

/* H2/H3 white text in dark sections */
.bg-navy h2,.bg-navy h3,
.bg-deep h2,.bg-deep h3,
.cta-banner h2,.cta-banner h3,
.hero-boutique h2,.hero-boutique h3{
  color:var(--white);
}
.page-hero-inner h1,.page-hero-inner h2,.page-hero-inner h3{
  color:var(--white);
}
.hero-content h1,.hero-content h2{
  color:var(--white);
}

h4,h5,h6{font-family:'Poppins',sans-serif;font-weight:600;line-height:1.35;color:var(--navy)}
h1{font-size:clamp(2.8rem,6vw,4.8rem)}h2{font-size:clamp(2rem,4vw,3.2rem)}h3{font-size:clamp(1.4rem,2.5vw,2rem)}
h4{font-size:1rem}h5{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase}
p{margin-bottom:1.4em}p:last-child{margin-bottom:0}
a{color:var(--blue);transition:color .2s}a:hover{color:var(--navy)}
img{max-width:100%;height:auto;display:block}
strong{font-weight:700;font-family:'Poppins',sans-serif;font-size:.95em}
ul,ol{padding-left:1.5rem}li{margin-bottom:.4em}

/* ══ PRIMARY LAYOUT DEFINITIONS (must come before responsive overrides) ════ */

/* HERO */
.hero-boutique{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background:var(--navy-deep)}
.hero-photo{position:absolute;inset:0;background-size:cover;background-position:center center;opacity:.18;filter:grayscale(20%)}
.hero-content{position:relative;z-index:2;width:100%;max-width:var(--max-w);margin:0 auto;padding:clamp(6rem,12vw,10rem) clamp(1.5rem,5vw,4rem) clamp(4rem,8vw,6rem)}
.hero-areas{position:relative;z-index:2;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:1.25rem clamp(1.5rem,5vw,4rem);background:rgba(10,11,34,.6);backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,.08)}
.hero-areas a{font-family:'Poppins',sans-serif;font-size:.7rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.55);text-decoration:none;transition:color .2s}
.hero-areas a:hover{color:rgba(255,255,255,.88)}
.hero-areas 
.hero-rule-v{position:absolute;left:clamp(1.5rem,5vw,4rem);top:0;bottom:0;width:1px;background:linear-gradient(to bottom,transparent 0%,rgba(201,168,76,.3) 20%,rgba(201,168,76,.3) 80%,transparent 100%);z-index:1}
.hero-est{position:absolute;left:calc(clamp(1.5rem,5vw,4rem) + 1.5rem);top:50%;transform:translateY(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.4rem}
.hero-scroll{position:absolute;bottom:7rem;right:2.5rem;z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.hero-scroll span{font-family:'Poppins',sans-serif;font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3);writing-mode:vertical-rl}

/* INTRO SPLIT (About Debbie on homepage) */
.intro-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(4rem,8vw,10rem);align-items:center}

/* BIO SPLIT (About page) */
.bio-split{display:grid;grid-template-columns:1fr 1.6fr;gap:clamp(3rem,6vw,7rem);align-items:start}

/* AUDIENCE GRID */
.audience-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:3rem}
.audience-item{padding:2rem;border:1px solid var(--g200);background:var(--white);transition:box-shadow .25s}
.audience-item:hover{box-shadow:0 4px 20px rgba(0,0,0,.06)}
.audience-icon-wrap{width:44px;height:44px;background:var(--cream);border-radius:2px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;color:var(--navy)}
.audience-item h4{font-family:'Poppins',sans-serif;font-weight:700;font-size:.9rem;color:var(--navy);margin-bottom:.5rem}
.audience-item p{font-family:'Radley',serif;font-size:.92rem;color:var(--muted);line-height:1.68;margin:0}

/* ADVISE GRID */
.advise-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px;background:rgba(255,255,255,.06)}
.advise-item{padding:2.25rem 2rem;display:flex;flex-direction:column;position:relative;overflow:hidden;transition:background .3s;background:rgba(255,255,255,.03)}
.advise-item:hover{background:rgba(255,255,255,.07)}
.advise-icon{width:52px;height:52px;background:rgba(10,116,204,.12);border:1px solid rgba(10,116,204,.2);border-radius:2px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;color:var(--blue);flex-shrink:0}
.advise-item h4{color:rgba(255,255,255,.88);font-size:.9rem;margin-bottom:.6rem}
.advise-item p{font-size:.88rem;color:rgba(255,255,255,.65);margin:0;line-height:1.72}

/* TEAM GRID */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.team-card{background:var(--white);overflow:hidden;border:1px solid var(--g200)}
.team-card-photo{aspect-ratio:1;overflow:hidden;background:var(--navy)}
.team-card-photo img{width:100%;height:100%;object-fit:cover;object-position:top}
.team-card h3{font-family:'Poppins',sans-serif;font-weight:700;font-size:1rem;color:var(--navy);margin:0 0 .3rem;padding:1.5rem 1.5rem 0}
.team-card .role{font-family:'Poppins',sans-serif;font-size:.73rem;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);display:block;padding:0 1.5rem .5rem}
.team-card p{font-family:'Radley',serif;font-size:.9rem;color:var(--muted);line-height:1.65;padding:0 1.5rem;margin:0 0 1rem}
.team-link{font-family:'Poppins',sans-serif;font-size:.78rem;font-weight:600;color:var(--blue);text-decoration:none;padding:0 1.5rem 1.5rem;display:block;transition:color .2s}
.team-link:hover{color:var(--navy)}

/* REVIEWS GRID */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}

/* CONTACT SPLIT */
.contact-split{display:grid;grid-template-columns:1.4fr 1fr;gap:4rem;align-items:start}

/* CTA BANNER */
.cta-banner{background:var(--navy-deep);padding:clamp(4rem,7vw,6rem) 0;text-align:center;position:relative;overflow:hidden;border-top:2px solid rgba(201,168,76,.25)}
.cta-banner::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(201,168,76,.06) 0%,transparent 60%)}
.cta-banner h2{font-size:clamp(1.75rem,4vw,2.5rem);margin-bottom:1rem;color:var(--white)}
.cta-banner p{font-family:'Radley',serif;font-size:1.05rem;color:rgba(255,255,255,.62);max-width:560px;margin:0 auto 2.5rem;line-height:1.75}
.cta-actions{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}

/* ══ MISSING PRIMARY DEFINITIONS ═══════════════════════════════════════════ */

/* Hero headline - the most important element on the site */
.hero-headline{
  font-family:'Abril Fatface',serif;
  font-size:clamp(3rem,7vw,5.5rem);
  color:var(--white);
  line-height:1.05;
  letter-spacing:-.03em;
  margin:0;
}
.hero-headline em{
  font-style:italic;
  color:var(--gold);
}

/* Practice area layout - 2-col with sidebar */
.pa-layout{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:4rem;
  align-items:start;
}
.pa-sidebar{
  position:sticky;
  top:calc(var(--nav-h) + 2rem);
}

/* Intro photo frame */
.intro-photo-frame{
  position:absolute;
  bottom:-2rem;
  left:-2rem;
  background:var(--navy);
  padding:1.5rem 2rem;
  z-index:2;
}

/* LAYOUT */
.wrap{max-width:var(--max-w);margin:0 auto;padding:0 clamp(1.5rem,5vw,4rem)}
.wrap--sm{max-width:960px;margin:0 auto;padding:0 clamp(1.5rem,5vw,4rem)}
.wrap--text{max-width:740px;margin:0 auto;padding:0 clamp(1.5rem,5vw,4rem)}
.section{padding:clamp(5rem,9vw,9rem) 0}
.section--sm{padding:clamp(3rem,5vw,5rem) 0}
.section--lg{padding:clamp(7rem,12vw,12rem) 0}
.section--xs{padding:clamp(2rem,3.5vw,3.5rem) 0}
.bg-white{background:var(--white)}.bg-warm{background:var(--warm)}.bg-cream{background:var(--cream)}.bg-gray{background:var(--g50)}.bg-navy{background:var(--navy);border-bottom:1px solid rgba(255,255,255,.06)}.bg-deep{background:var(--navy-deep)}.bg-gold{background:var(--gold)}
.text-center{text-align:center}.text-gold{color:var(--gold)}.text-blue{color:var(--blue)}.text-white{color:var(--white)!important}.text-italic{font-style:italic}
.mt-1{margin-top:.5rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mt-6{margin-top:3rem}.mb-0{margin-bottom:0!important}.mb-2{margin-bottom:1rem}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.revealed{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-32px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal-left.revealed,.reveal-right.revealed{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.32s}.reveal-delay-4{transition-delay:.46s}

/* EYEBROW / SECTION RULE */
.eyebrow{display:inline-flex;align-items:center;gap:.85rem;font-family:'Poppins',sans-serif;font-size:.73rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);margin-bottom:1.1rem}
.eyebrow::before{content:'';display:block;width:2.5rem;height:1.5px;background:var(--gold);flex-shrink:0}
.eyebrow--gold{color:var(--gold)}.eyebrow--white{color:rgba(255,255,255,.42)}.eyebrow--white::before{background:rgba(201,168,76,.45)}
.section-rule{display:flex;align-items:center;gap:1.25rem;margin-bottom:1.25rem}
.section-rule::before,.section-rule::after{content:'';flex:0 0 2rem;height:1.5px;background:var(--gold)}
.section-rule::after{display:none}
.section-rule span{font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);white-space:nowrap}
.section-rule
.section-rule.centered::after{display:block}
.section-rule.on-dark span{color:rgba(255,255,255,.62)}.section-rule.on-dark::before,.section-rule.on-dark::after{background:rgba(201,168,76,.38)}
.section-header{margin-bottom:3.5rem}.section-header h2{margin-bottom:.85rem}
.section-header p{font-size:1.05rem;color:var(--muted);max-width:540px;line-height:1.72;margin:0}
.section-header.section-header.centered p{margin-inline:auto}
.lead{font-size:clamp(1.05rem,1.8vw,1.22rem);line-height:1.72;color:var(--g700);margin-bottom:1.75rem}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:'Poppins',sans-serif;font-weight:600;font-size:.72rem;letter-spacing:.17em;text-transform:uppercase;text-decoration:none;cursor:pointer;padding:.9rem 2rem;border:1.5px solid transparent;transition:all .28s var(--ease);line-height:1;white-space:nowrap;position:relative;overflow:hidden}
.btn-primary,.btn-navy{background:var(--navy);color:var(--white);border-color:var(--navy)}
.btn-primary:hover,.btn-navy:hover{background:var(--navy-mid);border-color:var(--navy-mid);color:var(--white)}
.btn-accent{background:var(--blue);color:var(--white);border-color:var(--blue)}
.btn-accent:hover{background:var(--blue-light);border-color:var(--blue-light);color:var(--white)}
.btn-gold{background:var(--gold);color:var(--navy-deep);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-lt);border-color:var(--gold-lt)}
.btn-outline{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:var(--white)}
.btn-outline-white{background:transparent;color:var(--white);border-color:rgba(255,255,255,.3)}
.btn-outline-white:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7);color:var(--white)}
.btn-ghost-gold{background:transparent;color:var(--gold);border-color:var(--gold)}
.btn-ghost-gold:hover{background:var(--gold);color:var(--navy-deep)}
.btn--lg{padding:1.15rem 2.75rem;font-size:.76rem}.btn--sm{padding:.55rem 1.4rem;font-size:.72rem}.btn--full{width:100%}
.btn-group{display:flex;gap:1rem;flex-wrap:wrap}

/* NAV */
/* ══ SITE HEADER ══════════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════════════
   SITE HEADER
═══════════════════════════════════════════════════════════════ */
.site-header{
  position:fixed;top:var(--banner-offset,0px);left:0;right:0;
  z-index:900;
  transition:background .35s ease,box-shadow .35s ease,top .3s ease;
}
.site-header.scrolled,
.site-header.page-nav{
  background:rgba(10,11,34,.97);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(255,255,255,.06),0 4px 24px rgba(0,0,0,.3);
}

/* Gradient accent bar — always visible on page-nav, appears on scroll for hero pages */
.nav-top-bar{
  height:2px;
  background:linear-gradient(90deg,var(--navy-deep) 0%,var(--gold) 45%,var(--blue) 70%,var(--navy-deep) 100%);
  opacity:0;
  transition:opacity .35s;
}
.site-header.scrolled .nav-top-bar,
.site-header.page-nav .nav-top-bar{opacity:1}


/* Nav inner layout */
.nav-inner{
  max-width:1440px;margin:0 auto;
  padding:0 clamp(1.5rem,3.5vw,3rem);
  height:70px;
  display:flex;align-items:center;gap:1.75rem;
}

/* Logo */
.nav-logo{display:flex;align-items:center;flex-shrink:0;text-decoration:none;margin-right:.5rem}
.nav-logo-img{height:40px;width:auto;filter:brightness(0) invert(1);opacity:.88;transition:opacity .2s}
.nav-logo:hover .nav-logo-img{opacity:1}

/* Nav links list */
.nav-links{
  display:flex;align-items:stretch;list-style:none;
  margin:0;padding:0;gap:0;margin-left:auto;
}
.nav-links > li > a{
  font-family:'Poppins',sans-serif;font-weight:500;
  font-size:.73rem;letter-spacing:.09em;text-transform:uppercase;
  color:rgba(255,255,255,.68);text-decoration:none;
  padding:0 .95rem;height:70px;
  display:flex;align-items:center;gap:.28rem;
  position:relative;transition:color .2s;white-space:nowrap;
}
.nav-links > li > a::after{
  content:'';position:absolute;bottom:0;left:.95rem;right:.95rem;
  height:2px;background:var(--gold);
  transform:scaleX(0);transform-origin:left;
  transition:transform .28s ease;
}
.nav-links > li > a:hover{color:rgba(255,255,255,.95)}
.nav-links > li > a:hover::after,
.nav-links > li > a.active::after{transform:scaleX(1)}
.nav-links > li > a.active{color:var(--white)}

/* Chevron */
.nav-chevron{transition:transform .22s;opacity:.55;flex-shrink:0}
.nav-has-sub:hover .nav-chevron{transform:rotate(180deg);opacity:.85}

/* Dropdown */
.nav-has-sub{position:relative}
.nav-sub{
  position:absolute;top:100%;left:50%;
  transform:translateX(-50%) translateY(-4px);
  min-width:200px;
  background:rgba(10,11,34,.98);
  backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.1);
  border-top:2px solid var(--gold);
  padding:.5rem 0;
  opacity:0;pointer-events:none;
  transition:opacity .2s ease,transform .2s ease;
  z-index:10;
}
.nav-has-sub:hover .nav-sub{
  opacity:1;pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.nav-sub a{
  display:block;
  font-family:'Poppins',sans-serif;font-size:.75rem;font-weight:500;
  letter-spacing:.04em;
  color:rgba(255,255,255,.68);
  text-decoration:none;
  padding:.65rem 1.4rem;
  border-left:2px solid transparent;
  transition:color .16s,background .16s,border-color .16s,padding-left .16s;
}
.nav-sub a:hover{
  color:white;background:rgba(255,255,255,.05);
  border-left-color:var(--gold);padding-left:1.65rem;
}

/* Right cluster */
.nav-right{display:flex;align-items:center;gap:.85rem;flex-shrink:0}
.nav-phone{
  display:flex;align-items:center;gap:.45rem;
  font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:500;
  color:rgba(255,255,255,.5);text-decoration:none;letter-spacing:.03em;
  transition:color .2s;white-space:nowrap;
}
.nav-phone:hover{color:rgba(255,255,255,.8)}
.nav-cta-btn{
  flex-shrink:0;white-space:nowrap;
  font-family:'Poppins',sans-serif;font-weight:700;
  font-size:.71rem;letter-spacing:.13em;text-transform:uppercase;
  color:var(--navy-deep);text-decoration:none;
  padding:.62rem 1.35rem;
  background:var(--gold);border:2px solid var(--gold);
  transition:background .22s,color .22s;
}
.nav-cta-btn:hover{background:transparent;color:var(--gold)}

/* Hamburger */
.hamburger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  background:none;border:none;cursor:pointer;
  padding:.5rem;width:40px;height:40px;margin-left:auto;flex-shrink:0;
}
.hamburger span{
  display:block;width:22px;height:1.5px;
  background:rgba(255,255,255,.8);
  transition:all .28s;transform-origin:center;
}
.hamburger.open span:first-child{transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:last-child{transform:translateY(-6.5px) rotate(-45deg)}

/* ══ MOBILE MENU ════════════════════════════════════════════════ */
.mobile-menu{
  position:fixed;top:0;right:0;bottom:0;
  width:min(340px,88vw);
  background:var(--navy-deep);
  z-index:1100;
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
}
.mobile-menu.open{transform:translateX(0)}
.mobile-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.72);backdrop-filter:blur(3px);
  z-index:1099;opacity:0;pointer-events:none;
  transition:opacity .35s;
}
.mobile-overlay.open{opacity:1;pointer-events:auto}
.mobile-menu-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.35rem 1.75rem;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.mobile-menu-close{
  background:none;border:none;cursor:pointer;
  color:rgba(255,255,255,.55);padding:.5rem;
  transition:color .2s;
}
.mobile-menu-close:hover{color:white}
.mobile-nav{flex:1;padding:.5rem 0;display:flex;flex-direction:column}
.mobile-link{
  font-family:'Poppins',sans-serif;font-weight:500;
  font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.7);text-decoration:none;
  padding:.95rem 1.75rem;
  display:flex;align-items:center;justify-content:flex-start;gap:.5rem;
  border-bottom:1px solid rgba(255,255,255,.05);
  transition:color .18s,background .18s;
;display:flex;align-items:center;justify-content:space-between}
.mobile-link:hover{color:white;background:rgba(255,255,255,.04)}
.mobile-sub{
  display:none;flex-direction:column;
  background:rgba(0,0,0,.2);
  border-bottom:1px solid rgba(255,255,255,.05);
}
.mobile-group.open 
.mobile-group.open .mobile-link svg{transform:rotate(180deg)}
.mobile-sub a{
  font-family:'Poppins',sans-serif;font-size:.76rem;
  color:rgba(255,255,255,.55);text-decoration:none;
  padding:.75rem 1.75rem .75rem 2.25rem;
  border-left:2px solid transparent;
  transition:color .16s,border-color .16s,padding-left .16s;
}
.mobile-sub a:hover{color:white;border-left-color:var(--gold);padding-left:2.5rem}
.mobile-footer{
  padding:1.5rem 1.75rem;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;gap:.75rem;
}
.mobile-cta{
  display:block;text-align:center;
  font-family:'Poppins',sans-serif;font-weight:700;
  font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--navy-deep);background:var(--gold);
  padding:.85rem 1.5rem;text-decoration:none;
  transition:opacity .2s;
}
.mobile-cta:hover{opacity:.9}
.mobile-contact{
  text-align:center;
  font-family:'Poppins',sans-serif;font-size:.78rem;
  color:rgba(255,255,255,.4);margin:0;
}
.mobile-contact a{color:rgba(255,255,255,.5);text-decoration:none}
.mobile-contact a:hover{color:rgba(255,255,255,.8)}

/* Responsive header */

/* ══ MISSING GLOBAL LAYOUT DEFINITIONS ═════════════════════════════════════ */

/* Pillars grid (Philosophy section on About page) */
.pillars{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.5rem 2.5rem;
  margin-top:2.5rem;
}
.pillar{
  padding:1.25rem 1.5rem;
  border-left:2px solid rgba(201,168,76,.2);
  transition:border-color .2s;
}
.pillar:hover{border-left-color:var(--gold)}
.pillar p{
  font-family:'Radley',serif;
  font-size:.9rem;
  color:rgba(255,255,255,.62);
  line-height:1.72;
  margin:0;
}


/* ══ INTRO PHOTO BADGE (overlaid on Debbie's photo) ══════════════════════ */
.intro-photo{position:relative;flex-shrink:0}
.intro-photo img{width:100%;display:block;object-fit:cover;position:relative;z-index:1}
.intro-photo-badge{
  position:absolute;
  bottom:2rem;
  right:-1.5rem;
  background:var(--navy);
  color:var(--white);
  padding:1.5rem 1.75rem;
  z-index:3;
  min-width:180px;
}
.intro-photo-badge p{
  font-family:'Poppins',sans-serif;
  font-weight:700;
  font-size:.85rem;
  line-height:1.65;
  letter-spacing:.02em;
  color:var(--white);
  margin:0;
}
.intro-photo-frame{
  position:absolute;
  top:-1rem;
  left:-1rem;
  right:-1rem;
  bottom:-1rem;
  border:2px solid var(--gold);
  opacity:.3;
  z-index:0;
  pointer-events:none;
}


/* ══ PA STAT GRID (nested 2x2 inside two-col-grid) ═════════════════════════ */
.pa-stat-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.25rem;
}
@media(max-width:640px){
  .pa-stat-grid{grid-template-columns:1fr}
}

@media(max-width:1100px){
  .nav-phone{display:none}
  .pa-layout{grid-template-columns:1fr}.pa-sidebar{position:static}.contact-split{grid-template-columns:1fr}.footer-inner{grid-template-columns:1fr 1fr;gap:2.5rem}.intro-split{gap:3.5rem}
}
@media(max-width:900px){
  .hero-boutique{min-height:90vh}
  .hero-headline{font-size:clamp(2.5rem,8vw,4rem)}
  .hero-content{padding:0 1.75rem 5rem}
  .hero-rule-v,.hero-scroll,.hero-areas,.hero-est{display:none}
  .nav-links,.nav-right{display:none}
  .hamburger{display:flex}
  .nav-inner{height:62px;gap:1rem}
  .nav-logo-img{height:36px}
  .nav-links,.nav-cta-btn{display:none}
  .bio-split{grid-template-columns:1fr}
  .bio-photo-wrap{max-width:420px}
  .bio-photo-frame{display:none}
  .intro-split{grid-template-columns:1fr;gap:3rem}
  .intro-photo-frame{display:none}
  .intro-photo-badge{position:static;margin-top:1.25rem;align-self:flex-start}
  .team-grid,.team-strip-grid{grid-template-columns:repeat(2,1fr)}
  .causes-grid{grid-template-columns:1fr}
  .pa-overview-grid{grid-template-columns:1fr}
  .pa-outcome-list{grid-template-columns:1fr}
  .stats-inner{grid-template-columns:1fr}
  .stat-item+.stat-item::before{display:none}
  .pillars{grid-template-columns:1fr}
  .video-inner{grid-template-columns:1fr}
  .cause-mini-grid{grid-template-columns:1fr}
  .accolades-inner{justify-content:flex-start}
  .accolade-item{padding:.85rem .9rem;gap:.55rem;flex:0 0 auto}
  .accolade-featured{padding:.85rem 1rem}
  .accolade-logo{height:32px}
  .accolade-icon{width:30px;height:30px;min-width:30px}
  .accolade-text strong{font-size:.68rem}
  .accolade-text span{font-size:.6rem}
  .advise-header-grid{grid-template-columns:1fr;gap:1.5rem;margin-bottom:2rem}
  .community-split{grid-template-columns:1fr;gap:3rem}
  .honorable-grid{grid-template-columns:repeat(2,1fr)}
  .framework-grid{grid-template-columns:repeat(2,1fr)}
  .framework-step:nth-child(3){border-right:1.5px solid var(--g200);border-bottom:1.5px solid var(--g200)}
  .framework-step:nth-child(2n){border-right:none}
  .framework-step:nth-child(5),.framework-step:nth-child(6){border-bottom:none}
  .awards-grid{grid-template-columns:repeat(2,1fr)}
}

/* ══════════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════════ */
.site-footer{background:var(--navy-deep);border-top:2px solid rgba(201,168,76,.15)}
.footer-main{padding:clamp(4rem,7vw,6rem) 0 clamp(3rem,5vw,4.5rem)}
.footer-grid{
  display:grid;
  grid-template-columns:1.7fr 1fr 1fr 1.35fr;
  gap:3rem;align-items:start;
}

/* Brand column */
.footer-brand-col{display:flex;flex-direction:column}
.footer-logo-link{display:inline-block;margin-bottom:1.35rem}
.footer-logo-img{height:38px;width:auto;filter:brightness(0) invert(1);opacity:.78;display:block}
.footer-desc{
  font-family:'Radley',serif;font-size:.88rem;
  color:rgba(255,255,255,.5);line-height:1.78;margin:0 0 .75rem;
}
.footer-quote{
  font-family:'Radley',serif;font-style:italic;font-size:.83rem;
  color:rgba(255,255,255,.38);
  border-left:2px solid var(--gold);padding-left:.85rem;
  margin:0 0 1.75rem;line-height:1.55;
}
.footer-socials{display:flex;gap:.85rem;flex-wrap:wrap}
.footer-social-link{
  display:inline-flex;align-items:center;gap:.45rem;
  font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:500;
  color:rgba(255,255,255,.42);text-decoration:none;letter-spacing:.04em;
  padding:.38rem .85rem .38rem .7rem;
  border:1px solid rgba(255,255,255,.1);
  transition:color .18s,border-color .18s,background .18s;
}
.footer-social-link:hover{
  color:var(--gold);border-color:rgba(201,168,76,.35);
  background:rgba(201,168,76,.06);
}

/* Nav columns */
.footer-nav-col h5{
  font-family:'Poppins',sans-serif;font-weight:700;
  font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);margin:0 0 1.25rem;
  padding-bottom:.55rem;border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-nav-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.05rem}
.footer-nav-col ul li a{
  font-family:'Poppins',sans-serif;font-size:.79rem;
  color:rgba(255,255,255,.5);text-decoration:none;
  padding:.32rem 0;display:flex;align-items:center;
  border-left:2px solid transparent;padding-left:0;
  transition:color .16s,padding-left .16s,border-color .16s;
}
.footer-nav-col ul li a:hover{
  color:rgba(255,255,255,.9);padding-left:.5rem;border-left-color:var(--gold);
}

/* Contact column */
.footer-contact h5{
  font-family:'Poppins',sans-serif;font-weight:700;
  font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);margin:0 0 1.25rem;
  padding-bottom:.55rem;border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-contact-items{list-style:none;padding:0;margin:0 0 1.5rem;display:flex;flex-direction:column;gap:.85rem}
.footer-contact-items li{
  display:flex;align-items:flex-start;gap:.7rem;
  font-family:'Poppins',sans-serif;font-size:.79rem;
  color:rgba(255,255,255,.48);line-height:1.55;
}
.footer-contact-items li svg{flex-shrink:0;color:var(--gold);opacity:.65;margin-top:.12rem}
.footer-contact-items li a{color:rgba(255,255,255,.58);text-decoration:none;transition:color .18s}
.footer-contact-items li a:hover{color:rgba(255,255,255,.88)}
.footer-cta-link{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:'Poppins',sans-serif;font-weight:700;
  font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--gold);text-decoration:none;
  border-bottom:1.5px solid rgba(201,168,76,.35);
  padding-bottom:.2rem;
  transition:border-color .2s,gap .2s;
}
.footer-cta-link:hover{border-color:var(--gold);gap:.75rem}

/* Bottom bar */
.footer-bar{border-top:1px solid rgba(255,255,255,.06);padding:1.2rem 0}
.footer-bar-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;flex-wrap:wrap;
}
.footer-bar p{
  font-family:'Poppins',sans-serif;font-size:.7rem;
  color:rgba(255,255,255,.35);margin:0;
}
.footer-bar nav{display:flex;align-items:center;gap:.75rem}
.footer-bar nav a{
  font-family:'Poppins',sans-serif;font-size:.7rem;
  color:rgba(255,255,255,.38);text-decoration:none;
  transition:color .18s;
}
.footer-bar nav a:hover{color:rgba(255,255,255,.65)}
.footer-bar nav span{color:rgba(255,255,255,.2)}

/* Responsive footer */
@media(max-width:1080px){.footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}}
@media(max-width:640px){
  .footer-grid{grid-template-columns:1fr;gap:2.25rem}
  .footer-bar-inner{flex-direction:column;align-items:center;text-align:center;gap:.6rem}
  .team-grid,.team-strip-grid{grid-template-columns:1fr;max-width:400px;margin-inline:auto}.awards-grid{grid-template-columns:1fr}.audience-grid{grid-template-columns:1fr}.advise-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}.footer-inner{grid-template-columns:1fr}.cta-actions{flex-direction:column;align-items:center}.pb-criteria{grid-template-columns:1fr}.reviews-grid{grid-template-columns:1fr}.newsletter-form{flex-direction:column}.newsletter-form input{border-right:1.5px solid rgba(255,255,255,.12)}.contact-form-card{padding:2rem 1.75rem}.pa-outcome-grid{grid-template-columns:1fr}
  .phil-grid{grid-template-columns:1fr!important;gap:3rem}.contact-form{padding:2rem 1.5rem}
}

/* RESPONSIVE */

@media(max-width:960px){
  .audience-grid{grid-template-columns:repeat(2,1fr)}.advise-grid{grid-template-columns:repeat(2,1fr)}.awards-grid{grid-template-columns:repeat(2,1fr)}.faq-grid{grid-template-columns:1fr}.faq-item:nth-child(2){border-top:none}.reviews-grid{grid-template-columns:repeat(2,1fr)}
  .practice-cards{grid-template-columns:1fr}.two-col-grid{grid-template-columns:1fr;gap:3rem}.contact-layout{grid-template-columns:1fr}.probono-layout{grid-template-columns:1fr}
}

/* =====================================================
   SUPPLEMENT — MISSING CLASS DEFINITIONS
   ===================================================== */

/* FOOTER — base classes */
.footer-brand{/* grid area — child styles handle content */}
.footer-col{/* grid area — child styles handle content */}
.footer-contact p{font-family:'Poppins',sans-serif;font-size:.82rem;color:rgba(255,255,255,.62);line-height:1.72;margin-bottom:.5rem}
.footer-contact a{color:rgba(255,255,255,.65);text-decoration:none;transition:color .2s}
.footer-contact a:hover{color:rgba(255,255,255,.82)}

/* MOBILE NAV — group with sub-menu */
.mobile-group{position:relative}
.mobile-group>
.mobile-group>.mobile-link svg{transition:transform .28s;opacity:.5;flex-shrink:0}
.mobile-group 
.mobile-group .mobile-sub a{display:block;font-family:'Poppins',sans-serif;font-size:.82rem;color:rgba(255,255,255,.65);padding:.55rem .75rem;text-decoration:none;transition:color .2s,padding-left .2s}
.mobile-group .mobile-sub a:hover{color:rgba(255,255,255,.92);padding-left:1rem}
.mobile-logo-img{height:36px;width:auto;filter:brightness(0) invert(1);opacity:.7}

/* CTA BANNER INNER */
.cta-banner-inner{max-width:760px;margin:0 auto;text-align:center;padding:0 clamp(1.5rem,5vw,4rem)}

/* EYEBROW — LIGHT VARIANT */
.eyebrow--light{color:rgba(255,255,255,.45);border-left-color:var(--gold)}

/* SECTION TITLE */
.section-title{margin-bottom:3.5rem}
.section-title h2{margin-bottom:1rem}
.section-title p{font-family:'Radley',serif;font-size:1.05rem;color:var(--muted);max-width:620px;line-height:1.8}
.section-title.centered{text-align:center}
.section-title.centered p{margin:0 auto}

/* PHILOSOPHY GRID */
.phil-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}

/* REVIEW STARS */
.review-stars{color:var(--gold);font-size:1rem;letter-spacing:.1em;margin-bottom:1.25rem}

/* BIO PHOTO CAPTION */
.bio-photo-caption{font-family:'Poppins',sans-serif;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-align:center;margin-top:.75rem}

/* PRACTICE AREA CARDS GRID */
.practice-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:3.5rem}
.practice-card{background:var(--white);border:1px solid var(--g200);padding:2.5rem 2rem;transition:box-shadow .25s,transform .25s;display:flex;flex-direction:column}
.practice-card:hover{box-shadow:0 12px 40px rgba(21,20,68,.1);transform:translateY(-3px)}
.practice-card-icon{width:52px;height:52px;background:var(--cream);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}
.practice-card h3{font-family:'Abril Fatface',serif;font-size:1.5rem;color:var(--navy);margin-bottom:.85rem;line-height:1.2}
.practice-card p{font-family:'Radley',serif;font-size:.97rem;color:var(--muted);line-height:1.78;margin-bottom:1.5rem;flex:1}
.practice-card-services{list-style:none;padding:0;margin:0 0 1.75rem;border-top:1px solid var(--g200);padding-top:1.25rem}
.practice-card-services li{font-family:'Poppins',sans-serif;font-size:.77rem;color:var(--text);padding:.38rem 0;border-bottom:1px solid var(--g100);display:flex;align-items:center;gap:.5rem}
.practice-card-services li::before{content:'';width:4px;height:4px;background:var(--gold);border-radius:50%;flex-shrink:0}
.practice-card-link{font-family:'Poppins',sans-serif;font-size:.78rem;font-weight:600;color:var(--navy);text-decoration:none;letter-spacing:.04em;transition:color .2s;display:inline-flex;align-items:center;gap:.35rem;margin-top:auto}
.practice-card-link:hover{color:var(--blue)}

/* TWO COL GRID */
.two-col-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}

/* PA MAIN */
.pa-main{min-width:0}

/* ADVISE ON NAVY */
.advise-on-navy{background:var(--navy-deep);padding:clamp(5rem,8vw,7.5rem) 0}

/* TEAM CARD sub-elements */
.team-card-body{padding:1.75rem;display:flex;flex-direction:column;flex:1}
.team-card-img{position:relative;overflow:hidden;aspect-ratio:3/4;background:var(--g100);margin-bottom:0}.team-card-img img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;transition:transform .65s var(--ease)}.team-card:hover .team-card-img img{transform:scale(1.04)}
.team-card-name{font-family:'Abril Fatface',serif;font-size:1.25rem;color:var(--navy);margin-bottom:.2rem;line-height:1.2}
.team-card-role{font-family:'Poppins',sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.team-card-bio{font-family:'Radley',serif;font-size:.93rem;color:var(--muted);line-height:1.75;flex:1;margin-bottom:1.25rem}
.team-card-creds{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:auto}
.team-placeholder{background:var(--cream);aspect-ratio:3/4;display:flex;align-items:center;justify-content:center}
.team-placeholder svg{opacity:.2}

/* CONTACT PAGE */
.contact-layout{display:grid;grid-template-columns:1.15fr 0.85fr;gap:3.5rem;align-items:start}
.contact-form{background:var(--white);border:1px solid var(--g200);padding:2.75rem 2.5rem}
.contact-form h3{font-family:'Abril Fatface',serif;font-size:1.65rem;color:var(--navy);margin-bottom:.75rem}
.contact-form>p{font-family:'Radley',serif;font-size:.95rem;color:var(--muted);line-height:1.75;margin-bottom:2rem}
.form-field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.25rem}
.form-field label{font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text)}
.form-field input,.form-field select,.form-field textarea{font-family:'Poppins',sans-serif;font-size:.88rem;color:var(--text);border:1.5px solid var(--g300);padding:.7rem 1rem;background:var(--white);outline:none;transition:border-color .2s;width:100%;box-sizing:border-box}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--navy)}
.form-field textarea{min-height:140px;resize:vertical;line-height:1.65}
.contact-info-card{background:var(--white);border:1px solid var(--g200);padding:2.5rem}
.contact-info-card h4{font-family:'Abril Fatface',serif;font-size:1.35rem;color:var(--navy);margin-bottom:2rem}
.contact-detail{
  display:flex;gap:1rem;align-items:flex-start;padding:.75rem 0;border-bottom:1px solid var(--g100)
  font-family:'Poppins',sans-serif;font-size:.78rem;color:var(--muted);margin:0;line-height:1.65
}
.contact-detail:last-of-type{border-bottom:none}
.contact-icon{width:38px;height:38px;background:var(--cream);border:1px solid var(--g200);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--navy)}
.contact-text h5{font-family:'Poppins',sans-serif;font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--navy);margin-bottom:.25rem}
.contact-text p,.contact-text a{font-family:'Poppins',sans-serif;font-size:.83rem;color:var(--muted);text-decoration:none;line-height:1.6}
.contact-text a:hover{color:var(--navy)}
.response-promise{background:var(--navy);padding:1.75rem 2rem;display:flex;gap:1.25rem;align-items:flex-start;margin-top:1.5rem}
.promise-icon{width:40px;height:40px;min-width:40px;background:var(--cream);border:1.5px solid var(--g200);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--navy);flex-shrink:0}
.promise-text h5{font-family:'Poppins',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.promise-text p{font-family:'Radley',serif;font-size:.88rem;color:rgba(255,255,255,.58);line-height:1.72;margin:0}

/* PRO BONO PAGE */
.probono-layout{display:grid;grid-template-columns:1.1fr 0.9fr;gap:3.5rem;align-items:start}
.probono-sidebar{display:flex;flex-direction:column;gap:1.5rem}
.eligibility-card{background:var(--white);border:1px solid var(--g200);padding:2.5rem}
.eligibility-card h4{font-family:'Abril Fatface',serif;font-size:1.35rem;color:var(--navy);margin-bottom:1.5rem}
.eligibility-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.85rem}
.eligibility-list li{display:flex;gap:.85rem;align-items:flex-start;font-family:'Poppins',sans-serif;font-size:.82rem;color:var(--text);line-height:1.6}
.eligibility-list li::before{content:'✓';color:var(--gold);font-weight:700;flex-shrink:0;margin-top:.05rem}

/* RESPONSIVE ADDITIONS */

/* ADDITIONAL ALIASES */
.contact-text{}
.promise-text{}
.footer-contact-col p{font-family:'Poppins',sans-serif;font-size:.8rem;color:rgba(255,255,255,.36);line-height:1.72;margin-bottom:.5rem}
.footer-contact-col a{color:rgba(255,255,255,.65);text-decoration:none;transition:color .2s}.footer-contact-col a:hover{color:rgba(255,255,255,.92)}

/* FOCUS — Keyboard accessibility */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
a:focus-visible,button:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* REDUCED MOTION — Accessibility */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal,.reveal-left,.reveal-right{opacity:1!important;transform:none!important}
  .hero-photo{animation:none!important}
  .hero-scroll::after{animation:none!important}
  .positioning-track{animation:none!important}
}

/* PRINT */
@media print{
  .site-header,.news-banner,.mobile-menu,.mobile-overlay,.hero-scroll,.positioning-strip,.newsletter-section,.cta-banner{display:none!important}
  body{font-size:12pt;color:#000;background:#fff}
  a{color:var(--navy);text-decoration:underline}
  .hero-boutique{min-height:auto;padding:2rem 0}
  .hero-headline{font-size:28pt;color:var(--navy)}
  .page-hero{min-height:auto;padding:1.5rem 0 1rem;background:#fff}
  .page-hero h1{color:var(--navy)}
  .site-footer{background:#fff;color:#333;padding:1rem 0}
}

/* ══ ACCOLADES BAR ═══════════════════════════════════════════════════════ */
.accolades-bar{background:var(--white);border-bottom:1.5px solid var(--g100);position:relative;overflow:hidden;padding:1.5rem 0}
.accolades-bar::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy) 0%,var(--blue) 30%,var(--gold) 50%,var(--blue) 70%,var(--navy) 100%)}

/* Single-row scroll strip — never wraps */
.accolades-inner{
  display:flex;
  flex-wrap:nowrap;
  align-items:stretch;
  justify-content:space-evenly;
  width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.accolades-inner::-webkit-scrollbar{display:none}

/* Items */
.accolade-item{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.6rem;
  padding:1rem .9rem;
  flex:1 1 0;
  min-width:0;
  position:relative;
  transition:background .2s;
  white-space:nowrap;
}
.accolade-item:hover{background:var(--g50)}
.accolade-featured{padding:1rem 1.1rem}

/* Vertical dividers */
.accolade-divider{width:1px;background:var(--g200);align-self:stretch;margin:0;flex-shrink:0}

/* Logo (Super Lawyers image) */
.accolade-logo-wrap{flex-shrink:0;display:flex;align-items:center}
.accolade-logo{height:38px;width:auto;object-fit:contain;display:block}

/* Generic circle icon */
.accolade-icon{
  width:36px;height:36px;min-width:36px;
  border-radius:50%;
  background:var(--cream);
  border:1.5px solid var(--g200);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  color:var(--navy);
  transition:background .2s,border-color .2s;
  overflow:hidden;
}
.accolade-item:hover .accolade-icon{background:var(--navy-deep);border-color:var(--navy);color:var(--white)}

/* Rising star icon — gold star, transparent bg */
.accolade-icon--star{background:transparent;border:none}
.accolade-item:hover .accolade-icon--star{background:var(--cream);border:1.5px solid var(--g200)}

/* Scales of justice / Florida Bar — same */
.accolade-icon--bar{background:var(--cream);padding:3px}
.accolade-item:hover .accolade-icon--bar{background:var(--navy)}

/* Google G — transparent bg, full-color G shows */
.accolade-icon--google{background:var(--white);border:1.5px solid var(--g200)}
.accolade-item:hover .accolade-icon--google{background:var(--g50);border-color:var(--g300)}

/* Text */
.accolade-text{display:flex;flex-direction:column;gap:.12rem}
.accolade-text strong{font-family:'Poppins',sans-serif;font-weight:700;font-size:.72rem;color:var(--navy);letter-spacing:.01em;line-height:1.2;white-space:nowrap}
.accolade-text span{font-family:'Poppins',sans-serif;font-size:.63rem;color:var(--g600,#6a6a62);line-height:1.3;white-space:nowrap}

/* Score numeral */
.accolade-score{font-family:'Abril Fatface',serif;font-size:1rem;letter-spacing:-.02em;color:var(--navy);vertical-align:middle}

/* Mobile — smaller padding, still single row */

/* ══ HOW WE ADVISE — Header layout ════════════════════════════════════════ */
.advise-header-grid{display:grid;grid-template-columns:1fr 2fr;gap:4rem;margin-bottom:3.5rem;align-items:end}

/* ══ COMMUNITY — 2-col split ═══════════════════════════════════════════════ */
.community-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,6vw,8rem);align-items:center}

/* ══ ICON CONTAINERS ══════════════════════════════════════════════════════ */
.cause-list-icon{width:36px;height:36px;min-width:36px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;flex-shrink:0}
.team-feature-icon{width:44px;height:44px;min-width:44px;background:var(--cream);border:1.5px solid var(--g200);border-radius:2px;display:flex;align-items:center;justify-content:center;color:var(--navy);flex-shrink:0}

/* ══ HONORABLE MENTIONS GRID ═══════════════════════════════════════════════ */
.honorable-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
  margin-top:2rem;
}
.honorable-item{
  padding:1.5rem 1.75rem;
  border:1px solid var(--g200);
  background:var(--white);
  border-top:2px solid var(--gold);
  transition:box-shadow .2s;
}
.honorable-item:hover{box-shadow:0 4px 16px rgba(0,0,0,.06)}
.honorable-item .cause-tag{
  display:inline-block;
  font-family:'Poppins',sans-serif;
  font-size:.65rem;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--blue);
  margin-bottom:.75rem;
}
.honorable-item strong{
  display:block;
  font-family:'Poppins',sans-serif;
  font-weight:700;
  font-size:.9rem;
  color:var(--navy);
  margin-bottom:.5rem;
}
.honorable-item p{
  font-family:'Radley',serif;
  font-size:.88rem;
  color:var(--muted);
  line-height:1.65;
  margin-bottom:.6rem;
}
.honorable-item a{
  font-family:'Poppins',sans-serif;
  font-size:.75rem;
  font-weight:500;
  color:var(--blue);
  text-decoration:none;
  transition:opacity .18s;
}
.honorable-item a:hover{opacity:.75}

@media(max-width:540px){
  .honorable-grid{grid-template-columns:1fr}
  .framework-grid{grid-template-columns:1fr}
  .framework-step{border-right:none;border-bottom:1.5px solid var(--g200)}
  .framework-step:last-child{border-bottom:none}
  .framework-num{font-size:2.25rem}
  .cause-mini-grid{grid-template-columns:1fr}
  .awards-grid{grid-template-columns:1fr}
}

/* ══ STATS BAR ══════════════════════════════════════════════════════════════ */
.stats-bar{background:var(--gold);padding:clamp(2.5rem,5vw,4rem) 0}
.stats-inner{
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 clamp(1.5rem,5vw,4rem);
  display:grid;
  grid-template-columns:repeat(3,1fr);
  position:relative;
}
.stat-item{
  text-align:center;
  padding:0 2rem;
  position:relative;
}
.stat-item+.stat-item::before{
  content:'';
  position:absolute;
  left:0;top:15%;bottom:15%;
  width:1px;
  background:rgba(10,11,34,.15);
}
.stat-num{
  font-family:'Abril Fatface',serif;
  font-size:clamp(2.8rem,5vw,4rem);
  color:var(--navy-deep);
  line-height:1;
  display:block;
  letter-spacing:-.03em;
}
.stat-label{
  font-family:'Poppins',sans-serif;
  font-weight:700;
  font-size:.82rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--navy-deep);
  display:block;
  margin:.5rem 0 .4rem;
  opacity:.85;
}
.stat-desc{
  font-family:'Radley',serif;
  font-size:.88rem;
  color:rgba(10,11,34,.62);
  line-height:1.5;
  margin:0;
}

/* ══ FRAMEWORK SECTION (How We Advise) ══════════════════════════════════════ */
.framework-section{background:var(--white);padding:clamp(5rem,9vw,8rem) 0;border-top:1px solid var(--g100)}
.framework-header{text-align:center;margin-bottom:clamp(3rem,5vw,5rem)}
.framework-header h2{margin-bottom:1rem;color:var(--navy)}
.framework-header p{font-family:'Radley',serif;font-size:1.1rem;color:var(--muted);max-width:600px;margin:0 auto;line-height:1.75}
.framework-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1.5px solid var(--g200)}
.framework-step{display:flex;align-items:flex-start;gap:1.5rem;padding:2.5rem 2.25rem;border-right:1.5px solid var(--g200);border-bottom:1.5px solid var(--g200);position:relative;background:var(--white);transition:background .25s}
.framework-step:hover{background:var(--warm)}
.framework-step:nth-child(3),.framework-step:nth-child(6){border-right:none}
.framework-step:nth-child(4),.framework-step:nth-child(5),.framework-step:nth-child(6){border-bottom:none}
.framework-num{font-family:'Abril Fatface',serif;font-size:3rem;line-height:1;color:var(--gold);flex-shrink:0;letter-spacing:-.04em;margin-top:-.2rem;opacity:.9}
.framework-content h3{font-family:'Poppins',sans-serif;font-weight:700;font-size:1.05rem;color:var(--navy);margin-bottom:.6rem;line-height:1.25}
.framework-content p{font-family:'Radley',serif;font-size:.95rem;color:var(--muted);line-height:1.72;margin:0}
.framework-step::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.framework-step:hover::before{transform:scaleX(1)}
.framework-cta{text-align:center;margin-top:3rem}

/* ══ CAUSE CARDS — Community Page ══════════════════════════════════════════ */
.causes-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:2rem;
  margin-top:2.5rem;
}
.cause-card{
  background:var(--white);
  border:1px solid var(--g200);
  border-top:3px solid var(--gold);
  overflow:hidden;
  transition:box-shadow .25s,transform .25s;
}
.cause-card:hover{
  box-shadow:0 8px 32px rgba(0,0,0,.08);
  transform:translateY(-2px);
}
.cause-card-header{
  padding:1.75rem 2rem 1.25rem;
  border-bottom:1px solid var(--g100);
}
.cause-badge{
  display:inline-block;
  font-family:'Poppins',sans-serif;
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--blue);
  background:rgba(10,116,204,.07);
  padding:.25rem .65rem;
  margin-bottom:.85rem;
}
.cause-card-header h3{
  font-family:'Poppins',sans-serif;
  font-weight:700;
  font-size:1.1rem;
  color:var(--navy);
  margin-bottom:.4rem;
  line-height:1.3;
}
.cause-location{
  font-family:'Poppins',sans-serif;
  font-size:.75rem;
  color:var(--g600,#6a6a62);
  font-weight:500;
  letter-spacing:.03em;
}
.cause-card-body{
  padding:1.5rem 2rem 1.75rem;
}
.cause-card-body p{
  font-family:'Radley',serif;
  font-size:.95rem;
  color:var(--muted);
  line-height:1.78;
  margin-bottom:1rem;
}
.cause-card-body p:last-of-type{margin-bottom:0}
.cause-link{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-family:'Poppins',sans-serif;
  font-size:.78rem;
  font-weight:600;
  color:var(--blue);
  text-decoration:none;
  margin-top:1rem;
  transition:gap .2s;
}
.cause-link:hover{gap:.7rem}

/* Mini cause cards — homepage */
.cause-mini-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
}
.cause-mini-grid 
.cause-mini-grid .cause-card .cause-tag{
  display:block;
  font-family:'Poppins',sans-serif;
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--blue);
  margin-bottom:.5rem;
}
.cause-mini-grid .cause-card h3{
  font-family:'Poppins',sans-serif;
  font-weight:700;
  font-size:.88rem;
  color:var(--navy);
  margin-bottom:.4rem;
}
.cause-mini-grid .cause-card p{
  font-family:'Radley',serif;
  font-size:.82rem;
  color:var(--muted);
  line-height:1.6;
  margin:0;
}

@media(max-width:760px){
  .causes-grid{grid-template-columns:1fr}
  .pa-outcome-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr}.faq-item:nth-child(odd){border-right:none}
}

/* ══ HERO ELEMENTS ═══════════════════════════════════════════════════════════ */
.hero-eyebrow{font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:1.25rem;display:flex;align-items:center;gap:.75rem}
.hero-sub{font-family:'Radley',serif;font-size:clamp(1rem,2vw,1.2rem);color:rgba(255,255,255,.72);max-width:480px;line-height:1.7;margin:1.25rem 0 0}
.hero-divider{width:3rem;height:1.5px;background:var(--gold);opacity:.6;margin:1.5rem 0}
.hero-ctas{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:2.25rem}
.hero-cta-primary{display:inline-flex;align-items:center;gap:.6rem;font-family:'Poppins',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--navy-deep);background:var(--gold);padding:.85rem 1.85rem;text-decoration:none;transition:all .25s;border:2px solid var(--gold)}
.hero-cta-primary:hover{background:transparent;color:var(--gold)}
.hero-cta-ghost{font-family:'Poppins',sans-serif;font-weight:500;font-size:.8rem;color:rgba(255,255,255,.65);text-decoration:none;transition:color .2s;letter-spacing:.02em}
.hero-cta-ghost:hover{color:rgba(255,255,255,.92)}
.hero-grain{position:absolute;inset:0;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-size:200px}
.hero-vignette{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,9,32,.25) 0%,rgba(8,9,32,0) 38%,rgba(8,9,32,.9) 100%),linear-gradient(to right,rgba(8,9,32,.78) 0%,rgba(8,9,32,.08) 55%,transparent 100%)}
.est-num{font-family:'Abril Fatface',serif;font-size:1.85rem;color:rgba(255,255,255,.18);line-height:1;display:block}
.est-label{font-family:'Poppins',sans-serif;font-size:.58rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.22);display:block;margin-top:.25rem}
.breadcrumb{font-family:'Poppins',sans-serif;font-size:.72rem;color:rgba(255,255,255,.5);display:flex;align-items:center;gap:.4rem;margin-bottom:1rem}
.breadcrumb a{color:rgba(255,255,255,.5);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:rgba(255,255,255,.8)}
.breadcrumb .sep{color:rgba(255,255,255,.25)}

.news-close:hover{opacity:1}

/* ══ PRACTICE AREA OUTCOME CARDS ════════════════════════════════════════════ */
.pa-outcome-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0}
.pa-outcome-card{display:flex;flex-direction:column;padding:3rem 2.75rem;background:var(--navy);border:1px solid rgba(255,255,255,.06);text-decoration:none;position:relative;overflow:hidden;transition:background .3s}
.pa-outcome-card:nth-child(odd){background:var(--navy)}
.pa-outcome-card:nth-child(even){background:var(--navy-deep)}
.pa-outcome-card:hover{background:rgba(10,11,34,.95)}
.pa-outcome-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.pa-outcome-card:hover::before{transform:scaleX(1)}
.pa-card-num{font-family:'Poppins',sans-serif;font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:1.25rem;display:block}
.pa-outcome-card h3{font-family:'Abril Fatface',serif;font-size:1.5rem;color:var(--white);margin-bottom:1rem;line-height:1.25;letter-spacing:-.02em}
.pa-outcome{font-family:'Poppins',sans-serif;font-size:.82rem;font-weight:600;color:var(--gold);margin-bottom:1rem;line-height:1.5;opacity:.9}
.pa-outcome-card p{font-family:'Radley',serif;font-size:.95rem;color:rgba(255,255,255,.58);line-height:1.75;margin:0;flex:1}
.pa-link{font-family:'Poppins',sans-serif;font-size:.75rem;font-weight:600;letter-spacing:.08em;color:rgba(255,255,255,.45);display:inline-flex;align-items:center;gap:.5rem;margin-top:1.75rem;transition:color .2s}
.pa-outcome-card:hover .pa-link{color:var(--gold)}

/* ══ FAQ SECTION ═════════════════════════════════════════════════════════════ */
.faq-section{background:var(--white);padding:clamp(4rem,7vw,6rem) 0}
.faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:3rem;border-top:1px solid var(--g200)}
.faq-item{border-bottom:1px solid var(--g200);padding:0}
.faq-item:nth-child(odd){border-right:1px solid var(--g200)}
.faq-question{width:100%;background:none;border:none;text-align:left;padding:1.5rem 1.75rem;font-family:'Poppins',sans-serif;font-weight:600;font-size:.88rem;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;line-height:1.4;transition:background .2s}
.faq-question:hover{background:var(--warm)}
.faq-icon{font-size:1.25rem;font-weight:300;color:var(--gold);flex-shrink:0;line-height:1;transition:transform .3s}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-answer{padding:0 1.75rem 1.5rem;display:none}
.faq-item.open .faq-answer{display:block}
.faq-answer p{font-family:'Radley',serif;font-size:.95rem;color:var(--muted);line-height:1.78;margin:0}

/* ══ AWARD CARDS — About Page ════════════════════════════════════════════════ */
.awards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.award-card{padding:2rem 1.75rem;border:1px solid var(--g200);background:var(--white);border-top:3px solid var(--gold);transition:box-shadow .25s}
.award-card:hover{box-shadow:0 6px 24px rgba(0,0,0,.07)}
.award-icon{width:46px;height:46px;background:var(--cream);border-radius:2px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;color:var(--navy)}
.award-card h4{font-family:'Poppins',sans-serif;font-weight:700;font-size:.9rem;color:var(--navy);margin-bottom:.6rem;line-height:1.3}
.award-card p{font-family:'Radley',serif;font-size:.9rem;color:var(--muted);line-height:1.68;margin:0}

/* ══ BIO CREDENTIALS ═════════════════════════════════════════════════════════ */
.bio-credentials{display:flex;flex-direction:column;gap:.75rem;margin-top:2.25rem}
.bio-cred-item{display:flex;align-items:center;gap:1rem;padding:.7rem 1rem;background:var(--g50);border-left:2.5px solid var(--gold)}
.bio-cred-item span{font-family:'Poppins',sans-serif;font-size:.82rem;font-weight:500;color:var(--navy)}
.cred-tag{display:inline-block;font-family:'Poppins',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);background:rgba(10,116,204,.07);padding:.2rem .6rem;margin:.15rem}

/* ══ MINI TESTIMONIALS ═══════════════════════════════════════════════════════ */
.mini-testimonial{background:var(--g50);border-left:3px solid var(--gold);padding:1.5rem 1.75rem;margin:2rem 0}
.mini-testimonial .stars{color:var(--gold);font-size:.9rem;letter-spacing:1px;margin-bottom:.75rem}
.mini-testimonial blockquote{font-family:'Radley',serif;font-style:italic;font-size:.95rem;color:var(--navy);margin:0 0 .75rem;line-height:1.72}
.mini-testimonial cite{font-family:'Poppins',sans-serif;font-size:.75rem;font-weight:600;color:var(--g600,#6a6a62);font-style:normal}

/* ══ INTRO PHOTO ═════════════════════════════════════════════════════════════ */
.intro-photo{position:relative}
.intro-photo img{width:100%;display:block;object-fit:cover}

/* ══ FRAMEWORK CONTENT ═══════════════════════════════════════════════════════ */
.framework-content{flex:1}

/* ══ PAGE HERO (inner pages) ═════════════════════════════════════════════════ */
.page-hero{position:relative;min-height:clamp(300px,40vw,480px);display:flex;align-items:flex-end;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:grayscale(15%);opacity:.22}
.page-hero::after{content:'';position:absolute;inset:0;background:var(--navy-deep)}
.page-hero-inner{position:relative;z-index:1;width:100%;max-width:var(--max-w);margin:0 auto;padding:clamp(7rem,10vw,9rem) clamp(1.5rem,5vw,4rem) clamp(2.5rem,5vw,4rem)}
.page-hero-deco{position:absolute;right:clamp(1.5rem,5vw,4rem);bottom:0;font-family:'Abril Fatface',serif;font-size:clamp(6rem,15vw,14rem);color:rgba(255,255,255,.04);line-height:1;pointer-events:none;user-select:none}
.page-hero-sub{font-family:'Radley',serif;font-size:1rem;color:rgba(255,255,255,.62);margin-top:.6rem;max-width:560px;line-height:1.65}

/* ══ TIMELINE — About Page ═══════════════════════════════════════════════════ */
.timeline{list-style:none;padding:0;margin:0;position:relative}
.timeline::before{content:'';position:absolute;left:0;top:.5rem;bottom:0;width:1.5px;background:var(--g200)}
.timeline-item{padding:0 0 2.5rem 2.25rem;position:relative}
.timeline-item::before{content:'';position:absolute;left:-4px;top:.45rem;width:9px;height:9px;border-radius:50%;background:var(--gold);border:2px solid var(--white);box-shadow:0 0 0 1.5px var(--gold)}
.timeline-year{font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin-bottom:.5rem}
.timeline-item h4{font-family:'Poppins',sans-serif;font-weight:700;font-size:.95rem;color:var(--navy);margin-bottom:.6rem;line-height:1.3}
.timeline-item p{font-family:'Radley',serif;font-size:.92rem;color:var(--muted);line-height:1.72;margin:0}

/* ══ PULL QUOTES ═════════════════════════════════════════════════════════════ */
.pull-quote{border-left:3px solid var(--gold);padding:1.5rem 2rem;background:var(--warm);margin:2rem 0}
.pull-quote p{font-family:'Radley',serif;font-style:italic;font-size:1.08rem;color:var(--navy);line-height:1.72;margin:0}
.pull-quote-brief{border-left:2px solid var(--blue);padding:1.25rem 1.75rem;background:var(--g50);margin:2.5rem 0}
.pull-quote-brief p{font-family:'Radley',serif;font-style:italic;font-size:.98rem;color:var(--navy);line-height:1.72;margin:0}

/* ══ REVIEW CARDS — Testimonials Page ═══════════════════════════════════════ */
.review-card{background:var(--white);border:1px solid var(--g200);padding:2rem;position:relative}
.review-card::before{content:open-quote;font-family:'Abril Fatface',serif;font-size:4rem;color:var(--gold);opacity:.25;position:absolute;top:.5rem;left:1.25rem;line-height:1}
.review-text{font-family:'Radley',serif;font-style:italic;font-size:1rem;color:var(--navy);line-height:1.75;margin:0 0 1.25rem;padding-top:2rem}
.review-meta{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.review-author{font-family:'Poppins',sans-serif;font-weight:700;font-size:.82rem;color:var(--navy)}

/* ══ SERVICE BLOCKS ══════════════════════════════════════════════════════════ */
.service-blocks{display:flex;flex-direction:column;gap:0;border:1.5px solid var(--g200)}
.service-block{display:flex;align-items:flex-start;gap:1.25rem;padding:1.5rem 2rem;border-bottom:1px solid var(--g200);transition:background .2s}
.service-block:last-child{border-bottom:none}
.service-block:hover{background:var(--warm)}
.service-block-num{font-family:'Abril Fatface',serif;font-size:1.5rem;color:var(--gold);flex-shrink:0;line-height:1.1;opacity:.75}
.service-block h4{font-family:'Poppins',sans-serif;font-weight:700;font-size:.9rem;color:var(--navy);margin-bottom:.4rem}
.service-block p{font-family:'Radley',serif;font-size:.9rem;color:var(--muted);line-height:1.65;margin:0}

/* ══ SIDEBAR BOX ═════════════════════════════════════════════════════════════ */
.sidebar-box{padding:1.75rem;background:var(--cream);border:1px solid var(--g200);margin-bottom:1.5rem}
.sidebar-box h4{font-family:'Poppins',sans-serif;font-weight:700;font-size:.85rem;color:var(--navy);margin-bottom:.85rem;padding-bottom:.6rem;border-bottom:1px solid var(--g200)}
.sidebar-box p{font-family:'Radley',serif;font-size:.88rem;color:var(--muted);line-height:1.65;margin-bottom:.75rem}
.sidebar-box ul{list-style:none;padding:0;margin:0}
.sidebar-box ul li{font-family:'Radley',serif;font-size:.88rem;color:var(--muted);padding:.3rem 0;border-bottom:1px solid var(--g100);display:flex;align-items:center;gap:.6rem}
.sidebar-box ul li::before{content:'';width:5px;height:5px;background:var(--gold);border-radius:50%;flex-shrink:0}

/* ══ TEAM CREDENTIALS ════════════════════════════════════════════════════════ */
.team-cred{font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:500;letter-spacing:.06em;color:var(--blue);background:rgba(10,116,204,.07);padding:.2rem .6rem;display:inline-block;margin:.15rem}

/* ══ PILLAR NUMBERS ══════════════════════════════════════════════════════════ */
.pillar-num{font-family:'Abril Fatface',serif;font-size:2.5rem;color:var(--gold);line-height:1;opacity:.8;margin-bottom:.75rem}

/* ══ PRACTICE AREAS — Stat boxes ═══════════════════════════════════════════ */
.pa-stat-box{background:var(--white);border:1px solid var(--g200);padding:1.5rem 1.25rem;border-top:3px solid var(--gold)}
.pa-stat-num{font-family:'Abril Fatface',serif;font-size:2.5rem;color:var(--gold);line-height:1;margin-bottom:1rem;display:block}
.pa-stat-label{color:var(--navy);font-size:.85rem;margin-bottom:.5rem;font-family:'Poppins',sans-serif;font-weight:700;letter-spacing:.02em}
.pa-stat-desc{font-family:'Poppins',sans-serif;font-size:.78rem;color:var(--muted);margin:0;line-height:1.65}
.pa-hero-sub{color:var(--muted);line-height:1.8;margin-bottom:1.5rem}

/* ══ COMMUNITY — Cause list ═════════════════════════════════════════════════ */
.cause-navy-box{background:var(--navy);padding:3rem}
.cause-list{display:flex;flex-direction:column;gap:1.25rem}
.cause-list-row{display:flex;gap:1rem;align-items:center;padding:.85rem 0;border-bottom:1px solid rgba(255,255,255,.08)}
.cause-list-row:last-child{border-bottom:none}

/* ══ UTILITY CLASSES ════════════════════════════════════════════════════════ */

.mb-4{margin-bottom:1rem}
.mt-2{margin-top:.5rem}
.mt-section{margin-top:3rem}

.stack{display:flex;flex-direction:column;gap:1.5rem}
.stack-sm{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}
.flex-row{display:flex;align-items:center;gap:1rem}

/* ══ LAYOUT UTILITIES ═══════════════════════════════════════════════════════ */
.glass-box{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);padding:3rem}
.glass-box--sm{padding:2rem}
.cream-box{background:var(--cream);border:1px solid var(--g200);padding:2rem;margin-top:1.5rem}
.cream-strip{background:var(--cream);padding:.75rem 1rem;border-top:1px solid var(--g200)}
.white-box{background:var(--white);border:1px solid var(--g200);padding:2rem}
.white-box-flex{background:var(--white);border:1px solid #e8e8e4;padding:2rem;display:flex;gap:1.25rem;align-items:flex-start}
.bg-navy-deep{background:var(--navy-deep)}
.flex-center{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.flex-start{display:flex;gap:.75rem;align-items:flex-start}
.flex-item{display:flex;gap:1rem;align-items:center;padding:.85rem 0}
.stack-md{display:flex;flex-direction:column;gap:.85rem}
.text-muted-light{color:rgba(255,255,255,.55);line-height:1.8}
.body-text{color:var(--muted);font-family:'Radley',serif;font-size:1rem;line-height:1.75;margin-bottom:1rem}
.body-text--lg{font-size:1.05rem}
.centered-text{color:var(--muted);max-width:560px;margin:0 auto}
.navy-heading{color:var(--navy);margin-bottom:1rem}

/* ══ ADDITIONAL UTILITY CLASSES ════════════════════════════════════════════ */
.gold-label{color:var(--gold);font-size:1rem;margin-bottom:1.5rem}
.gold-num{color:var(--gold);font-weight:700;font-size:.9rem;flex-shrink:0}
.eyebrow--blue{font-family:'Poppins',sans-serif;font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue)}
.hint-text{font-family:'Poppins',sans-serif;font-size:.68rem;color:rgba(255,255,255,.55);margin-top:1rem}
.hint-center{font-family:'Poppins',sans-serif;font-size:.7rem;color:var(--g500);margin-top:1rem;text-align:center}
.light-caption{font-family:'Poppins',sans-serif;font-size:.78rem;color:rgba(255,255,255,.62);margin-bottom:.75rem}
.white-label{font-family:'Poppins',sans-serif;font-size:.82rem;font-weight:600;color:white;margin:0}
.strong-label{font-family:'Poppins',sans-serif;font-size:.92rem;font-weight:600;color:var(--navy)}
.pull-quote-text{font-family:'Radley',serif;font-style:italic;font-size:1.08rem;line-height:1.75;color:var(--navy)}
.center-box{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--cream);padding:2.5rem;text-align:center}
.three-col-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.nav-chevron-mobile{margin-left:.5rem;transition:transform .25s;flex-shrink:0}
.full-center{padding:8rem 2rem 4rem;background:var(--off-white,#fafaf8);min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center}
.error-text{color:var(--muted);max-width:460px;margin:0 auto 2.5rem}

@media(max-width:760px){.three-col-grid{grid-template-columns:1fr}}

/* ══ FINAL UTILITY CLASSES ══════════════════════════════════════════════════ */
.small-muted{font-size:.86rem;color:var(--muted);margin:0;line-height:1.6}

.map-frame{margin-top:1.5rem;overflow:hidden;border:1px solid var(--g200)}
.coming-soon-box{margin:2.5rem auto 3rem;padding:2.5rem 3rem;border:1.5px solid var(--g200);background:white;border-top:3px solid var(--gold)}
.box-heading{font-family:'Poppins',sans-serif;font-size:1.2rem;color:var(--navy);margin-bottom:1rem}
.list-heading{color:var(--navy);margin-bottom:.5rem;font-size:.9rem;font-family:'Poppins',sans-serif;font-weight:700}
.list-detail{font-size:.82rem;color:var(--muted);font-family:'Radley',serif;line-height:1.65}
.section-sep-light{margin-top:2.5rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08)}

/* ══ MISSING FIXES ════════════════════════════════════════════════════════ */
.nav-sub-caption{font-family:'Poppins',sans-serif;font-size:.72rem;color:rgba(255,255,255,.65);margin:0}
.btn-outline-ghost{color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.25)}

/* ══ LAST BATCH UTILITIES ═══════════════════════════════════════════════════ */
.error-numeral{font-family:'Abril Fatface',serif;font-size:8rem;color:var(--g200);line-height:1;margin-bottom:1rem}
.pull-quote-text.light{color:rgba(255,255,255,.7)}
.detail-link{font-family:'Poppins',sans-serif;font-size:.74rem;font-weight:600;color:var(--navy);text-decoration:none}
.eyebrow--dim{font-family:'Poppins',sans-serif;font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.5)}

/* ══ MICRO UTILITIES ════════════════════════════════════════════════════════ */
.mb-3{margin-bottom:.75rem}
.mb-6{margin-bottom:1.5rem}
.text-muted{color:var(--muted)}
.navy-sm-heading{color:var(--navy);margin-bottom:.4rem;font-family:'Poppins',sans-serif;font-weight:700;font-size:.9rem}
.bg-cream-inline{background:var(--cream)}
.iframe-clean{border:0;display:block}
.text-white-muted{color:rgba(255,255,255,.65)}
.icon-center{margin:0 auto 1.5rem;display:block}
.justify-center{justify-content:center}
.w-full{width:100%}

.mt-section-lg{margin-top:4rem}
.mt-section-sm{margin-top:2.5rem}
.display-num{font-size:2rem;color:var(--gold);margin-bottom:1rem}

.team-placeholder-label{font-family:'Poppins',sans-serif;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.45)}

/* ══ NEWS BANNER ════════════════════════════════════════════════════════════ */
.news-banner{
  background:var(--navy);
  border-bottom:1px solid rgba(201,168,76,.25);
  padding:.6rem clamp(1.5rem,5vw,4rem);
  display:flex;align-items:center;justify-content:center;gap:1.5rem;
  position:relative;z-index:1000;
}
.news-banner p{
  font-family:'Poppins',sans-serif;font-size:.75rem;
  color:rgba(255,255,255,.8);margin:0;text-align:center;line-height:1.5;
}
.news-banner p strong{color:var(--gold)}
.news-banner p a{color:rgba(255,255,255,.9);text-decoration:underline;text-decoration-color:rgba(201,168,76,.5)}
.news-banner p a:hover{color:var(--gold)}
.news-close{
  background:none;border:none;cursor:pointer;
  color:rgba(255,255,255,.4);font-size:1rem;
  padding:.25rem .5rem;line-height:1;flex-shrink:0;
  transition:color .2s;position:absolute;right:1rem;
}
.news-close:hover{color:rgba(255,255,255,.8)}

/* ══ SKIP TO MAIN (Accessibility) ══════════════════════════════════════════ */
.skip-link{
  position:fixed;top:-100%;left:1rem;z-index:9999;
  background:var(--gold);color:var(--navy-deep);
  padding:.6rem 1.25rem;font-family:'Poppins',sans-serif;
  font-size:.8rem;font-weight:700;text-decoration:none;
  transform:translateY(-100%);transition:transform .2s;
  border-radius:0 0 4px 4px;
}
.skip-link:focus{top:0;transform:translateY(0);outline:3px solid var(--navy)}

/* ══ MAIN LANDMARK ══════════════════════════════════════════════════════════ */
main[id="main"]{display:block}
main[id="main"]:focus{outline:none}

/* ══ SPACING SYSTEM IMPROVEMENTS ════════════════════════════════════════════ */
/* Consistent section spacing */
.section{padding:clamp(5rem,9vw,9rem) 0}
.section--sm{padding:clamp(3rem,5vw,5rem) 0}
.section--lg{padding:clamp(6rem,10vw,10rem) 0}
.section--flush{padding:0}

/* Ensure wrap is consistent */
.wrap{max-width:var(--max-w);margin:0 auto;padding-inline:clamp(1.5rem,5vw,4rem)}

/* Better vertical rhythm */
.eyebrow{margin-bottom:1rem}
.lead{margin-bottom:2.5rem}
h1 + .hero-divider{margin-top:1.5rem}
.hero-divider + .hero-sub{margin-top:1.25rem}
.hero-sub + .hero-ctas{margin-top:2rem}

/* Fix potential layout shift on hero image */
.hero-photo{will-change:transform}
.page-hero-bg{will-change:transform}

/* CTA banner content alignment */
.cta-banner-inner{
  max-width:680px;
  margin-inline:auto;
  text-align:center;
  padding:0 clamp(1.5rem,5vw,4rem);
}

/* Fix section background stripes — ensure no gap */
.bg-warm{background:var(--warm)}
.bg-cream{background:var(--cream)}
.bg-navy{background:var(--navy)}
.bg-gray{background:var(--g50)}
.bg-white{background:var(--white)}
.bg-deep{background:var(--navy-deep)}

/* ══ PRINT STYLES — clean up ════════════════════════════════════════════════ */

/* ══ NON-HERO PAGE SPACING ══════════════════════════════════════════════════ */
/* Pages without a hero section need top padding for the fixed nav */
.page-content-top{
  padding-top:calc(var(--nav-h, 70px) + var(--banner-offset, 42px) + 2rem);
}
/* Ensure sections have proper visual separation */
.section + .section{position:relative}
.section + .section::before{
  content:'';
  display:block;
  height:1px;
  background:transparent;
}

/* ══ SECTION TRANSITION IMPROVEMENTS ════════════════════════════════════════ */
/* Slightly softer boundary between warm/cream neighbors */
.bg-warm + .bg-gray,
.bg-gray + .bg-warm{border-top:1px solid var(--g200)}

/* Dark sections should have a thin gold top accent line */
.bg-navy{
  background:var(--navy);
  border-top:3px solid rgba(201,168,76,.3);
  border-bottom:1px solid rgba(255,255,255,.06);
}

/* ══ IMPROVED CTA BANNER SEPARATION ═════════════════════════════════════════ */
.section.bg-navy + .cta-banner,
.bg-navy + .cta-banner{
  border-top:4px solid var(--gold) !important;
  margin-top:0;
}
/* Add space between consecutive dark sections */
.section.bg-navy{
  padding-bottom:clamp(5rem,9vw,9rem);
}
.section.bg-navy + .cta-banner{
  padding-top:clamp(5rem,9vw,9rem);
}

/* ══ SECTION-SEP (light background version) ════════════════════════════════ */
.section-sep{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--g200)}
.text-navy{color:var(--navy)!important}
.text-sm{font-family:'Poppins',sans-serif;font-size:.72rem;color:var(--muted)}

/* ══ TEAM FEATURED LAYOUT ═══════════════════════════════════════════════════ */
.team-featured{
  display:grid;
  grid-template-columns:380px 1fr;
  gap:clamp(3rem,6vw,6rem);
  align-items:start;
  margin-top:3rem;
}
.team-featured-photo{
  position:sticky;
  top:calc(var(--nav-h,76px) + var(--banner-offset,42px) + 2rem);
}
.team-featured-photo img{
  width:100%;
  display:block;
  object-fit:cover;
  border:1px solid var(--g200);
}
.team-featured-content .team-card-name{
  font-family:'Abril Fatface',serif;
  font-size:1.75rem;
  color:var(--navy);
  margin-bottom:.35rem;
}
.team-featured-content .team-card-role{
  font-family:'Poppins',sans-serif;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--blue);
  margin-bottom:1.5rem;
  padding-bottom:1.5rem;
  border-bottom:1px solid var(--g100);
}
.team-featured-content p{
  margin-bottom:1.25rem;
}
.team-support-note{
  margin-top:3.5rem;
  padding:2rem;
  background:var(--g50);
  border-left:3px solid var(--gold);
}
.team-support-note .eyebrow{
  margin-bottom:.75rem;
}
.team-support-note p{
  font-size:.92rem;
  color:var(--muted);
  margin:0;
}
@media(max-width:900px){
  .team-featured{grid-template-columns:1fr}
  .team-featured-photo{position:static;max-width:360px}
}
@media(max-width:640px){
  .team-featured-photo{max-width:100%}
}
