
:root{
  --bg:#0e0f12;--card:#15171c;--card-2:#1a1d23;--text:#e9eef5;--muted:#a9b4c0;
  --brand:#5bc6b8;--accent:#88e1d5;--border:#23262d;--shadow:0 6px 24px rgba(0,0,0,.25);
  --pill-upcoming:#e0b30d;--pill-completed:#37c978
}
*{box-sizing:border-box}
body{margin:0;background:linear-gradient(180deg,#0c0d10,#101217);color:var(--text);font:400 16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial}
.wrap{max-width:1180px;margin:0 auto;padding:24px}
header.global{display:flex;align-items:center;gap:16px;padding:12px 0 18px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text)}
.logo-mark{width:28px;height:28px;border-radius:8px;background:linear-gradient(155deg,var(--brand),var(--accent));box-shadow:var(--shadow)}
nav a{color:var(--muted);text-decoration:none;margin-right:18px}
nav a.active, nav a:hover{color:var(--text)}
.breadcrumbs{color:var(--muted);font-size:14px;margin:12px 0 10px}
.breadcrumbs a{color:var(--muted);text-decoration:none}
h1{margin:.1em 0;font-size:clamp(26px,4vw,40px);line-height:1.2}
.meta{color:var(--muted)}
.status{display:inline-flex;gap:8px;align-items:center}
.pill{display:inline-block;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;color:#0b1212}
.completed{background:var(--pill-completed)}
.upcoming{background:var(--pill-upcoming)}
.hero{display:flex;justify-content:space-between;gap:24px;align-items:end;flex-wrap:wrap}
.filters{position:sticky;top:0;background:linear-gradient(180deg,#0c0d10ef,#0c0d10ef);backdrop-filter:saturate(140%) blur(6px);border-bottom:1px solid var(--border);z-index:5}
.filters-inner{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:12px 0}
.chipbar{display:flex;gap:8px;flex-wrap:wrap}
.chip{appearance:none;border:1px solid var(--border);background:var(--card);color:var(--text);padding:8px 12px;border-radius:999px;cursor:pointer}
.chip[aria-pressed="true"], .chip:hover{border-color:var(--brand);box-shadow:0 0 0 2px color-mix(in oklab, var(--brand) 30%, transparent)}
.selects{display:flex;gap:10px;align-items:center}
.selects select, .search input{appearance:none;background:var(--card);color:var(--text);border:1px solid var(--border);padding:10px 12px;border-radius:12px}
.search{display:flex;align-items:center;gap:8px}
.search input{min-width:220px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:18px 0 24px}
@media (max-width:980px){.grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.grid{grid-template-columns:1fr}}
.card{list-style:none;background:linear-gradient(180deg,var(--card),var(--card-2));border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);transition:transform .2s ease, box-shadow .2s ease}
.card:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(0,0,0,.35)}
.card a{display:block;color:inherit;text-decoration:none}
.thumb{position:relative;aspect-ratio:16/9;background:#0a0b0d}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.loc{margin:0;color:var(--muted);font-size:14px}
.meta-card{padding:14px 14px 16px}
.title{margin:2px 0 4px;font-size:18px;letter-spacing:.2px}
.tags{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}
.tag{font-size:12px;color:var(--brand);background:rgba(91,198,184,.1);border:1px solid color-mix(in oklab, var(--brand) 30%, transparent);padding:4px 8px;border-radius:999px}
.pager{display:flex;justify-content:center}
.btn{appearance:none;border:1px solid var(--border);background:var(--card);color:var(--text);padding:12px 16px;border-radius:12px;cursor:pointer}
.btn:hover{border-color:var(--brand)}
footer.cta{margin:36px 0 16px;padding:18px;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,#0f1216,#12151b)}
.cta .row{display:flex;gap:18px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.cta h3{margin:0;font-size:18px}
.cta a.button{display:inline-block;background:linear-gradient(155deg,var(--brand),var(--accent));color:#051010;text-decoration:none;font-weight:700;padding:12px 16px;border-radius:12px}
/* Detail page */ 
.titlebar{display:flex;flex-wrap:wrap;gap:16px;align-items:end;justify-content:space-between}
.hero-image{margin:14px 0 18px;border:1px solid var(--border);border-radius:16px;overflow:hidden;background:linear-gradient(180deg,var(--card),var(--card-2));box-shadow:var(--shadow)}
.hero-image img{width:100%;height:auto;display:block;object-fit:cover}
.section{margin:22px 0;border:1px solid var(--border);border-radius:16px;background:linear-gradient(180deg,#0f1216,#12151b)}
.section .hd{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}
.section h2{margin:0;font-size:18px}
.section .bd{padding:16px}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media (max-width:980px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.gallery{grid-template-columns:1fr}}
.gallery a{display:block;position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--border)}
.gallery img{width:100%;height:220px;object-fit:cover;display:block}
.cols{display:grid;grid-template-columns:2.1fr 1fr;gap:18px}
@media (max-width:980px){.cols{grid-template-columns:1fr}}
.facts{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.facts li{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:10px}
.detail-cta{margin:26px 0 8px;padding:18px;border:1px solid var(--border);border-radius:16px;background:linear-gradient(155deg,var(--brand),var(--accent));color:#051010;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.detail-cta a{background:#061313;color:#e6fffa;text-decoration:none;font-weight:700;padding:12px 16px;border-radius:12px}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
