/* Hannig Cup Regatta — shared styles */
:root{
  --navy:#0b2545;
  --ocean:#13507a;
  --sky:#2a8bc1;
  --foam:#eaf4fb;
  --sand:#f7f4ec;
  --ink:#1a2433;
  --muted:#5b6b7d;
  --white:#ffffff;
  --rainbow:linear-gradient(90deg,#e0245e,#f5a623,#f8e71c,#2ecc71,#2a8bc1,#7b4dff);
  --shadow:0 10px 30px rgba(11,37,69,.12);
  --radius:14px;
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Helvetica Neue',Arial,sans-serif;
  color:var(--ink);
  line-height:1.65;
  background:var(--white);
}
h1,h2,h3{font-family:Georgia,'Times New Roman',serif;color:var(--navy);line-height:1.2;margin:0 0 .5em}
h1{font-size:clamp(2rem,5vw,3.3rem)}
h2{font-size:clamp(1.5rem,3.2vw,2.2rem)}
h3{font-size:1.2rem}
p{margin:0 0 1rem}
a{color:var(--ocean)}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.rainbow-bar{height:6px;background:var(--rainbow)}

/* Header / nav */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);border-bottom:1px solid #e6edf3}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 24px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img{height:52px;width:auto}
.brand span{font-family:Georgia,serif;font-weight:700;color:var(--navy);font-size:1.05rem;letter-spacing:.5px}
.nav-links{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.nav-links a{text-decoration:none;color:var(--ink);font-weight:600;font-size:.95rem;padding:8px 14px;border-radius:8px;transition:.2s}
.nav-links a:hover{background:var(--foam);color:var(--ocean)}
.nav-links a.cta{background:var(--ocean);color:#fff}
.nav-links a.cta:hover{background:var(--navy);color:#fff}
.nav-toggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--navy)}

/* Hero */
.hero{position:relative;color:#fff;text-align:center;padding:120px 24px;background:linear-gradient(rgba(11,37,69,.55),rgba(11,37,69,.55)),url('images/sail5.jpg') center/cover no-repeat}
.hero h1{color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.4)}
.hero .tagline{font-size:clamp(1.1rem,2.5vw,1.6rem);font-style:italic;margin-top:.3rem;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.hero .stat{display:inline-block;margin-top:18px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.4);padding:10px 20px;border-radius:50px;font-weight:600}
.btn{display:inline-block;text-decoration:none;font-weight:700;padding:14px 30px;border-radius:50px;transition:.2s;cursor:pointer;border:0}
.btn-primary{background:var(--rainbow);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ocean{background:var(--ocean);color:#fff}
.btn-ocean:hover{background:var(--navy)}
.hero .btn{margin-top:26px}

/* Sections */
section{padding:72px 0}
.section-sand{background:var(--sand)}
.section-foam{background:var(--foam)}
.lead{font-size:1.15rem;color:var(--muted);max-width:760px;margin:0 auto 2.4rem;text-align:center}
.center{text-align:center}

/* Pillars / cards */
.grid{display:grid;gap:28px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border-radius:var(--radius);padding:30px;box-shadow:var(--shadow);border-top:4px solid transparent;border-image:var(--rainbow) 1}
.card h3{margin-top:0}
.card .icon{font-size:2rem;margin-bottom:8px}

/* Directors */
.directors{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.director{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:34px 24px;text-align:center}
.director .avatar{width:84px;height:84px;border-radius:50%;margin:0 auto 16px;background:var(--rainbow);display:flex;align-items:center;justify-content:center;color:#fff;font-family:Georgia,serif;font-size:1.7rem;font-weight:700}
.director h3{margin:.2rem 0}
.director .title{color:var(--sky);font-weight:600;letter-spacing:.5px;text-transform:uppercase;font-size:.85rem}

/* Schedule */
.schedule{max-width:680px;margin:0 auto}
.event{display:flex;align-items:baseline;gap:20px;padding:18px 22px;background:#fff;border-radius:12px;box-shadow:var(--shadow);margin-bottom:14px;border-left:5px solid var(--sky)}
.event .time{font-family:Georgia,serif;font-size:1.25rem;color:var(--navy);font-weight:700;min-width:130px}
.event .what{font-weight:600}
.event .desc{color:var(--muted);font-size:.95rem}

/* Charities */
.charity-list{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:860px;margin:0 auto}
.chip{background:#fff;border:1px solid #dce6ee;border-radius:50px;padding:10px 20px;font-weight:600;color:var(--ocean);box-shadow:0 3px 10px rgba(11,37,69,.06)}

/* Registration / Summer of Love */
.sol-hero{position:relative;text-align:center;color:#fff;padding:90px 24px;background:linear-gradient(rgba(123,77,255,.45),rgba(224,36,94,.45)),url('images/sail3.jpg') center/cover no-repeat}
.sol-hero h1{color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.45)}
.peace{font-size:2.4rem}
.poster-flex{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:center}
.poster-flex img{border-radius:var(--radius);box-shadow:var(--shadow);margin:0 auto}
.detail-list{list-style:none;padding:0;margin:0 0 1.4rem}
.detail-list li{padding:10px 0;border-bottom:1px dashed #d8e2ea;display:flex;gap:12px}
.detail-list .k{font-weight:700;color:var(--navy);min-width:120px}
.box{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:34px}
.flowers{font-size:1.6rem;letter-spacing:6px;text-align:center;margin:6px 0}

/* Footer */
.site-footer{background:var(--navy);color:#cdd9e5;padding:48px 24px 28px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;max-width:var(--maxw);margin:0 auto}
.site-footer h4{color:#fff;font-family:Georgia,serif;margin:0 0 12px}
.site-footer a{color:#9fc4e0;text-decoration:none}
.site-footer a:hover{color:#fff}
.site-footer img{height:48px;margin-bottom:12px}
.footer-bottom{text-align:center;border-top:1px solid #1d3a5f;margin-top:32px;padding-top:18px;font-size:.85rem;color:#7e97ad}

/* Responsive */
@media(max-width:860px){
  .grid-3,.directors{grid-template-columns:1fr 1fr}
  .poster-flex{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .grid-3,.grid-2,.directors{grid-template-columns:1fr}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:12px;border-bottom:1px solid #e6edf3}
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
  .event{flex-direction:column;gap:4px}
  .hero{padding:90px 20px}
}
