/* ===========================================================
   L'OMBRE D'EL GHALI — landing page
   Investigation-board / true-crime cinematic system
   =========================================================== */

:root{
  /* palette */
  --ink:        #0a0a0c;
  --ink-2:      #0f0f12;
  --ink-3:      #16161a;
  --bone:       #e9e5dd;
  --ash:        #9c968c;
  --ash-dim:    #6a655d;
  --line:       rgba(233,229,221,.10);

  --red:        #c1352c;
  --red-bright: #e03a2e;
  --blood:      #6e1812;
  --tape:       #d8b323;

  /* derived (overridden by Tweaks) */
  --accent:      var(--red);
  --accent-glow: rgba(193,53,44,.55);

  /* type */
  --display: "Anton", "Oswald", sans-serif;
  --label:   "Oswald", sans-serif;
  --body:    "Barlow", sans-serif;
  --type:    "Special Elite", "Courier New", monospace;

  --maxw: 1240px;
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  background:var(--ink);
  color:var(--bone);
  font-family:var(--body);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}

/* page-wide deep texture */
body::before{
  content:"";
  position:fixed; inset:0;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(110,24,18,.22), transparent 55%),
    radial-gradient(90% 70% at 100% 0%, rgba(0,0,0,.0), rgba(0,0,0,.55) 90%),
    var(--ink);
  z-index:-2;
}
body::after{
  content:"";
  position:fixed; inset:0;
  background-image:url("assets/noise.svg");
  background-size:260px;
  opacity:.05;
  mix-blend-mode:overlay;
  pointer-events:none;
  z-index:-1;
}

/* ---------- cinematic grain + flicker (toggle via .fx-cinematic) ---------- */
.grain{
  position:fixed; inset:-50%;
  width:200%; height:200%;
  background-image:url("assets/noise.svg");
  background-size:200px;
  opacity:0; pointer-events:none;
  z-index:60;
  mix-blend-mode:overlay;
}
.fx-cinematic .grain{ opacity:.07; animation:grain .7s steps(6) infinite; }
@keyframes grain{
  0%{transform:translate(0,0)} 20%{transform:translate(-6%,4%)}
  40%{transform:translate(4%,-6%)} 60%{transform:translate(-4%,6%)}
  80%{transform:translate(6%,-4%)} 100%{transform:translate(0,0)}
}
.vignette{
  position:fixed; inset:0; pointer-events:none; z-index:55;
  box-shadow:inset 0 0 220px 70px rgba(0,0,0,.85);
}
.fx-cinematic .vignette{ animation:flick 6s ease-in-out infinite; }
@keyframes flick{ 0%,100%{opacity:1} 47%{opacity:.92} 49%{opacity:1} 92%{opacity:.95} }

/* ===========================================================
   shared elements
   =========================================================== */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }

.eyebrow{
  font-family:var(--label);
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.42em;
  font-size:13px;
  color:var(--bone);
  display:inline-flex; align-items:center; gap:14px;
}
.eyebrow .red{ color:var(--accent); }
.eyebrow.center{ justify-content:center; }

/* animated audio waveform */
.wave{ display:inline-flex; align-items:center; gap:3px; height:16px; }
.wave i{
  width:2px; height:40%;
  background:var(--accent);
  border-radius:2px;
  animation:wv 1.1s ease-in-out infinite;
}
.wave i:nth-child(2){ animation-delay:.12s } .wave i:nth-child(3){ animation-delay:.24s }
.wave i:nth-child(4){ animation-delay:.36s } .wave i:nth-child(5){ animation-delay:.48s }
.wave i:nth-child(6){ animation-delay:.60s } .wave i:nth-child(7){ animation-delay:.72s }
.wave i:nth-child(8){ animation-delay:.84s } .wave i:nth-child(9){ animation-delay:.96s }
@keyframes wv{ 0%,100%{height:18%} 50%{height:100%} }

.section-head{ display:flex; flex-direction:column; gap:18px; margin-bottom:48px; }
.section-title{
  font-family:var(--display);
  font-weight:400;
  text-transform:uppercase;
  font-size:clamp(34px,5.5vw,72px);
  line-height:.92;
  letter-spacing:.005em;
}
.section-title .red{ color:var(--accent); }

/* push pin */
.pin{
  position:absolute; width:18px; height:18px; border-radius:50%; z-index:5;
  background:radial-gradient(circle at 35% 30%, #ff6a5a, var(--accent) 45%, #5e120d 100%);
  box-shadow:0 5px 10px rgba(0,0,0,.6), inset -1px -2px 3px rgba(0,0,0,.5);
}
.pin::after{ content:""; position:absolute; left:50%; top:50%; width:5px; height:5px;
  border-radius:50%; background:rgba(255,255,255,.5); transform:translate(-90%,-90%); }

/* crime-scene tape */
.tape-strip{
  --tape-c:var(--tape);
  position:relative;
  background:var(--tape-c);
  color:#1a1505;
  font-family:var(--label); font-weight:700;
  letter-spacing:.22em; text-transform:uppercase;
  font-size:14px;
  padding:10px 0;
  white-space:nowrap; overflow:hidden;
  box-shadow:0 14px 30px rgba(0,0,0,.5);
}
.tape-strip .roll{ display:inline-block; animation:roll 22s linear infinite; }
.tape-strip span{ padding:0 20px; opacity:.92; }
.tape-strip span::before{ content:"✕ "; opacity:.5; }
@keyframes roll{ to{ transform:translateX(-50%) } }

/* evidence stamp */
.stamp{
  font-family:var(--type);
  color:var(--accent);
  border:3px solid var(--accent);
  text-transform:uppercase;
  letter-spacing:.08em;
  padding:6px 14px;
  font-size:15px;
  display:inline-block;
  transform:rotate(-7deg);
  opacity:.9;
  border-radius:3px;
  box-shadow:0 0 0 2px rgba(193,53,44,.12);
  -webkit-mask-image:url("assets/noise.svg");
  mask-image:url("assets/noise.svg");
  -webkit-mask-size:120px; mask-size:120px;
}

/* buttons */
.btn{
  font-family:var(--label); font-weight:600;
  text-transform:uppercase; letter-spacing:.14em; font-size:14px;
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 26px; border:none; cursor:pointer;
  background:var(--accent); color:#fff;
  clip-path:polygon(0 0,100% 0,100% 100%,8px 100%,0 calc(100% - 8px));
  transition:transform .25s, box-shadow .25s, background .25s;
  box-shadow:0 0 0 0 var(--accent-glow);
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 12px 30px -8px var(--accent-glow); background:var(--red-bright); }
.btn.ghost{
  background:transparent; color:var(--bone);
  border:1px solid var(--line);
  clip-path:none;
}
.btn.ghost:hover{ border-color:var(--accent); color:#fff; box-shadow:none; transform:translateY(-2px); }

/* reveal-on-scroll */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.1s } .reveal.d2{ transition-delay:.2s } .reveal.d3{ transition-delay:.3s }

/* ===========================================================
   NAV
   =========================================================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 28px;
  transition:background .4s, padding .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{ background:rgba(8,8,10,.82); backdrop-filter:blur(12px); border-color:var(--line); padding:12px 28px; }
.nav .brand{ display:flex; align-items:center; gap:12px; text-decoration:none; }
.nav .brand img{ width:42px; height:42px; object-fit:contain; }
.nav .brand b{ font-family:var(--label); font-weight:600; text-transform:uppercase; letter-spacing:.18em; font-size:14px; color:var(--bone); }
.nav .brand b .red{ color:var(--accent); }
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{
  font-family:var(--label); text-transform:uppercase; letter-spacing:.16em;
  font-size:13px; color:var(--ash); text-decoration:none; transition:color .25s;
}
.nav-links a:hover{ color:var(--bone); }
.nav-cta{ display:flex; align-items:center; gap:18px; }
.menu-btn{ display:none; background:none; border:none; color:var(--bone); cursor:pointer; }

/* ===========================================================
   HERO
   =========================================================== */
.hero{
  position:relative; min-height:100vh;
  display:flex; align-items:center;
  padding:140px 0 90px;
  overflow:hidden;
}
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; object-position:72% 13%; opacity:.4; filter:grayscale(.2) contrast(1.05); }
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg, var(--ink) 6%, rgba(10,10,12,.74) 40%, rgba(10,10,12,.4) 68%, rgba(10,10,12,.72) 100%),
    linear-gradient(0deg, var(--ink) 22%, transparent 62%);
}
.hero-inner{ position:relative; z-index:3; max-width:760px; }
.hero h1{
  font-family:var(--display); font-weight:400;
  text-transform:uppercase;
  font-size:clamp(64px,12vw,168px);
  line-height:.82; letter-spacing:.004em;
  margin:22px 0 0;
  text-shadow:0 8px 40px rgba(0,0,0,.7);
}
.hero h1 .l1{ color:var(--bone); display:block; }
.hero h1 .l2{ color:var(--accent); display:block; }
.hero .tagline{
  font-family:var(--label); text-transform:uppercase; letter-spacing:.2em;
  font-size:clamp(14px,2vw,19px); color:var(--ash);
  margin-top:28px; display:flex; align-items:center; gap:12px; flex-wrap:wrap;
}
.hero .tagline b{ color:var(--bone); font-weight:600; }
.hero .tagline .sep{ color:var(--accent); }

/* hero platform row */
.hero-platforms{ margin-top:40px; display:flex; align-items:center; gap:13px; flex-wrap:wrap; }
.hero-platforms .label{ font-family:var(--label); text-transform:uppercase; letter-spacing:.18em; font-size:12px; color:var(--ash-dim); margin-right:6px; }
.pchip{
  width:50px; height:50px; border-radius:50%;
  display:grid; place-items:center; color:var(--bone);
  border:1px solid var(--line); background:rgba(15,15,18,.6);
  transition:transform .25s, border-color .25s, color .25s, background .25s;
}
.pchip svg{ width:24px; height:24px; }
.pchip:hover{ transform:translateY(-4px); color:var(--brand,#fff); border-color:var(--brand,#fff); background:rgba(0,0,0,.5); }

/* decor visibility toggle */
.hero-decor{ opacity:0; transition:opacity .6s; }
.show-decor .hero-decor{ opacity:1; }

/* floating board decor in hero */
.hero-decor{ position:absolute; inset:0; z-index:2; pointer-events:none; }
.polaroid{
  position:absolute;
  background:#e8e4da; padding:8px 8px 30px;
  box-shadow:0 22px 50px rgba(0,0,0,.65);
  filter:saturate(.7) contrast(1.05);
}
.polaroid .ph{ display:block; width:100%; height:100%; object-fit:cover; filter:grayscale(.5) brightness(.7); }
.polaroid .cap{ position:absolute; left:0; right:0; bottom:6px; text-align:center; font-family:var(--type); font-size:11px; color:#2a2620; letter-spacing:.04em; }
.scribble{ position:absolute; pointer-events:none; }

/* scroll cue */
.scroll-cue{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%);
  z-index:4; display:flex; flex-direction:column; align-items:center; gap:8px;
  font-family:var(--label); text-transform:uppercase; letter-spacing:.24em; font-size:11px; color:var(--ash-dim);
}
.scroll-cue .bar{ width:1px; height:46px; background:linear-gradient(var(--accent),transparent); animation:cue 1.8s ease-in-out infinite; }
@keyframes cue{ 0%,100%{opacity:.3; transform:scaleY(.6); transform-origin:top} 50%{opacity:1; transform:scaleY(1)} }

/* ===========================================================
   FEATURED EPISODE
   =========================================================== */
.episodes{ padding:120px 0 110px; position:relative; }
.ep-grid{ display:grid; grid-template-columns:1.45fr 1fr; gap:54px; align-items:start; }

.player-card{ position:relative; }
.thumb{
  position:relative; display:block; width:100%; aspect-ratio:16/9;
  border:1px solid var(--line); overflow:hidden; cursor:pointer;
  background:#000;
  box-shadow:0 40px 80px -30px rgba(0,0,0,.9);
}
.thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .8s cubic-bezier(.2,.7,.2,1), filter .5s; }
.thumb::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(0,0,0,.6), transparent 55%); }
.thumb:hover img{ transform:scale(1.045); filter:brightness(1.06); }
.play{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); z-index:3;
  width:96px; height:96px; border-radius:50%;
  display:grid; place-items:center;
  background:rgba(193,53,44,.92);
  box-shadow:0 0 0 0 var(--accent-glow);
  transition:transform .3s, box-shadow .3s, background .3s;
}
.thumb:hover .play{ transform:translate(-50%,-50%) scale(1.08); background:var(--red-bright); }
.play::before{ content:""; position:absolute; inset:0; border-radius:50%; box-shadow:0 0 0 2px rgba(255,255,255,.3); animation:ping 2.4s ease-out infinite; }
@keyframes ping{ 0%{transform:scale(1); opacity:.8} 100%{transform:scale(1.7); opacity:0} }
.play svg{ width:34px; height:34px; margin-left:5px; fill:#fff; }
.thumb .ep-badge{
  position:absolute; top:0; left:0; z-index:3;
  background:var(--accent); color:#fff;
  font-family:var(--label); font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  font-size:13px; padding:9px 16px;
}
.thumb .runtime{
  position:absolute; bottom:14px; right:14px; z-index:3;
  background:rgba(0,0,0,.78); color:var(--bone);
  font-family:var(--label); letter-spacing:.05em; font-size:13px; padding:5px 11px;
}
.thumb .tape-corner{
  position:absolute; bottom:0; left:-6%; right:-6%; z-index:3;
  transform:rotate(-2.4deg) translateY(40%);
}

.ep-meta{ margin-top:22px; display:flex; align-items:center; gap:18px; flex-wrap:wrap; font-family:var(--label); text-transform:uppercase; letter-spacing:.14em; font-size:13px; color:var(--ash); }
.ep-meta .dot{ width:5px; height:5px; border-radius:50%; background:var(--accent); }
.ep-meta .new{ color:var(--accent); }

/* case-file side panel */
.case-file{
  background:linear-gradient(180deg, var(--ink-2), var(--ink));
  border:1px solid var(--line);
  padding:34px 32px;
  position:relative;
}
.case-file .stamp{ position:absolute; top:-18px; right:18px; }
.case-file h3{
  font-family:var(--display); font-weight:400; text-transform:uppercase;
  font-size:clamp(28px,3.4vw,42px); line-height:.94; margin-bottom:8px;
}
.case-file .file-no{ font-family:var(--type); color:var(--ash-dim); font-size:13px; letter-spacing:.05em; margin-bottom:18px; }
.case-file p{ color:var(--ash); font-size:16px; margin-bottom:14px; }
.case-file p b{ color:var(--bone); font-weight:600; }
.case-file .warn{
  display:flex; gap:10px; align-items:flex-start;
  border-left:2px solid var(--accent); padding:10px 0 10px 14px;
  font-size:14px; color:var(--ash); margin:18px 0;
}
.tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:18px; }
.tags span{ font-family:var(--label); text-transform:uppercase; letter-spacing:.08em; font-size:11px; color:var(--ash); border:1px solid var(--line); padding:5px 10px; }

/* upcoming / season strip */
.season{ margin-top:80px; }
.season-head{ display:flex; align-items:baseline; justify-content:space-between; gap:20px; margin-bottom:26px; border-bottom:1px solid var(--line); padding-bottom:14px; }
.season-head h4{ font-family:var(--display); font-weight:400; text-transform:uppercase; font-size:clamp(22px,3vw,34px); }
.season-head .count{ font-family:var(--label); text-transform:uppercase; letter-spacing:.16em; font-size:12px; color:var(--ash-dim); }
.up-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.up-card{ position:relative; aspect-ratio:16/9; border:1px solid var(--line); background:var(--ink-2); overflow:hidden; }
.up-card.active{ cursor:pointer; }
.up-card.active img{ width:100%; height:100%; object-fit:cover; transition:transform .6s; }
.up-card.active:hover img{ transform:scale(1.05); }
.up-card .mini-badge{ position:absolute; top:10px; left:10px; z-index:3; font-family:var(--label); letter-spacing:.14em; text-transform:uppercase; font-size:11px; padding:5px 10px; background:rgba(0,0,0,.7); color:var(--bone); }
.up-card.active .mini-badge{ background:var(--accent); color:#fff; }
.up-card.locked{ display:grid; place-items:center; }
.up-card.locked::after{ content:""; position:absolute; inset:0; background-image:url("assets/noise.svg"); background-size:160px; opacity:.06; }
.up-card.locked .redact{ font-family:var(--type); color:var(--ash-dim); text-align:center; letter-spacing:.05em; padding:0 18px; }
.up-card.locked .redact b{ display:block; color:var(--ash); margin-bottom:6px; }
.up-card.locked .bars{ position:absolute; inset:0; }
.up-card.locked .bars i{ position:absolute; height:14px; background:#000; left:14px; right:14px; }

/* ===========================================================
   ABOUT
   =========================================================== */
.about{ padding:120px 0; position:relative; }
.about-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:64px; align-items:center; }
.about-visual{ position:relative; }
.about-visual .frame{
  position:relative; border:10px solid #16151a; box-shadow:0 40px 90px -30px rgba(0,0,0,.9);
  background:#000;
}
.about-visual .frame img{ width:100%; display:block; filter:grayscale(.15) contrast(1.05); }
.about-visual .stamp{ position:absolute; bottom:-22px; left:-18px; }
.about-text .lead{
  font-family:var(--display); font-weight:400; text-transform:uppercase;
  font-size:clamp(26px,3.4vw,46px); line-height:1; margin:20px 0 26px;
}
.about-text .lead .red{ color:var(--accent); }
.about-text p{ color:var(--ash); margin-bottom:18px; font-size:18px; }
.about-text p b{ color:var(--bone); font-weight:600; }
.about-text .signoff{ font-family:var(--type); color:var(--bone); font-size:17px; margin-top:24px; }

/* ===========================================================
   PLATFORMS
   =========================================================== */
.platforms{ padding:110px 0; background:linear-gradient(180deg, transparent, rgba(110,24,18,.06) 50%, transparent); }
.plat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:8px; }
.plat{
  display:flex; align-items:center; gap:16px;
  padding:22px 24px; text-decoration:none;
  background:var(--ink-2); border:1px solid var(--line);
  transition:transform .3s, border-color .3s, background .3s;
  position:relative; overflow:hidden;
}
.plat::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--brand,#fff); transform:scaleY(0); transform-origin:bottom; transition:transform .35s; }
.plat:hover{ transform:translateY(-3px); border-color:rgba(233,229,221,.2); background:var(--ink-3); }
.plat:hover::before{ transform:scaleY(1); }
.plat .ic{ width:38px; height:38px; flex:none; display:grid; place-items:center; color:var(--bone); transition:color .3s; }
.plat:hover .ic{ color:var(--brand,#fff); }
.plat .txt{ display:flex; flex-direction:column; }
.plat .txt .t{ font-family:var(--label); text-transform:uppercase; letter-spacing:.1em; font-size:15px; color:var(--bone); }
.plat .txt .s{ font-size:13px; color:var(--ash-dim); }
.plat .go{ margin-left:auto; color:var(--ash-dim); transition:transform .3s, color .3s; }
.plat:hover .go{ transform:translate(4px,-4px); color:var(--bone); }

/* ===========================================================
   SUGGEST A CASE
   =========================================================== */
.suggest{ padding:110px 0; }
.suggest-grid{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.suggest .lead-copy p{ color:var(--ash); font-size:18px; margin-top:18px; max-width:480px; }
.dossier{
  background:
    repeating-linear-gradient(0deg, transparent, transparent 33px, rgba(233,229,221,.04) 34px),
    var(--ink-2);
  border:1px solid var(--line);
  padding:36px 34px;
  position:relative;
}
.dossier .tab{ position:absolute; top:-15px; left:28px; background:var(--accent); color:#fff; font-family:var(--label); text-transform:uppercase; letter-spacing:.16em; font-size:12px; padding:6px 16px; }
.dossier h3{ font-family:var(--type); font-size:15px; color:var(--ash); letter-spacing:.04em; margin-bottom:22px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-family:var(--label); text-transform:uppercase; letter-spacing:.14em; font-size:11px; color:var(--ash-dim); margin-bottom:7px; }
.field input, .field textarea{
  width:100%; background:rgba(0,0,0,.4); border:1px solid var(--line);
  color:var(--bone); font-family:var(--body); font-size:16px; padding:13px 15px;
  transition:border-color .25s, box-shadow .25s; resize:vertical;
}
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(193,53,44,.16); }
.dossier .done-msg{ display:none; align-items:center; gap:10px; color:var(--bone); font-family:var(--label); text-transform:uppercase; letter-spacing:.12em; font-size:14px; margin-top:8px; }
.dossier.sent .done-msg{ display:flex; }

/* ===========================================================
   NEWSLETTER / CONTACT
   =========================================================== */
.contact{ padding:100px 0; background:linear-gradient(180deg, transparent, rgba(0,0,0,.4)); }
.contact-inner{ display:grid; grid-template-columns:1.2fr 1fr; gap:64px; align-items:center; }
.news-form{ display:flex; gap:0; margin-top:26px; max-width:520px; }
.news-form input{ flex:1; background:rgba(0,0,0,.4); border:1px solid var(--line); border-right:none; color:var(--bone); font-family:var(--body); font-size:16px; padding:16px 18px; }
.news-form input:focus{ outline:none; border-color:var(--accent); }
.contact-card{ border:1px solid var(--line); background:var(--ink-2); padding:30px 30px; }
.contact-card .k{ font-family:var(--label); text-transform:uppercase; letter-spacing:.16em; font-size:11px; color:var(--ash-dim); margin-bottom:6px; }
.contact-card a{ color:var(--bone); text-decoration:none; font-size:19px; transition:color .25s; word-break:break-all; }
.contact-card a:hover{ color:var(--accent); }
.contact-card .row + .row{ margin-top:24px; padding-top:24px; border-top:1px solid var(--line); }

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{ padding:70px 0 40px; border-top:1px solid var(--line); }
.footer-top{ display:flex; align-items:flex-start; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.footer .brand{ display:flex; align-items:center; gap:16px; }
.footer .brand img{ width:74px; height:74px; object-fit:contain; }
.footer .brand .nm{ font-family:var(--display); text-transform:uppercase; font-size:26px; line-height:.9; }
.footer .brand .nm .red{ color:var(--accent); }
.footer .brand .nm small{ display:block; font-family:var(--label); font-size:11px; letter-spacing:.22em; color:var(--ash-dim); margin-top:6px; }
.socials{ display:flex; gap:12px; }
.socials a{ width:46px; height:46px; display:grid; place-items:center; border:1px solid var(--line); color:var(--ash); transition:all .25s; }
.socials a:hover{ color:#fff; border-color:var(--accent); background:var(--accent); transform:translateY(-3px); }
.footer-bottom{ margin-top:48px; padding-top:24px; border-top:1px solid var(--line); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:13px; color:var(--ash-dim); font-family:var(--label); letter-spacing:.08em; text-transform:uppercase; }

/* ===========================================================
   FULLSCREEN VIDEO OVERLAY
   =========================================================== */
.video-modal{
  position:fixed; inset:0; z-index:200; display:none;
  background:rgba(4,4,5,.96); backdrop-filter:blur(8px);
  align-items:center; justify-content:center;
  opacity:0; transition:opacity .35s;
}
.video-modal.open{ display:flex; opacity:1; }
.video-modal .frame-wrap{ width:min(94vw,1500px); aspect-ratio:16/9; box-shadow:0 0 120px rgba(193,53,44,.25); transform:scale(.96); transition:transform .4s cubic-bezier(.2,.7,.2,1); border:1px solid rgba(233,229,221,.1); }
.video-modal.open .frame-wrap{ transform:scale(1); }
.video-modal iframe{ width:100%; height:100%; border:0; }
.video-close{
  position:absolute; top:24px; right:28px; z-index:3;
  width:54px; height:54px; border-radius:50%;
  background:rgba(20,20,24,.8); border:1px solid var(--line); color:var(--bone);
  cursor:pointer; display:grid; place-items:center; transition:all .25s;
}
.video-close:hover{ background:var(--accent); color:#fff; border-color:var(--accent); transform:rotate(90deg); }
.video-modal .vm-title{ position:absolute; top:30px; left:30px; z-index:3; font-family:var(--label); text-transform:uppercase; letter-spacing:.16em; font-size:13px; color:var(--ash); }
.video-modal .vm-title b{ color:var(--bone); }

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:1000px){
  .ep-grid{ grid-template-columns:1fr; gap:36px; }
  .about-grid, .suggest-grid, .contact-inner{ grid-template-columns:1fr; gap:40px; }
  .plat-grid{ grid-template-columns:repeat(2,1fr); }
  .nav-links{ display:none; }
  .menu-btn{ display:grid; place-items:center; }
}
@media (max-width:620px){
  body{ font-size:16px; }
  .wrap{ padding:0 18px; }
  .nav{ padding:14px 18px; }
  .hero{ padding:120px 0 70px; }
  .up-grid{ grid-template-columns:1fr; }
  .plat-grid{ grid-template-columns:1fr; }
  .news-form{ flex-direction:column; }
  .news-form input{ border-right:1px solid var(--line); }
  .news-form .btn{ margin-top:10px; clip-path:none; justify-content:center; }
  .hero .polaroid{ display:none; }
}

/* reduce motion */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; }
  .reveal{ opacity:1; transform:none; }
}
