/* Montclair Real Estate Law Group — "Cornerstone" identity
   warm limestone + deep charcoal-ink + architectural slate-blue + brass hairline
   EB Garamond + Manrope · arch / cornerstone-line motif */
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Manrope:wght@300;400;500;600;700;800&display=swap');

:root{
  --paper:#f2eee5; --paper-2:#e9e3d6; --card:#fbf9f3;
  --ink:#23262d; --ink-2:#363a44; --ink-soft:#5b5f69; --line:#ddd5c5;
  --slate:#3a5a78; --slate-2:#2c4661; --slate-soft:#e4eaf0;
  --brass:#a9844a; --brass-2:#8a6a35;
  --maxw:1160px; --r:3px; --r-lg:8px;
  --shadow:0 1px 2px rgba(35,38,45,.05),0 16px 44px rgba(35,38,45,.10);
  --shadow-sm:0 1px 2px rgba(35,38,45,.06),0 6px 18px rgba(35,38,45,.06);
  --serif:'EB Garamond',Georgia,serif; --sans:'Manrope',-apple-system,system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:var(--slate-2);text-decoration:none}
a:hover{color:var(--brass-2)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.16;letter-spacing:.002em;margin:0 0 .5em;color:var(--ink)}
h1{font-size:clamp(2.5rem,5.4vw,4.1rem);font-weight:400}
h2{font-size:clamp(1.9rem,3.4vw,2.8rem);font-weight:400}
h3{font-size:1.34rem;font-weight:600}
p{margin:0 0 1.1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.24em;
  text-transform:uppercase;color:var(--brass-2);margin:0 0 1.1rem;display:flex;align-items:center;gap:.7rem}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--brass)}
.eyebrow.c{justify-content:center}
.lede{font-size:1.22rem;color:var(--ink-soft);line-height:1.7}
.muted{color:var(--ink-soft)}
.center{text-align:center}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-weight:600;
  font-size:.92rem;letter-spacing:.02em;padding:.95rem 1.8rem;border-radius:var(--r);border:1px solid transparent;cursor:pointer;transition:.18s ease}
.btn-primary{background:var(--ink);color:#f2eee5}
.btn-primary:hover{background:var(--slate-2);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--brass)}
.btn-ghost:hover{background:var(--card);color:var(--brass-2)}
.btn-on-ink{background:var(--brass);color:#241c0c}
.btn-on-ink:hover{background:#c19a55;transform:translateY(-1px)}

/* header */
.site-header{position:sticky;top:0;z-index:60;background:rgba(242,238,229,.86);
  backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid transparent;transition:.25s}
.site-header.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 22px rgba(35,38,45,.06)}
.nav-bar{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--serif);font-size:1.2rem;color:var(--ink);font-weight:500}
.brand .mk{width:38px;height:38px;flex:0 0 38px}
.brand b{font-weight:600;letter-spacing:.04em}
.brand small{display:block;font-family:var(--sans);font-size:.57rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-2);font-weight:700;margin-top:2px}
.nav-links{display:flex;align-items:center;gap:1.5rem;list-style:none;margin:0;padding:0}
.nav-links a{font-family:var(--sans);font-size:.9rem;font-weight:600;color:var(--ink);letter-spacing:.01em}
.nav-links a:hover{color:var(--brass-2)}
.nav-cta{margin-left:.4rem}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);transition:.2s}
.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;overflow:hidden;border-bottom:1px solid var(--line)}
.hero::before{content:"";position:absolute;right:-5%;top:-10%;width:520px;height:620px;opacity:.5;
  background:no-repeat center/contain url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 240' fill='none'%3E%3Cpath d='M30 230V70a70 70 0 0 1 140 0v160' stroke='%23a9844a' stroke-width='1'/%3E%3Cpath d='M55 230V78a45 45 0 0 1 90 0v152' stroke='%233a5a78' stroke-width='1'/%3E%3Cpath d='M80 230v-150a20 20 0 0 1 40 0v150' stroke='%23a9844a' stroke-width='.8'/%3E%3C/svg%3E")}
.hero-inner{position:relative;padding:6rem 0 5.5rem;max-width:740px}
.hero h1{margin-bottom:.3em}
.hero h1 .acc{font-style:italic;color:var(--slate-2)}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.6rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:1.4rem;margin-top:2.4rem;align-items:center}
.hero-trust span{font-size:.82rem;font-weight:600;color:var(--ink-soft);display:flex;align-items:center;gap:.5rem}
.hero-trust span::before{content:"";width:7px;height:7px;background:var(--brass);transform:rotate(45deg)}

/* cornerstone rule */
.cstone{display:flex;align-items:center;gap:1rem;margin:0}
.cstone::before,.cstone::after{content:"";height:1px;background:var(--line);flex:1}
.cstone span{width:9px;height:9px;border:1px solid var(--brass);transform:rotate(45deg)}

/* sections */
section{padding:5.5rem 0}
.alt{background:var(--paper-2)}
.ink-sec{background:var(--ink);color:#cdd0d7}
.ink-sec h2,.ink-sec h3{color:#fbf9f3}
.ink-sec .lede,.ink-sec p{color:#bcc0c8}
.ink-sec .eyebrow{color:#c9a96a}.ink-sec .eyebrow::before{background:#c9a96a}
.sec-head{max-width:680px;margin:0 0 3rem}
.sec-head.c{margin:0 auto 3rem;text-align:center}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.split.r .split-aside{order:2}
.aside-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:2.3rem;box-shadow:var(--shadow-sm);position:relative}
.aside-card::before{content:"";position:absolute;left:0;top:0;width:34px;height:34px;border-top:2px solid var(--brass);border-left:2px solid var(--brass);border-radius:8px 0 0 0;margin:-1px}
.aside-card h3{color:var(--ink)}
.kv{display:flex;justify-content:space-between;gap:1rem;padding:.85rem 0;border-bottom:1px dashed var(--line);font-size:.96rem}
.kv:last-child{border-bottom:0}
.kv .k{color:var(--ink-soft)}.kv .v{font-weight:700;color:var(--ink);text-align:right}

/* practice cards */
.grid{display:grid;gap:1.5rem}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.pa{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:2.1rem 1.9rem;transition:.2s;position:relative}
.pa:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:#cdbf9f}
.pa .n{font-family:var(--serif);font-size:1.7rem;color:var(--brass);line-height:1;display:block;margin-bottom:.6rem}
.pa h3{font-size:1.22rem;margin-bottom:.45rem}
.pa p{margin:0;font-size:.96rem;color:var(--ink-soft)}

/* feat detail */
.feat{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:2.1rem;border-left:3px solid var(--slate)}
.feat h3{font-size:1.3rem;margin-bottom:.5rem}.feat p{margin:0;color:var(--ink-soft)}
.feat+.feat{margin-top:1.2rem}

/* attorneys */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem}
.member{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.8rem;text-align:center}
.member .mono{width:96px;height:96px;border-radius:50%;margin:0 auto 1.1rem;display:flex;align-items:center;justify-content:center;
  background:var(--ink);color:var(--paper);font-family:var(--serif);font-size:2rem;font-weight:500;border:2px solid var(--brass)}
.member h3{margin-bottom:.15rem;font-size:1.12rem}
.member .role{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass-2);font-weight:700}

/* serve chips */
.chips{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-top:1.5rem}
.chip{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:.5rem 1.1rem;font-size:.92rem;color:var(--ink);font-weight:500}

/* stat band */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;text-align:center}
.stat .n{font-family:var(--serif);font-size:3rem;color:#fbf9f3;line-height:1}
.stat .l{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:#9aa0aa;margin-top:.5rem}

/* checks */
.checks{list-style:none;margin:1.2rem 0 0;padding:0;display:grid;gap:.7rem}
.checks li{position:relative;padding-left:1.7rem;color:var(--ink-soft)}
.checks li::before{content:"";position:absolute;left:.1rem;top:.55em;width:8px;height:8px;border:1px solid var(--brass);transform:rotate(45deg)}
.cols-2{columns:2;column-gap:2.5rem}.cols-2 li{break-inside:avoid}
@media (max-width:620px){.cols-2{columns:1}}

/* faq */
.faq{max-width:800px;margin:0 auto;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:.4rem 2rem}
.faq details{border-bottom:1px solid var(--line);padding:1.3rem 0}.faq details:last-child{border-bottom:0}
.faq summary{font-family:var(--serif);font-weight:600;font-size:1.18rem;cursor:pointer;list-style:none;display:flex;
  justify-content:space-between;gap:1rem;align-items:center;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--sans);font-size:1.5rem;color:var(--brass);transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:1rem 0 0;color:var(--ink-soft)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.8rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.4rem}
.field input,.field textarea,.field select{width:100%;padding:.85rem 1rem;border:1px solid var(--line);
  border-radius:var(--r);background:#fff;font-family:var(--sans);font-size:1rem;color:var(--ink)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--slate);box-shadow:0 0 0 3px var(--slate-soft)}
.info-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.8rem}
.info-row{display:flex;gap:.9rem;padding:.85rem 0;border-bottom:1px solid var(--line)}
.info-row:last-child{border-bottom:0}
.info-row .ic{color:var(--brass-2);flex:0 0 22px;margin-top:2px}
.info-row b{display:block;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin-bottom:.15rem}
.map-embed{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);height:300px;margin-top:1.3rem}
.map-embed iframe{width:100%;height:100%;border:0;filter:grayscale(.2)}

/* CTA band */
.cta-band{background:var(--ink);border-radius:var(--r-lg);padding:3.5rem;text-align:center;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:linear-gradient(90deg,var(--brass),var(--slate))}
.cta-band h2{color:#fbf9f3}.cta-band p{color:#bcc0c8}

/* footer */
.site-footer{background:var(--ink);color:#a4a9b2;padding:4rem 0 2rem}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
.site-footer h4{color:#fbf9f3;font-family:var(--sans);font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:1.1rem}
.site-footer a{color:#a4a9b2;display:block;margin-bottom:.55rem;font-size:.95rem}
.site-footer a:hover{color:#c9a96a}
.foot-brand{font-family:var(--serif);font-size:1.4rem;color:#fbf9f3;margin-bottom:.6rem;display:flex;align-items:center;gap:.6rem}
.foot-brand .mk{width:32px;height:32px}
.foot-bot{border-top:1px solid rgba(255,255,255,.12);padding-top:1.6rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#7e838d}
.foot-bot a{display:inline;color:#7e838d}

/* sticky mobile bar */
.mobar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:70;background:rgba(242,238,229,.97);
  backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:.6rem;gap:.6rem}
.mobar a{flex:1;text-align:center;justify-content:center}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}.reveal[data-d="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* responsive */
@media (max-width:980px){
  .split{grid-template-columns:1fr;gap:2.2rem}.split.r .split-aside{order:0}
  .g-3,.g-4{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .hero::before{opacity:.25}
}
@media (max-width:760px){
  .nav-links{position:fixed;inset:78px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);padding:.5rem 24px 1.2rem;
    transform:translateY(-130%);transition:transform .3s ease;box-shadow:0 16px 30px rgba(35,38,45,.1)}
  .nav-links.open{transform:none}
  .nav-links li{border-bottom:1px solid var(--line)}.nav-links li:last-child{border-bottom:0}
  .nav-links a{display:block;padding:.95rem .2rem}
  .nav-cta{margin:.7rem 0 0}.nav-cta a{display:block;text-align:center}
  .nav-toggle{display:flex}
  .g-2,.g-3,.g-4,.team-grid{grid-template-columns:1fr}
  .cta-band{padding:2.4rem 1.6rem}
  .foot-grid{grid-template-columns:1fr}
  body{padding-bottom:64px}.mobar{display:flex}
  section{padding:3.8rem 0}
}
