/* =====================================================================
   SCHWAB LAW — Design System
   Refined navy + antique gold. Editorial, upscale, fast.
   Display: Newsreader (serif authority) · Body: Hanken Grotesk (humanist)
   ===================================================================== */

/* ---- Tokens -------------------------------------------------------- */
:root{
  /* Brand — refined from the firm's existing navy (#183154) + gold */
  --ink:        #11243B;   /* deep navy — primary brand */
  --ink-deep:   #0A1626;   /* midnight — footer / depth */
  --ink-soft:   #243a55;   /* navy tint for panels */
  --gold:       #B0883C;   /* antique gold — primary accent */
  --gold-bright:#C9A24B;   /* warm gold — hover / highlight */
  --gold-tint:  #efe6d2;   /* faint gold wash */

  /* Grounds */
  --paper:  #F8F5EF;       /* warm cream page ground */
  --stone:  #EDE7DA;       /* secondary surface */
  --white:  #FFFFFF;

  /* Text */
  --text:   #1B2A3C;
  --muted:  #5C6877;
  --on-dark:#E9E3D5;
  --on-dark-muted:#A9B3C0;

  /* Lines */
  --line:      #DED5C4;
  --line-dark: rgba(255,255,255,.14);

  /* Type */
  --font-display:'Newsreader', Georgia, 'Times New Roman', serif;
  --font-body:'Hanken Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* Scale & rhythm */
  --container: 1180px;
  --container-narrow: 760px;
  --gutter: clamp(20px, 5vw, 64px);
  --section-y: clamp(64px, 9vw, 132px);
  --radius: 4px;          /* restrained — upscale firms avoid bubbly corners */
  --shadow: 0 18px 50px -28px rgba(10,22,38,.45);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---- Reset / base -------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:clamp(16px,1.05vw,17.5px);
  line-height:1.7;
  color:var(--text);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"kern" 1,"liga" 1;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--gold)}
strong{font-weight:600}

/* ---- Typography ---------------------------------------------------- */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:500;
  line-height:1.1;
  letter-spacing:-.01em;
  color:var(--ink);
  margin:0 0 .5em;
}
h1{font-size:clamp(2.4rem,5.2vw,4rem);font-weight:400}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:clamp(1.3rem,2.1vw,1.6rem)}
h4{font-size:1.15rem}
p{margin:0 0 1.1em}
.lead{font-size:clamp(1.12rem,1.6vw,1.32rem);line-height:1.6;color:var(--ink-soft)}

/* Eyebrow — the firm's signature label device */
.eyebrow{
  font-family:var(--font-body);
  font-weight:700;
  font-size:.74rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:.7em;
  margin:0 0 1.1rem;
}
.eyebrow::before{
  content:"";
  width:30px;height:1px;
  background:var(--gold);
  display:inline-block;
}
.eyebrow--center{justify-content:center}

/* ---- Layout helpers ------------------------------------------------ */
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.container--narrow{max-width:var(--container-narrow)}
.section{padding-block:var(--section-y)}
.section--stone{background:var(--stone)}
.section--ink{background:var(--ink);color:var(--on-dark)}
.section--ink h1,.section--ink h2,.section--ink h3{color:var(--white)}
.section--ink .lead{color:var(--on-dark)}
.center{text-align:center}
.measure{max-width:62ch}
.measure-center{max-width:62ch;margin-inline:auto}

/* ---- Buttons ------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-body);font-weight:700;
  font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;
  padding:1.05em 1.9em;border-radius:var(--radius);
  border:1px solid transparent;cursor:pointer;
  transition:all .22s var(--ease);
}
.btn--gold{background:var(--gold);color:var(--ink-deep)}
.btn--gold:hover{background:var(--gold-bright);color:var(--ink-deep);transform:translateY(-2px)}
.btn--ink{background:var(--ink);color:var(--white)}
.btn--ink:hover{background:var(--ink-deep);color:var(--white);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--white)}
.btn--ghost-light{background:transparent;color:var(--white);border-color:rgba(255,255,255,.4)}
.btn--ghost-light:hover{background:var(--white);color:var(--ink)}

/* ===================================================================
   HEADER / NAV
   =================================================================== */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(17,36,59,.97);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line-dark);
}
.topbar{
  background:var(--ink-deep);
  color:var(--on-dark-muted);
  font-size:.8rem;letter-spacing:.02em;
}
.topbar .container{display:flex;justify-content:space-between;align-items:center;
  padding-block:.5rem;gap:1rem}
.topbar a{color:var(--on-dark-muted)}
.topbar a:hover{color:var(--gold-bright)}
.topbar__nap{display:flex;gap:1.6rem;flex-wrap:wrap}
.topbar__cta{font-weight:700;color:var(--gold-bright);letter-spacing:.04em}

.nav{display:flex;align-items:center;justify-content:space-between;
  gap:2rem;padding-block:.65rem;position:relative}
.brand{display:flex;align-items:center;gap:.85rem;line-height:1}
.brand img,.brand .custom-logo{height:66px;width:auto;display:block}
.brand__text{font-family:var(--font-display);color:var(--white);
  font-size:1.5rem;letter-spacing:.01em}
.brand__text span{display:block;font-family:var(--font-body);font-weight:600;
  font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-top:.35em}

.menu{display:flex;align-items:center;gap:.3rem;list-style:none;margin:0;padding:0}
.menu>li{position:relative}
.menu>li>a{
  display:block;color:var(--on-dark);font-weight:600;
  font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.7rem .85rem;border-radius:var(--radius);
}
.menu>li>a:hover,.menu>li.current-menu-item>a{color:var(--gold-bright)}
.menu .sub-menu{
  position:absolute;top:100%;left:0;min-width:248px;
  background:var(--white);border-top:2px solid var(--gold);
  box-shadow:var(--shadow);list-style:none;margin:0;padding:.5rem;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:all .2s var(--ease);z-index:70;
}
.menu>li:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.menu .sub-menu a{display:block;color:var(--text);font-size:.92rem;
  padding:.6rem .8rem;border-radius:var(--radius);text-transform:none;letter-spacing:0;font-weight:500}
.menu .sub-menu a:hover{background:var(--stone);color:var(--ink)}

/* Dropdown caret on parent items */
.menu>li>a .caret{display:inline-block;width:.46em;height:.46em;margin-left:.5em;
  border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:translateY(-2px) rotate(45deg);opacity:.65;transition:transform .2s var(--ease)}
.menu>li.has-mega:hover>a .caret{transform:translateY(1px) rotate(225deg)}

/* Mega-menu panels (full-width under the nav) */
.menu>li.has-mega{position:static}
.mega{position:absolute;left:0;right:0;top:100%;
  background:var(--white);border-top:2px solid var(--gold);box-shadow:var(--shadow);
  padding:2.1rem 2.4rem;display:grid;gap:1.3rem 2.6rem;z-index:70;
  opacity:0;visibility:hidden;transform:translateY(10px);
  transition:opacity .2s var(--ease),transform .2s var(--ease),visibility .2s}
.menu>li.has-mega:hover>.mega,
.menu>li.has-mega:focus-within>.mega{opacity:1;visibility:visible;transform:none}
.mega--family{grid-template-columns:1fr 1fr 1.15fr}
.mega--practice{grid-template-columns:repeat(4,1fr)}
.mega__col{display:flex;flex-direction:column;gap:.05rem}
.mega__head{font-family:var(--font-display);font-size:1.08rem;color:var(--ink);
  font-weight:500;margin-bottom:.55rem;display:block;letter-spacing:0;text-transform:none}
a.mega__head:hover{color:var(--gold)}
.mega a{color:var(--ink-soft);font-size:.92rem;padding:.34rem 0;font-weight:500;
  text-transform:none;letter-spacing:0;border-radius:0}
.mega a:hover{color:var(--gold);background:none}
.mega__cta{background:var(--ink);color:var(--on-dark);padding:1.5rem 1.7rem;border-radius:var(--radius)}
.mega__cta p{color:var(--on-dark);font-size:.9rem;margin:.2rem 0 1.1rem;line-height:1.55}
.mega__cta .eyebrow{margin-bottom:.7rem}
.nav__phone{display:inline-flex;align-items:center;gap:.5em;color:var(--white);
  font-weight:700;letter-spacing:.02em;white-space:nowrap}
.nav__phone .num{font-size:1.05rem}

.nav-toggle{display:none;background:none;border:0;cursor:pointer;
  width:46px;height:46px;flex-direction:column;justify-content:center;gap:5px}
.nav-toggle span{height:2px;background:var(--white);border-radius:2px;transition:.25s var(--ease)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===================================================================
   HERO
   =================================================================== */
.hero{position:relative;background:var(--ink);color:var(--on-dark);overflow:hidden}
.hero::after{ /* gold hairline frame — signature */
  content:"";position:absolute;inset:clamp(14px,2vw,28px);
  border:1px solid rgba(176,136,60,.28);pointer-events:none;z-index:2}
.hero__bg{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;
  opacity:.22;filter:saturate(.85)}
.hero__overlay{position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(10,22,38,.92) 38%,rgba(10,22,38,.55) 100%)}
.hero__inner{position:relative;z-index:3;padding-block:clamp(78px,12vw,148px);max-width:780px}
.hero h1{color:var(--white);margin-bottom:.35em}
.hero h1 em{font-style:italic;color:var(--gold-bright)}
.hero__sub{font-size:clamp(1.1rem,1.6vw,1.3rem);color:var(--on-dark);
  max-width:60ch;margin-bottom:2rem;line-height:1.6}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.hero__trust{display:flex;flex-wrap:wrap;gap:1.8rem 2.6rem;margin-top:3rem;
  padding-top:1.8rem;border-top:1px solid var(--line-dark)}
.hero__trust-item{font-size:.86rem;color:var(--on-dark-muted);max-width:200px;line-height:1.4}
.hero__trust-item b{display:block;font-family:var(--font-display);font-size:1.5rem;
  color:var(--gold-bright);font-weight:400;margin-bottom:.15em}

/* ===================================================================
   PRACTICE GRID
   =================================================================== */
.practice-grid{display:grid;gap:1.25rem;
  grid-template-columns:repeat(auto-fit,minmax(255px,1fr))}
.pcard{
  position:relative;display:flex;flex-direction:column;
  background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);padding:2rem 1.8rem;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);
  overflow:hidden;
}
.pcard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .3s var(--ease)}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold-tint)}
.pcard:hover::before{transform:scaleY(1)}
.pcard--feature{background:var(--ink);color:var(--on-dark);grid-column:span 2;
  justify-content:center;padding:2.6rem}
.pcard--feature h3,.pcard--feature .pcard__title{color:var(--white)}
.pcard--feature p{color:var(--on-dark)}
.pcard--feature::before{background:var(--gold-bright)}
.pcard__icon{width:34px;height:34px;color:var(--gold);margin-bottom:1.1rem}
.pcard__title{font-family:var(--font-display);font-size:1.45rem;margin:0 0 .5rem}
.pcard p{font-size:.95rem;color:var(--muted);margin-bottom:1.2rem;flex:1}
.pcard--feature p{color:var(--on-dark-muted)}
.pcard__link{font-weight:700;font-size:.78rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--gold);display:inline-flex;gap:.5em;align-items:center}
.pcard--feature .pcard__link{color:var(--gold-bright)}
.pcard__sub{list-style:none;margin:.4rem 0 1.2rem;padding:0;display:flex;
  flex-wrap:wrap;gap:.4rem}
.pcard__sub li a{font-size:.8rem;color:var(--ink-soft);background:var(--stone);
  padding:.3rem .7rem;border-radius:100px}
.pcard--feature .pcard__sub li a{background:var(--ink-soft);color:var(--on-dark)}
.pcard__sub li a:hover{background:var(--gold);color:var(--ink-deep)}

/* ===================================================================
   SPLIT / NARRATIVE
   =================================================================== */
.split{display:grid;gap:clamp(2rem,5vw,4.5rem);align-items:center;
  grid-template-columns:1.05fr .95fr}
.split--flip .split__media{order:2}
.split__media{position:relative}
.split__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover}
.split__media::after{content:"";position:absolute;right:-14px;bottom:-14px;
  width:64%;height:64%;border:1px solid var(--gold);border-radius:var(--radius);z-index:-1}

/* ===================================================================
   ATTORNEYS
   =================================================================== */
.attorneys{display:grid;gap:1.4rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.acard{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.acard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.acard__photo{aspect-ratio:4/5;background:var(--stone);object-fit:cover;width:100%}
.acard__body{padding:1.4rem 1.5rem 1.7rem}
.acard__role{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:.5rem}
.acard__name{font-family:var(--font-display);font-size:1.4rem;margin:0 0 .5rem}
.acard p{font-size:.92rem;color:var(--muted);margin-bottom:1rem}
.acard__link{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.acard__link:hover{color:var(--gold)}

/* ===================================================================
   FAQ (AEO/GEO) — accordion
   =================================================================== */
.faq{max-width:840px;margin-inline:auto}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{width:100%;background:none;border:0;cursor:pointer;text-align:left;
  font-family:var(--font-display);font-size:1.18rem;color:var(--ink);
  padding:1.35rem 2.5rem 1.35rem 0;position:relative;display:block}
.faq__q::after{content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);
  font-family:var(--font-body);font-weight:400;font-size:1.6rem;color:var(--gold);transition:transform .25s var(--ease)}
.faq__item[open] .faq__q::after{content:"–"}
.faq__a{padding:0 0 1.5rem;color:var(--muted);max-width:70ch}
.faq__a p:last-child{margin-bottom:0}

/* ===================================================================
   REVIEWS strip
   =================================================================== */
.reviews{display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.rcard{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem}
.rcard__stars{color:var(--gold);letter-spacing:.15em;margin-bottom:.8rem;font-size:1rem}
.rcard p{font-style:italic;color:var(--text);margin-bottom:1rem}
.rcard__by{font-size:.82rem;color:var(--muted);font-weight:600;font-style:normal}

/* ===================================================================
   CTA BAND
   =================================================================== */
.cta-band{background:var(--ink-deep);color:var(--on-dark);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% -20%,rgba(176,136,60,.22),transparent 60%)}
.cta-band .container{position:relative}
.cta-band h2{color:var(--white)}
.cta-band__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1.8rem}

/* ===================================================================
   FOOTER + NAP / MAP CITATION MODULE
   =================================================================== */
.map-citation{background:var(--ink);color:var(--on-dark)}
.map-citation__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:0;align-items:stretch}
.map-citation__info{padding:clamp(2.5rem,5vw,4rem) var(--gutter)}
.map-citation__map{min-height:340px}
.map-citation__map iframe{width:100%;height:100%;min-height:340px;border:0;display:block;filter:grayscale(.25) contrast(1.05)}
.nap{font-style:normal;line-height:1.8}
.nap__name{font-family:var(--font-display);font-size:1.6rem;color:var(--white);margin-bottom:.3rem}
.nap__line{color:var(--on-dark)}
.nap__label{display:block;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin:1.3rem 0 .35rem}
.nap a{color:var(--on-dark)}.nap a:hover{color:var(--gold-bright)}

.site-footer{background:var(--ink-deep);color:var(--on-dark-muted);font-size:.9rem}
.footer-main{display:grid;gap:2.5rem;grid-template-columns:1.4fr 1fr 1fr 1fr;
  padding-block:clamp(3rem,6vw,4.5rem)}
.footer-col h4{color:var(--white);font-family:var(--font-body);font-size:.78rem;
  letter-spacing:.16em;text-transform:uppercase;margin-bottom:1.1rem}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin-bottom:.55rem}
.footer-col a{color:var(--on-dark-muted)}
.footer-col a:hover{color:var(--gold-bright)}
.footer-brand p{color:var(--on-dark-muted);max-width:34ch;margin-top:1rem}
.footer-social{display:flex;gap:.8rem;margin-top:1.3rem}
.footer-social a{width:38px;height:38px;display:grid;place-items:center;
  border:1px solid var(--line-dark);border-radius:50%;color:var(--on-dark)}
.footer-social a:hover{background:var(--gold);color:var(--ink-deep);border-color:var(--gold)}
.footer-bottom{border-top:1px solid var(--line-dark);padding-block:1.5rem;
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.82rem}

/* ===================================================================
   BREADCRUMBS
   =================================================================== */
.crumbs{font-size:.8rem;color:var(--muted);padding-block:1rem;letter-spacing:.02em}
.crumbs a{color:var(--ink-soft)}
.crumbs a:hover{color:var(--gold)}
.crumbs span[aria-current]{color:var(--gold)}

/* ===================================================================
   ANSWER BLOCK (AEO direct-answer device)
   =================================================================== */
.answer-block{background:var(--white);border-left:3px solid var(--gold);
  padding:1.6rem 1.8rem;border-radius:var(--radius);box-shadow:var(--shadow);
  font-size:1.08rem;line-height:1.6;color:var(--ink-soft);max-width:72ch}
.answer-block strong{color:var(--ink)}

/* ===================================================================
   UTIL / MOTION / A11Y
   =================================================================== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
:focus-visible{outline:2px solid var(--gold-bright);outline-offset:3px}
.skip-link{position:absolute;left:-999px;top:0;background:var(--gold);color:var(--ink-deep);
  padding:.7rem 1.2rem;z-index:200;font-weight:700}
.skip-link:focus{left:0}

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

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:1000px){
  .split,.map-citation__grid{grid-template-columns:1fr}
  .split--flip .split__media{order:0}
  .pcard--feature{grid-column:span 1}
  .footer-main{grid-template-columns:1fr 1fr}
  .map-citation__map{min-height:300px;order:2}
  /* keep the primary nav on one row until the mobile drawer (820px) */
  .nav{gap:1rem}
  .brand img,.brand .custom-logo{height:56px}
  .menu>li>a{padding:.6rem .5rem;font-size:.76rem;letter-spacing:.05em}
  .mega--practice{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:820px){
  .topbar{display:none}
  .nav-toggle{display:flex}
  .nav__phone .label{display:none}
  .menu{
    position:fixed;inset:0 0 0 auto;width:min(86vw,400px);
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--ink-deep);padding:5rem 1.4rem 2rem;
    transform:translateX(100%);transition:transform .3s var(--ease);
    overflow-y:auto;box-shadow:-20px 0 50px rgba(0,0,0,.4)}
  .menu.is-open{transform:translateX(0)}
  .menu>li>a{padding:1rem .4rem;border-bottom:1px solid var(--line-dark)}
  .menu .sub-menu{position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;background:transparent;border-top:0;padding:0 0 .5rem .8rem}
  .menu .sub-menu a{color:var(--on-dark-muted)}
  .menu .sub-menu a:hover{background:transparent;color:var(--gold-bright)}
  .menu>li>a .caret{display:none}
  .menu>li.has-mega{position:static}
  .mega{position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;background:transparent;border-top:0;padding:.2rem 0 .6rem .8rem;
    display:block;gap:0}
  .mega__head{color:var(--on-dark);margin-top:.7rem;font-size:1rem}
  .mega a{color:var(--on-dark-muted);font-size:.95rem}
  .mega a:hover{color:var(--gold-bright)}
  .mega__cta{display:none}
}
@media (max-width:560px){
  .footer-main{grid-template-columns:1fr}
  .hero__trust{gap:1.4rem}
}

/* ===================================================================
   BLOG POST (single) — article layout + typography
   =================================================================== */
.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}
.post-hero-img{width:100%;height:auto;display:block;border-radius:var(--radius);
  box-shadow:var(--shadow);margin-bottom:2.5rem}
.article-grid{display:grid;gap:clamp(2rem,4vw,3.5rem);
  grid-template-columns:minmax(0,1fr) 320px;align-items:flex-start}
.post-meta{font-size:.82rem;letter-spacing:.04em;color:var(--muted);
  text-transform:uppercase;margin-bottom:1.4rem}
.post-meta a{color:var(--gold)}
.post-body{max-width:70ch;font-size:1.1rem;line-height:1.82;color:var(--text)}
.post-body h2{font-size:clamp(1.5rem,2.4vw,1.95rem);margin:2.4rem 0 .8rem}
.post-body h3{font-size:1.3rem;margin:1.9rem 0 .6rem}
.post-body p{margin:0 0 1.2rem}
.post-body ul,.post-body ol{margin:0 0 1.35rem;padding-left:1.3rem;line-height:1.9}
.post-body li{margin-bottom:.45rem}
.post-body a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.post-body a:hover{color:var(--ink)}
.post-body strong{color:var(--ink)}
.post-sidebar{position:sticky;top:120px;display:flex;flex-direction:column;gap:1.25rem}
.post-tags{margin-top:2.5rem;display:flex;flex-wrap:wrap;gap:.5rem}
.post-tags a{font-size:.8rem;background:var(--stone);color:var(--ink-soft);
  padding:.35rem .8rem;border-radius:100px}

/* Google review cards */
.rcard__head{display:flex;align-items:center;gap:.7rem;margin-bottom:.9rem}
.rcard__avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;
  background:var(--stone);flex:none;display:inline-block}
.rcard__meta{font-size:.8rem;color:var(--muted)}
.rcard__text{font-style:normal;color:var(--text);
  display:-webkit-box;-webkit-line-clamp:7;-webkit-box-orient:vertical;overflow:hidden}
.reviews-summary{display:inline-flex;align-items:center;gap:.55rem;justify-content:center}
.reviews-summary__stars{color:var(--gold);letter-spacing:.1em}

@media (max-width:1000px){
  .article-grid{grid-template-columns:1fr}
  .post-sidebar{position:static;flex-direction:row;flex-wrap:wrap}
  .post-sidebar>*{flex:1 1 240px}
}
