/* ===== Gorval & Associates — shared site styles ===== */
:root{
  --claret:#5E1A24;
  --claret-deep:#3A0F15;
  --ink:#1C1815;
  --bone:#FBF8F2;
  --parchment:#F1EBE0;
  --brass:#B08D4F;
  --stone:#8A8178;
  --line:rgba(28,24,21,.14);
  --display:"Libre Caslon Display",Georgia,serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;
  --pad:clamp(1.4rem,5vw,6rem);
  --max:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{font-family:var(--body);color:var(--ink);background:var(--bone);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
::selection{background:var(--brass);color:var(--claret-deep)}
:focus-visible{outline:2px solid var(--brass);outline-offset:3px;border-radius:2px}
.sil{font-family:var(--display);font-style:normal}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);display:inline-flex;align-items:center;gap:.7ch}

/* ---------- UTILITY BAR ---------- */
.util{background:var(--claret);border-bottom:1px solid rgba(176,141,79,.28)}
.util-inner{max-width:var(--max);margin:0 auto;padding:.85rem var(--pad);display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.brand{display:flex;align-items:baseline;gap:.55ch;color:var(--parchment)}
.brand .mark{font-family:var(--display);font-size:1.5rem;color:var(--brass);line-height:1;transform:translateY(2px)}
.brand .name{font-family:var(--display);font-size:1.18rem;letter-spacing:.01em}
.brand .name span{color:var(--brass)}
.util-right{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap}
.util-right a{color:rgba(241,235,224,.82);font-size:.86rem;font-weight:500;transition:color .2s}
.util-right a:hover{color:var(--parchment)}
.util-right .fees{font-family:var(--mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase}
.util-right .phone{font-family:var(--mono);font-size:.82rem;color:var(--brass)}
.util-cta{font-family:var(--body);font-weight:600;border:1px solid var(--brass);color:var(--parchment)!important;padding:.5rem .95rem;border-radius:2px;transition:background .2s,color .2s}
.util-cta:hover{background:var(--brass);color:var(--claret-deep)!important}

/* ---------- SECONDARY (PRACTICE) MENU ---------- */
.submenu{position:sticky;top:0;z-index:50;background:var(--parchment);border-bottom:1px solid var(--line)}
.submenu-inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad);display:flex;gap:.4rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.submenu-inner::-webkit-scrollbar{display:none}
.submenu a{
  position:relative;white-space:nowrap;padding:1.05rem .4rem;margin:0 .9rem;
  font-size:.96rem;font-weight:500;color:#5a514a;transition:color .2s;
}
.submenu a:first-child{margin-left:0}
.submenu a:hover{color:var(--claret)}
.submenu a::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;background:var(--brass);transform:scaleX(0);transition:transform .25s ease}
.submenu a:hover::after{transform:scaleX(1)}
.submenu a.is-active{color:var(--claret);font-weight:600}
.submenu a.is-active::after{transform:scaleX(1)}

/* ---------- PAGE HERO ---------- */
.page-hero{background:var(--bone);border-bottom:1px solid var(--line)}
.page-hero-inner{max-width:var(--max);margin:0 auto;padding:clamp(2.8rem,7vw,5rem) var(--pad) clamp(2.2rem,5vw,3.5rem);position:relative;overflow:hidden}
.page-hero::after{content:"§";position:absolute;right:2vw;top:-2vw;font-family:var(--display);font-size:24vw;line-height:1;color:rgba(94,26,36,.05);pointer-events:none;user-select:none}
.page-hero h1{font-family:var(--display);font-weight:400;font-size:clamp(2.4rem,6vw,4.4rem);line-height:1.02;letter-spacing:-.01em;margin:1rem 0 0;max-width:18ch;position:relative}
.page-hero .lede{max-width:60ch;margin-top:1.4rem;font-size:clamp(1.04rem,1.6vw,1.22rem);color:#4b423c;position:relative}
.page-hero .lede + .lede{margin-top:1rem}

/* ---------- GENERIC SECTION ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding:clamp(3rem,7vw,5.5rem) var(--pad)}
.wrap-narrow{max-width:920px}
.section-head{max-width:64ch}
.section-head h2{font-family:var(--display);font-weight:400;font-size:clamp(1.9rem,4.2vw,3rem);line-height:1.06;letter-spacing:-.01em;margin:.8rem 0 0}
.section-head p{margin-top:1rem;color:#4b423c;font-size:1.05rem;max-width:60ch}

/* intro value blurbs */
.pillars{margin-top:clamp(2rem,4vw,3rem);display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:760px){.pillars{grid-template-columns:1fr}}
.pillar{background:var(--bone);padding:clamp(1.5rem,3vw,2.1rem)}
.pillar .sil{font-size:1.3rem;color:var(--brass)}
.pillar h3{font-family:var(--display);font-weight:400;font-size:1.3rem;margin:.55rem 0 .45rem}
.pillar p{color:#5a514a;font-size:.95rem}

/* ---------- PROSE ---------- */
.prose{max-width:70ch}
.prose h2{font-family:var(--display);font-weight:400;font-size:1.6rem;line-height:1.2;margin:2rem 0 .7rem;color:var(--claret)}
.prose h3{font-family:var(--display);font-weight:400;font-size:1.3rem;margin:1.6rem 0 .5rem}
.prose p{margin:.85rem 0;color:#3f3833}
.prose ul{margin:.85rem 0 .85rem 1.1rem;color:#3f3833}
.prose li{margin:.4rem 0;padding-left:.3rem}
.prose strong{font-weight:600}

/* ---------- ACCORDION ---------- */
.acc{margin-top:clamp(2rem,4vw,3rem);border-top:1px solid var(--line)}
.acc-item{border-bottom:1px solid var(--line)}
.acc-item.open{background:rgba(94,26,36,.025)}
.acc-btn{
  width:100%;background:none;border:none;cursor:pointer;text-align:left;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.1rem;
  padding:1.5rem 0;font-family:inherit;color:var(--ink);
  border-left:3px solid transparent;padding-left:0;transition:border-color .25s,padding-left .25s;
}
.acc-item.open .acc-btn{border-left-color:var(--brass);padding-left:1.1rem}
.acc-btn .sil{font-size:1.5rem;color:var(--brass);line-height:1}
.acc-btn .t{font-family:var(--display);font-weight:400;font-size:clamp(1.25rem,2.4vw,1.6rem);line-height:1.15}
.acc-btn .ind{position:relative;width:18px;height:18px;flex:none;margin-right:.2rem}
.acc-btn .ind::before,.acc-btn .ind::after{content:"";position:absolute;background:var(--claret);transition:transform .25s,opacity .25s}
.acc-btn .ind::before{top:8px;left:0;width:18px;height:2px}
.acc-btn .ind::after{top:0;left:8px;width:2px;height:18px}
.acc-item.open .acc-btn .ind::after{transform:scaleY(0);opacity:0}
.acc-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s ease}
.acc-item.open .acc-panel{grid-template-rows:1fr}
.acc-panel > div{overflow:hidden}
.acc-inner{padding:0 0 1.8rem 0}
.acc-item.open .acc-inner{padding-left:1.1rem}
@media(max-width:560px){.acc-btn{grid-template-columns:auto 1fr auto;gap:.8rem}}

/* ---------- CTA BAND ---------- */
.band{background:linear-gradient(160deg,var(--claret),var(--claret-deep));color:var(--parchment);position:relative;overflow:hidden}
.band::before{content:"§";position:absolute;right:-2vw;bottom:-6vw;font-family:var(--display);font-size:30vw;line-height:.7;color:rgba(176,141,79,.06);pointer-events:none}
.band-inner{max-width:var(--max);margin:0 auto;padding:clamp(3.2rem,7vw,5rem) var(--pad);position:relative}
.band h2{font-family:var(--display);font-weight:400;font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.1;max-width:20ch}
.band p{margin-top:1rem;color:rgba(241,235,224,.84);max-width:52ch;font-size:1.06rem}
.band-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.8rem}
.btn{display:inline-flex;align-items:center;gap:.6ch;font-weight:600;font-size:.98rem;padding:.92rem 1.6rem;border-radius:2px;transition:transform .15s ease,background .2s,color .2s,box-shadow .2s}
.btn-primary{background:var(--brass);color:var(--claret-deep)}
.btn-primary:hover{background:#c79f5d;transform:translateY(-2px);box-shadow:0 10px 30px -12px rgba(0,0,0,.55)}
.btn-ghost{border:1px solid rgba(241,235,224,.4);color:var(--parchment)}
.btn-ghost:hover{border-color:var(--brass);color:var(--brass)}
.btn-ghost .num{font-family:var(--mono);font-size:.92rem}

/* ---------- STUB NOTE ---------- */
.stub-note{margin-top:2rem;padding:1.2rem 1.4rem;border:1px dashed var(--line);border-radius:3px;background:var(--parchment);color:#5a514a;font-size:.95rem;max-width:60ch}
.stub-note .sil{color:var(--brass);margin-right:.4ch}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:rgba(241,235,224,.62)}
.foot-inner{max-width:var(--max);margin:0 auto;padding:clamp(2.8rem,6vw,4rem) var(--pad);display:flex;flex-wrap:wrap;justify-content:space-between;gap:1.5rem;align-items:flex-start}
.foot-brand{display:flex;align-items:baseline;gap:.55ch}
.foot-brand .mark{font-family:var(--display);font-size:1.4rem;color:var(--brass);transform:translateY(2px)}
.foot-brand .name{font-family:var(--display);font-size:1.1rem;color:var(--parchment)}
.foot-brand .name span{color:var(--brass)}
.foot-meta{font-size:.85rem;line-height:1.8;max-width:40ch;margin-top:.6rem}
.foot-cols{display:flex;gap:3.5rem;flex-wrap:wrap}
.foot-cols h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);margin-bottom:.8rem}
.foot-cols a,.foot-cols span{display:block;font-size:.9rem;padding:.18rem 0;color:rgba(241,235,224,.62);transition:color .2s}
.foot-cols a:hover{color:var(--parchment)}
.foot-legal{max-width:var(--max);margin:0 auto;padding:0 var(--pad) clamp(2.4rem,5vw,3.4rem);font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:rgba(241,235,224,.4)}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
