/* =========================================================================
   WWMR — homepage sections
   ========================================================================= */

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;isolation:isolate;overflow:hidden;background:var(--navy-deep)}
.hero__poster,#hero-gl{position:absolute;inset:0;width:100%;height:100%}
.hero__poster{
  object-fit:cover;z-index:0;
  background:
    radial-gradient(110% 80% at 80% 10%,rgba(176,138,79,.30),transparent 55%),
    radial-gradient(90% 80% at 10% 100%,rgba(46,110,115,.30),transparent 55%),
    linear-gradient(160deg,#0C1828 0%,#13233A 55%,#0C1828 100%);
}
#hero-gl{z-index:1;opacity:.9}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.42;mix-blend-mode:luminosity}
.hero::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(12,24,40,.55) 0%,rgba(12,24,40,.30) 40%,rgba(12,24,40,.78) 100%)}
.hero__content{position:relative;z-index:3;color:#fff;padding-top:var(--header-h)}
.hero__content .eyebrow{color:var(--brass-light)}
.hero__content .eyebrow::before{background:var(--brass-light)}
.hero h1{color:#fff;font-size:clamp(2.6rem,1.5rem + 5vw,5rem);max-width:16ch}
.hero h1 em{font-style:normal;color:var(--brass-light)}
.hero__lede{font-size:1.22rem;color:#d7dde6;max-width:54ch;margin:1.4rem 0 2.2rem}
.hero__meta{margin-top:3rem;display:flex;flex-wrap:wrap;gap:2rem 3rem;align-items:center;border-top:1px solid rgba(255,255,255,.14);padding-top:1.8rem}
.hero__meta .m{display:flex;flex-direction:column;gap:.2rem}
.hero__meta .m b{font-family:var(--serif);font-size:1.6rem;color:#fff;line-height:1}
.hero__meta .m b .suf{color:var(--brass-light)}
.hero__meta .m span{font-size:.8rem;letter-spacing:.04em;color:#9aa7b8;text-transform:uppercase}
.hero__scroll{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);z-index:3;color:#9aa7b8;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.6rem}
.hero__scroll::after{content:"";width:1px;height:34px;background:linear-gradient(var(--brass-light),transparent);animation:scrolldrop 2s infinite}
@keyframes scrolldrop{0%{opacity:0;transform:scaleY(.3)}50%{opacity:1}100%{opacity:0;transform:scaleY(1) translateY(10px)}}

/* ---------- trust strip ---------- */
.trust{background:var(--navy);color:#cfd6e0;padding:1.5rem 0}
.trust__row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1rem 2.6rem;text-align:center}
.trust__item{display:inline-flex;align-items:center;gap:.6rem;font-size:.92rem;letter-spacing:.02em}
.trust__item svg{width:18px;height:18px;color:var(--brass-light);flex:none}
.trust__sep{width:1px;height:20px;background:rgba(255,255,255,.16)}
@media(max-width:760px){.trust__sep{display:none}}

/* ---------- intro / about ---------- */
.intro{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.intro__media{position:relative}
.intro__media img{border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;aspect-ratio:4/3;object-fit:cover}
.intro__badge{position:absolute;right:-1.2rem;bottom:-1.2rem;background:var(--navy);color:#fff;border-radius:var(--radius);padding:1.3rem 1.5rem;box-shadow:var(--shadow-lg);max-width:230px}
.intro__badge b{font-family:var(--serif);font-size:2.4rem;color:var(--brass-light);display:block;line-height:1}
.intro__badge span{font-size:.84rem;color:#c3cbd7}
@media(max-width:860px){.intro{grid-template-columns:1fr}.intro__media{order:-1}}

/* ---------- practice areas ---------- */
.practice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.practice-card{display:flex;flex-direction:column;min-height:420px;color:#fff;border-radius:var(--radius);overflow:hidden;position:relative;isolation:isolate;border:0}
.practice-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .6s ease}
.practice-card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(12,24,40,.25),rgba(12,24,40,.92))}
.practice-card:hover img{transform:scale(1.06)}
.practice-card__body{margin-top:auto;padding:1.8rem}
.practice-card__num{font-family:var(--serif);font-size:.9rem;color:var(--brass-light);letter-spacing:.1em}
.practice-card h3{color:#fff;margin:.5rem 0 .6rem}
.practice-card p{color:#cfd6e0;font-size:.95rem;margin-bottom:1rem}
.practice-card .link-arrow{color:#fff}
.practice-card .link-arrow::after{background:var(--brass-light)}
@media(max-width:900px){.practice-grid{grid-template-columns:1fr}}

/* ---------- why-us / differentiators ---------- */
.why{background:var(--navy-deep);color:#fff;position:relative;overflow:hidden}
.why .eyebrow{color:var(--brass-light)}.why .eyebrow::before{background:var(--brass-light)}
.why h2{color:#fff}
.why__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.4rem;margin-top:2.6rem}
.why__item{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:1.8rem;transition:background .3s,transform .3s}
.why__item:hover{background:rgba(176,138,79,.1);transform:translateY(-4px)}
.why__item .ico{width:46px;height:46px;border-radius:10px;background:rgba(176,138,79,.16);display:grid;place-items:center;margin-bottom:1.1rem;color:var(--brass-light)}
.why__item .ico svg{width:24px;height:24px}
.why__item h3{color:#fff;font-size:1.18rem}
.why__item p{color:#aeb8c6;font-size:.93rem;margin:0}

/* ---------- attorneys preview ---------- */
.team-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1.5rem;margin-bottom:2.4rem;flex-wrap:wrap}
.team-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.team-card{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--navy);aspect-ratio:3/4}
.team-card img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .5s,filter .5s;filter:grayscale(.25)}
.team-card:hover img{transform:scale(1.05);filter:grayscale(0)}
.team-card__cap{position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1.1rem .9rem;background:linear-gradient(transparent,rgba(12,24,40,.92));color:#fff}
.team-card__cap b{font-family:var(--serif);font-size:1.05rem;display:block}
.team-card__cap span{font-size:.78rem;color:var(--brass-light);letter-spacing:.04em}
@media(max-width:900px){.team-strip{grid-template-columns:repeat(2,1fr)}}

/* ---------- testimonials ---------- */
.teste{background:var(--cream-2)}
.teste-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.quote-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.9rem;position:relative}
.quote-card .mark{font-family:var(--serif);font-size:3.4rem;color:var(--brass);line-height:.6;opacity:.5}
.quote-card p{font-size:1rem;color:var(--ink);font-style:italic}
.quote-card .who{margin-top:1.1rem;border-top:1px solid var(--line);padding-top:1rem}
.quote-card .who b{color:var(--navy);font-family:var(--serif);font-size:1.02rem}
.quote-card .who span{display:block;font-size:.84rem;color:var(--muted)}
@media(max-width:900px){.teste-grid{grid-template-columns:1fr}}

/* ---------- CTA band ---------- */
.cta-band{position:relative;background:var(--navy-deep);color:#fff;text-align:center;overflow:hidden;isolation:isolate}
.cta-band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;opacity:.25}
.cta-band::after{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(80% 120% at 50% 0%,rgba(176,138,79,.22),rgba(12,24,40,.92))}
.cta-band h2{color:#fff;max-width:20ch;margin-inline:auto}
.cta-band p{color:#c3cbd7;max-width:54ch;margin:1rem auto 2rem}

/* ---------- offices ---------- */
.offices{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem}
.office-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem;position:relative;overflow:hidden}
.office-card .tag{font:600 .72rem/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--brass)}
.office-card h3{margin:.7rem 0 .3rem}
.office-card address{font-style:normal;color:var(--muted);line-height:1.7}
.office-card .ph{margin-top:1rem;display:inline-flex;gap:.5rem;align-items:center;font-weight:600;color:var(--navy)}
@media(max-width:760px){.offices{grid-template-columns:1fr}}

/* contact split */
.contact-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
@media(max-width:860px){.contact-split{grid-template-columns:1fr}}
