/* Bontozis Law Refresh v1 — 2025-10-02
   Accessible, responsive, light CSS (no frameworks)
*/
:root{
  --bg:#ffffff;
  --text:#0e2a47;
  --muted:#4b5b70;
  --line:#e5e8ec;
  --brand:#0e2a47;
  --accent:#b59b52;
  --surface:#f7f9fb;
  --radius:10px;
  --shadow:0 6px 16px rgba(0,0,0,.06);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
}
h1,h2,h3{font-family:"Source Serif 4",Georgia,Times,serif; line-height:1.25}
h1{font-weight:700;font-size:clamp(2rem,3.8vw,3rem);margin:.2rem 0 1rem}
h2{font-weight:700;font-size:clamp(1.4rem,2.5vw,2rem);margin:0 0 1rem}
h3{font-weight:600;font-size:1.15rem;margin:0 0 .5rem}
p{margin:.2rem 0 1rem;color:var(--muted)}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1080px;margin:0 auto;padding:0 1rem}
.section{padding:3.5rem 0}
.section.alt{background:var(--surface)}
.section-lead{font-size:1.05rem}

/* Header */
.site-header{position:sticky;top:0;backdrop-filter:saturate(180%) blur(8px);background:rgba(255,255,255,.92);border-bottom:1px solid var(--line);z-index:10}
.header-grid{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;padding:.6rem 0}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:700}
.brandmark{width:36px;height:36px;fill:var(--brand)}
.brand-text{font-weight:700}
.main-nav ul{list-style:none;display:flex;gap:1rem;padding:0;margin:0;flex-wrap:wrap}
.main-nav a{padding:.5rem .4rem;border-radius:.4rem}
.main-nav a:hover{background:var(--surface);text-decoration:none}
.header-cta{display:flex;gap:.6rem}
.menu-toggle{display:none}

@media (max-width:900px){
  .header-grid{grid-template-columns:1fr auto}
  .menu-toggle{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1rem;border:1px solid var(--line);background:#fff;border-radius:.5rem;font-size:.95rem;min-height:44px}
  .main-nav{display:none}
  .main-nav.open{display:block;position:absolute;top:60px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 8px 24px rgba(0,0,0,.1)}
  .main-nav ul{display:flex;flex-direction:column;padding:1rem}
  .main-nav a{display:block;padding:.75rem 1rem;min-height:44px;font-size:1.05rem}
  .header-cta{display:none}
}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1rem;border-radius:.6rem;border:1px solid var(--brand);font-weight:600;cursor:pointer;text-decoration:none}
.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn-outline{background:#fff;color:var(--brand)}
.btn-ghost{border-color:transparent;background:transparent}
.btn:hover{text-decoration:none;box-shadow:var(--shadow)}

/* Hero */
.hero{padding:3rem 0 1rem}
.hero .sub{max-width:54ch}
.hero-ctas{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1rem}
.hero-splide{margin-top:1rem}
.hero-splide img{width:100%;height:380px;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}
.card .more{display:inline-block;margin-top:.5rem;font-weight:600}

/* Areas grid */
.grid-areas{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem}
.area{display:flex;align-items:center;gap:.8rem;border:1px solid var(--line);padding:1rem;border-radius:var(--radius);background:#fff;box-shadow:var(--shadow)}
.area svg{width:28px;height:28px;fill:var(--accent)}
.area:hover{transform:translateY(-1px);transition:transform .2s ease;text-decoration:none}

/* Why */
.why{display:grid;gap:.7rem;padding-left:1.2rem}
.why li{margin:.2rem 0}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-top:1rem}
.gallery img{width:100%;height:220px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow)}

/* Contact */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem;margin:1rem 0}
.form-grid .full{grid-column:1/-1}
label{display:grid;gap:.3rem;font-size:.95rem}
input,textarea{padding:.7rem;border:1px solid var(--line);border-radius:.5rem;font:inherit}
input:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:1px}
.disclaimer{font-size:.9rem;color:var(--muted)}
.contact-details{margin-top:1.2rem}
.map-embed iframe{border-radius:.8rem}

/* Footer */
.site-footer{border-top:1px solid var(--line);background:#fff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr;gap:1rem;padding:2rem 0}
.nap{margin:.2rem 0 1rem}
.small{font-size:.85rem;color:var(--muted)}

/* Cookie consent */
.cookie-consent{position:fixed;z-index:20;left:1rem;right:1rem;bottom:1rem;background:#fff;border:1px solid var(--line);padding:1rem;border-radius:.8rem;box-shadow:var(--shadow);display:flex;gap:1rem;align-items:center;justify-content:space-between}
.cookie-consent[hidden]{display:none}

/* Utility */
.hidden{position:absolute !important;left:-9999px !important}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:1rem;top:1rem;width:auto;height:auto;background:#fff;border:2px solid var(--accent);padding:.6rem;border-radius:.4rem;z-index:999}

@media (max-width:900px){
  .section{padding:2.5rem 0}
  .hero{padding:2rem 0 1rem}
  .cards{grid-template-columns:1fr}
  .grid-areas{grid-template-columns:1fr 1fr}
  .area{padding:.8rem;font-size:.9rem}
  .gallery{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:.5rem}
  .footer-grid nav ul{display:flex;flex-wrap:wrap;gap:.3rem}
  .footer-grid nav a{padding:.4rem .5rem;display:inline-block}
  .hero-splide img{height:240px}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn{width:100%;justify-content:center;text-align:center}
  .cta-band{flex-direction:column}
  .cta-band .btn{width:100%;justify-content:center;text-align:center}
  .cookie-consent{flex-direction:column;text-align:center;gap:.8rem}
  .cookie-consent .btn{width:100%}
}

@media (max-width:480px){
  .section{padding:2rem 0}
  .hero{padding:1.5rem 0 .5rem}
  .hero-splide img{height:180px}
  .grid-areas{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  .gallery img{height:auto;aspect-ratio:3/2}
  h1{font-size:1.6rem}
  h2{font-size:1.25rem}
  .cv-header{flex-direction:column;align-items:center;text-align:center}
  .cv-header img{width:160px;height:210px}
}

/* Bullets list */
.bullets{padding-left:1.2rem}
.bullets li{margin:.5rem 0}

/* Check list (extended for practice areas) */
.check{list-style:none;padding:0}
.check li{position:relative;padding-left:1.6rem;margin:.5rem 0}
.check li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:700}

/* CTA band */
.cta-band{display:flex;gap:.8rem;flex-wrap:wrap;padding:1.5rem 0}

/* Mobile bottom CTA bar */
.mobile-cta{display:none}
@media (max-width:900px){
  .mobile-cta{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:15;background:#fff;border-top:1px solid var(--line);padding:.5rem;gap:.5rem;box-shadow:0 -4px 12px rgba(0,0,0,.08)}
  .mobile-cta .btn{flex:1;justify-content:center;text-align:center;padding:.8rem;font-size:1rem;min-height:48px}
  body{padding-bottom:72px}
  .cookie-consent{bottom:72px}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important}
}
