*{box-sizing:border-box}
:root{
  --lav:#d9c2f0;
  --lav2:#e7d6f7;
  --purple:#4b1471;
  --purple-deep:#2c0f4b;
  --cyan:#00a9c6;
  --cyan-deep:#007a96;
}
html,body{height:100%}
body{margin:0;background:linear-gradient(180deg,var(--lav) 0%,var(--lav2) 55%,var(--lav) 100%);color:var(--purple);font-family:"Aleo",serif;-webkit-font-smoothing:antialiased}

/* NAV */
.nav{position:sticky;top:0;z-index:50;display:flex;justify-content:space-between;align-items:center;padding:14px 22px;background:rgba(255,255,255,.3);backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid rgba(0,0,0,.06)}
.nav .brand{font-weight:800;color:var(--purple);text-decoration:none}
.nav a{margin:0 10px;color:var(--purple);text-decoration:none}
.nav .cta{padding:.55rem 1rem;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--purple));color:#fff}

/* HERO */
.hero{position:relative;min-height:68vh;display:grid;place-items:center;text-align:center;overflow:hidden}
.hero-layer{position:absolute;inset:0;background:
  radial-gradient(900px 380px at 25% 10%,rgba(0,169,198,.22),transparent 60%),
  radial-gradient(1000px 420px at 80% 15%,rgba(75,20,113,.24),transparent 60%);
  z-index:0}
.hero-inner{position:relative;z-index:2;padding-bottom:100px}
.full-logo{width:min(720px,78vw);max-width:100%;filter:drop-shadow(0 16px 40px rgba(0,0,0,.12))}
.actions{display:flex;gap:12px;justify-content:center;margin-top:18px;flex-wrap:wrap}
.btn{display:inline-block;padding:.8rem 1.3rem;border-radius:12px;text-decoration:none;font-weight:700;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}
.btn.primary{background:linear-gradient(135deg,var(--cyan),var(--cyan-deep));color:#fff;box-shadow:0 10px 20px rgba(0,169,198,.25)}
.btn.ghost{border:2px solid var(--purple);color:var(--purple);background:transparent}
.btn.outline{border:2px solid var(--cyan);color:var(--cyan);background:transparent}
.btn:hover{transform:translateY(-2px)}
.curve{position:absolute;bottom:-1px;left:0;width:100%;height:120px;z-index:1}
.curve path{fill:#fff}

/* CONTENT */
.container{max-width:1080px;margin:0 auto;padding:28px}
.card{background:rgba(255,255,255,.55);border:1px solid rgba(0,0,0,.06);border-radius:18px;box-shadow:0 14px 40px rgba(75,20,113,.08);padding:28px;margin:26px 0}
.card.accent{border-color:rgba(0,169,198,.35);box-shadow:0 14px 40px rgba(0,169,198,.10)}
h2{font-weight:800;font-size:clamp(1.6rem,2.5vw,2.2rem);margin:0 0 12px;color:var(--purple-deep)}
h3{font-weight:800;margin:18px 0 6px;font-size:1.2rem;color:var(--purple)}
.two-col{display:grid;grid-template-columns:1.5fr 1fr;gap:22px;align-items:start}
.headshot img{width:100%;border-radius:16px;box-shadow:0 12px 28px rgba(0,0,0,.18)}
.headshot figcaption{text-align:center;color:var(--purple-deep);opacity:.85;margin-top:6px}
p{line-height:1.7;font-size:1.05rem;color:#2e2152}
ul.chips{display:flex;flex-wrap:wrap;gap:10px;padding:0;margin:8px 0 0;list-style:none}
ul.chips li{background:linear-gradient(135deg,rgba(0,169,198,.14),rgba(75,20,113,.14));color:var(--purple-deep);border:1px solid rgba(75,20,113,.22);padding:.5rem .9rem;border-radius:999px}
details{border:1px solid rgba(0,0,0,.08);background:#fff;border-radius:12px;padding:.8rem 1rem;margin:.6rem 0}

/* CONTACT + MAP */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}
.info .name{font-weight:800;font-size:1.25rem}
.info a{text-decoration:none;color:var(--purple)} .info a:hover{color:var(--cyan-deep)}
.map-wrap{border-radius:16px;overflow:hidden;box-shadow:0 12px 28px rgba(0,0,0,.12);background:#fff}
.map-wrap iframe{display:block;width:100%;height:320px;border:0}
.notice,.fallback,.crisis{margin:.5rem 0}
.accent-logo{width:120px;opacity:.95;margin-top:14px;filter:drop-shadow(0 6px 14px rgba(75,20,113,.25))}

/* LEGAL */
.legal-card{position:relative}
.legal-card details summary{cursor:pointer;font-weight:700}
.legal-watermark{position:absolute;right:18px;bottom:18px;width:90px;opacity:.25}

/* FOOTER */
.footer{display:grid;place-items:center;text-align:center;padding:26px 16px;color:var(--purple-deep);background:linear-gradient(0deg,rgba(0,169,198,.10),transparent)}
.badge{width:60px;opacity:.95;filter:drop-shadow(0 6px 14px rgba(75,20,113,.25))}
.footlinks a{color:var(--purple);text-decoration:none;margin:0 .25rem}
.footlinks a:hover{color:var(--cyan-deep)}

@media (max-width:960px){
  .two-col{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .hero{min-height:60vh}
  .full-logo{width:min(88vw,700px)}
}

/* Turnstile form */
.contact-form{margin-top:14px;background:rgba(255,255,255,.6);border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:14px;box-shadow:0 6px 20px rgba(0,0,0,.06)}
.contact-form .row{display:flex;flex-direction:column;margin:8px 0}
.contact-form label{font-weight:700;margin-bottom:6px;color:var(--purple-deep)}
.contact-form input,.contact-form textarea{padding:.7rem .8rem;border:1px solid rgba(0,0,0,.15);border-radius:10px;font-family:inherit}
.form-note{font-size:.9rem;opacity:.8;margin-top:8px}
.form-status{margin-top:10px;color:var(--purple-deep);font-weight:800}
