/* ===== Schmitt Family Reunion — shared styles ===== */
:root{
  --navy:#162a40;
  --navy-2:#0f1f30;
  --gold:#d8a64a;
  --gold-2:#c9912f;
  --cream:#f7f1e6;
  --cream-2:#efe6d4;
  --ink:#1c2733;
  --muted:#6b7785;
  --white:#ffffff;
  --shadow:0 10px 30px rgba(16,31,48,.12);
  --radius:16px;
  --maxw:1080px;
  --serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);
  background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:var(--serif);line-height:1.15;margin:0 0 .4em;font-weight:700}
a{color:var(--gold-2);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.center{text-align:center}
.muted{color:var(--muted)}

/* ---- Top nav ---- */
.nav{position:sticky;top:0;z-index:50;background:rgba(22,42,64,.96);
  backdrop-filter:blur(6px);box-shadow:0 2px 14px rgba(0,0,0,.18)}
.nav .inner{display:flex;align-items:center;justify-content:space-between;
  max-width:var(--maxw);margin:0 auto;padding:12px 22px}
.brand{display:flex;align-items:center;gap:10px;color:var(--cream);font-family:var(--serif);
  font-weight:700;font-size:1.15rem;letter-spacing:.3px}
.brand .crest{width:30px;height:30px;border-radius:50%;background:var(--gold);
  color:var(--navy);display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:1rem}
.nav-links{display:flex;gap:6px;flex-wrap:wrap}
.nav-links a{color:var(--cream);padding:8px 14px;border-radius:999px;font-size:.92rem;
  font-weight:500;transition:background .15s}
.nav-links a:hover{background:rgba(255,255,255,.12);text-decoration:none}
.nav-links a.active{background:var(--gold);color:var(--navy)}
.nav-toggle{display:none;background:none;border:0;color:var(--cream);font-size:1.6rem;cursor:pointer}

/* ---- Buttons ---- */
.btn{display:inline-block;background:var(--gold);color:var(--navy);font-weight:700;
  padding:13px 26px;border-radius:999px;border:0;cursor:pointer;font-size:1rem;
  box-shadow:var(--shadow);transition:transform .12s,background .15s;font-family:var(--sans)}
.btn:hover{background:var(--gold-2);text-decoration:none;transform:translateY(-2px)}
.btn.ghost{background:transparent;color:var(--cream);border:2px solid var(--cream)}
.btn.ghost:hover{background:rgba(255,255,255,.12)}
.btn.dark{background:var(--navy);color:var(--cream)}
.btn.dark:hover{background:var(--navy-2)}

/* ---- Hero ---- */
.hero{position:relative;min-height:88vh;display:grid;place-items:center;text-align:center;
  color:var(--cream);overflow:hidden}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.04)}
.hero .scrim{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,31,48,.55),rgba(15,31,48,.78))}
.hero .inner{position:relative;padding:90px 22px;max-width:820px}
.kicker{text-transform:uppercase;letter-spacing:.32em;font-size:.8rem;font-weight:600;
  color:var(--gold);margin-bottom:18px}
.hero h1{font-size:clamp(2.6rem,7vw,5rem);color:var(--white);text-shadow:0 2px 24px rgba(0,0,0,.35)}
.hero .sub{font-size:clamp(1.05rem,2.4vw,1.4rem);max-width:620px;margin:14px auto 0;color:var(--cream-2)}
.dates{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin:30px 0 8px}
.date-card{background:rgba(247,241,230,.10);border:1px solid rgba(247,241,230,.28);
  border-radius:14px;padding:16px 22px;min-width:140px;backdrop-filter:blur(3px)}
.date-card .dow{font-family:var(--serif);font-size:1.25rem;color:var(--gold);font-weight:700}
.date-card .dnum{font-size:2rem;font-weight:700;line-height:1;margin:4px 0;color:var(--white)}
.date-card .mon{text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;color:var(--cream-2)}
.hero-cta{margin-top:28px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.countdown{margin-top:26px;font-size:.95rem;color:var(--cream-2)}
.countdown b{color:var(--gold);font-size:1.15rem}

/* ---- Sections ---- */
section{padding:64px 0}
.section-head{text-align:center;max-width:640px;margin:0 auto 40px}
.section-head h2{font-size:clamp(1.8rem,4vw,2.6rem);color:var(--navy)}
.section-head p{color:var(--muted);font-size:1.05rem}
.divider{width:64px;height:3px;background:var(--gold);border-radius:2px;margin:14px auto 0}

/* ---- Feature cards ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:22px}
.card{background:var(--white);border-radius:var(--radius);padding:28px 24px;box-shadow:var(--shadow);
  border:1px solid rgba(22,42,64,.06);transition:transform .15s,box-shadow .15s;text-align:center}
a.card:hover{text-decoration:none;transform:translateY(-4px);box-shadow:0 16px 38px rgba(16,31,48,.16)}
.card .ic{width:58px;height:58px;border-radius:14px;background:var(--cream-2);color:var(--navy);
  display:grid;place-items:center;margin:0 auto 16px;font-size:1.7rem}
.card h3{color:var(--navy);font-size:1.3rem;margin-bottom:6px}
.card p{color:var(--muted);margin:0;font-size:.96rem}

/* ---- Schedule ---- */
.day-block{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);
  overflow:hidden;margin-bottom:28px;border:1px solid rgba(22,42,64,.06)}
.day-head{background:var(--navy);color:var(--cream);padding:18px 26px;display:flex;
  align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}
.day-head h3{margin:0;color:var(--white);font-size:1.5rem}
.day-head .d{color:var(--gold);font-weight:600;letter-spacing:.04em}
.events{padding:8px 26px 18px}
.event{display:flex;gap:20px;padding:16px 0;border-bottom:1px dashed rgba(22,42,64,.14)}
.event:last-child{border-bottom:0}
.event .time{min-width:104px;font-weight:700;color:var(--gold-2);font-variant-numeric:tabular-nums}
.event .what h4{margin:0 0 2px;font-family:var(--sans);font-size:1.06rem;color:var(--ink)}
.event .what p{margin:0;color:var(--muted);font-size:.94rem}
.badge{display:inline-block;background:var(--cream-2);color:var(--navy);border-radius:999px;
  padding:2px 10px;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-left:8px}

/* ---- Video ---- */
.video-wrap{max-width:880px;margin:0 auto;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);background:#000}
.video-wrap video{width:100%;display:block}

/* ---- Page header (interior pages) ---- */
.page-hero{background:var(--navy);color:var(--cream);padding:56px 0 48px;text-align:center;
  position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;inset:0;opacity:.16;
  background-size:cover;background-position:center}
.page-hero .container{position:relative}
.page-hero h1{color:var(--white);font-size:clamp(2rem,5vw,3.2rem)}
.page-hero p{color:var(--cream-2);max-width:600px;margin:8px auto 0}

/* ---- Footer ---- */
footer{background:var(--navy-2);color:var(--cream-2);padding:34px 0;text-align:center;font-size:.9rem}
footer .brand{justify-content:center;margin-bottom:8px}
footer a{color:var(--gold)}

/* ---- Lock / password gate ---- */
.gate{min-height:70vh;display:grid;place-items:center;padding:40px 22px}
.gate .box{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:40px 34px;max-width:420px;width:100%;text-align:center}
.gate .lockic{font-size:2.6rem;margin-bottom:6px}
.gate h2{color:var(--navy)}
.gate input{width:100%;padding:13px 16px;border:2px solid var(--cream-2);border-radius:12px;
  font-size:1rem;margin:14px 0;font-family:var(--sans)}
.gate input:focus{outline:none;border-color:var(--gold)}
.gate .err{color:#c0392b;font-size:.9rem;min-height:20px;margin-top:4px}

/* ---- Upload form ---- */
.form-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:34px;max-width:560px;margin:0 auto}
.drop{border:2px dashed var(--gold);border-radius:14px;padding:34px 20px;text-align:center;
  background:var(--cream);cursor:pointer;transition:background .15s}
.drop:hover,.drop.over{background:var(--cream-2)}
.drop .big{font-size:2.2rem}
label.fld{display:block;font-weight:600;margin:18px 0 6px;color:var(--navy)}
input[type=text],input[type=password]{width:100%;padding:12px 14px;border:2px solid var(--cream-2);
  border-radius:12px;font-size:1rem;font-family:var(--sans)}
input:focus{outline:none;border-color:var(--gold)}
.filelist{margin:14px 0;font-size:.92rem;color:var(--muted)}
.progress{height:10px;background:var(--cream-2);border-radius:6px;overflow:hidden;margin-top:14px;display:none}
.progress > i{display:block;height:100%;width:0;background:var(--gold);transition:width .2s}
.note{font-size:.86rem;color:var(--muted);margin-top:14px}

/* ---- Gallery ---- */
.grid-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.grid-gallery .item{border-radius:12px;overflow:hidden;background:#000;box-shadow:var(--shadow);
  aspect-ratio:1/1;position:relative}
.grid-gallery .item img,.grid-gallery .item video{width:100%;height:100%;object-fit:cover}
.grid-gallery .item .play{position:absolute;inset:0;display:grid;place-items:center;
  color:#fff;font-size:2.4rem;background:rgba(0,0,0,.25);pointer-events:none}
.empty{text-align:center;color:var(--muted);padding:50px 0}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(8,15,24,.92);display:none;place-items:center;z-index:100;padding:24px}
.lb.open{display:grid}
.lb img,.lb video{max-width:92vw;max-height:88vh;border-radius:10px}
.lb .x{position:absolute;top:18px;right:24px;color:#fff;font-size:2.2rem;cursor:pointer;background:none;border:0}

@media(max-width:720px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--navy);
    flex-direction:column;padding:10px 18px 18px;gap:2px}
  .nav-links.show{display:flex}
  .nav-links a{padding:12px 14px}
  .nav-toggle{display:block}
  .event{gap:12px}
  .event .time{min-width:78px}
}
