@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow:wght@300;400;500;600&family=Barlow+Condensed:wght@300;400;600;700&display=swap');

:root {
  --black:   #070707;
  --red:     #c0392b;
  --red-d:   #8e1b10;
  --gold:    #c9920e;
  --gold-l:  #e8b422;
  --white:   #f2f0eb;
  --grey:    #111;
  --grey2:   #1a1a1a;
  --grey3:   #252525;
  --line:    rgba(255,255,255,0.07);
  --text:    #ccc9c0;
  --muted:   #666660;
  --nav-h:   68px;
  --ease:    cubic-bezier(0.16,1,0.3,1);
  --max-w:   1320px;
  --pad:     64px;
  --pad-sm:  24px;
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--black); color:var(--text); font-family:'Barlow',sans-serif; font-weight:300; line-height:1.7; overflow-x:hidden; cursor:none; }
a,button { cursor:none; }
img { max-width:100%; display:block; }

/* ── RACECAR CURSOR ── */
.cursor {
  position:fixed; top:0; left:0; z-index:9999;
  width:32px; height:16px;
  pointer-events:none;
  transform:translate(-50%,-50%);
  transition:transform .1s;
  filter:drop-shadow(0 0 4px rgba(192,57,43,.6));
}
.cursor svg { width:100%; height:100%; }
.cursor.hover { transform:translate(-50%,-50%) scale(1.4); filter:drop-shadow(0 0 8px rgba(192,57,43,.9)); }
.cursor-ring {
  position:fixed; top:0; left:0; z-index:9998;
  width:48px; height:48px;
  border:1px solid rgba(192,57,43,.2);
  border-radius:50%;
  pointer-events:none;
  transform:translate(-50%,-50%);
  transition:transform .15s;
}

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0;
  height:var(--nav-h); z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 var(--pad);
  border-bottom:1px solid transparent;
  transition:background .4s,border-color .4s,backdrop-filter .4s;
}
nav.scrolled { background:rgba(7,7,7,.95); border-color:var(--line); backdrop-filter:blur(20px); }
.nav-logo { font-family:'Bebas Neue',sans-serif; font-size:20px; letter-spacing:3px; color:var(--white); text-decoration:none; display:flex; align-items:center; gap:8px; }
.nav-logo em { color:var(--red); font-style:normal; }
.nav-dot { width:5px; height:5px; border-radius:50%; background:var(--red); animation:blink 2s ease infinite; flex-shrink:0; }
@keyframes blink { 0%,100%{opacity:1}50%{opacity:.15} }
.nav-links { display:flex; align-items:center; gap:28px; }
.nav-links a { font-family:'Barlow Condensed',sans-serif; font-size:12px; letter-spacing:3px; text-transform:uppercase; color:var(--muted); text-decoration:none; transition:color .2s; position:relative; white-space:nowrap; }
.nav-links a::after { content:''; position:absolute; bottom:-3px; left:0; width:0; height:1px; background:var(--red); transition:width .3s var(--ease); }
.nav-links a:hover,.nav-links a.active { color:var(--white); }
.nav-links a:hover::after,.nav-links a.active::after { width:100%; }
.nav-cta { background:var(--red)!important; color:white!important; padding:9px 20px; }
.nav-cta:hover { background:var(--red-d)!important; }
.nav-cta::after { display:none!important; }
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:4px; }
.nav-toggle span { display:block; width:22px; height:2px; background:var(--white); transition:all .3s; }

/* ── MOBILE NAV ── */
.mobile-nav { display:none; position:fixed; inset:0; z-index:99; background:rgba(7,7,7,.98); flex-direction:column; align-items:center; justify-content:center; gap:20px; padding:40px; }
.mobile-nav.open { display:flex; }
.mobile-nav a { font-family:'Bebas Neue',sans-serif; font-size:36px; letter-spacing:3px; color:var(--white); text-decoration:none; transition:color .2s; }
.mobile-nav a:hover { color:var(--red); }
.mobile-close { position:absolute; top:24px; right:24px; background:none; border:none; color:var(--white); font-size:26px; }

/* ── INNER WIDTH WRAPPER ── */
.inner { max-width:var(--max-w); margin:0 auto; width:100%; }

/* ── PAGE HERO ── */
.page-hero {
  min-height:44vh;
  padding:calc(var(--nav-h) + 60px) var(--pad) 60px;
  position:relative; overflow:hidden;
  border-bottom:1px solid var(--line);
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:end;
  gap:48px;
}
.page-hero::before { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px); background-size:80px 80px; pointer-events:none; }
.page-hero-bg { position:absolute; inset:0; pointer-events:none; }
.page-hero-num { position:absolute; right:-10px; bottom:-20px; font-family:'Bebas Neue',sans-serif; font-size:clamp(100px,15vw,240px); color:rgba(192,57,43,.04); line-height:1; user-select:none; pointer-events:none; letter-spacing:-5px; }
.page-hero-left { position:relative; z-index:1; }
.page-hero-right { position:relative; z-index:1; }
.page-hero-label { font-family:'Barlow Condensed',sans-serif; font-size:11px; letter-spacing:7px; text-transform:uppercase; color:var(--red); margin-bottom:10px; }
.page-hero-label.gold { color:var(--gold); }
.page-hero h1 { font-family:'Bebas Neue',sans-serif; font-size:clamp(56px,7vw,108px); line-height:.9; color:var(--white); letter-spacing:2px; }
.page-hero h1 em { color:var(--red); font-style:normal; }
.page-hero p { font-size:15px; color:var(--muted); max-width:480px; line-height:1.85; }

/* ── SECTIONS ── */
.section { padding:96px var(--pad); border-bottom:1px solid var(--line); }
.section.dark { background:var(--grey); }
.section-label { font-family:'Barlow Condensed',sans-serif; font-size:11px; letter-spacing:7px; text-transform:uppercase; color:var(--red); margin-bottom:8px; }
.section-label.gold { color:var(--gold); }
.section-title { font-family:'Bebas Neue',sans-serif; font-size:clamp(40px,4vw,68px); line-height:.92; color:var(--white); letter-spacing:2px; margin-bottom:24px; }
.section-body { font-size:15px; color:var(--muted); max-width:560px; line-height:1.9; margin-bottom:32px; }

/* ── BUTTONS ── */
.btn { display:inline-flex; align-items:center; gap:10px; padding:14px 28px; font-family:'Barlow Condensed',sans-serif; font-size:13px; font-weight:700; letter-spacing:3px; text-transform:uppercase; text-decoration:none; transition:all .25s var(--ease); }
.btn-primary { background:var(--red); color:white; }
.btn-primary:hover { background:var(--red-d); transform:translateY(-2px); box-shadow:0 12px 32px rgba(192,57,43,.35); }
.btn-secondary { background:transparent; color:var(--white); border:1px solid rgba(255,255,255,.18); }
.btn-secondary:hover { border-color:var(--white); transform:translateY(-2px); }
.btn-gold { background:var(--gold); color:var(--black); }
.btn-gold:hover { background:var(--gold-l); transform:translateY(-2px); }

/* ── SERIES GRID ── */
.series-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:3px; }
.series-card { background:var(--grey2); position:relative; overflow:hidden; cursor:pointer; aspect-ratio:16/9; display:flex; flex-direction:column; justify-content:flex-end; padding:32px; border-bottom:3px solid transparent; transition:border-color .3s; text-decoration:none; }
.series-card:hover { border-bottom-color:var(--red); }
.series-card-bg { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.2) 60%,transparent 100%); z-index:1; }
.series-card-img { position:absolute; inset:0; object-fit:cover; width:100%; height:100%; transition:transform .6s var(--ease); }
.series-card:hover .series-card-img { transform:scale(1.04); }
.series-card-content { position:relative; z-index:2; }
.series-card-label { font-family:'Barlow Condensed',sans-serif; font-size:10px; letter-spacing:5px; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:4px; }
.series-card-title { font-family:'Bebas Neue',sans-serif; font-size:30px; letter-spacing:2px; color:var(--white); margin-bottom:4px; }
.series-card-count { font-size:12px; color:rgba(255,255,255,.4); }
.series-card-placeholder { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:56px; opacity:.12; }

/* ── PHOTO GALLERY ── */
.gallery-header { display:flex; align-items:center; gap:16px; margin-bottom:24px; flex-wrap:wrap; }
.back-btn { display:inline-flex; align-items:center; gap:8px; font-family:'Barlow Condensed',sans-serif; font-size:12px; letter-spacing:3px; text-transform:uppercase; color:var(--muted); text-decoration:none; transition:color .2s; background:none; border:none; padding:0; }
.back-btn:hover { color:var(--white); }
.gallery-title { font-family:'Bebas Neue',sans-serif; font-size:40px; letter-spacing:2px; color:var(--white); }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3px; }
.gallery-item { position:relative; overflow:hidden; aspect-ratio:3/2; background:var(--grey2); cursor:pointer; }
.gallery-item img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s var(--ease); pointer-events:none; user-select:none; -webkit-user-drag:none; }
.gallery-item:hover img { transform:scale(1.04); }
.gallery-item-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 50%); opacity:0; transition:opacity .3s; display:flex; align-items:flex-end; padding:14px; }
.gallery-item:hover .gallery-item-overlay { opacity:1; }
.gallery-item-caption { font-family:'Barlow Condensed',sans-serif; font-size:12px; letter-spacing:2px; text-transform:uppercase; color:white; }
.gallery-empty { grid-column:1/-1; padding:100px 40px; text-align:center; border:1px dashed rgba(255,255,255,.06); }
.gallery-empty h3 { font-family:'Bebas Neue',sans-serif; font-size:32px; color:var(--muted); letter-spacing:2px; margin-bottom:8px; }
.gallery-empty p { font-size:14px; color:var(--muted); }

/* ── LIGHTBOX ── */
.lightbox { position:fixed; inset:0; z-index:1000; background:rgba(0,0,0,.97); display:none; flex-direction:column; align-items:center; justify-content:center; }
.lightbox.open { display:flex; }
.lightbox-img { max-width:88vw; max-height:78vh; object-fit:contain; user-select:none; -webkit-user-drag:none; pointer-events:none; }
.lightbox-caption { font-family:'Barlow Condensed',sans-serif; font-size:13px; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,.45); margin-top:14px; }
.lightbox-close { position:absolute; top:20px; right:24px; background:none; border:none; color:rgba(255,255,255,.5); font-size:32px; transition:color .2s; }
.lightbox-close:hover { color:white; }
.lightbox-prev,.lightbox-next { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.07); border:none; color:white; font-size:28px; padding:18px 22px; transition:background .2s; }
.lightbox-prev { left:20px; }
.lightbox-next { right:20px; }
.lightbox-prev:hover,.lightbox-next:hover { background:rgba(255,255,255,.15); }
.lightbox-counter { position:absolute; bottom:24px; left:50%; transform:translateX(-50%); font-family:'Barlow Condensed',sans-serif; font-size:12px; letter-spacing:4px; color:rgba(255,255,255,.3); }
.lightbox-dots { display:flex; gap:6px; margin-top:14px; flex-wrap:wrap; justify-content:center; max-width:80vw; }
.lightbox-dot { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,.2); transition:background .2s; cursor:pointer; flex-shrink:0; }
.lightbox-dot.active { background:var(--red); }

/* ── FORMS ── */
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.form-label { font-family:'Barlow Condensed',sans-serif; font-size:11px; letter-spacing:4px; text-transform:uppercase; color:var(--muted); }
.form-input,.form-select,.form-textarea { background:var(--grey2); border:1px solid var(--line); color:var(--white); padding:13px 16px; font-family:'Barlow',sans-serif; font-size:14px; font-weight:300; outline:none; transition:border-color .2s; width:100%; }
.form-input:focus,.form-select:focus,.form-textarea:focus { border-color:var(--red); }
.form-textarea { resize:vertical; min-height:120px; }
.form-submit { background:var(--red); color:white; border:none; padding:15px 32px; font-family:'Barlow Condensed',sans-serif; font-size:14px; font-weight:700; letter-spacing:3px; text-transform:uppercase; transition:background .2s,transform .2s; width:100%; }
.form-submit:hover { background:var(--red-d); transform:translateY(-2px); }

/* ── FOOTER ── */
footer { background:var(--grey); border-top:1px solid var(--line); padding:64px var(--pad) 40px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer-brand { font-family:'Bebas Neue',sans-serif; font-size:28px; letter-spacing:3px; color:var(--white); margin-bottom:6px; }
.footer-brand em { color:var(--red); font-style:normal; }
.footer-tagline { font-size:13px; color:var(--muted); margin-bottom:12px; }
.footer-col h4 { font-family:'Barlow Condensed',sans-serif; font-size:11px; letter-spacing:4px; text-transform:uppercase; color:var(--muted); margin-bottom:12px; }
.footer-col a { display:block; font-size:13px; color:var(--text); text-decoration:none; padding:4px 0; transition:color .2s; }
.footer-col a:hover { color:var(--white); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:24px; border-top:1px solid var(--line); flex-wrap:wrap; gap:12px; }
.footer-copy { font-size:12px; color:var(--muted); }

/* ── REVEAL ── */
.reveal { opacity:0; transform:translateY(20px); transition:opacity .6s var(--ease),transform .6s var(--ease); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── TABLET ── */
@media(max-width:1100px) {
  :root { --pad:40px; }
  .page-hero { grid-template-columns:1fr; gap:24px; }
  .footer-grid { grid-template-columns:1fr 1fr 1fr; }
}

/* ── MOBILE ── */
@media(max-width:900px) {
  :root { --pad:20px; }
  nav { padding:0 20px; }
  .nav-links { display:none; }
  .nav-toggle { display:flex; }
  .cursor,.cursor-ring { display:none; }
  body { cursor:auto; }
  a,button { cursor:pointer; }
  .page-hero { padding:calc(var(--nav-h) + 32px) 20px 36px; grid-template-columns:1fr; gap:16px; min-height:auto; }
  .page-hero-num { display:none; }
  .page-hero h1 { font-size:clamp(44px,12vw,72px); }
  .section { padding:56px 20px; }
  .series-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:28px; }
  footer { padding:40px 20px 28px; }
}
@media(max-width:600px) {
  .page-hero h1 { font-size:clamp(36px,14vw,60px); }
  .gallery-grid { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .series-grid { grid-template-columns:1fr; }
  .lightbox-prev { left:4px; padding:12px 14px; }
  .lightbox-next { right:4px; padding:12px 14px; }
}
