:root{
  --bg:#000000;
  --ink:#ffffff;
  --ink-2:#e9e9e9;
  --mute:#6b6b6b;
  --mute-2:#3a3a3a;
  --line:rgba(255,255,255,0.08);
  --line-strong:rgba(255,255,255,0.18);
  --accent:#ff5b1a;
  --accent-dim:rgba(255,91,26,0.18);
  --display:"Tourney", "Arial Black", sans-serif;
  --mono:"JetBrains Mono", ui-monospace, monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;background:var(--bg);color:var(--ink);font-family:var(--mono);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{overflow-x:hidden}

/* ============================================================
   HERO — full-bleed cinematic video + left editorial text
   ============================================================ */
.hero{
  position:relative;
  width:100%;
  min-height:100vh;
  background:#000;
  overflow:hidden;
  isolation:isolate;
}

/* full-screen video layer */
.hero-video{
  position:absolute;inset:0;z-index:0;
  overflow:hidden;
}
.hero-video video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  /* keep face center-right on desktop */
  object-position:75% 50%;
  filter:contrast(1.05) saturate(0.9) brightness(0.92);
}
/* darkening gradient — heavier on the left where text sits */
.hero-video::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(90deg, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.7) 30%, rgba(0,0,0,0.25) 55%, rgba(0,0,0,0.15) 75%, rgba(0,0,0,0.4) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.5) 0%, transparent 18%, transparent 70%, rgba(0,0,0,0.75) 100%);
}
/* faint scanlines + vignette overlay */
.hero-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse at 50% 50%, transparent 0%, transparent 55%, rgba(0,0,0,0.45) 100%),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.015) 0 1px, transparent 1px 3px);
  mix-blend-mode:overlay;
}

/* corner crosshair markers */
.crosshair{position:absolute;width:12px;height:12px;z-index:6;pointer-events:none}
.crosshair::before,.crosshair::after{content:"";position:absolute;background:rgba(255,255,255,0.22)}
.crosshair::before{left:50%;top:0;bottom:0;width:1px;transform:translateX(-50%)}
.crosshair::after{top:50%;left:0;right:0;height:1px;transform:translateY(-50%)}
.crosshair.tl{top:24px;left:24px}
.crosshair.tr{top:24px;right:24px}
.crosshair.bl{bottom:24px;left:24px}
.crosshair.br{bottom:24px;right:24px}

/* ----- TOP BAR ----- */
.topbar{
  position:absolute;top:0;left:0;right:0;z-index:10;
  display:flex;justify-content:space-between;align-items:center;
  padding:28px clamp(20px, 4vw, 56px);
  font-family:var(--mono);font-size:11px;letter-spacing:0.22em;color:var(--mute);
  text-transform:uppercase;
}
.brandmark{display:flex;align-items:center;gap:14px}
.brandmark .dot{width:7px;height:7px;background:var(--ink);border-radius:50%;box-shadow:0 0 0 4px rgba(255,255,255,0.06)}
.brandmark .gm{font-family:var(--display);font-weight:800;font-size:13px;letter-spacing:0.12em;color:var(--ink)}
.brandmark .sep{width:28px;height:1px;background:var(--line-strong)}
.brandmark .role{color:var(--mute)}
.top-right{display:inline-flex;align-items:center;gap:12px;color:var(--ink-2)}
.top-right .live{display:inline-flex;align-items:center;gap:8px;color:var(--accent)}
.top-right .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}

/* ----- HERO CONTENT ----- */
.hero-content{
  position:relative;z-index:5;
  display:flex;align-items:flex-end;
  min-height:100vh;
  padding:120px clamp(20px, 4vw, 56px) 96px;
  max-width:1680px;margin:0 auto;
}
.hero-text{
  max-width:640px;
  display:flex;flex-direction:column;
  opacity:0;animation:rise 1s cubic-bezier(.2,.7,.2,1) .2s forwards;
}
@keyframes rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

.eyebrow{
  display:flex;align-items:center;gap:14px;
  color:var(--mute);font-size:10.5px;letter-spacing:0.3em;
  margin-bottom:28px;text-transform:uppercase;
}
.eyebrow .tick{width:18px;height:1px;background:var(--accent)}
.eyebrow b{color:var(--ink-2);font-weight:500}

.headline{
  font-family:var(--display);font-weight:800;
  font-size:clamp(48px, 7.5vw, 116px);
  line-height:0.92;letter-spacing:-0.01em;
  color:var(--ink);text-transform:uppercase;
  font-stretch:expanded;
  text-wrap:balance;
}
.headline .line{display:block}
.headline .slash{color:var(--accent);margin-left:6px}

.headline .line{opacity:0;transform:translateY(20px);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.headline .line:nth-child(1){animation-delay:.25s}
.headline .line:nth-child(2){animation-delay:.38s}
.headline .line:nth-child(3){animation-delay:.50s}

.subtext{
  margin-top:28px;max-width:440px;
  color:var(--ink-2);font-size:13px;line-height:1.65;letter-spacing:0.02em;
  opacity:0;animation:rise .9s cubic-bezier(.2,.7,.2,1) .7s forwards;
}
.subtext em{font-style:normal;color:#fff}
.subtext span.mute{color:var(--mute)}

.cta-row{
  display:flex;flex-wrap:wrap;gap:12px;align-items:center;
  margin-top:36px;
  opacity:0;animation:rise .9s cubic-bezier(.2,.7,.2,1) .85s forwards;
}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 20px;border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:0.24em;text-transform:uppercase;
  cursor:pointer;transition:all .25s ease;text-decoration:none;
  border:1px solid var(--line-strong);
  color:var(--ink);background:rgba(255,255,255,0.04);
  backdrop-filter:blur(6px);
}
.btn:hover{border-color:var(--accent);color:#000;background:var(--accent)}
.btn.primary{background:var(--ink);color:#000;border-color:var(--ink)}
.btn.primary:hover{background:var(--accent);border-color:var(--accent);color:#000}
.btn .arrow{width:14px;height:1px;background:currentColor;position:relative;display:inline-block}
.btn .arrow::after{content:"";position:absolute;right:0;top:-3px;width:7px;height:7px;border-top:1px solid currentColor;border-right:1px solid currentColor;transform:rotate(45deg)}
.btn .play{width:0;height:0;border-left:7px solid currentColor;border-top:5px solid transparent;border-bottom:5px solid transparent;display:inline-block}

/* small specs strip below CTA */
.mini-specs{
  display:flex;flex-wrap:wrap;gap:28px;
  margin-top:48px;padding-top:20px;border-top:1px solid var(--line);
  font-size:10px;letter-spacing:0.26em;text-transform:uppercase;color:var(--mute);
  opacity:0;animation:rise .9s cubic-bezier(.2,.7,.2,1) 1s forwards;
}
.mini-specs .k{color:var(--mute);display:block;margin-bottom:6px}
.mini-specs .v{color:var(--ink);font-size:11px;letter-spacing:0.18em}
.mini-specs .v .accent{color:var(--accent)}

/* ----- HERO FOOTER TICKER ----- */
.hero-foot{
  position:absolute;left:0;right:0;bottom:0;z-index:5;
  padding:18px clamp(20px, 4vw, 56px);
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:9.5px;letter-spacing:0.3em;color:var(--mute);
  text-transform:uppercase;
  border-top:1px solid var(--line);
  background:linear-gradient(180deg, transparent, rgba(0,0,0,0.7));
  backdrop-filter:blur(2px);
}
.hero-foot .mid{color:var(--ink-2)}
.hero-foot .scroll{display:inline-flex;align-items:center;gap:10px;color:var(--ink)}
.hero-foot .scroll::after{content:"";width:1px;height:18px;background:currentColor;animation:scrollPulse 1.8s ease-in-out infinite}
@keyframes scrollPulse{0%{transform:translateY(-3px);opacity:0.4}50%{transform:translateY(2px);opacity:1}100%{transform:translateY(-3px);opacity:0.4}}

/* responsive hero ---------------------------------------- */
@media (max-width: 900px){
  /* on mobile: stack — topbar, video, text content, footer */
  .hero{min-height:auto;display:flex;flex-direction:column}
  .topbar{
    position:relative;order:0;
    padding:20px 22px;background:rgba(0,0,0,0.85);
    border-bottom:1px solid var(--line);
  }
  .hero-video{
    position:relative;inset:auto;
    width:100%;height:62vh;min-height:380px;
    order:1;
  }
  .hero-video video{
    object-position:65% 50%;
    filter:contrast(1.02) saturate(0.98) brightness(1.05);
  }
  /* drop the heavy darkening gradient on mobile so the portrait stays bright */
  .hero-video::after{
    background:linear-gradient(180deg, rgba(0,0,0,0.25) 0%, transparent 20%, transparent 80%, rgba(0,0,0,0.45) 100%);
  }
  .hero-overlay{display:none}
  .crosshair{display:none}
  .hero-content{
    position:relative;order:2;
    flex-direction:column;align-items:stretch;justify-content:flex-start;
    min-height:auto;
    padding:40px 22px 56px;
    max-width:none;
  }
  .hero-text{max-width:none}
  .hero-foot{
    position:relative;order:3;
    background:rgba(0,0,0,0.85);
  }
  .headline{font-size:clamp(42px, 11vw, 72px)}
  .subtext{max-width:none}
  .mini-specs{gap:22px}
}
@media (max-width: 480px){
  .hero-foot{flex-wrap:wrap;gap:6px 12px;justify-content:flex-start}
  .hero-foot .mid{order:3;flex-basis:100%;color:var(--mute)}
  .top-right .label{display:none}
  .brandmark .role{display:none}
}

/* ============================================================
   PROJECTS SECTION
   ============================================================ */
.projects{
  position:relative;
  padding:140px 64px 160px;
  background:#000;
  border-top:1px solid var(--line);
  z-index:2;
}
.projects::before{
  content:"";position:absolute;left:0;right:0;top:-1px;height:120px;pointer-events:none;
  background:linear-gradient(180deg, rgba(0,0,0,0.95), transparent);
}

.projects-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:48px;
  max-width:1680px;margin:0 auto 72px;
}
.projects-head .left-col{max-width:780px}
.projects-eyebrow{
  display:flex;align-items:center;gap:14px;
  color:var(--mute);font-family:var(--mono);font-size:11px;letter-spacing:0.28em;
  margin-bottom:28px;text-transform:uppercase;
}
.projects-eyebrow .tick{width:18px;height:1px;background:var(--accent)}
.projects-eyebrow span:last-child{color:var(--ink-2)}

.projects-title{
  font-family:var(--display);font-weight:800;
  font-size:clamp(56px, 7vw, 112px);
  line-height:0.92;letter-spacing:-0.01em;
  text-transform:uppercase;color:var(--ink);
  font-stretch:expanded;
}
.projects-title .slash{color:var(--accent);margin-left:6px}

.projects-sub{
  margin-top:24px;max-width:520px;
  color:var(--mute);font-family:var(--mono);font-size:13px;line-height:1.65;letter-spacing:0.02em;
}
.projects-sub em{font-style:normal;color:var(--ink-2)}

.projects-meta{
  text-align:right;
  font-family:var(--mono);font-size:10px;letter-spacing:0.28em;color:var(--mute);
  line-height:1.8;text-transform:uppercase;
  flex-shrink:0;
}
.projects-meta .count{color:var(--ink);font-size:11px}
.projects-meta .accent-line{display:inline-block;width:32px;height:1px;background:var(--accent);vertical-align:middle;margin-right:10px}

.grid{
  max-width:1680px;margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px;
}

/* -------- CARD -------- */
.card{
  position:relative;
  display:flex;flex-direction:column;
  background:linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.008));
  border:1px solid var(--line-strong);
  border-radius:14px;
  overflow:hidden;
  text-decoration:none;color:inherit;
  transition:transform .45s cubic-bezier(.2,.7,.2,1), border-color .45s ease, box-shadow .45s ease, background .45s ease;
  isolation:isolate;
}
.card::before{
  content:"";position:absolute;inset:-2px;border-radius:16px;pointer-events:none;
  background:radial-gradient(60% 60% at 50% 50%, rgba(255,91,26,0.28), transparent 70%);
  opacity:0;transition:opacity .5s ease;z-index:-1;filter:blur(24px);
}
.card::after{
  content:"";position:absolute;top:10px;right:10px;width:10px;height:10px;
  border-top:1px solid rgba(255,255,255,0.25);border-right:1px solid rgba(255,255,255,0.25);
  transition:border-color .4s ease;pointer-events:none;
}

.card .media{
  position:relative;aspect-ratio:4 / 3;overflow:hidden;
  background:#070707;
  border-bottom:1px solid var(--line);
}
.card .media .placeholder{
  position:absolute;inset:0;
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
  transform-origin:center;
}
.card .media .placeholder::before{
  content:"";position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 14px),
    repeating-linear-gradient(45deg, rgba(255,255,255,0.025) 0 1px, transparent 1px 22px);
}
.card .media .placeholder::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(255,91,26,0.18), transparent 55%),
    radial-gradient(ellipse at 80% 80%, rgba(255,91,26,0.08), transparent 60%);
  mix-blend-mode:screen;
  transition:opacity .5s ease;
}

.card:nth-child(1) .placeholder{background:radial-gradient(ellipse at 35% 35%, #2a1208, #050505 70%)}
.card:nth-child(2) .placeholder{background:radial-gradient(ellipse at 60% 40%, #0a1422, #050505 70%)}
.card:nth-child(3) .placeholder{background:radial-gradient(ellipse at 50% 50%, #1b0b16, #050505 70%)}
.card:nth-child(4) .placeholder{background:radial-gradient(ellipse at 40% 60%, #0e1a10, #050505 70%)}
.card:nth-child(5) .placeholder{background:radial-gradient(ellipse at 70% 30%, #2a0a0a, #050505 70%)}
.card:nth-child(6) .placeholder{background:radial-gradient(ellipse at 50% 30%, #11131f, #050505 70%)}
.card:nth-child(7) .placeholder{background:radial-gradient(ellipse at 35% 55%, #1c1408, #050505 70%)}
.card:nth-child(8) .placeholder{background:radial-gradient(ellipse at 60% 60%, #0a1818, #050505 70%)}
.card:nth-child(9) .placeholder{background:radial-gradient(ellipse at 45% 45%, #160a1f, #050505 70%)}

.card .media-label{
  position:absolute;top:14px;left:14px;z-index:3;
  font-family:var(--mono);font-size:9.5px;letter-spacing:0.28em;color:var(--ink-2);
  background:rgba(0,0,0,0.55);backdrop-filter:blur(6px);
  border:1px solid var(--line-strong);
  padding:5px 9px;border-radius:4px;
  display:inline-flex;align-items:center;gap:8px;
  text-transform:uppercase;
}
.card .media-label .dot{width:5px;height:5px;background:var(--accent);border-radius:50%;box-shadow:0 0 8px var(--accent)}

.card .media .frame-bottom{
  position:absolute;left:14px;right:14px;bottom:12px;z-index:3;
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:9px;letter-spacing:0.28em;color:var(--mute);
}
.card .media .frame-bottom .pill{
  padding:4px 8px;border:1px solid var(--line-strong);border-radius:4px;
  background:rgba(0,0,0,0.45);color:var(--ink-2);
}

.card .body{
  padding:22px 22px 18px;
  display:flex;flex-direction:column;gap:14px;
  flex:1;
}
.card .row-meta{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:10px;letter-spacing:0.26em;color:var(--mute);
  text-transform:uppercase;
}
.card .row-meta .cat{color:var(--accent)}
.card .row-meta .idx{color:var(--ink-2)}

.card .title{
  font-family:var(--display);font-weight:700;
  font-size:24px;line-height:1.04;letter-spacing:0.01em;
  text-transform:uppercase;color:var(--ink);
}
.card .desc{
  color:var(--mute);font-family:var(--mono);font-size:12px;line-height:1.6;letter-spacing:0.02em;
  text-wrap:pretty;
}
.card .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.card .tag{
  font-family:var(--mono);font-size:9px;letter-spacing:0.22em;text-transform:uppercase;
  padding:5px 9px;border:1px solid var(--line);border-radius:999px;color:var(--ink-2);
  background:rgba(255,255,255,0.015);
}
.card .cta{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:6px;padding-top:18px;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:10px;letter-spacing:0.28em;color:var(--ink);
  text-transform:uppercase;
}
.card .cta .arrow{
  width:28px;height:28px;border-radius:50%;
  border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  transition:all .4s ease;color:var(--ink);
}
.card .cta .arrow svg{width:11px;height:11px;transition:transform .4s ease}

.card:hover{
  transform:translateY(-4px) scale(1.012);
  border-color:rgba(255,91,26,0.55);
  background:linear-gradient(180deg, rgba(255,91,26,0.04), rgba(255,255,255,0.01));
  box-shadow:
    0 30px 60px -30px rgba(0,0,0,0.9),
    0 0 0 1px rgba(255,91,26,0.25),
    0 0 80px -20px rgba(255,91,26,0.35);
}
.card:hover::before{opacity:1}
.card:hover::after{border-color:var(--accent)}
.card:hover .media .placeholder{transform:scale(1.06)}
.card:hover .media .placeholder::after{opacity:1.2}
.card:hover .cta{color:var(--accent)}
.card:hover .cta .arrow{border-color:var(--accent);background:var(--accent);color:#000}
.card:hover .cta .arrow svg{transform:translate(2px,-2px)}

.projects-foot{
  max-width:1680px;margin:96px auto 0;
  padding-top:24px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:10px;letter-spacing:0.28em;color:var(--mute-2);
  text-transform:uppercase;
}

@media (max-width: 1100px){
  .projects{padding:100px 36px 120px}
  .projects-head{flex-direction:column;align-items:flex-start;gap:32px}
  .projects-meta{text-align:left}
  .grid{grid-template-columns:repeat(2, 1fr);gap:22px}
  .projects-foot{margin-top:64px;flex-direction:column;gap:10px;align-items:flex-start}
}
@media (max-width: 640px){
  .projects{padding:80px 22px 96px}
  .grid{grid-template-columns:1fr;gap:18px}
  .card .body{padding:18px 18px 16px}
  .card .title{font-size:20px}
}

/* ============================================================
   CARD IMAGE (real project thumbnail)
   ============================================================ */
.card .media .card-image{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;
  transition:transform .6s cubic-bezier(.2,.7,.2,1), filter .4s ease;
  filter:saturate(0.95) contrast(1.05) brightness(0.92);
}
.card:hover .media .card-image{transform:scale(1.04);filter:saturate(1.05) contrast(1.1) brightness(1)}
