/* ==========================================================================
   Nick Aronoff for Laguna Beach City Council 2026
   Palette: LBHS maroon + warm cream, with a soft Laguna sea accent
   ========================================================================== */

:root{
  --maroon:#7a1c1c;
  --maroon-deep:#5c1414;
  --maroon-ink:#46100f;
  --cream:#f7f2e9;
  --cream-2:#efe7d6;
  --paper:#fbf8f1;
  --ink:#2b2422;
  --ink-soft:#5b524c;
  --sea:#2f6f6a;          /* muted Laguna sea-glass accent, used sparingly */
  --sand:#e6d8c0;
  --line:rgba(122,28,28,.18);
  --shadow:0 18px 50px -22px rgba(70,16,15,.45);
  --maxw:1140px;
  --serif:'Fraunces', 'Playfair Display', Georgia, 'Times New Roman', serif;
  --script:'Pinyon Script', 'Fraunces', cursive;
  --sans:'Hanken Grotesk', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
  font-optical-sizing:auto;
}
img{max-width:100%;display:block}
a{color:var(--maroon);text-decoration:none}
a:hover{color:var(--maroon-deep)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:84px 0}
.section--tight{padding:56px 0}

h1,h2,h3{font-family:var(--serif);font-weight:800;line-height:1.12;color:var(--maroon-ink);margin:0 0 .5em;letter-spacing:-.012em}
h1{font-size:clamp(2.4rem,5vw,3.9rem);font-weight:900}
h2{font-size:clamp(1.8rem,3.4vw,2.7rem)}
h3{font-size:1.35rem;font-weight:700}
p{margin:0 0 1.1em}
.eyebrow{
  font-family:var(--sans);font-weight:800;letter-spacing:.22em;text-transform:uppercase;
  font-size:.78rem;color:var(--maroon);margin:0 0 14px
}
.lead{font-size:1.2rem;color:var(--ink-soft)}
.script{font-family:var(--script);font-weight:400}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;font-family:var(--sans);font-weight:800;letter-spacing:.02em;
  padding:15px 30px;border-radius:999px;border:2px solid var(--maroon);
  transition:.18s ease;cursor:pointer;font-size:1rem;
}
.btn--primary{background:var(--maroon);color:var(--cream)}
.btn--primary:hover{background:var(--maroon-deep);border-color:var(--maroon-deep);color:#fff;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--maroon)}
.btn--ghost:hover{background:var(--maroon);color:var(--cream)}
.btn--cream{background:var(--cream);color:var(--maroon);border-color:var(--cream)}
.btn--cream:hover{background:#fff;transform:translateY(-2px);color:var(--maroon-deep)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* ---------- header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(251,248,241,.92);
  backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:12px 24px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:46px;width:auto}
.brand-word{display:flex;flex-direction:column;line-height:1;white-space:nowrap}
.brand-word .nm{font-family:var(--serif);font-weight:800;font-size:1.18rem;color:var(--maroon-ink);letter-spacing:.01em}
.brand-word .sb{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin-top:3px}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0}
.nav-links a{
  font-weight:700;font-size:.96rem;color:var(--ink);padding:9px 14px;border-radius:8px;letter-spacing:.01em
}
.nav-links a:hover{background:var(--cream-2);color:var(--maroon)}
.nav-links a.active{color:var(--maroon)}
.nav-links .nav-donate{background:var(--maroon);color:var(--cream);padding:10px 20px;border-radius:999px}
.nav-links .nav-donate:hover{background:var(--maroon-deep);color:#fff}
.mobile-donate{display:none}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:26px;height:2.5px;background:var(--maroon);margin:5px 0;border-radius:2px;transition:.2s}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--maroon);color:var(--cream);overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(1200px 480px at 80% -10%, rgba(255,255,255,.08), transparent 60%),
  radial-gradient(900px 500px at -10% 110%, rgba(0,0,0,.25), transparent 60%);pointer-events:none}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;padding:74px 0}
.hero h1{color:var(--cream)}
.hero .lead{color:#ecdfce}
.hero .eyebrow{color:#e6c9a8}
.hero-tower{display:flex;justify-content:center}
.hero-tower img{height:380px;width:auto;filter:drop-shadow(0 22px 30px rgba(0,0,0,.35))}
.hero-center{position:relative;z-index:2;text-align:center;padding:60px 0 70px;display:flex;flex-direction:column;align-items:center}
.hero-mark{height:140px;width:auto;filter:drop-shadow(0 16px 24px rgba(0,0,0,.32));margin-bottom:20px}
.hero-wordmark{width:min(500px,84%);height:auto;filter:drop-shadow(0 8px 18px rgba(0,0,0,.16))}
.tagline-rule{display:flex;align-items:center;gap:14px;margin:6px 0 22px;color:#e9d6bf}
.tagline-rule::before,.tagline-rule::after{content:"";height:1px;background:rgba(243,233,216,.4);flex:1}
.tagline-rule span{font-family:var(--script);font-size:1.9rem;color:var(--cream)}

/* wave divider */
.wave{display:block;width:100%;height:54px;color:var(--maroon)}
.wave--flip{transform:rotate(180deg)}

/* ---------- wordmark lockup (reusable) ---------- */
.lockup{text-align:center;line-height:1}
.lockup .nm{font-family:var(--serif);font-weight:800;font-size:clamp(2rem,4vw,3rem);color:var(--maroon);letter-spacing:.01em}
.lockup .for{font-family:var(--script);font-size:1.7rem;color:var(--maroon);margin:2px 0}
.lockup .cc{font-family:var(--serif);font-weight:700;font-size:clamp(1.5rem,3vw,2.1rem);color:var(--maroon)}
.lockup .rule{display:flex;align-items:center;gap:12px;justify-content:center;color:var(--maroon)}
.lockup .rule::before,.lockup .rule::after{content:"";height:1.5px;width:60px;background:currentColor;opacity:.5}

/* ---------- cards / pillars ---------- */
.grid{display:grid;gap:26px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:30px 28px;
  box-shadow:var(--shadow);transition:.2s ease
}
.card--priority{position:relative;overflow:hidden;border-radius:12px;padding:34px 24px 28px;text-align:left}
.card--priority::before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:var(--maroon)}
.card:hover{transform:translateY(-4px);border-color:rgba(122,28,28,.35)}
.card .num{font-family:var(--serif);font-size:1.05rem;font-weight:800;color:var(--maroon);
  width:42px;height:42px;border-radius:50%;border:2px solid var(--maroon);display:grid;place-items:center;margin-bottom:16px}
.card--priority .num{background:var(--cream);border-radius:10px}
.card h3{color:var(--maroon-ink);margin-bottom:.4em}
.card p{color:var(--ink-soft);margin:0;font-size:1rem}

.bg-cream{background:var(--cream)}
.bg-maroon{background:var(--maroon);color:var(--cream)}
.bg-maroon h2,.bg-maroon h3{color:var(--cream)}
.bg-maroon p{color:#ecdfce}

/* ---------- about / split ---------- */
.split{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:center}
.portrait{
  background:linear-gradient(160deg,var(--cream-2),var(--sand));
  border:1px solid var(--line);border-radius:170px 170px 18px 18px;box-shadow:var(--shadow);
  aspect-ratio:4/5;display:grid;place-items:center;text-align:center;color:var(--ink-soft);overflow:hidden
}
.portrait img{width:100%;height:100%;object-fit:cover}
.portrait .ph{padding:28px}
.portrait .ph svg{width:54px;height:54px;color:var(--maroon);opacity:.5;margin:0 auto 10px}
.placeholder-note{font-size:.82rem;letter-spacing:.04em}
.bio-split{align-items:start}
.bio-copy{max-width:680px}
.bio-copy p:last-child{margin-bottom:0}

/* ---------- letter ---------- */
.letter{background:var(--paper);border:1px solid var(--line);border-left:5px solid var(--maroon);
  border-radius:12px;padding:42px 46px;box-shadow:var(--shadow);max-width:820px;margin:0 auto}
.letter p{font-size:1.06rem}
.letter .signoff{font-family:var(--script);font-size:2rem;color:var(--maroon);margin-top:10px}

/* ---------- priorities list ---------- */
.pri{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.pri-item{display:flex;gap:18px;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:24px}
.pri-item .n{flex:0 0 auto;font-family:var(--serif);font-weight:800;font-size:1.2rem;color:#fff;background:var(--maroon);
  width:44px;height:44px;border-radius:10px;display:grid;place-items:center}
.pri-item h3{font-size:1.12rem;margin:0 0 .3em}
.pri-item p{margin:0;font-size:.97rem;color:var(--ink-soft)}

/* ---------- involve ---------- */
.ways{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:10px}
.way{display:flex;gap:14px;align-items:flex-start;padding:20px 22px;background:var(--cream);border-radius:12px;border:1px solid var(--line)}
.way .dot{flex:0 0 auto;width:12px;height:12px;border-radius:50%;background:var(--maroon);margin-top:8px}
.way b{color:var(--maroon-ink)}

/* ---------- forms ---------- */
.form{display:grid;gap:16px;max-width:620px}
.form label{font-weight:700;font-size:.92rem;color:var(--maroon-ink);display:block;margin-bottom:6px}
.form input,.form textarea,.form select{
  width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;font:inherit;font-size:1rem;
  background:#fff;color:var(--ink)
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--maroon);box-shadow:0 0 0 3px rgba(122,28,28,.12)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ---------- CTA band ---------- */
.cta{background:var(--maroon-deep);color:var(--cream);text-align:center;border-radius:20px;padding:56px 28px;box-shadow:var(--shadow)}
.cta h2{color:var(--cream)}
.cta p{color:#ecdfce;max-width:620px;margin:0 auto 26px}

/* ---------- footer ---------- */
.site-footer{background:var(--maroon-ink);color:#e9dccb;padding:54px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;align-items:start}
.site-footer .brand-word .nm{color:var(--cream)}
.site-footer .brand-word .sb{color:#c9b39a}
.site-footer img{height:52px}
.site-footer h4{font-family:var(--sans);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:#d8b893;margin:0 0 14px}
.site-footer a{color:#ecdfce;display:block;padding:4px 0}
.site-footer a:hover{color:#fff}
.foot-bottom{margin-top:40px;padding-top:20px;border-top:1px solid rgba(243,233,216,.18);
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.84rem;color:#c4ad94}

/* ---------- misc ---------- */
.center{text-align:center}
.mt0{margin-top:0}.maxr{max-width:760px;margin-left:auto;margin-right:auto}
.pill{display:inline-block;background:var(--cream);color:var(--maroon);border:1px solid var(--line);
  padding:6px 14px;border-radius:999px;font-weight:700;font-size:.82rem;letter-spacing:.04em}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;text-align:center;gap:26px;padding:54px 0}
  .hero-tower{order:-1}.hero-tower img{height:260px}
  .hero-mark{height:104px}.hero-wordmark{width:86%}.hero-center{padding:44px 0 54px}
  .tagline-rule{justify-content:center}
  .split{grid-template-columns:1fr;gap:30px}
  .grid-3{grid-template-columns:1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .pri{grid-template-columns:1fr}
  .ways,.form .row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:26px}
  .nav{gap:12px}
  .brand{min-width:0;flex:1}
  .brand-word{min-width:0}
  .brand-word .nm{font-size:1.04rem}
  .brand-word .sb{font-size:.56rem;letter-spacing:.14em;white-space:normal}
  .mobile-donate{
    display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;
    background:var(--maroon);color:var(--cream);border-radius:999px;
    padding:8px 14px;font-weight:800;font-size:.9rem;line-height:1
  }
  .mobile-donate:hover{background:var(--maroon-deep);color:#fff}
  .nav-toggle{display:block}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;background:var(--paper);border-bottom:1px solid var(--line);
    flex-direction:column;align-items:stretch;gap:0;padding:8px 16px 16px;display:none;box-shadow:var(--shadow)
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 10px;border-radius:8px}
  .nav-links .nav-donate{display:none}
}
@media(max-width:560px){
  body{font-size:17px}.section{padding:60px 0}
  .letter{padding:30px 24px}
  .grid-4{grid-template-columns:1fr}
  .nav{padding:10px 16px}
  .brand img{height:40px}
  .brand-word .nm{font-size:.98rem}
  .brand-word .sb{display:none}
  .mobile-donate{padding:8px 12px;font-size:.86rem}
}
