/* ============================================================
   HUSAIN CREATIVE STUDIOS — shared system
   Bold / energetic / acid-green / poster-condensed
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Archivo:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

:root{
  --bg:        #0b0c08;
  --bg-2:      #14160e;
  --bg-3:      #1c1f14;
  --line:      #2a2e1f;
  --ink:       #f3f4e9;
  --muted:     #9a9d8a;
  --muted-2:   #6f7263;
  --lime:      #c8ff2e;
  --lime-deep: #a6e000;
  --lime-ink:  #131500;

  --maxw: 1280px;
  --pad:  clamp(20px, 5vw, 64px);

  --font-display: 'Anton', 'Arial Narrow', sans-serif;
  --font-body:    'Archivo', system-ui, sans-serif;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:18px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }

/* ---- display type ---------------------------------------- */
.display{
  font-family:var(--font-display);
  font-weight:400;
  line-height:0.92;
  letter-spacing:0.005em;
  text-transform:uppercase;
}
.eyebrow{
  font-family:var(--font-body);
  font-weight:700;
  font-size:13px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--lime);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:"";
  width:26px; height:2px;
  background:var(--lime);
  display:inline-block;
}
.lime{ color:var(--lime); }
.outline{
  color:transparent;
  -webkit-text-stroke:1.5px var(--ink);
}

/* ---- buttons (used sparingly) ---------------------------- */
.btn{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--font-body); font-weight:800;
  font-size:14px; letter-spacing:0.06em; text-transform:uppercase;
  padding:16px 28px; border-radius:100px;
  border:2px solid transparent;
  cursor:pointer; transition:transform .25s ease, background .25s ease, color .25s ease;
  white-space:nowrap;
}
.btn-lime{ background:var(--lime); color:var(--lime-ink); }
.btn-lime:hover{ transform:translateY(-2px); background:#d6ff5c; }
.btn-ghost{ border-color:var(--line); color:var(--ink); }
.btn-ghost:hover{ border-color:var(--lime); color:var(--lime); }
.btn .arr{ transition:transform .25s ease; }
.btn:hover .arr{ transform:translateX(4px); }

/* ---- header ---------------------------------------------- */
.site-head{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(14px);
  background:color-mix(in srgb, var(--bg) 78%, transparent);
  border-bottom:1px solid var(--line);
}
.site-head .wrap{
  display:flex; align-items:center; justify-content:space-between;
  height:74px;
}
.brand{ display:flex; align-items:center; gap:11px; }
.brand .mark{
  width:13px; height:13px; border-radius:50%;
  background:var(--lime); box-shadow:0 0 16px var(--lime);
}
.brand .name{
  font-family:var(--font-display); text-transform:uppercase;
  font-size:19px; letter-spacing:0.02em; line-height:1;
}
.brand .name small{ display:block; font-family:var(--font-body); font-weight:600; font-size:9.5px; letter-spacing:0.24em; color:var(--muted); margin-top:3px; }
.nav{ display:flex; align-items:center; gap:34px; }
.nav a{
  font-weight:700; font-size:14px; letter-spacing:0.04em;
  text-transform:uppercase; color:var(--muted);
  transition:color .2s ease; position:relative; padding:4px 0;
}
.nav a:hover, .nav a[aria-current="page"]{ color:var(--ink); }
.nav a[aria-current="page"]::after{
  content:""; position:absolute; left:0; bottom:-2px;
  width:100%; height:2px; background:var(--lime);
}
.nav-cta{ color:var(--lime-ink)!important; background:var(--lime); padding:11px 20px; border-radius:100px; }
.nav-cta:hover{ background:#d6ff5c; }
.burger{ display:none; background:none; border:0; cursor:pointer; flex-direction:column; gap:5px; padding:8px; }
.burger span{ width:24px; height:2px; background:var(--ink); display:block; }

/* ---- sections ------------------------------------------- */
section{ position:relative; }
.sec-pad{ padding-block:clamp(72px,11vw,150px); }
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; flex-wrap:wrap; margin-bottom:54px; }
.sec-head h2{ margin:0; }

/* ---- image slots ---------------------------------------- */
image-slot{
  --slot-bg: var(--bg-2);
  background:
    repeating-linear-gradient(135deg, var(--bg-2) 0 11px, var(--bg-3) 11px 22px);
  border:1px solid var(--line);
  color:var(--muted-2);
  font-family:var(--font-body); font-size:12px; letter-spacing:0.16em;
  text-transform:uppercase;
}

/* play badge overlay for video thumbnails */
.thumb{ position:relative; overflow:hidden; }
.thumb .play{
  position:absolute; inset:0; margin:auto;
  width:64px; height:64px; border-radius:50%;
  background:var(--lime); color:var(--lime-ink);
  display:flex; align-items:center; justify-content:center;
  pointer-events:none; z-index:3;
  box-shadow:0 8px 30px rgba(0,0,0,.45);
  transition:transform .3s ease;
}
.thumb:hover .play{ transform:scale(1.08); }
.thumb .play svg{ margin-left:3px; }
.thumb .tag{
  position:absolute; left:14px; top:14px; z-index:3;
  font-weight:800; font-size:11px; letter-spacing:0.1em; text-transform:uppercase;
  background:var(--bg); color:var(--ink); padding:6px 11px; border-radius:100px;
  border:1px solid var(--line);
}

/* ---- footer --------------------------------------------- */
.site-foot{ border-top:1px solid var(--line); background:var(--bg-2); }
.site-foot .wrap{ padding-block:64px 40px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:48px; }
.foot-grid h4{ font-family:var(--font-body); font-weight:800; text-transform:uppercase; letter-spacing:0.12em; font-size:12px; color:var(--muted); margin:0 0 16px; }
.foot-grid a, .foot-grid p{ color:var(--ink); margin:0 0 10px; font-weight:500; }
.foot-grid a:hover{ color:var(--lime); }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap; margin-top:54px; padding-top:24px; border-top:1px solid var(--line); color:var(--muted-2); font-size:13px; }

/* ---- marquee -------------------------------------------- */
.marquee{ overflow:hidden; border-block:1px solid var(--line); background:var(--lime); }
.marquee-track{ display:flex; gap:0; width:max-content; animation:scroll 26s linear infinite; }
.marquee-track span{
  font-family:var(--font-display); text-transform:uppercase;
  font-size:clamp(28px,4vw,46px); color:var(--lime-ink);
  padding:16px 0; line-height:1; white-space:nowrap; display:inline-flex; align-items:center;
}
.marquee-track .dot{ width:12px; height:12px; border-radius:50%; background:var(--lime-ink); margin:0 30px; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ---- reveal animation (progressive enhancement) ----------
   Base state is fully visible so content always shows even when
   the animation timeline is paused. When motion is allowed and JS
   has marked the document, below-fold items fade up on scroll. */
.reveal{ opacity:1; transform:none; }
@media (prefers-reduced-motion:no-preference){
  html.js-reveal .reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s ease; }
  html.js-reveal .reveal.in{ opacity:1; transform:none; }
}
@media (prefers-reduced-motion:reduce){
  .marquee-track{ animation:none; }
}

/* ---- mobile --------------------------------------------- */
@media (max-width:860px){
  .nav{
    position:fixed; inset:74px 0 auto 0;
    flex-direction:column; gap:0; align-items:stretch;
    background:var(--bg-2); border-bottom:1px solid var(--line);
    transform:translateY(-130%); transition:transform .35s ease; padding:10px var(--pad) 22px;
  }
  .nav.open{ transform:none; }
  .nav a{ padding:15px 0; border-bottom:1px solid var(--line); font-size:16px; }
  .nav a[aria-current="page"]::after{ display:none; }
  .nav-cta{ text-align:center; margin-top:14px; }
  .burger{ display:flex; }
  .foot-grid{ grid-template-columns:1fr; gap:34px; }
}
