@import url('https://fonts.googleapis.com/css2?family=Big+Shoulders+Display:wght@600;700;800&family=Source+Serif+4:opsz,wght@8..60,400;8..60,500;8..60,600&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  --night:#1B2430;
  --wheat:#F2E9D8;
  --amber:#E8A33D;
  --rust:#A63D2F;
  --sage:#6B7C63;
  --ink:#24211B;
  --paper:#F7F3EC;
  --line: rgba(36,33,27,0.14);
  --line-dark: rgba(247,243,236,0.16);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
html{scroll-padding-top:100px;}
body{
  margin:0;
  background:var(--wheat);
  color:var(--ink);
  font-family:'Source Serif 4', serif;
  font-size:17px;
  line-height:1.6;
}
h1,h2,h3,.display{
  font-family:'Big Shoulders Display', sans-serif;
  text-transform:uppercase;
  letter-spacing:0.02em;
  line-height:0.95;
  margin:0;
}
.mono{font-family:'JetBrains Mono', monospace; letter-spacing:0.03em;}
a{color:inherit;}
a:focus-visible, button:focus-visible, summary:focus-visible{
  outline:3px solid var(--amber);
  outline-offset:3px;
}
img{max-width:100%;display:block;}
.wrap{max-width:1120px;margin:0 auto;padding:0 28px;}

/* ---------- Header ---------- */
header{
  position:sticky; top:0; z-index:50;
  background:var(--night); color:var(--paper);
  border-bottom:1px solid var(--line-dark);
}
.nav-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 28px; max-width:1120px; margin:0 auto; gap:20px;
}
.callsign-mark{
  display:flex; align-items:baseline; gap:10px;
  font-family:'Big Shoulders Display', sans-serif;
  font-weight:800; font-size:1.5rem; letter-spacing:0.03em;
  text-decoration:none; color:var(--paper); flex-shrink:0;
}
.callsign-mark .dot{width:9px;height:9px;border-radius:50%;background:var(--amber);display:inline-block;}

.brand-mark{
  display:flex; align-items:center; flex-shrink:0;
  text-decoration:none;
}
.brand-mark img{
  height:104px; width:auto;
  background:var(--wheat);
  padding:1px 1px;
  border-radius:6px;
  display:block;
}
.footer-logo{
  height:104px; width:auto;
  background:var(--wheat);
  padding:1px 1px;
  border-radius:6px;
  display:block;
  margin-bottom:16px;
}
.nav-links{
  list-style:none; display:flex; gap:26px; margin:0; padding:0;
  font-family:'JetBrains Mono', monospace; font-size:0.78rem;
  letter-spacing:0.08em; text-transform:uppercase; flex-wrap:wrap;
}
.nav-links a{
  text-decoration:none; color:var(--paper); opacity:0.78;
  padding-bottom:3px; border-bottom:2px solid transparent;
  transition:opacity .15s ease, border-color .15s ease;
}
.nav-links a:hover, .nav-links a[aria-current="page"]{opacity:1; border-color:var(--amber);}
.nav-cta{
  font-family:'JetBrains Mono', monospace; font-size:0.75rem;
  letter-spacing:0.06em; text-transform:uppercase; text-decoration:none;
  background:var(--amber); color:var(--night); padding:9px 16px;
  border-radius:2px; font-weight:600; flex-shrink:0;
}

/* ---------- Nav dropdown ---------- */
.nav-dropdown{position:relative;}
.nav-dropdown > button{
  background:none; border:none; margin:0; cursor:pointer;
  font-family:'JetBrains Mono', monospace; font-size:0.78rem;
  letter-spacing:0.08em; text-transform:uppercase; color:var(--paper); opacity:0.78;
  padding-bottom:3px; border-bottom:2px solid transparent;
  display:flex; align-items:center; gap:5px;
  transition:opacity .15s ease, border-color .15s ease;
}
.nav-dropdown .caret{font-size:0.62rem; transition:transform .15s ease;}
.nav-dropdown:hover > button,
.nav-dropdown:focus-within > button,
.nav-dropdown > button[aria-current="page"]{opacity:1; border-color:var(--amber);}
.nav-dropdown:hover .caret, .nav-dropdown:focus-within .caret{transform:rotate(180deg);}
.nav-drop-menu{
  list-style:none; margin:0; padding:8px 0;
  position:absolute; top:100%; left:50%; transform:translate(-50%, -4px);
  background:var(--night); border:1px solid var(--line-dark); min-width:210px;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .15s ease, transform .15s ease, visibility .15s ease;
  z-index:60;
}
.nav-dropdown:hover .nav-drop-menu,
.nav-dropdown:focus-within .nav-drop-menu{
  opacity:1; visibility:visible; pointer-events:auto; transform:translate(-50%, 0);
}
.nav-drop-menu li{margin:0;}
.nav-drop-menu a{
  display:block; padding:11px 20px; text-decoration:none; color:var(--paper);
  font-family:'JetBrains Mono', monospace; font-size:0.75rem;
  letter-spacing:0.06em; text-transform:uppercase; opacity:0.8; border-bottom:none;
}
.nav-drop-menu a:hover{opacity:1; color:var(--amber); background:rgba(247,243,236,0.05);}

/* ---------- Buttons ---------- */
.btn{
  font-family:'JetBrains Mono', monospace; font-size:0.82rem;
  letter-spacing:0.06em; text-transform:uppercase; text-decoration:none;
  padding:14px 22px; border-radius:2px; border:1px solid transparent;
  display:inline-block; transition:transform .15s ease, background .15s ease;
}
.btn-primary{background:var(--amber); color:var(--night); font-weight:600;}
.btn-primary:hover{transform:translateY(-2px);}
.btn-ghost{border-color:var(--line-dark); color:var(--paper);}
.btn-ghost:hover{border-color:var(--amber); color:var(--amber);}
.btn-dark{border-color:var(--ink); color:var(--ink);}
.btn-dark:hover{background:var(--ink); color:var(--paper);}

/* ---------- Big hero (home only) ---------- */
.hero{position:relative; background:var(--night); color:var(--paper); overflow:hidden; padding:88px 0 76px;}
.hero::before{
  content:""; position:absolute; right:-120px; top:-160px; width:640px; height:640px;
  border-radius:50%;
  background:repeating-radial-gradient(circle at center, rgba(232,163,61,0.14) 0px, rgba(232,163,61,0.14) 1.5px, transparent 1.5px, transparent 42px);
  pointer-events:none;
}
.hero-inner{position:relative; display:grid; grid-template-columns:1.3fr 0.9fr; gap:40px; align-items:end;}
.eyebrow{font-family:'JetBrains Mono', monospace; font-size:0.8rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--amber); margin-bottom:18px;}
.hero h1{font-size:clamp(3.4rem, 9vw, 6.4rem); font-weight:800;}
.hero h1 span{color:var(--amber);}
.hero p.lede{font-family:'Source Serif 4', serif; font-size:1.2rem; max-width:44ch; margin-top:22px; color:var(--paper); opacity:0.92;}
.hero-actions{margin-top:34px; display:flex; gap:14px; flex-wrap:wrap;}
.freq-card{background:rgba(247,243,236,0.05); border:1px solid var(--line-dark); padding:26px; font-family:'JetBrains Mono', monospace;}
.freq-card .label{font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--sage); opacity:0.9;}
.freq-card .value{font-size:2rem; color:var(--amber); margin:6px 0 18px; font-weight:500;}
.freq-card .sub{font-size:0.8rem; opacity:0.75;}
.freq-card hr{border:none; border-top:1px solid var(--line-dark); margin:16px 0;}

/* ---------- Photo hero (home) ---------- */
.hero-photo{position:relative; min-height:600px; display:flex; align-items:flex-end; overflow:hidden; background:var(--night);}
.hero-photo-bg{
  position:absolute; inset:0; background-size:cover; background-position:center;
  background-color:var(--night);
}
.hero-photo-bg::before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(0deg, rgba(27,36,48,0.94) 0%, rgba(27,36,48,0.55) 42%, rgba(27,36,48,0.35) 100%),
    radial-gradient(circle at 82% 12%, rgba(232,163,61,0.22), transparent 55%);
}
.hero-photo-bg::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:repeating-radial-gradient(circle at 85% 8%, rgba(232,163,61,0.16) 0px, rgba(232,163,61,0.16) 1.5px, transparent 1.5px, transparent 40px);
}
.hero-photo-inner{position:relative; padding:64px 0 56px; max-width:760px;}
.hero-photo h1{font-size:clamp(2.8rem, 6.4vw, 5.2rem); font-weight:800; color:var(--paper);}
.hero-photo h1 span{color:var(--amber);}
.hero-photo p.lede{font-family:'Source Serif 4', serif; font-size:1.15rem; max-width:52ch; margin-top:18px; color:var(--paper); opacity:0.94;}
.hero-photo .hero-actions{margin-top:30px; display:flex; gap:14px; flex-wrap:wrap;}

/* ---------- What is ham radio hook ---------- */
.hook{padding:64px 0 12px;}
.hook-inner{max-width:66ch; margin:0 auto; text-align:center;}
.hook .tag{font-family:'JetBrains Mono', monospace; font-size:0.75rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--rust); display:block; margin-bottom:16px;}
.hook p{font-family:'Source Serif 4', serif; font-size:1.28rem; line-height:1.55; margin:0;}
.hook p strong{color:var(--rust); font-weight:600;}

/* ---------- Highlight band: next meeting + repeater quick ref ---------- */
.highlight-band{padding:52px 0 76px;}
.highlight-grid{display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line);}
.info-box{background:var(--wheat); padding:34px 36px;}
.info-box .tag{font-family:'JetBrains Mono', monospace; font-size:0.75rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--rust); display:block; margin-bottom:14px;}
.info-box .headline{font-family:'Big Shoulders Display', sans-serif; font-weight:700; font-size:1.7rem; text-transform:uppercase; line-height:1.15; margin-bottom:6px;}
.info-box .subline{font-family:'JetBrains Mono', monospace; font-size:0.88rem; opacity:0.75; margin-bottom:18px;}
.info-box .freq-row{display:flex; justify-content:space-between; align-items:baseline; padding:11px 0; border-top:1px solid var(--line); font-size:0.95rem;}
.info-box .freq-row:first-of-type{border-top:none;}
.info-box .freq-row .k{font-family:'JetBrains Mono', monospace; font-size:0.78rem; letter-spacing:0.05em; text-transform:uppercase; color:var(--sage);}
.info-box .freq-row .v{font-family:'JetBrains Mono', monospace; font-weight:600;}
.info-box .link{display:inline-block; margin-top:16px; font-family:'JetBrains Mono', monospace; font-size:0.8rem; text-transform:uppercase; letter-spacing:0.06em; text-decoration:none; color:var(--ink); border-bottom:1px solid var(--ink); padding-bottom:2px;}

/* ---------- Upcoming list (home, before calendar embed) ---------- */
.upcoming-list{list-style:none; margin:0 0 32px; padding:0; display:flex; flex-direction:column; gap:1px; background:var(--line-dark); border:1px solid var(--line-dark);}
.upcoming-list li{background:var(--night); padding:18px 22px; display:flex; justify-content:space-between; align-items:baseline; gap:16px; flex-wrap:wrap;}
.upcoming-list .when{font-family:'JetBrains Mono', monospace; font-size:0.82rem; color:var(--amber); flex-shrink:0;}
.upcoming-list .what{font-family:'Big Shoulders Display', sans-serif; font-weight:700; font-size:1.15rem; text-transform:uppercase; color:var(--paper); flex-grow:1;}
.upcoming-list .where{font-family:'JetBrains Mono', monospace; font-size:0.78rem; color:var(--paper); opacity:0.65;}

/* ---------- Page hero (subpages) ---------- */
.page-hero{background:var(--night); color:var(--paper); padding:64px 0 48px; position:relative; overflow:hidden;}
.page-hero::before{
  content:""; position:absolute; right:-140px; top:-180px; width:480px; height:480px; border-radius:50%;
  background:repeating-radial-gradient(circle at center, rgba(232,163,61,0.12) 0px, rgba(232,163,61,0.12) 1.5px, transparent 1.5px, transparent 36px);
  pointer-events:none;
}
.page-hero-inner{position:relative;}
.crumb{font-family:'JetBrains Mono', monospace; font-size:0.75rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--amber); margin-bottom:14px;}
.crumb a{text-decoration:none; opacity:0.8;}
.crumb a:hover{opacity:1;}
.page-hero h1{font-size:clamp(2.6rem, 6vw, 4.2rem); font-weight:800;}
.page-hero p.lede{font-family:'Source Serif 4', serif; font-size:1.1rem; max-width:60ch; margin-top:16px; opacity:0.9;}

/* ---------- Morse divider ---------- */
.morse-divider{background:var(--wheat); padding:34px 0;}
.morse-row{display:flex; align-items:center; justify-content:center; gap:26px; flex-wrap:wrap;}
.morse-letter{display:flex; flex-direction:column; align-items:center; gap:8px;}
.morse-marks{display:flex; gap:5px; align-items:center; height:10px;}
.morse-marks .dot{width:7px;height:7px;border-radius:50%;background:var(--rust);}
.morse-marks .dash{width:22px;height:7px;border-radius:2px;background:var(--rust);}
.morse-letter .char{font-family:'JetBrains Mono', monospace; font-size:0.72rem; letter-spacing:0.05em; color:var(--ink); opacity:0.55;}
.morse-caption{text-align:center; font-family:'JetBrains Mono', monospace; font-size:0.7rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--sage); margin-top:14px;}
@media (prefers-reduced-motion: no-preference){
  .morse-marks .dot, .morse-marks .dash{animation: blink 2.4s ease-in-out infinite;}
  @keyframes blink{0%, 40%, 100%{opacity:1;} 20%{opacity:0.25;}}
}

/* ---------- Section scaffolding ---------- */
section{padding:76px 0;}
.section-head{display:flex; justify-content:space-between; align-items:flex-end; gap:20px; margin-bottom:40px; border-bottom:1px solid var(--line); padding-bottom:20px;}
.section-head h2{font-size:clamp(2rem, 4vw, 2.7rem);}
.section-head .tag{font-family:'JetBrains Mono', monospace; font-size:0.75rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--rust);}
.dark-section{background:var(--night); color:var(--paper);}
.dark-section .section-head{border-bottom:1px solid var(--line-dark);}
.dark-section .tag{color:var(--amber);}

.prose{max-width:70ch;}
.prose p{margin:0 0 16px;}
.prose h3{font-size:1.5rem; margin:34px 0 12px; text-transform:none; letter-spacing:0;}
.prose a{color:var(--rust); text-decoration-color:rgba(166,61,47,0.4);}

/* ---------- Two column layout ---------- */
.profile-grid{display:grid; grid-template-columns:1.4fr 1fr; gap:56px;}

/* ---------- Stat / spec list ---------- */
.stat-list{display:flex; flex-direction:column; gap:0; border-top:1px solid var(--line);}
.stat-item{display:flex; justify-content:space-between; align-items:baseline; gap:16px; padding:16px 0; border-bottom:1px solid var(--line);}
.stat-item .k{font-family:'JetBrains Mono', monospace; font-size:0.78rem; letter-spacing:0.06em; text-transform:uppercase; color:var(--sage);}
.stat-item .v{font-family:'Big Shoulders Display', sans-serif; font-weight:700; font-size:1.15rem; text-align:right;}
.stat-item .v.mono-v{font-family:'JetBrains Mono', monospace; font-weight:600; font-size:1rem;}

/* ---------- Calendar / embed card ---------- */
.cal-card{border:1px solid var(--line-dark); background:rgba(247,243,236,0.04); padding:6px;}
.cal-card iframe{width:100%; height:460px; border:0;}
.dark-section .cal-card iframe{filter:invert(0.92) hue-rotate(180deg) contrast(0.9);}
.cal-note{margin-top:14px; font-family:'JetBrains Mono', monospace; font-size:0.78rem; opacity:0.65;}
.form-card{border:1px solid var(--line); background:var(--paper); padding:6px;}
.form-card iframe{width:100%; height:900px; border:0;}

/* ---------- Resource grid ---------- */
.grid-4{display:grid; grid-template-columns:repeat(4, 1fr); gap:1px; background:var(--line); border:1px solid var(--line);}
.grid-3{display:grid; grid-template-columns:repeat(3, 1fr); gap:1px; background:var(--line); border:1px solid var(--line);}
.res-card{background:var(--wheat); padding:28px 24px; text-decoration:none; color:var(--ink); display:flex; flex-direction:column; gap:14px; min-height:190px; transition:background .15s ease;}
.res-card:hover{background:#ece2cd;}
.res-card .num{font-family:'JetBrains Mono', monospace; font-size:0.75rem; color:var(--rust);}
.res-card h3{font-size:1.25rem; font-weight:700;}
.res-card .desc{font-family:'Source Serif 4', serif; font-size:0.92rem; color:var(--ink); opacity:0.8; flex-grow:1;}
.res-card .go{font-family:'JetBrains Mono', monospace; font-size:0.75rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--sage);}

/* ---------- Two-up panels ---------- */
.two-up{display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line);}
.panel{background:var(--wheat); padding:40px; color:var(--ink);}
.panel .tag{font-family:'JetBrains Mono', monospace; font-size:0.75rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--rust); margin-bottom:10px; display:block;}
.panel h3{font-size:1.9rem; margin-bottom:14px;}
.panel p{margin:0 0 12px;}
.panel .link{font-family:'JetBrains Mono', monospace; font-size:0.8rem; text-transform:uppercase; letter-spacing:0.06em; text-decoration:none; color:var(--ink); border-bottom:1px solid var(--ink); padding-bottom:2px;}

/* ---------- Step list (genuinely sequential content: exam process) ---------- */
.step-list{display:flex; flex-direction:column; gap:0; counter-reset:step;}
.step{display:grid; grid-template-columns:56px 1fr; gap:22px; padding:28px 0; border-bottom:1px solid var(--line);}
.step:first-child{border-top:1px solid var(--line);}
.step .step-num{font-family:'JetBrains Mono', monospace; font-size:1.6rem; color:var(--rust); font-weight:600;}
.step h3{font-size:1.3rem; margin-bottom:8px;}
.step .desc{margin:0 0 12px;}
.step ul{margin:0; padding-left:20px;}
.step li{margin-bottom:6px;}

/* ---------- FAQ accordion ---------- */
.faq-item{border-bottom:1px solid var(--line); padding:22px 0;}
.faq-item summary{
  cursor:pointer; list-style:none; font-family:'Big Shoulders Display', sans-serif;
  font-weight:700; font-size:1.3rem; text-transform:uppercase; letter-spacing:0.01em;
  display:flex; justify-content:space-between; align-items:center; gap:16px;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{
  content:"+"; font-family:'JetBrains Mono', monospace; font-size:1.4rem; color:var(--rust);
  flex-shrink:0; transition:transform .15s ease;
}
.faq-item[open] summary::after{transform:rotate(45deg);}
.faq-item .faq-body{margin-top:14px; max-width:68ch;}
.faq-item .faq-body p{margin:0 0 14px;}

/* ---------- Callout ---------- */
.callout{background:rgba(107,124,99,0.12); border-left:3px solid var(--sage); padding:18px 22px; margin:22px 0; font-size:0.95rem;}
.callout strong{color:var(--rust);}

/* ---------- Photo grid ---------- */
.photo-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:10px; margin:28px 0;}
.photo-grid img{width:100%; height:220px; object-fit:cover; border:1px solid var(--line);}
.photo-grid.two-col{grid-template-columns:repeat(2, 1fr);}

/* ---------- Link library (resources page) ---------- */
.lib-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:1px; background:var(--line); border:1px solid var(--line);}
.lib-cat{background:var(--wheat); padding:30px 32px; color:var(--ink);}
.lib-cat .cat-tag{font-family:'JetBrains Mono', monospace; font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--rust); margin-bottom:14px; display:block;}
.lib-cat h3{font-size:1.35rem; margin-bottom:14px;}
.lib-cat ul{list-style:none; margin:0; padding:0;}
.lib-cat li{border-top:1px solid var(--line); padding:11px 0;}
.lib-cat li:first-of-type{border-top:none;}
.lib-cat a{text-decoration:none; font-size:0.95rem; display:flex; justify-content:space-between; gap:10px; align-items:baseline;}
.lib-cat a:hover{color:var(--rust);}
.lib-cat a .req{font-family:'JetBrains Mono', monospace; font-size:0.65rem; text-transform:uppercase; color:var(--sage); opacity:0.8; flex-shrink:0;}

/* ---------- Minutes archive ---------- */
.year-group{margin-bottom:44px;}
.year-group h2{font-size:2rem; color:var(--rust); margin-bottom:16px; border-bottom:1px solid var(--line); padding-bottom:12px;}
.year-list{list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(3, 1fr); gap:1px; background:var(--line); border:1px solid var(--line);}
.year-list li{background:var(--wheat);}
.year-list a{
  display:flex; justify-content:space-between; align-items:center; gap:10px;
  text-decoration:none; padding:16px 18px; font-family:'JetBrains Mono', monospace; font-size:0.85rem;
}
.year-list a:hover{background:#ece2cd; color:var(--rust);}
.year-list a::after{content:"↓"; opacity:0.5;}

/* ---------- Join CTA ---------- */
.join{background:var(--rust); color:var(--paper); text-align:center; padding:90px 0;}
.join .eyebrow{color:rgba(247,243,236,0.75);}
.join h2{font-size:clamp(2.4rem, 6vw, 4rem); max-width:16ch; margin:0 auto 22px;}
.join p{max-width:52ch; margin:0 auto 30px; opacity:0.92;}
.join .btn-primary{background:var(--wheat); color:var(--ink);}

/* ---------- Footer ---------- */
footer{background:var(--night); color:var(--paper); padding:50px 0 32px;}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:36px; padding-bottom:34px; border-bottom:1px solid var(--line-dark);}
.footer-grid h4{font-family:'JetBrains Mono', monospace; font-size:0.75rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--amber); margin-bottom:14px;}
.footer-grid ul{list-style:none; margin:0; padding:0;}
.footer-grid li{margin-bottom:9px;}
.footer-grid a{text-decoration:none; opacity:0.8; font-size:0.92rem;}
.footer-grid a:hover{opacity:1; color:var(--amber);}
.footer-bottom{display:flex; justify-content:space-between; align-items:center; padding-top:22px; font-family:'JetBrains Mono', monospace; font-size:0.72rem; opacity:0.6; flex-wrap:wrap; gap:10px;}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .nav-links{display:none;}
  .brand-mark img{height:42px;}
  .hero-inner{grid-template-columns:1fr;}
  .profile-grid{grid-template-columns:1fr;}
  .two-up{grid-template-columns:1fr;}
  .grid-4{grid-template-columns:1fr 1fr;}
  .grid-3{grid-template-columns:1fr;}
  .lib-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .photo-grid{grid-template-columns:1fr 1fr;}
  .year-list{grid-template-columns:1fr;}
  .step{grid-template-columns:40px 1fr;}
  .highlight-grid{grid-template-columns:1fr;}
  .hero-photo{min-height:520px;}
  .upcoming-list li{flex-direction:column; gap:4px;}
}
@media (max-width:520px){
  .grid-4{grid-template-columns:1fr;}
  .hero{padding:64px 0 52px;}
  .photo-grid{grid-template-columns:1fr;}
  .hook p{font-size:1.1rem;}
  .info-box{padding:28px 24px;}
}
