
:root{
  --bg:#0b0f17;
  --card:#111827;
  --text:#f3f4f6;
  --muted:#9ca3af;
  --primary:#ef4444;
  --ghost:#2a3343;
  --border:#1f2937;
  --radius:14px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit}
img{max-width:100%;height:auto;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 16px}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:16px;top:16px;width:auto;height:auto;background:#000;color:#fff;padding:8px 12px;border-radius:8px;z-index:1000}

.site-header{
  position:sticky;top:0;z-index:50;
  border-bottom:1px solid var(--border);
  backdrop-filter:saturate(140%) blur(6px);
  background:linear-gradient(180deg, rgba(11,15,23,.9), rgba(11,15,23,.6) 70%, rgba(11,15,23,0));
}
.header-inner{
  display:flex;align-items:center;gap:16px;padding:12px 0;
}
.logo{display:inline-flex;align-items:center;gap:8px;text-decoration:none}
.site-nav{margin-left:auto}
.nav-list{display:flex;gap:16px;list-style:none;margin:0;padding:0}
.nav-list a{padding:8px 10px;border-radius:8px;text-decoration:none}
.nav-list a:hover{background:var(--ghost)}

.auth{display:flex;gap:10px;margin-left:12px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;border-radius:10px;text-decoration:none;border:1px solid transparent;white-space:nowrap}
.btn-primary{background:var(--primary);border-color:transparent;color:#fff;font-weight:600}
.btn-ghost{background:transparent;border-color:var(--border);color:var(--text)}

.hero{padding:32px 0 12px;border-bottom:1px solid var(--border)}
.hero-inner{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:center}
.hero h1{font-size:clamp(24px,3vw,38px);line-height:1.2;margin:0 0 8px}
.hero p{color:var(--muted);margin:0 0 16px}
.cta{display:flex;gap:12px;flex-wrap:wrap}

.strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#0e1420}
.section-title{font-size:1.5rem;margin:20px 0 10px}
.muted{color:var(--muted)}

.chips{display:flex;gap:8px;flex-wrap:wrap;list-style:none;margin:10px 0 20px;padding:0}
.chips a{display:inline-block;padding:8px 12px;border:1px solid var(--border);border-radius:999px;text-decoration:none}
.chips a:hover{background:var(--ghost)}

.cards{grid-template-columns:repeat(4,minmax(0,1fr))}
.grid{display:grid;gap:16px;margin:12px 0 28px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
.card img{aspect-ratio:16/9;object-fit:cover;background:#0b1220}
.card-title{font-size:1.05rem;margin:12px 12px 0}
.card-actions{display:flex;gap:8px;padding:12px}

.site-footer{border-top:1px solid var(--border);margin-top:24px}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 0;color:var(--muted)}
.footer-inner a{color:var(--muted);text-decoration:none;margin-right:12px}
.footer-inner a:hover{color:var(--text)}

@media (max-width: 900px){
  .hero-inner{grid-template-columns:1fr}
  .cards{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 520px){
  .nav-list{display:none}
  .cards{grid-template-columns:1fr}
}


/* --- Banner with overlay text --- */
.banner{position:relative; overflow:hidden; border-bottom:1px solid var(--border)}
.banner-media img{width:100%; height:auto; display:block; object-fit:cover}
.banner-caption{
  position:absolute; inset:auto auto 8% 5%;
  max-width:min(48ch, 46%);
  display:flex; flex-direction:column; gap:12px;
  color:#fff; text-shadow: 1px 1px 1px #1e225d, 1px -1px 1px #1e225d, -1px 1px 1px #1e225d, -1px -1px 1px #1e225d, 0 0 1px #1e225d;
}
.banner-title{font-size:clamp(24px,3.4vw,40px); line-height:1.15; margin:0}
.banner-subtitle{font-size:clamp(16px,2vw,22px); margin:0; opacity:.95}
@media (max-width: 900px){
  .banner-caption{inset:auto auto 6% 4%; max-width:70%}
}
@media (max-width: 520px){
  .banner-caption{inset:auto auto 5% 4%; max-width:88%}
}





/* === Lightweight JS slider === */
.banner-slider{position:relative;border-bottom:1px solid var(--border);aspect-ratio:1600/395;max-height:520px;overflow:hidden}
.banner-slider .slide{position:absolute;inset:0;margin:0;opacity:0;transition:opacity .6s ease;pointer-events:none}
.banner-slider .slide.is-active{opacity:1;pointer-events:auto}
.banner-slider img{width:100%;height:100%;object-fit:cover;display:block}

.banner-caption{position:absolute;left:5%;bottom:8%;max-width:min(48ch,46%);display:flex;flex-direction:column;gap:12px;color:#fff;text-shadow:1px 1px 1px #1e225d,1px -1px 1px #1e225d,-1px 1px 1px #1e225d,-1px -1px 1px #1e225d,0 0 1px #1e225d}
.banner-title{font-size:clamp(24px,3.6vw,42px);line-height:1.12;margin:0}
.banner-subtitle{font-size:clamp(16px,2vw,22px);margin:0;opacity:.95}

.slider-arrow{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:999px;border:1px solid #ffffff33;background:#00000055;color:#fff;font-size:26px;line-height:1;display:grid;place-items:center;cursor:pointer;user-select:none}
.slider-arrow:hover{background:#00000077}
.slider-arrow.prev{left:10px}
.slider-arrow.next{right:10px}

.slider-dots{position:absolute;left:5%;bottom:4%;display:flex;gap:8px}
.slider-dots .dot{width:10px;height:10px;border-radius:999px;border:0;background:#ffffff66;cursor:pointer}
.slider-dots .dot.is-active{background:#fff}

@media (max-width:900px){ .banner-caption{left:4%;bottom:6%;max-width:70%} }
@media (max-width:520px){ .banner-slider{aspect-ratio:16/9} .banner-caption{left:4%;bottom:6%;max-width:88%} }
