/* Fryberger Law Firm — premium. Warm cream, navy + gold, soft rounded, lift-on-hover. */
:root{
  --cream:#f7f3ea;        /* page bg */
  --cream2:#f1ebdd;       /* alt section */
  --cream3:#e4dac6;       /* hairline / border */
  --navy:#15263f;         /* deep ink navy */
  --navy-2:#1d3556;       /* lighter navy (gradient top) */
  --navy-deep:#0f1d31;
  --gold:#b0894e;         /* gold for text on light (AA) */
  --gold-2:#9a7740;
  --gold-bright:#c9a46e;  /* decorative / on-dark */
  --white:#ffffff;
  --ink:#15263f;
  --slate:#5b6576;        /* muted body */
  --shadow:0 22px 48px -22px rgba(15,29,49,.34);
  --shadow-sm:0 12px 28px -16px rgba(15,29,49,.26);
  --shadow-gold:0 16px 34px -14px rgba(176,138,79,.5);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --wrap:1240px;
  --r:16px; --r-sm:12px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.06;margin:0;letter-spacing:-.005em;color:var(--ink)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 34px}
.eyebrow{font-family:var(--mono);font-size:.68rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--gold)}
.serif{font-family:var(--serif)}

/* BUTTONS — rounded, soft, lift on hover */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-size:.95rem;font-weight:600;letter-spacing:.01em;padding:15px 28px;border-radius:var(--r-sm);cursor:pointer;border:1px solid transparent;transition:transform .32s cubic-bezier(.2,.8,.2,1),box-shadow .32s,background .3s,color .25s,border-color .25s;white-space:nowrap}
.btn .arr{display:inline-block;transition:transform .32s cubic-bezier(.2,.8,.2,1)}
.btn:hover .arr{transform:translateX(5px)}
.btn-brass{background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#fff;box-shadow:var(--shadow-gold)}
.btn-brass:hover{transform:translateY(-2px);box-shadow:0 22px 42px -12px rgba(176,138,79,.6)}
.btn-ink{background:linear-gradient(180deg,var(--navy-2),var(--navy));color:#fff;box-shadow:0 12px 26px -10px rgba(15,29,49,.55)}
.btn-ink:hover{transform:translateY(-2px);box-shadow:0 24px 44px -12px rgba(15,29,49,.6)}
.btn-ghost{background:var(--white);color:var(--navy);border:1px solid var(--cream3);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{transform:translateY(-2px);border-color:var(--gold);color:var(--gold-2)}

/* Animated text CTAs — the line draws under the text, the arrow slides. No boxes. */
.alink{position:relative;display:inline-flex;align-items:center;gap:11px;background:none;border:0;padding:6px 3px 14px;font-family:var(--sans);font-weight:600;font-size:1.02rem;letter-spacing:.01em;color:var(--ink);cursor:pointer;transition:color .35s}
.alink .arr{display:inline-flex;transition:transform .55s cubic-bezier(.16,1,.3,1)}
.alink::after{content:"";position:absolute;left:3px;right:3px;bottom:6px;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .6s cubic-bezier(.16,1,.3,1)}
.alink:hover{color:var(--gold-2)}
.alink:hover .arr{transform:translateX(10px)}
.alink:hover::after{transform:scaleX(1)}
.alink.primary{font-size:1.18rem}
.alink.gold{color:var(--gold-2)}
.alink.on-dark{color:#fff}
.alink.on-dark::after{background:var(--gold-bright)}
.alink.on-dark:hover{color:var(--gold-bright)}
.alink + .alink{margin-left:8px}

/* NAV — white over the video hero, cream once scrolled */
nav.site{position:fixed;top:0;left:0;right:0;z-index:80;transition:background .4s,box-shadow .4s,padding .4s;padding:22px 0}
nav.site .row{display:flex;align-items:center;justify-content:space-between;gap:20px}
nav.site .logo{height:42px;width:auto}
nav.site .logo.dark{display:none}
nav.site .links{display:flex;gap:36px;align-items:center}
nav.site .links a{font-size:.82rem;letter-spacing:.04em;color:rgba(255,255,255,.92);font-weight:500;transition:color .2s;position:relative}
nav.site .links a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:1px;background:var(--gold-bright);transition:right .3s}
nav.site .links a:hover{color:#fff}
nav.site .links a:hover::after{right:0}
nav.site .navcta{display:flex;align-items:center;gap:20px}
nav.site .navphone{color:rgba(255,255,255,.92);font-size:.85rem;font-weight:600;letter-spacing:.02em;transition:color .2s;white-space:nowrap}
nav.site .navphone:hover{color:var(--gold-bright)}
nav.site.scrolled{background:rgba(247,243,234,.92);backdrop-filter:saturate(1.5) blur(12px);box-shadow:0 1px 0 var(--cream3),0 18px 40px -28px rgba(15,29,49,.4);padding:12px 0}
nav.site.scrolled .logo.white{display:none}
nav.site.scrolled .logo.dark{display:block}
nav.site.scrolled .links a{color:var(--ink)}
nav.site.scrolled .links a:hover{color:var(--gold-2)}
nav.site.scrolled .navphone{color:var(--ink)}
nav.site.scrolled .navphone:hover{color:var(--gold-2)}
.menu-btn{display:none;background:none;border:0;color:#fff;cursor:pointer}
nav.site.scrolled .menu-btn{color:var(--ink)}
/* nav CTA aligned with phone/links (symmetric padding); white over hero, gold when scrolled */
nav.site .navcta .alink{padding:10px 3px;color:#fff}
nav.site.scrolled .navcta .alink{color:var(--gold-2)}
/* keep white nav text crisp over the hero video; drop the shadow once over cream */
nav.site .links a,nav.site .navphone{color:#fff}
nav.site .links a,nav.site .navphone,nav.site .navcta .alink{text-shadow:0 1px 3px rgba(15,29,49,.45)}
nav.site.scrolled .links a,nav.site.scrolled .navphone,nav.site.scrolled .navcta .alink{text-shadow:none}

/* HERO — full-bleed cinematic video, tasteful scrim, Cormorant headline */
.hero{position:relative;min-height:94vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--navy-deep)}
.hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background-size:cover;background-position:center 55%;z-index:0;transition:opacity .9s ease}
#heroB{opacity:0}
.hero .hero-bg.kenburns{animation:kenburns 30s ease-in-out infinite alternate;will-change:transform}
@keyframes kenburns{0%{transform:scale(1.05)}100%{transform:scale(1.17) translate(-2%,-2.5%)}}
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(15,29,49,.34) 0%,rgba(15,29,49,.08) 36%,rgba(15,29,49,.5) 70%,rgba(15,29,49,.88) 100%)}
.hero .inner{position:relative;z-index:2;width:100%;max-width:960px;padding-top:118px;padding-bottom:9vh}
.hero .kicker{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.hero .kicker .rule{height:1px;width:46px;background:var(--gold-bright)}
.hero .eyebrow{color:var(--gold-bright)}
.hero h1{color:#fff;font-size:clamp(2.8rem,6vw,5.2rem);font-weight:600;line-height:1.02;letter-spacing:-.015em}
.hero h1 em{font-style:italic;color:var(--gold-bright)}
.hero .sub{font-family:var(--serif);font-style:italic;color:rgba(255,255,255,.9);font-size:clamp(1.2rem,2.2vw,1.5rem);max-width:46ch;margin:24px 0 34px;line-height:1.4}
.hero .cta-row{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.btn-hero-outline{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.5);border-radius:var(--r-sm);padding:15px 28px;font-family:var(--sans);font-size:.95rem;font-weight:600;cursor:pointer;backdrop-filter:blur(4px);transition:transform .3s cubic-bezier(.2,.8,.2,1),background .3s,color .3s}
.btn-hero-outline:hover{background:#fff;color:var(--navy);transform:translateY(-2px)}
.locs{border-top:1px solid var(--cream3);background:var(--cream)}
.locs .wrap{display:flex;gap:40px;flex-wrap:wrap;color:var(--slate);font-size:.8rem;letter-spacing:.04em;padding-top:18px;padding-bottom:18px;font-family:var(--mono)}
.locs b{color:var(--gold-2);font-weight:600}

/* STATS */
.stats{background:var(--cream)}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stats .cell{background:var(--white);border:1px solid var(--cream3);border-radius:var(--r);padding:38px 26px;text-align:center;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s}
.stats .cell:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.stats .n{font-family:var(--serif);font-size:3rem;color:var(--gold);line-height:1;font-weight:600}
.stats .l{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);margin-top:12px}

/* SECTIONS */
section{padding:110px 0}
.stats{padding:64px 0}
.sec-head{max-width:720px;margin-bottom:54px}
.sec-head h2{font-size:clamp(2.1rem,4vw,3.1rem);margin:14px 0 0}
.sec-head p{color:var(--slate);font-size:1.06rem;margin:18px 0 0;max-width:62ch}
.attorneys .sec-head{max-width:none}
.attorneys .sec-head h2{text-wrap:balance;font-size:clamp(1.9rem,3.4vw,2.8rem);white-space:nowrap}
@media(max-width:760px){.attorneys .sec-head h2{white-space:normal}}

/* FIRM */
.firm{background:var(--cream2)}
.firm .split{display:grid;grid-template-columns:1.05fr .95fr;gap:70px;align-items:center}
.firm .lead{font-family:var(--serif);font-size:1.85rem;line-height:1.36;color:var(--ink)}
.firm .lead em{font-style:italic;color:var(--gold)}
.firm p{color:var(--slate);margin:20px 0 0}
.firm .panel{background:var(--white);border:1px solid var(--cream3);padding:42px;border-radius:var(--r);position:relative;box-shadow:var(--shadow)}
.firm .panel h3{font-size:1.7rem}
.firm .panel .pa{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid var(--cream3);font-size:1rem;transition:color .2s,padding-left .3s;cursor:pointer}
.firm .panel .pa:hover{padding-left:6px}
.firm .panel .pa span{transition:transform .4s cubic-bezier(.16,1,.3,1)}
.firm .panel .pa:hover span{transform:translateX(6px)}
.firm .panel .pa:last-child{border-bottom:0}
.firm .panel .pa:hover{color:var(--gold-2)}
.firm .panel .pa span{color:var(--gold)}

/* PRACTICE */
.practice{background:var(--cream)}
.pa-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pa-card{background:var(--white);border:1px solid var(--cream3);border-radius:var(--r);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s}
.pa-card .ph{height:172px;overflow:hidden}
.pa-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.8,.2,1)}
.pa-card .lab{padding:24px 24px 26px}
.pa-card .lab h3{font-size:1.34rem;line-height:1.14}
.pa-card .lab .more{font-family:var(--mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-top:12px;display:inline-flex;gap:7px;opacity:0;transform:translateY(6px);transition:all .35s}
.pa-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pa-card:hover .ph img{transform:scale(1.07)}
.pa-card:hover .lab .more{opacity:1;transform:translateY(0)}

/* ATTORNEYS */
.attorneys{background:var(--cream2)}
.at-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.at-card{cursor:pointer}
.at-photo{position:relative;aspect-ratio:3/3.5;overflow:hidden;border-radius:var(--r);background:var(--cream3);box-shadow:var(--shadow-sm);transition:transform .35s,box-shadow .35s}
.at-photo img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .6s cubic-bezier(.2,.8,.2,1);filter:saturate(.97)}
.at-card:hover .at-photo{transform:translateY(-5px);box-shadow:var(--shadow)}
.at-card:hover .at-photo img{transform:scale(1.05);filter:saturate(1.05)}
.at-name{font-family:var(--serif);font-size:1.32rem;margin-top:16px}
.at-title{font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-top:6px}
.at-areas{font-size:.86rem;color:var(--slate);margin-top:8px;line-height:1.45}

/* OFFICES */
.offices{background:var(--cream)}
.off-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.off-card{background:var(--white);border:1px solid var(--cream3);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s;padding:0}
.off-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.off-photo{height:200px;background-size:cover;background-position:center;position:relative}
.off-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,29,49,0) 50%,rgba(15,29,49,.22))}
.off-info{padding:24px 28px 28px}
.off-desc{font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2)}
.off-card .city{font-family:var(--serif);font-size:1.8rem;margin-top:6px}
.off-card .addr{color:var(--slate);margin-top:12px;font-size:.95rem;line-height:1.6}
.off-phone{display:inline-block;margin-top:12px;color:var(--navy);font-weight:600;font-size:1.06rem;transition:color .2s}
.off-phone:hover{color:var(--gold-2)}
.off-links{display:flex;flex-direction:column;align-items:flex-start;margin-top:14px;border-top:1px solid var(--cream3);padding-top:8px}
.alink.small{font-size:.9rem;padding:9px 2px 13px;font-weight:600}
.alink.small::after{bottom:7px}

/* CTA BAND */
.band{background:linear-gradient(135deg,var(--navy-2),var(--navy-deep));color:#fff;text-align:center;position:relative;overflow:hidden}
.band::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 300px at 50% -10%,rgba(201,164,110,.16),transparent)}
.band .wrap{position:relative}
.band h2{font-size:clamp(2rem,4vw,3rem);max-width:22ch;margin:0 auto;color:#fff}
.band h2 em{font-style:italic;color:var(--gold-bright)}
.band p{max-width:54ch;margin:18px auto 30px;color:rgba(255,255,255,.82)}

/* FOOTER */
footer{background:var(--navy-deep);color:rgba(255,255,255,.6);padding:70px 0 40px}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
footer .logo{height:42px;margin-bottom:18px}
footer h4{font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-bright);margin:0 0 16px}
footer ul{list-style:none;padding:0;margin:0}
footer li{margin-bottom:10px;font-size:.92rem}
footer li a{transition:color .2s}
footer li a:hover{color:var(--gold-bright)}
footer .legal{margin-top:50px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);font-size:.78rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:rgba(255,255,255,.42);font-family:var(--mono);letter-spacing:.04em}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* scroll roll-in: headlines rise up from behind a mask as they enter view */
.roll-mask{overflow:hidden;padding-bottom:.14em;margin-bottom:-.14em}
.roll-inner{display:block;transform:translateY(120%);transition:transform 1.05s cubic-bezier(.16,1,.3,1)}
.roll-mask.in .roll-inner{transform:translateY(0)}
@media(prefers-reduced-motion:reduce){.roll-inner{transform:none;transition:none}}

/* CHAT */
#fab{position:fixed;right:28px;bottom:28px;z-index:90;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,var(--navy-2),var(--navy));color:#fff;border:0;cursor:pointer;box-shadow:0 16px 40px -12px rgba(15,29,49,.5);transition:transform .35s cubic-bezier(.2,.8,.2,1)}
#fab:hover{transform:scale(1.07)}
#fab svg{width:24px;height:24px;stroke:var(--gold-bright)}
#fab::after{content:"";position:absolute;inset:0;border-radius:50%;border:1.5px solid var(--gold-bright);animation:fabpulse 2.6s cubic-bezier(.2,.7,.3,1) infinite;pointer-events:none}
@keyframes fabpulse{0%{transform:scale(1);opacity:.55}70%,100%{transform:scale(1.65);opacity:0}}
#fab .t{position:absolute;right:72px;background:var(--ink);color:#fff;padding:9px 15px;border-radius:10px;font-size:.82rem;font-weight:600;white-space:nowrap;opacity:0;transform:translateX(8px);transition:opacity .3s,transform .3s;pointer-events:none;box-shadow:var(--shadow-sm)}
#fab:hover .t{opacity:1;transform:translateX(0)}
#chat{position:fixed;right:26px;bottom:26px;top:92px;z-index:70;width:392px;max-width:calc(100vw - 32px);background:var(--cream);border-radius:18px;box-shadow:0 40px 90px -30px rgba(15,29,49,.5);display:none;flex-direction:column;overflow:hidden;border:1px solid var(--cream3);transition:width .35s cubic-bezier(.2,.8,.2,1)}
#chat.open{display:flex}
#chat.wide{width:min(50vw,860px)}
#chat .ch-actions{margin-left:auto;display:flex;align-items:center;gap:4px}
#chat .ch-expand{background:none;border:0;color:rgba(255,255,255,.72);cursor:pointer;display:flex;align-items:center;padding:5px;border-radius:6px;transition:color .2s,background .2s}
#chat .ch-expand:hover{color:#fff;background:rgba(255,255,255,.12)}
#chat .ch-expand svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2}
#chat .ch-head{background:linear-gradient(180deg,var(--navy-2),var(--navy));color:#fff;padding:18px 20px;display:flex;align-items:center;gap:12px}
#chat .ch-head .av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--gold-bright),var(--gold));display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:700;color:#fff;font-size:1.1rem}
#chat .ch-head .nm{font-weight:600;font-size:.95rem}
#chat .ch-head .st{font-size:.72rem;color:var(--gold-bright)}
#chat .ch-head .x{background:none;border:0;color:rgba(255,255,255,.7);font-size:1.5rem;cursor:pointer;line-height:1;padding:0 2px}
#chat .ch-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px;background:var(--cream)}
#chat .msg{max-width:84%;padding:12px 15px;border-radius:14px;font-size:.93rem;line-height:1.5}
#chat .msg.bot{background:#fff;border:1px solid var(--cream3);align-self:flex-start;border-bottom-left-radius:4px;box-shadow:var(--shadow-sm)}
#chat .msg.me{background:linear-gradient(180deg,var(--navy-2),var(--navy));color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
#chat .chips{display:flex;flex-wrap:wrap;gap:8px;padding:0 20px 12px}
#chat .chip{font-size:.78rem;border:1px solid var(--cream3);background:#fff;color:var(--navy);padding:8px 13px;border-radius:50px;cursor:pointer;transition:all .18s}
#chat .chip:hover{border-color:var(--gold);color:var(--gold-2);transform:translateY(-1px)}
#chat .ch-in{display:flex;gap:8px;padding:14px;border-top:1px solid var(--cream3);background:#fff}
#chat .ch-in input{flex:1;border:1px solid var(--cream3);border-radius:50px;padding:11px 16px;font-family:inherit;font-size:.92rem;outline:none}
#chat .ch-in input:focus{border-color:var(--gold)}
#chat .ch-in button{background:linear-gradient(180deg,var(--navy-2),var(--navy));border:0;color:#fff;width:42px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}
#chat .ch-in button svg{width:18px;height:18px;stroke:#fff}
#chat .ch-in button.ch-star{background:transparent;color:var(--gold);width:34px;border-radius:50%;flex-shrink:0}
#chat .ch-in button.ch-star:hover{background:var(--cream2)}
#chat .ch-in button.ch-star svg{width:22px;height:22px;stroke:none;fill:var(--gold)}
#chat .ch-in button.ch-star:hover svg{fill:var(--gold-bright)}
.typing{display:flex;gap:4px;padding:14px 16px}
.typing span{width:7px;height:7px;background:var(--gold);border-radius:50%;animation:bob 1s infinite}
.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}
@keyframes bob{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-5px)}}

/* MODAL */
.modal{position:fixed;inset:0;z-index:100;background:rgba(15,29,49,.5);backdrop-filter:blur(5px);display:none;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal .sheet{background:var(--cream);width:640px;max-width:100%;max-height:92vh;overflow-y:auto;border-radius:20px;position:relative;box-shadow:0 50px 100px -34px rgba(15,29,49,.5)}
.modal .sheet .top{background:linear-gradient(180deg,var(--navy-2),var(--navy));color:#fff;padding:26px 34px;position:sticky;top:0;z-index:2}
.modal .sheet .top h3{font-size:1.7rem;color:#fff}
.modal .sheet .top .sub{font-family:var(--mono);color:var(--gold-bright);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;margin-top:6px}
.modal .sheet .top .x{position:absolute;top:18px;right:20px;background:none;border:0;color:rgba(255,255,255,.7);font-size:1.7rem;cursor:pointer;line-height:1}
.modal .pad{padding:30px 34px 36px}
.steps-dots{display:flex;gap:8px;margin-bottom:24px}
.steps-dots i{height:3px;flex:1;background:var(--cream3);border-radius:2px;transition:background .3s}
.steps-dots i.on{background:var(--gold)}
.modal label.fl{display:block;font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);margin:0 0 10px;font-weight:500}
.modal input,.modal textarea,.modal select{width:100%;padding:13px 15px;border:1px solid var(--cream3);border-radius:var(--r-sm);font-family:inherit;font-size:1rem;background:#fff;margin-bottom:18px;outline:none;transition:border-color .2s,box-shadow .2s}
.modal input:focus,.modal textarea:focus,.modal select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(176,138,79,.12)}
.modal textarea{min-height:96px;resize:vertical}
.opt-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.opt{border:1px solid var(--cream3);border-radius:var(--r-sm);padding:16px;cursor:pointer;background:#fff;transition:all .2s;font-size:.95rem;font-weight:500}
.opt:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.opt.sel{border-color:var(--gold);box-shadow:inset 0 0 0 1px var(--gold)}
.opt small{display:block;color:var(--slate);font-weight:400;font-size:.8rem;margin-top:3px}
.row-btns{display:flex;justify-content:space-between;gap:12px;margin-top:8px}
.summary{background:#fff;border:1px solid var(--cream3);border-left:3px solid var(--gold);border-radius:var(--r-sm);padding:22px 24px;margin-bottom:20px;box-shadow:var(--shadow-sm)}
.summary .r{display:flex;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid var(--cream3);font-size:.95rem}
.summary .r:last-child{border-bottom:0}
.summary .r b{color:var(--ink)}
.summary .r span{color:var(--slate);text-align:right}
.note{font-size:.84rem;color:var(--slate);margin-top:6px}

/* DETAIL overlay — attorney bio + practice page */
.modal.detail .sheet{width:980px;max-width:100%;max-height:92vh;overflow-y:auto;padding:0;background:var(--cream)}
.dx{position:absolute;top:16px;right:18px;z-index:6;background:rgba(21,38,63,.55);backdrop-filter:blur(6px);color:#fff;border:0;width:38px;height:38px;border-radius:50%;font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.dx:hover{background:var(--navy)}
.att-detail{display:grid;grid-template-columns:300px 1fr;gap:0}
.att-side{background:linear-gradient(180deg,var(--navy-2),var(--navy));padding:40px 30px}
.att-photo-lg{width:100%;aspect-ratio:3/3.6;object-fit:cover;object-position:top center;border-radius:14px;box-shadow:var(--shadow)}
.att-contact{margin-top:24px;display:flex;flex-direction:column;gap:14px}
.att-contact a{color:#fff;font-size:.92rem;word-break:break-word;border-bottom:1px solid rgba(255,255,255,.14);padding-bottom:12px;transition:color .2s}
.att-contact a span{display:block;font-family:var(--mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-bright);margin-bottom:5px}
.att-contact a:hover{color:var(--gold-bright)}
.att-contact a.vcard{border:1px solid var(--gold);border-radius:10px;padding:12px;text-align:center;color:var(--gold-bright);font-weight:600;font-size:.82rem;border-bottom:1px solid var(--gold)}
.att-contact a.vcard:hover{background:var(--gold);color:#fff}
.att-main{padding:48px 46px 46px}
.att-main h2{font-size:2.4rem;margin:6px 0 0}
.lead-p{font-family:var(--serif);font-size:1.32rem;line-height:1.46;color:var(--ink);margin:18px 0 0}
.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin:22px 0 6px}
.chip-link{font-size:.82rem;border:1px solid var(--cream3);background:#fff;color:var(--navy);padding:8px 14px;border-radius:50px;cursor:pointer;transition:all .18s;display:inline-block}
.chip-link:hover{border-color:var(--gold);color:var(--gold-2)}
.chip-link.static{cursor:default;color:var(--slate)}
/* animated practice-area index (replaces pills) */
.area-list{display:flex;flex-direction:column;margin-top:2px}
.area-link{display:flex;align-items:center;gap:13px;padding:12px 0;border-bottom:1px solid var(--cream3);cursor:pointer;color:var(--ink);font-weight:500;font-size:1.02rem;position:relative;transition:color .3s,padding-left .35s cubic-bezier(.2,.8,.2,1)}
.area-link::before{content:"";width:7px;height:7px;background:var(--gold);transform:rotate(45deg);flex-shrink:0;transition:transform .35s,background .3s}
.area-link>span:first-child{flex:1}
.area-link .arr{color:var(--gold);opacity:0;transform:translateX(-8px);transition:opacity .35s,transform .45s cubic-bezier(.16,1,.3,1)}
.area-link:hover{color:var(--gold-2);padding-left:9px}
.area-link:hover::before{transform:rotate(45deg) scale(1.35)}
.area-link:hover .arr{opacity:1;transform:translateX(0)}
.area-link.static{cursor:default}
.area-link.static::before{background:var(--cream3)}

/* Guided AI intake (conversational) */
.ik-sheet{display:flex;flex-direction:column;height:82vh;max-height:700px;padding:0;overflow:hidden}
.ik-sheet .top{flex-shrink:0}
.ik-chat{flex:1;overflow-y:auto;padding:24px 28px;display:flex;flex-direction:column;gap:14px;background:var(--cream)}
.ik-chat .msg{max-width:90%;padding:13px 16px;border-radius:14px;font-size:.92rem;line-height:1.5}
.ik-chat .msg.bot{background:#fff;border:1px solid var(--cream3);align-self:flex-start;border-bottom-left-radius:4px;box-shadow:var(--shadow-sm)}
.ik-chat .msg.me{background:linear-gradient(180deg,var(--navy-2),var(--navy));color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.ik-inbar{flex-shrink:0;display:flex;flex-direction:column;gap:10px;padding:14px 18px 16px;border-top:1px solid var(--cream3);background:#fff}
.ik-inbar textarea{width:100%;border:1px solid var(--cream3);border-radius:14px;padding:13px 15px;font-family:inherit;font-size:.92rem;resize:none;outline:none;min-height:64px;max-height:180px;line-height:1.5;background:var(--cream);transition:border-color .2s}
.ik-inbar textarea:focus{border-color:var(--gold)}
.ik-actions{display:flex;align-items:center;justify-content:space-between;gap:10px}
.ik-polish{display:inline-flex;align-items:center;gap:7px;background:none;border:1px solid var(--cream3);color:var(--gold-2);border-radius:12px;padding:9px 14px;font-family:inherit;font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s}
.ik-polish:hover{border-color:var(--gold);background:var(--cream)}
.ik-polish svg{width:15px;height:15px}
.ik-send{width:44px;height:44px;border-radius:50%;background:linear-gradient(180deg,var(--navy-2),var(--navy));border:0;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s}
.ik-send:hover{transform:scale(1.06)}
.ik-send svg{width:19px;height:19px}
.ik-inbar.done .ik-actions{display:none}
/* in-site office map */
.off-map{width:100%;height:400px;border:0;display:block}
.map-detail h2{font-size:2rem}
.dh{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-2);margin:30px 0 12px;font-weight:600}
.dp{color:var(--slate);margin:0}
.kv-list{display:flex;flex-direction:column;gap:12px}
.kv{display:flex;flex-direction:column}
.kv span{font-size:.82rem;color:var(--slate)}
.kv b{color:var(--ink);font-weight:600}
.dlist{margin:0;padding-left:20px;color:var(--slate);line-height:1.7}
.dlist.cols{columns:2;column-gap:34px}
.dlist li{margin-bottom:7px}
.prac-hero{height:250px;background-size:cover;background-position:center;position:relative;display:flex;align-items:flex-end}
.prac-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,29,49,.18),rgba(15,29,49,.84))}
.prac-hero-cap{position:relative;z-index:2;padding:30px 46px}
.prac-hero-cap h2{color:#fff;font-size:2.5rem;margin:8px 0 0}
.prac-main{padding:42px 46px 46px}
.prac-body p{color:var(--slate);line-height:1.78;margin:0 0 16px;font-size:1.04rem}
.mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.mini-att{display:flex;align-items:center;gap:14px;border:1px solid var(--cream3);border-radius:12px;padding:12px 14px;cursor:pointer;background:#fff;transition:all .2s}
.mini-att:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.mini-att img{width:54px;height:54px;border-radius:10px;object-fit:cover;object-position:top center;flex-shrink:0}
.mini-att b{display:block;color:var(--ink);font-size:.95rem;line-height:1.2}
.mini-att span{font-size:.72rem;color:var(--gold-2);font-family:var(--mono);letter-spacing:.06em}
@media(max-width:720px){
  .att-detail{grid-template-columns:1fr}
  .att-side{padding:28px}
  .att-main{padding:30px}
  .att-main h2,.prac-hero-cap h2{font-size:1.9rem}
  .dlist.cols{columns:1}
  .mini-grid{grid-template-columns:1fr}
  .prac-main{padding:28px}
}

@media(max-width:1000px){
  .hero-banner{height:38vh;min-height:240px}
  .firm .split{grid-template-columns:1fr;gap:40px}
  .pa-grid{grid-template-columns:repeat(2,1fr)}
  .at-grid{grid-template-columns:repeat(3,1fr)}
  .off-grid{grid-template-columns:1fr}
  .stats .grid{grid-template-columns:repeat(2,1fr)}
  footer .cols{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  body{font-size:16px}
  .wrap{padding:0 20px}
  nav.site .links{display:none}
  .menu-btn{display:block}
  section{padding:72px 0}
  .pa-grid{grid-template-columns:1fr}
  .at-grid{grid-template-columns:repeat(2,1fr)}
  .opt-grid{grid-template-columns:1fr}
  .locs .wrap{gap:16px;font-size:.72rem}
  .hero h1{font-size:clamp(2.4rem,9vw,3rem)}
  .ins-grid{grid-template-columns:1fr}
}
/* Insights / news */
.insights{padding:96px 0;background:var(--cream2,var(--cream))}
.ins-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:42px}
.ins-card{background:var(--white,#fffdf8);border:1px solid var(--cream3);border-radius:16px;padding:26px 24px;cursor:pointer;transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s;display:flex;flex-direction:column}
.ins-card:hover{transform:translateY(-5px);box-shadow:0 28px 52px -28px rgba(15,29,49,.42)}
.ins-cat{font-family:var(--mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);margin-bottom:13px}
.ins-card h3{font-family:var(--serif);font-weight:600;font-size:1.42rem;line-height:1.18;color:var(--navy);margin-bottom:10px}
.ins-card p{color:var(--slate);font-size:.92rem;line-height:1.55;flex:1}
.ins-meta{font-size:.74rem;color:var(--slate);margin:18px 0 12px}
.article{max-width:720px;margin:0 auto;padding:46px 48px 56px}
.article .eyebrow{margin-bottom:8px}
.article h2{font-family:var(--serif);font-weight:600;font-size:2.1rem;line-height:1.14;margin-bottom:10px;color:var(--navy)}
.art-meta{font-size:.74rem;color:var(--slate);margin-bottom:24px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase}
.art-body p{font-size:1.05rem;line-height:1.72;color:var(--ink);margin-bottom:16px}
.art-disc{font-size:.78rem;color:#9a8f78;font-style:italic;margin-top:20px;border-top:1px solid var(--cream3);padding-top:12px}
@media(max-width:820px){.article{padding:30px 22px 42px}}
/* Ambient music toggle (bottom-left) */
#ambientBtn{position:fixed;left:22px;bottom:22px;z-index:60;display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--navy);color:#fff;border:0;border-radius:50%;cursor:pointer;box-shadow:0 16px 34px -16px rgba(15,29,49,.55);transition:transform .2s,opacity .2s;opacity:.94}
#ambientBtn:hover{transform:translateY(-2px) scale(1.04);opacity:1}
#ambientBtn .abars{display:flex;align-items:center;gap:2.5px;height:18px}
#ambientBtn .abars i{width:2.5px;background:var(--gold-bright);border-radius:2px}
#ambientBtn .abars i:nth-child(1){height:7px}
#ambientBtn .abars i:nth-child(2){height:14px}
#ambientBtn .abars i:nth-child(3){height:9px}
#ambientBtn .abars i:nth-child(4){height:12px}
#ambientBtn.playing .abars i{animation:abar 1.1s ease-in-out infinite}
#ambientBtn.playing .abars i:nth-child(2){animation-delay:.22s}
#ambientBtn.playing .abars i:nth-child(3){animation-delay:.44s}
#ambientBtn.playing .abars i:nth-child(4){animation-delay:.13s}
@keyframes abar{0%,100%{height:5px}50%{height:18px}}
@media(max-width:820px){#ambientBtn{left:14px;bottom:14px}}
/* Podcast */
.podcast{padding:0 0 96px;background:var(--cream2,var(--cream))}
.pod-wrap{display:flex;align-items:center;gap:28px;background:var(--navy);color:#fff;border-radius:22px;padding:34px 40px;box-shadow:0 34px 64px -34px rgba(15,29,49,.62)}
.pod-play{flex-shrink:0;width:64px;height:64px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;cursor:pointer;border:0;transition:transform .2s,background .2s}
.pod-play:hover{transform:scale(1.06);background:var(--gold-bright)}
.pod-play svg{width:26px;height:26px;fill:var(--navy)}
.pod-play .pause{display:none}.pod-play.playing .play{display:none}.pod-play.playing .pause{display:block}
.pod-info{flex:1;min-width:0}
.pod-info .eyebrow{color:var(--gold-bright);margin-bottom:7px}
.pod-info h3{font-family:var(--serif);font-weight:600;font-size:1.55rem;margin-bottom:7px;color:#fff}
.pod-info p{color:rgba(255,255,255,.72);font-size:.92rem;line-height:1.5;margin-bottom:18px;max-width:56ch}
.pod-player{display:flex;align-items:center;gap:14px}
.pod-bar{flex:1;height:6px;background:rgba(255,255,255,.18);border-radius:4px;cursor:pointer;overflow:hidden;max-width:440px}
.pod-bar #podFill{height:100%;width:0;background:var(--gold);border-radius:4px;transition:width .15s linear}
.pod-time{font-family:var(--mono);font-size:.72rem;color:rgba(255,255,255,.72);white-space:nowrap}
@media(max-width:820px){.pod-wrap{flex-direction:column;text-align:center;padding:28px 22px;gap:18px}.pod-info p{max-width:none}.pod-player{flex-direction:column}.pod-bar{width:100%;max-width:none}}

/* Client Portal / Get the App modal */
.app-sheet{max-width:392px}
.app-body{padding:26px 28px 30px;text-align:center}
.qr{width:208px;height:208px;margin:0 auto 16px;background:#fff;padding:12px;border-radius:14px;border:1px solid var(--cream3);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center}
.qr img,.qr canvas,.qr table{display:block;margin:0 auto}
.qr-url{font-family:var(--mono);font-size:.82rem;letter-spacing:.01em;color:var(--gold-2);margin-bottom:18px;word-break:break-all}
.app-body .alink{margin:0 auto;display:inline-flex}
.qr-note{font-size:.86rem;color:var(--slate);line-height:1.5;margin-top:18px;max-width:32ch;margin-left:auto;margin-right:auto}

/* ===== Proper mobile menu overlay ===== */
.menu-btn .ic-x{display:none}
.menu-btn{position:relative;z-index:90}
.mnav{position:fixed;inset:0;z-index:75;background:linear-gradient(165deg,var(--navy-2),var(--navy-deep));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;opacity:0;visibility:hidden;transition:opacity .25s ease;padding:90px 24px 48px;overflow-y:auto}
.mnav a{color:#fff;font-family:var(--serif);font-style:italic;font-weight:600;font-size:1.75rem;padding:11px 0;text-shadow:none}
.mnav a:active{color:var(--gold-bright)}
.mnav-cta{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:16px;border-top:1px solid rgba(255,255,255,.14);padding-top:26px;width:100%;max-width:280px}
.mnav-phone{color:var(--gold-bright)!important;font-family:var(--mono)!important;font-size:1.12rem!important;font-weight:600!important;letter-spacing:.04em}
.mnav-btn{background:linear-gradient(135deg,var(--gold-bright),var(--gold));color:#1a1408;border:0;padding:15px 30px;border-radius:11px;font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;cursor:pointer;width:100%}
body.menu-open{overflow:hidden}
body.menu-open .mnav{opacity:1;visibility:visible}
body.menu-open nav.site{background:transparent!important;box-shadow:none!important}
body.menu-open nav.site .logo.white{display:block!important}
body.menu-open nav.site .logo.dark{display:none!important}
body.menu-open .menu-btn{color:#fff!important}
body.menu-open .menu-btn .ic-bars{display:none}
body.menu-open .menu-btn .ic-x{display:block}
@media(max-width:680px){ nav.site .navcta{display:none} }
html,body{overflow-x:hidden;max-width:100vw}
/* fix: News cards base rule was defined after its mobile override — force stack on mobile */
@media(max-width:680px){ .ins-grid{grid-template-columns:1fr} .insights{padding:64px 0} }
