/*
Theme Name: Diego Balarezo Portfolio
Theme URI: https://diegobalarezo.com/
Author: Diego Balarezo
Description: Portfolio theme for Diego Balarezo, Technical Animator. Dark editorial theme with crimson accent, Anton display type, animated SVG breakdowns, custom post type for projects and a manual setup flow. All assets local, no CDN. Elementor compatible.
Version: 5.4.1
License: Private
Text Domain: diegobalarezo
*/

/* =====================================================================
   LOCAL FONTS (no CDN)
===================================================================== */
@font-face {
  font-family: 'Anton';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/anton-latin.woff2') format('woff2');
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url('fonts/jetbrainsmono-latin.woff2') format('woff2');
}
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url('fonts/manrope-latin.woff2') format('woff2');
}

/* =====================================================================
   DESIGN TOKENS
===================================================================== */
:root{
  --bg:#08080a;
  --bg-2:#0d0d10;
  --bg-3:#141418;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.16);
  --fg:#f5f5f5;
  --fg-2:#a8a8ad;
  --fg-3:#6b6b72;
  --accent:#a82020;
  --accent-2:#d4a574;
  --accent-glow:rgba(168,32,32,0.3);
  --good:#9cd6a3;
  --display:"Anton",sans-serif;
  --sans:"Manrope",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{background:#000;color:var(--fg);font-family:var(--sans);font-weight:300;-webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:hidden}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}
img{display:block;max-width:100%}

.disp{font-family:var(--display);font-weight:400;text-transform:uppercase;letter-spacing:-.01em;line-height:.92}
.mono{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase}

/* ---------- GRID BG (subtle, global) ---------- */
.grid-bg{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%);
  mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%);
}
.view{position:relative;z-index:1}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 36px;
  background:linear-gradient(180deg, rgba(8,8,10,.9), rgba(8,8,10,0) 100%);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
}
.nav.solid{background:rgba(8,8,10,.94);border-bottom:1px solid var(--line)}
.brand{
  font-family:var(--display);font-size:22px;line-height:1;cursor:pointer;
  text-transform:uppercase;letter-spacing:.02em;display:flex;align-items:center;gap:10px;
}
.brand::before{content:"";width:8px;height:8px;background:var(--accent);border-radius:50%;box-shadow:0 0 12px var(--accent-glow)}
.brand .r{color:var(--accent)}
.nav-links{display:flex;gap:28px;font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-2);font-weight:500}
.nav-links a{transition:color .2s;cursor:pointer;position:relative}
.nav-links a::before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:4px;height:4px;background:var(--fg-3);opacity:0;transition:opacity .2s}
.nav-links a:hover,.nav-links a.active{color:var(--fg)}
.nav-links a.active::before{opacity:1;background:var(--accent)}
.nav-right{display:flex;align-items:center;gap:18px}
.nav-cta{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  padding:11px 18px;border:1px solid var(--accent);color:var(--fg);
  display:flex;align-items:center;gap:10px;cursor:pointer;
  background:rgba(168,32,32,.12);transition:background .2s,box-shadow .2s;
}
.nav-cta:hover{background:var(--accent);box-shadow:0 0 24px var(--accent-glow)}
.nav-cta::after{content:"\2197"}

/* mobile nav toggle */
.nav-toggle{
  display:none;background:none;border:1px solid var(--line-2);
  color:var(--fg);width:42px;height:42px;cursor:pointer;
  align-items:center;justify-content:center;
}
.mobile-nav{
  display:none;position:fixed;top:0;left:0;right:0;z-index:99;
  flex-direction:column;gap:4px;padding:84px 22px 28px;
  background:rgba(8,8,10,.98);border-bottom:1px solid var(--line);
}
.mobile-nav.open{display:flex}
.mobile-nav a{
  font-family:var(--mono);font-size:13px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--fg-2);padding:14px 0;border-bottom:1px solid var(--line);font-weight:500;
}
.mobile-nav a:last-child{border-bottom:0}
.mobile-nav a:hover{color:var(--accent)}

@media (max-width:880px){
  .nav{padding:16px 20px}
  .nav-links{display:none}
  .nav-cta{display:none}
  .nav-toggle{display:flex}
}

/* ---------- CORNER TICKS ---------- */
.corner-ticks{position:absolute;inset:24px;pointer-events:none;z-index:8}
.corner-ticks i{position:absolute;width:16px;height:16px;border:1px solid var(--line-2)}
.corner-ticks i.tl{top:0;left:0;border-right:0;border-bottom:0}
.corner-ticks i.tr{top:0;right:0;border-left:0;border-bottom:0}
.corner-ticks i.bl{bottom:0;left:0;border-right:0;border-top:0}
.corner-ticks i.br{bottom:0;right:0;border-left:0;border-top:0}

/* ---------- HERO ---------- */
.hero{
  position:relative;min-height:100vh;overflow:hidden;
  display:flex;align-items:center;
  background:linear-gradient(180deg,#0a0a0c 0%,#06060a 100%);
  padding:96px 0 56px;
}
.hero-bg{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(70% 55% at 30% 45%, oklch(0.35 0.18 22 / 0.55), transparent 65%),
    radial-gradient(60% 50% at 80% 30%, oklch(0.32 0.10 30 / 0.4), transparent 65%);
  animation:hero-pan 18s ease-in-out infinite alternate;
}
@keyframes hero-pan{
  from{transform:scale(1.0) translate(0,0)}
  to{transform:scale(1.08) translate(-2%,-1%)}
}
.hero-grain{
  position:absolute;inset:-50%;z-index:2;pointer-events:none;opacity:.08;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' seed='5'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  animation:grain 1.6s steps(8) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)} 12%{transform:translate(-5%,3%)} 25%{transform:translate(3%,-2%)}
  38%{transform:translate(-2%,4%)} 50%{transform:translate(4%,-3%)} 62%{transform:translate(-3%,2%)}
  75%{transform:translate(2%,-4%)} 88%{transform:translate(-4%,3%)} 100%{transform:translate(0,0)}
}
.hero-scan{
  position:absolute;inset:0;z-index:3;pointer-events:none;opacity:.04;
  background:repeating-linear-gradient(180deg, transparent 0 2px, #fff 2px 3px);
  mix-blend-mode:overlay;
}
.hero-grid{
  position:absolute;inset:0;z-index:3;pointer-events:none;
  background-image:
    linear-gradient(rgba(168,32,32,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(168,32,32,.04) 1px,transparent 1px);
  background-size:48px 48px;
  -webkit-mask-image:radial-gradient(ellipse at 50% 70%, black 0%, transparent 75%);
  mask-image:radial-gradient(ellipse at 50% 70%, black 0%, transparent 75%);
}
.hero-vignette{
  position:absolute;inset:0;z-index:4;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.55) 0%, transparent 25%, transparent 55%, rgba(0,0,0,.85) 100%);
}
.hero-content{
  position:relative;z-index:10;width:100%;
  max-width:1320px;margin:0 auto;
  padding:0 56px;
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
@media (max-width:1080px){
  .hero-content{grid-template-columns:1fr;gap:48px;padding:0 22px}
}
.hero-left{display:flex;flex-direction:column;gap:24px;max-width:560px;justify-self:start}
.hero-right{display:flex;justify-content:center;align-items:center;width:100%;justify-self:center}
.hero-eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--fg-2);display:flex;align-items:center;gap:12px;font-weight:500
}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent-glow);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.55}}
.hero h1{
  font-family:var(--display);font-weight:400;text-transform:uppercase;
  font-size:clamp(48px,7.2vw,112px);line-height:.92;letter-spacing:-.02em;
}
.hero h1 .red{color:var(--accent);position:relative}
.hero h1 .out{color:transparent;-webkit-text-stroke:1.5px var(--fg-2)}
.hero-sub{
  font-size:15.5px;color:var(--fg-2);max-width:42ch;font-weight:300;line-height:1.6;
}
.hero-sub b{color:var(--fg);font-weight:600}
.hero-meta{
  display:flex;gap:24px;flex-wrap:wrap;margin-top:12px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--fg-3);font-weight:500;padding-top:24px;border-top:1px solid var(--line);
}
.hero-meta b{color:var(--fg);font-weight:600}
.hero-meta .live{color:var(--good)}
.hero-meta .live::before{content:"\25CF";color:var(--good);margin-right:6px;animation:pulse 1.6s infinite}

/* ---- VIEWPORT FRAME (right) ---- */
.vp-frame{
  position:relative;width:100%;max-width:520px;aspect-ratio:1/1;
  background:#06060a;border:1px solid var(--line-2);
  display:grid;grid-template-rows:32px 1fr 32px;
  box-shadow:0 0 0 1px rgba(168,32,32,.08), 0 30px 80px rgba(0,0,0,.6);
}
.vp-frame::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(180deg, transparent 0 2px, rgba(255,255,255,.02) 2px 3px);
  pointer-events:none;z-index:2;
}
.vp-frame::after{
  content:"";position:absolute;inset:-1px;pointer-events:none;
  background:
    linear-gradient(135deg, transparent 96%, var(--accent) 96.5%, var(--accent) 100%) top left/24px 24px no-repeat,
    linear-gradient(225deg, transparent 96%, var(--accent) 96.5%, var(--accent) 100%) top right/24px 24px no-repeat;
}
.vp-bar{
  display:flex;align-items:center;gap:14px;padding:0 14px;
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  color:var(--fg-2);background:#0a0a0d;border-bottom:1px solid var(--line);position:relative;z-index:3;
}
.vp-bar.bottom{border-bottom:0;border-top:1px solid var(--line);justify-content:space-between}
.vp-bar .red{color:var(--accent)}
.vp-bar .red::before{content:"\25CF";margin-right:6px;animation:pulse 1.6s infinite}
.vp-stage{
  position:relative;overflow:hidden;
  background:
    radial-gradient(60% 60% at 50% 50%, oklch(0.20 0.10 22 / .15), transparent 70%),
    #08080a;
}
.bs-svg{position:absolute;inset:24px;width:calc(100% - 48px);height:calc(100% - 48px)}
.bs-grid line{stroke:rgba(255,255,255,.06);stroke-width:1}
.bs-axis line{stroke:rgba(255,255,255,.25);stroke-width:1}
.bs-axis text{fill:var(--fg-3);font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase}
.bs-sample{fill:rgba(168,32,32,.4);stroke:rgba(168,32,32,.5);stroke-width:1}
.bs-puck-inner-glow{fill:var(--accent);opacity:.25}
.bs-puck-inner-core{fill:var(--accent);stroke:#fff;stroke-width:2}
.bs-cross line{stroke:rgba(168,32,32,.35);stroke-width:1;stroke-dasharray:3 3}
.vp-state-tags{
  position:absolute;left:14px;bottom:14px;z-index:3;
  display:flex;flex-direction:column;gap:6px;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--fg-3)
}
.vp-state-tags span{transition:color .3s;color:var(--fg-3)}
.vp-state-tags span.is-active{color:var(--accent)}
.vp-readout{
  position:absolute;right:14px;top:14px;z-index:3;
  display:flex;flex-direction:column;gap:4px;text-align:right;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-3);
}
.vp-readout b{color:var(--fg-2);font-weight:600}
.vp-readout .acc{color:var(--accent)}

.hero-watch{
  position:absolute;left:50%;bottom:24px;transform:translateX(-50%);z-index:20;
  display:flex;align-items:center;gap:14px;cursor:pointer;
  padding:12px 18px 12px 14px;border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  transition:border-color .2s,background .2s;
}
.hero-watch:hover{border-color:var(--accent);background:rgba(168,32,32,.18)}
.hero-watch .play{
  width:28px;height:28px;border-radius:50%;background:var(--accent);
  display:flex;align-items:center;justify-content:center;box-shadow:0 0 14px var(--accent-glow);
}
.hero-watch .play::after{
  content:"";width:0;height:0;border-style:solid;border-width:6px 0 6px 10px;
  border-color:transparent transparent transparent #fff;margin-left:2px;
}

/* ---------- STATS STRIP ---------- */
.stats{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:repeat(4,1fr);
  background:var(--bg-2);
}
@media (max-width:880px){ .stats{grid-template-columns:repeat(2,1fr)} }
.stat{padding:36px 32px;border-right:1px solid var(--line);position:relative}
.stat::before{content:"";position:absolute;top:0;left:0;width:32px;height:1px;background:var(--accent)}
.stat:last-child{border-right:0}
.stat .k{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);margin-bottom:18px;font-weight:500}
.stat .v{font-family:var(--display);font-size:64px;line-height:.95;letter-spacing:-.02em;color:var(--accent);text-transform:uppercase}
.stat .v.small{font-size:42px;color:var(--fg)}
.stat .d{margin-top:10px;font-size:13px;color:var(--fg-2);font-weight:300}
@media (max-width:880px){
  .stat{padding:24px 22px}
  .stat:nth-child(2){border-right:0}
  .stat:nth-child(-n+2){border-bottom:1px solid var(--line)}
  .stat .v{font-size:48px}
  .stat .v.small{font-size:30px}
}

/* ---------- SECTION HEAD ---------- */
.section-head{
  padding:104px 56px 48px;
  display:grid;grid-template-columns:240px 1fr auto;gap:48px;align-items:end;
  position:relative;
}
@media (max-width:880px){ .section-head{grid-template-columns:1fr;padding:72px 22px 32px} }
.section-num{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500;
}
.section-num b{color:var(--accent);font-weight:700}
.section-num::before{content:"";display:block;width:32px;height:1px;background:var(--accent);margin-bottom:18px}
.section-title{
  font-family:var(--display);font-weight:400;text-transform:uppercase;
  font-size:clamp(48px,6.4vw,96px);line-height:.95;letter-spacing:-.015em;max-width:14ch;
}
.section-title .red{color:var(--accent)}
.section-title .out{color:transparent;-webkit-text-stroke:1.5px var(--fg-2)}
.section-link{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  color:var(--fg-2);display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  transition:color .2s,gap .2s;padding:10px 0;border-bottom:1px solid var(--line-2);
}
.section-link:hover{color:var(--accent);gap:14px;border-color:var(--accent)}
.section-link::after{content:"\2192"}

/* ---------- FEATURED PROJECT ---------- */
.featured{
  padding:24px 56px 72px;
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
  max-width:1320px;margin:0 auto;align-items:stretch;
}
@media (max-width:880px){ .featured{grid-template-columns:1fr;padding:24px 22px 56px;gap:32px} }
.featured-clip{
  position:relative;aspect-ratio:4/3;overflow:hidden;
  background:linear-gradient(135deg, #1a0e10 0%, #08080a 60%, #0a0d18 100%);
  cursor:pointer;border:1px solid var(--line);display:block;
}
.featured-clip img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;opacity:.85}
.featured-info{
  display:flex;flex-direction:column;justify-content:space-between;gap:18px;min-width:0;padding:8px 0;
}
.featured-clip::before{
  content:"";position:absolute;inset:0;z-index:2;
  background:
    radial-gradient(40% 80% at 30% 50%, oklch(0.40 0.20 22 / 0.35), transparent 60%),
    radial-gradient(50% 60% at 75% 60%, oklch(0.30 0.10 200 / 0.25), transparent 60%);
}
.featured-clip::after{
  content:"";position:absolute;inset:0;z-index:3;
  background:repeating-linear-gradient(180deg, transparent 0 2px, rgba(255,255,255,.03) 2px 3px),
             linear-gradient(180deg, transparent 60%, rgba(0,0,0,.55) 100%);
  pointer-events:none;
}
.featured-clip .play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5;
  width:84px;height:84px;border-radius:50%;border:1.5px solid rgba(255,255,255,.7);
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.35);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  transition:transform .2s,background .2s,border-color .2s;
}
.featured-clip:hover .play{transform:translate(-50%,-50%) scale(1.06);background:var(--accent);border-color:var(--accent);box-shadow:0 0 30px var(--accent-glow)}
.featured-clip .play::after{content:"";width:0;height:0;border-style:solid;border-width:11px 0 11px 17px;border-color:transparent transparent transparent #fff;margin-left:4px}
.featured-clip .label{
  position:absolute;top:18px;left:20px;z-index:5;
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.85);font-weight:600;
  padding:5px 9px;border:1px solid rgba(255,255,255,.18);background:rgba(0,0,0,.4);
}
.featured-clip .label b{color:var(--accent)}
.featured-info .meta{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500}
.featured-info .meta b{color:var(--accent);font-weight:700}
.featured-info h3{
  font-family:var(--display);font-weight:400;text-transform:uppercase;
  font-size:clamp(40px,4.5vw,68px);line-height:.9;letter-spacing:-.02em;word-break:break-word;
}
.featured-info h3 .red{color:var(--accent)}
.featured-info h3 .out{color:transparent;-webkit-text-stroke:1.5px var(--fg-2)}
.featured-info p{font-size:15.5px;color:var(--fg-2);max-width:44ch;font-weight:300;line-height:1.65;margin:0}
.featured-info .role{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-2);font-weight:500;
  padding-top:14px;border-top:1px solid var(--line-2);margin:0;
}
.featured-info .role b{color:var(--fg);font-weight:700}
.featured-info .open{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;
  color:var(--accent);cursor:pointer;width:fit-content;padding:14px 22px;
  border:1px solid var(--accent);background:rgba(168,32,32,.08);align-self:start;white-space:nowrap;
  transition:gap .2s,background .2s
}
.featured-info .open:hover{gap:18px;background:var(--accent);color:#fff;box-shadow:0 0 20px var(--accent-glow)}
.featured-info .open::after{content:"\2192"}

/* ---------- PROJECT GRID ---------- */
.proj-grid{
  padding:24px 56px 104px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:48px 28px;
}
@media (max-width:980px){ .proj-grid{grid-template-columns:repeat(2,1fr);padding:24px 22px 72px} }
@media (max-width:640px){ .proj-grid{grid-template-columns:1fr} }
.pcard{cursor:pointer;display:flex;flex-direction:column;gap:18px;padding:0;border:1px solid var(--line);background:var(--bg-2);transition:border-color .25s,transform .35s}
.pcard:hover{border-color:var(--line-2);transform:translateY(-3px)}
.pcard .thumb{
  position:relative;aspect-ratio:16/9;overflow:hidden;
  background:#0e0e10;border:0;
}
.pcard:hover .thumb{transform:none}
.pcard .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;transition:transform .5s ease}
.pcard:hover .thumb img{transform:scale(1.04)}
.pcard .thumb::after{
  content:"";position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg, transparent 40%, rgba(0,0,0,.75) 100%);
  pointer-events:none;
}
.pcard .thumb .meta{
  position:absolute;left:16px;right:16px;bottom:14px;z-index:5;
  display:flex;justify-content:space-between;align-items:flex-end;color:#fff;
}
.pcard .thumb .meta .num{font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:rgba(255,255,255,.75);font-weight:500}
.pcard .thumb .meta .eng{
  font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  padding:4px 8px;border:1px solid rgba(255,255,255,.28);color:rgba(255,255,255,.95);background:rgba(0,0,0,.45);
}
.pcard .thumb .play-mini{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.85);z-index:6;
  width:60px;height:60px;border-radius:50%;border:1.5px solid rgba(255,255,255,.65);
  background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .25s, transform .25s,background .25s,border-color .25s;
}
.pcard:hover .play-mini{opacity:1;transform:translate(-50%,-50%) scale(1)}
.pcard .thumb:hover .play-mini{background:var(--accent);border-color:var(--accent)}
.pcard .play-mini::after{content:"";width:0;height:0;border-style:solid;border-width:8px 0 8px 12px;border-color:transparent transparent transparent #fff;margin-left:3px}

/* INFO: title, role/studio, description, tags */
.pcard .info{display:flex;flex-direction:column;gap:8px;padding:18px 20px 22px}
.pcard .info .top{display:flex;justify-content:space-between;align-items:baseline;gap:12px;font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500;margin-bottom:2px}
.pcard .info .top .studio{color:var(--accent-2);font-weight:700}
.pcard .info .top .role-mini{color:var(--fg-3);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:50%}
.pcard .info h3{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:30px;line-height:.95;letter-spacing:-.01em;color:var(--fg)}
.pcard .info h3 .red{color:var(--accent)}
.pcard .info h3 .out{color:transparent;-webkit-text-stroke:1px var(--fg-2)}
.pcard .info .role{font-size:13px;color:var(--fg-2);font-weight:400;margin-top:2px}
.pcard .info .desc{font-size:13.5px;color:var(--fg-2);font-weight:300;line-height:1.55;margin-top:6px}
.pcard .info .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px;padding-top:14px;border-top:1px solid var(--line)}
.pcard .info .tags span{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;padding:4px 8px;border:1px solid var(--line-2);color:var(--fg-2);font-weight:500}
.pcard .info .tags .more{color:var(--accent);border-color:var(--accent);background:rgba(168,32,32,.08)}

.thumb::before{
  content:"";position:absolute;inset:0;z-index:3;
  background:repeating-linear-gradient(180deg, transparent 0 2px, rgba(255,255,255,.025) 2px 3px);
  mix-blend-mode:overlay;pointer-events:none;
}

/* ---------- BREAKDOWNS ---------- */
.breakdowns{
  padding:24px 56px 104px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--line);margin:0 56px;
}
@media (max-width:980px){ .breakdowns{grid-template-columns:1fr;margin:0 22px;padding:0 0 72px} }
.bd{padding:32px 28px 36px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);position:relative}
.bd::before{content:"";position:absolute;top:0;left:0;width:24px;height:1px;background:var(--accent)}
.bd:nth-child(3n){border-right:0}
.bd:nth-last-child(-n+3){border-bottom:0}
@media (max-width:980px){
  .bd{border-right:0;border-bottom:1px solid var(--line)}
  .bd:nth-child(3n){border-right:0}
  .bd:last-child{border-bottom:0}
  .bd:nth-last-child(-n+3){border-bottom:1px solid var(--line)}
  .bd:last-child{border-bottom:0}
}
.bd .num{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);margin-bottom:14px;font-weight:500}
.bd .num b{color:var(--accent);font-weight:700}
.bd h3{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:26px;line-height:.95;margin-bottom:12px;letter-spacing:-.01em}
.bd h3 .red{color:var(--accent)}
.bd p{font-size:13.5px;color:var(--fg-2);margin-bottom:18px;font-weight:300;line-height:1.6}
.bd .viz{
  position:relative;aspect-ratio:16/10;border:1px solid var(--line);
  background:#0a0a0d;overflow:hidden;margin-top:18px;
}
.bd .viz::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(180deg, transparent 0 2px, rgba(255,255,255,.02) 2px 3px);
}
.bd .viz svg{position:absolute;inset:0;width:100%;height:100%}
.bd .viz .tag-mini{position:absolute;left:10px;top:10px;font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--fg-3);text-transform:uppercase;z-index:5;font-weight:600}
.bd .viz .tag-mini b{color:var(--accent);font-weight:700}
.bd .tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:16px}
.bd .tags span{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;padding:4px 9px;border:1px solid var(--line-2);color:var(--fg-2);font-weight:500}

/* ===== visualization stylings ===== */
.vz-bs .grid line{stroke:rgba(255,255,255,.06);stroke-width:1}
.vz-bs .sample{fill:rgba(168,32,32,.4)}
.vz-bs .puck-glow{fill:var(--accent);opacity:.25;animation:bs-mini 8s ease-in-out infinite}
.vz-bs .puck-core{fill:var(--accent);stroke:#fff;stroke-width:1.5;animation:bs-mini 8s ease-in-out infinite}
@keyframes bs-mini{
  0%,100%{transform:translate(100px,65px)}
  20%{transform:translate(55px,90px)}
  40%{transform:translate(145px,40px)}
  60%{transform:translate(55px,35px)}
  80%{transform:translate(155px,95px)}
}
.vz-layers .lane{stroke:rgba(255,255,255,.08);stroke-width:1}
.vz-layers .bar{fill:rgba(168,32,32,.55);transform-origin:0 50%}
.vz-layers .bar.a{animation:layer-a 4s ease-in-out infinite}
.vz-layers .bar.b{animation:layer-b 4s ease-in-out infinite}
.vz-layers .bar.c{animation:layer-c 4s ease-in-out infinite}
.vz-layers .bar.d{animation:layer-d 4s ease-in-out infinite}
@keyframes layer-a{0%,100%{transform:scaleX(.6)}50%{transform:scaleX(1)}}
@keyframes layer-b{0%,100%{transform:scaleX(.4)}30%{transform:scaleX(.9)}70%{transform:scaleX(.55)}}
@keyframes layer-c{0%,100%{transform:scaleX(.7)}40%{transform:scaleX(.3)}}
@keyframes layer-d{0%,100%{transform:scaleX(.5)}25%{transform:scaleX(.95)}75%{transform:scaleX(.25)}}
.vz-layers .label{fill:var(--fg-3);font-family:var(--mono);font-size:8px;letter-spacing:.16em;text-transform:uppercase}
.vz-modular .skel{stroke:var(--accent);stroke-width:1.5;fill:none;opacity:.4}
.vz-modular .skel.center{opacity:1;stroke-width:2}
.vz-modular .joint{fill:var(--accent)}
.vz-modular .arrow{stroke:var(--fg-3);stroke-width:1;stroke-dasharray:3 3;fill:none;opacity:.6;animation:arr-flow 3s linear infinite}
@keyframes arr-flow{from{stroke-dashoffset:0}to{stroke-dashoffset:-12}}
.vz-ai .node{fill:#0a0a0d;stroke:var(--accent);stroke-width:1.5}
.vz-ai .node.active{fill:var(--accent)}
.vz-ai .edge{stroke:rgba(168,32,32,.3);stroke-width:1.5;fill:none}
.vz-ai .pulse{fill:var(--accent);filter:drop-shadow(0 0 6px var(--accent));opacity:0;animation:ai-travel 5s linear infinite}
@keyframes ai-travel{
  0%   {opacity:0;transform:translate(80px, 30px)}
  10%  {opacity:1}
  30%  {transform:translate(180px, 30px)}
  40%  {opacity:0;transform:translate(180px, 30px)}
  45%  {opacity:1;transform:translate(180px, 80px)}
  65%  {transform:translate(80px, 80px)}
  75%  {opacity:0;transform:translate(80px, 80px)}
  100% {opacity:0;transform:translate(80px, 30px)}
}
.vz-ai .lbl{fill:var(--fg-3);font-family:var(--mono);font-size:8px;letter-spacing:.14em;text-transform:uppercase}
.vz-cloth .chain{stroke:var(--accent);stroke-width:2;fill:none;transform-origin:140px 20px;transform-box:view-box;animation:cloth-swing 3.5s ease-in-out infinite}
.vz-cloth .knot{fill:var(--accent);transform-origin:140px 20px;transform-box:view-box;animation:cloth-swing 3.5s ease-in-out infinite}
.vz-cloth .anchor{fill:var(--fg-3)}
@keyframes cloth-swing{0%,100%{transform:rotate(-18deg)}50%{transform:rotate(18deg)}}
.vz-retarget .skel{stroke:var(--accent);stroke-width:1.5;fill:none}
.vz-retarget .skel.dim{opacity:.45}
.vz-retarget .joint{fill:var(--accent)}
.vz-retarget .map{stroke:var(--accent);stroke-width:1;stroke-dasharray:2 4;fill:none;animation:retarget-flow 1.5s linear infinite}
@keyframes retarget-flow{from{stroke-dashoffset:0}to{stroke-dashoffset:-12}}
.vz-retarget .joint.pulse{animation:joint-pulse 1.6s ease-in-out infinite}
@keyframes joint-pulse{0%,100%{opacity:.4}50%{opacity:1}}

/* ---------- ABOUT ---------- */
.about{
  padding:120px 56px;border-top:1px solid var(--line);
  display:grid;grid-template-columns:240px 1fr 1fr;gap:64px;background:var(--bg-2);
}
@media (max-width:980px){ .about{grid-template-columns:1fr;padding:80px 22px;gap:36px} }
.about .num{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500}
.about .num b{color:var(--accent);font-weight:700}
.about .num::before{content:"";display:block;width:32px;height:1px;background:var(--accent);margin-bottom:18px}
.about .head{
  font-family:var(--display);font-weight:400;text-transform:uppercase;
  font-size:clamp(40px,5.2vw,76px);line-height:.95;letter-spacing:-.015em
}
.about .head .red{color:var(--accent)}
.about .head .out{color:transparent;-webkit-text-stroke:1.5px var(--fg-2)}
.about .body{display:flex;flex-direction:column;gap:18px;color:var(--fg-2);font-size:16px;max-width:48ch;font-weight:300;line-height:1.65}
.about .body b{color:var(--fg)}
.about .body .sig{
  margin-top:24px;font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-3);font-weight:500;
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-top:18px;border-top:1px solid var(--line)
}
.about .body .sig b{color:var(--fg);font-weight:700}
.about .stack{display:flex;flex-direction:column;gap:12px;border-left:1px solid var(--line);padding-left:40px}
@media (max-width:980px){ .about .stack{border-left:0;padding-left:0;border-top:1px solid var(--line);padding-top:32px} }
.about .stack .label{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:10px;font-weight:700}
.about .stack .row{display:flex;gap:18px;align-items:baseline;padding:8px 0;border-bottom:1px dashed var(--line)}
.about .stack .row:last-child{border-bottom:0}
.about .stack .row .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-2);font-weight:600;min-width:88px}
.about .stack .row .v{color:var(--fg-2);font-size:14.5px;font-weight:300}

/* ---------- CONTACT CTA ---------- */
.contact{
  position:relative;padding:140px 56px 160px;border-top:1px solid var(--line);
  background:
    radial-gradient(70% 80% at 50% 50%, var(--accent-glow), transparent 70%),
    linear-gradient(180deg,#0a0a0c,#08080a);
  overflow:hidden;
}
.contact::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(168,32,32,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(168,32,32,.05) 1px,transparent 1px);
  background-size:48px 48px;
  -webkit-mask-image:radial-gradient(ellipse at center,black 0%,transparent 70%);
  mask-image:radial-gradient(ellipse at center,black 0%,transparent 70%);
}
@media (max-width:880px){ .contact{padding:96px 22px 120px} }
.contact .num{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);margin-bottom:36px;font-weight:500;position:relative;z-index:2}
.contact .num b{color:var(--accent);font-weight:700}
.contact h2{
  position:relative;z-index:2;
  font-family:var(--display);font-weight:400;text-transform:uppercase;
  font-size:clamp(72px,10vw,180px);line-height:.9;letter-spacing:-.025em;max-width:14ch;
}
.contact h2 .red{color:var(--accent);position:relative}
.contact h2 .red::after{
  content:"";position:absolute;left:0;right:-8px;bottom:.1em;height:.18em;background:var(--accent);opacity:.18;z-index:-1;
}
.contact h2 .out{color:transparent;-webkit-text-stroke:1.5px var(--fg-2)}
.contact .links{
  position:relative;z-index:2;
  margin-top:64px;display:flex;flex-wrap:wrap;gap:14px;
}
.contact .links a{
  font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  padding:16px 24px;border:1px solid var(--line-2);
  display:inline-flex;align-items:center;gap:12px;
  transition:border-color .2s,background .2s,color .2s,box-shadow .2s;
}
.contact .links a:hover{border-color:var(--accent);background:rgba(168,32,32,.12);color:var(--fg)}
.contact .links a.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.contact .links a.primary:hover{background:transparent;color:var(--accent);box-shadow:0 0 24px var(--accent-glow)}
.contact .links a::after{content:"\2197"}

/* ---------- FOOTER ---------- */
.site-footer{
  border-top:1px solid var(--line);padding:36px 56px;
  display:flex;justify-content:space-between;align-items:center;background:#06060a;gap:18px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500;
}
@media (max-width:880px){ .site-footer{padding:28px 22px;flex-direction:column;gap:14px;align-items:flex-start} }
.site-footer b{color:var(--fg-2);font-weight:700}
.site-footer .red{color:var(--accent)}
.site-footer .foot-social{display:flex;gap:14px}
.site-footer .foot-social a{color:var(--fg-3);transition:color .2s;display:flex}
.site-footer .foot-social a:hover{color:var(--accent)}

/* =====================================================================
   INNER PAGE TEMPLATES (Portfolio / About / Community / Contact / Project)
===================================================================== */
.page-wrap{padding:140px 56px 96px;max-width:1320px;margin:0 auto;position:relative;z-index:1}
@media (max-width:880px){ .page-wrap{padding:112px 22px 72px} }
.page-eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--fg-3);font-weight:500;
  display:flex;align-items:center;gap:12px;margin-bottom:22px;
}
.page-eyebrow::before{content:"";width:32px;height:1px;background:var(--accent)}
.page-title{
  font-family:var(--display);font-weight:400;text-transform:uppercase;
  font-size:clamp(52px,8vw,120px);line-height:.92;letter-spacing:-.02em;margin-bottom:24px;
}
.page-title .red{color:var(--accent)}
.page-title .out{color:transparent;-webkit-text-stroke:1.5px var(--fg-2)}
.page-lead{font-size:16.5px;color:var(--fg-2);max-width:54ch;font-weight:300;line-height:1.7}

/* Portfolio archive grid (reuses pcard) */
.portfolio-archive{
  margin-top:64px;display:grid;grid-template-columns:repeat(3,1fr);gap:48px 28px;
}
@media (max-width:980px){ .portfolio-archive{grid-template-columns:repeat(2,1fr)} }
@media (max-width:640px){ .portfolio-archive{grid-template-columns:1fr} }

/* About page */
.about-page{margin-top:56px;display:grid;grid-template-columns:1.3fr 1fr;gap:64px}
@media (max-width:980px){ .about-page{grid-template-columns:1fr;gap:40px} }
.about-page .prose{display:flex;flex-direction:column;gap:20px;color:var(--fg-2);font-size:16.5px;font-weight:300;line-height:1.75;max-width:56ch}
.about-page .prose b{color:var(--fg);font-weight:600}
.highlights{margin-top:36px;display:grid;gap:2px;background:var(--line)}
.highlight-item{
  display:flex;align-items:center;gap:16px;padding:20px 22px;background:var(--bg-2);
  font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-2);font-weight:500;
}
.highlight-item svg{color:var(--accent);flex-shrink:0}
.about-aside{border-left:1px solid var(--line);padding-left:40px}
@media (max-width:980px){ .about-aside{border-left:0;padding-left:0;border-top:1px solid var(--line);padding-top:36px} }
.about-aside .label{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:18px;font-weight:700}
.about-aside .row{display:flex;justify-content:space-between;gap:18px;padding:12px 0;border-bottom:1px dashed var(--line);font-size:14px;color:var(--fg-2)}
.about-aside .row:last-of-type{border-bottom:0}
.about-aside .row .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-3);font-weight:600}
.connect-block{margin-top:36px}
.connect-block .label{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;font-weight:700}
.connect-links{display:flex;flex-wrap:wrap;gap:10px}
.connect-links a{
  display:inline-flex;align-items:center;gap:10px;padding:12px 18px;border:1px solid var(--line-2);
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--fg-2);
  transition:border-color .2s,background .2s,color .2s;
}
.connect-links a:hover{border-color:var(--accent);background:rgba(168,32,32,.12);color:var(--fg)}

/* Community page */
.community-cta{margin-top:32px;display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;
  padding:16px 26px;border:1px solid var(--accent);background:var(--accent);color:#fff;
  transition:background .2s,color .2s,box-shadow .2s;
}
.community-cta:hover{background:transparent;color:var(--accent);box-shadow:0 0 24px var(--accent-glow)}
.community-cta::after{content:"\2197"}
.community-topics{
  margin-top:72px;display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line);
}
@media (max-width:880px){ .community-topics{grid-template-columns:1fr} }
.topic-item{
  display:flex;align-items:center;gap:16px;padding:30px 26px;background:var(--bg-2);position:relative;
}
.topic-item::before{content:"";position:absolute;top:0;left:0;width:24px;height:1px;background:var(--accent)}
.topic-item svg{color:var(--accent);flex-shrink:0}
.topic-item .topic-label{font-family:var(--display);font-size:21px;text-transform:uppercase;letter-spacing:-.01em;line-height:1}

/* Contact page */
.contact-list{margin-top:56px;display:grid;gap:2px;background:var(--line);max-width:640px}
.contact-item{
  display:flex;align-items:center;gap:20px;padding:26px 26px;background:var(--bg-2);
  transition:background .2s;position:relative;
}
.contact-item::before{content:"";position:absolute;top:0;left:0;width:24px;height:1px;background:var(--accent)}
.contact-item:hover{background:var(--bg-3)}
.contact-item svg{color:var(--accent);flex-shrink:0}
.contact-item .contact-label{font-family:var(--display);font-size:24px;text-transform:uppercase;letter-spacing:-.01em;line-height:1;margin-bottom:4px}
.contact-item .contact-desc{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-3);font-weight:500}

/* ===== PROJECT DETAIL ===== */
.pd-hero{
  position:relative;height:84vh;min-height:560px;overflow:hidden;
  background:
    radial-gradient(60% 80% at 25% 50%, rgba(168,32,32,.35), transparent 65%),
    radial-gradient(50% 60% at 80% 40%, rgba(212,165,116,.18), transparent 65%),
    linear-gradient(180deg, #0a0608 0%, #06060a 100%);
  display:flex;align-items:flex-end;
}
.pd-hero .pd-hero-img{
  position:absolute;inset:-4%;width:108%;height:108%;object-fit:cover;z-index:0;
  opacity:.55;filter:blur(8px) saturate(1.1);
}
.pd-hero::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    repeating-linear-gradient(180deg, transparent 0 2px, rgba(255,255,255,.03) 2px 3px),
    radial-gradient(60% 80% at 30% 50%, rgba(168,32,32,.18), transparent 65%),
    linear-gradient(180deg, rgba(0,0,0,.3) 0%, transparent 35%, rgba(0,0,0,.85) 100%);
}
.pd-hero-content{position:relative;z-index:5;padding:0 56px 64px;width:100%}
@media (max-width:880px){ .pd-hero-content{padding:0 22px 48px} }
.pd-back{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  color:var(--fg-2);margin-bottom:32px;transition:color .2s,gap .2s
}
.pd-back::before{content:"\2190"}
.pd-back:hover{color:var(--accent);gap:14px}
.pd-eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--fg-2);font-weight:500;
  margin-bottom:22px;display:flex;gap:14px;align-items:center;flex-wrap:wrap;
}
.pd-eyebrow b{color:var(--accent);font-weight:700}
.pd-eyebrow span+span::before{content:"\00B7";margin-right:14px;color:var(--fg-3)}
.pd-title{
  font-family:var(--display);font-weight:400;text-transform:uppercase;
  font-size:clamp(56px,10vw,140px);line-height:.9;letter-spacing:-.025em;max-width:18ch
}
.pd-title .red{color:var(--accent)}

.pd-meta{
  padding:36px 56px;border-bottom:1px solid var(--line);background:var(--bg-2);
  display:grid;grid-template-columns:repeat(5,1fr);gap:24px;position:relative;z-index:1;
}
@media (max-width:980px){ .pd-meta{grid-template-columns:repeat(2,1fr);padding:28px 22px;gap:18px} }
.pd-meta .item .k{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);margin-bottom:8px;font-weight:500}
.pd-meta .item .v{font-size:15.5px;color:var(--fg);font-weight:500}
.pd-meta .item .v a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;display:inline-flex;align-items:center;gap:5px}

.pd-section{padding:64px 56px;border-top:1px solid var(--line);position:relative;z-index:1}
@media (max-width:880px){ .pd-section{padding:48px 22px} }
.pd-section-grid{display:grid;grid-template-columns:240px 1fr;gap:64px}
@media (max-width:980px){ .pd-section-grid{grid-template-columns:1fr;gap:24px} }
.pd-num{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500}
.pd-num b{color:var(--accent);font-weight:700}
.pd-num::before{content:"";display:block;width:32px;height:1px;background:var(--accent);margin-bottom:18px}
.pd-section h2{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(32px,4vw,56px);line-height:.95;letter-spacing:-.015em;margin-bottom:24px}
.pd-section h2 .red{color:var(--accent)}
.pd-body{display:flex;flex-direction:column;gap:20px}
.pd-body p{font-size:16px;color:var(--fg-2);max-width:60ch;font-weight:300;line-height:1.7}
.video-container{
  position:relative;aspect-ratio:16/9;overflow:hidden;border:1px solid var(--line);background:#0a0a0d;
}
.video-container iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

.checklist{display:flex;flex-direction:column;gap:2px;background:var(--line);margin-top:8px}
.checklist li{
  display:flex;align-items:flex-start;gap:14px;padding:16px 18px;background:var(--bg-2);
  font-size:14.5px;color:var(--fg-2);font-weight:300;line-height:1.55;list-style:none;
}
.checklist li svg{color:var(--accent);flex-shrink:0;margin-top:2px}
.pd-two-col{display:grid;grid-template-columns:1fr 1fr;gap:48px}
@media (max-width:880px){ .pd-two-col{grid-template-columns:1fr;gap:36px} }
.pd-two-col h3{font-family:var(--display);font-size:24px;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:16px}
.enemy-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.enemy-tag,.pd-tag{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  padding:6px 12px;border:1px solid var(--line-2);color:var(--fg-2);font-weight:500;
}
.pd-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px}

.pd-next{
  padding:104px 56px 120px;border-top:1px solid var(--line);
  display:grid;grid-template-columns:240px 1fr;gap:64px;align-items:end;background:var(--bg-2);position:relative;z-index:1;
}
@media (max-width:980px){ .pd-next{grid-template-columns:1fr;padding:64px 22px;gap:24px} }
.pd-next .label{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500}
.pd-next .label b{color:var(--accent);font-weight:700}
.pd-next .label::before{content:"";display:block;width:32px;height:1px;background:var(--accent);margin-bottom:18px}
.pd-next a{display:flex;justify-content:space-between;align-items:end;cursor:pointer;padding-bottom:18px;border-bottom:1px solid var(--line-2);transition:border-color .2s;gap:24px}
.pd-next a:hover{border-color:var(--accent)}
.pd-next h2{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(36px,5vw,72px);line-height:.95;letter-spacing:-.015em}
.pd-next h2 .red{color:var(--accent)}
.pd-next .arr{font-family:var(--mono);font-size:32px;color:var(--accent);font-weight:700}

/* ===== Generic Elementor / default page content ===== */
.page-content-default{padding:140px 56px 96px;max-width:900px;margin:0 auto;position:relative;z-index:1}
.page-content-default h1,.page-content-default h2,.page-content-default h3{font-family:var(--display);text-transform:uppercase;letter-spacing:-.01em;margin:1.2em 0 .5em}
.page-content-default p{color:var(--fg-2);font-weight:300;line-height:1.7;margin-bottom:1em}
.page-content-default a{color:var(--accent)}
@media (max-width:880px){ .page-content-default{padding:112px 22px 72px} }

/* ===== scroll reveal ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* ===== empty state ===== */
.empty-note{
  grid-column:1/-1;text-align:center;padding:64px 0;color:var(--fg-3);
  font-family:var(--mono);font-size:12px;letter-spacing:.06em;
}
/* =====================================================================
   v5.1 NEW COMPONENTS - Hero CTAs, Studios marquee, Featured 16:10,
   Breakdowns major/minor split, interactive blendspace hints,
   pcard variants (wide / no-video).
===================================================================== */

/* HERO CTA ROW */
.hero-cta-row{
  display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;
}
.hero-cta{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;
  padding:13px 18px;border:1px solid var(--line-2);
  transition:border-color .2s,background .2s,color .2s,box-shadow .2s,transform .15s;
  color:var(--fg);
}
.hero-cta:hover{transform:translateY(-1px)}
.hero-cta .arr{font-size:14px}
.hero-cta.primary{
  background:var(--accent);border-color:var(--accent);color:#fff;
}
.hero-cta.primary:hover{box-shadow:0 0 24px var(--accent-glow);background:#c12525}
.hero-cta.secondary{background:rgba(168,32,32,.08)}
.hero-cta.secondary:hover{border-color:var(--accent);background:rgba(168,32,32,.18)}
.hero-cta.secondary .play-dot{
  width:0;height:0;border-style:solid;border-width:5px 0 5px 8px;
  border-color:transparent transparent transparent var(--accent);
}
.hero-cta.tertiary{color:var(--fg-2)}
.hero-cta.tertiary:hover{color:var(--fg);border-color:var(--accent-2)}

/* HERO viewport hint */
.vp-hint{
  position:absolute;right:14px;bottom:14px;z-index:4;
  font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-2);opacity:.85;pointer-events:none;
  animation:hint-pulse 2.4s ease-in-out infinite;
  padding:5px 8px;background:rgba(0,0,0,.5);border:1px solid var(--line);
}
@keyframes hint-pulse{0%,100%{opacity:.5}50%{opacity:1}}
.vp-stage.is-active .vp-hint{display:none}
.vp-stage{cursor:crosshair}
.vp-stage.is-active{cursor:crosshair}
.bs-puck{transition:transform .25s cubic-bezier(.2,.7,.3,1)}
.vp-stage.is-active .bs-puck{transition:transform .08s cubic-bezier(.2,.7,.3,1)}

/* STATS - real metrics, BIG numbers */
.stat .v:not(.small){
  font-family:var(--display);font-size:84px;line-height:.95;letter-spacing:-.02em;
  color:var(--accent);
}

/* STUDIOS marquee strip */
.studios-strip{
  border-bottom:1px solid var(--line);
  background:#06060a;
  padding:18px 0;
  overflow:hidden;
  position:relative;
}
.studios-label{
  position:absolute;left:56px;top:50%;transform:translateY(-50%);z-index:3;
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);font-weight:600;
  background:linear-gradient(90deg, #06060a 0%, #06060a 80%, transparent);
  padding-right:36px;min-width:240px;
}
.studios-marquee{
  position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 18%,#000 82%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 18%,#000 82%,transparent);
}
.studios-track{
  display:flex;gap:24px;align-items:center;
  white-space:nowrap;
  animation:studios-scroll 50s linear infinite;
  padding-left:320px;
}
.studio-tag{
  font-family:var(--display);font-size:22px;letter-spacing:.01em;text-transform:uppercase;
  color:var(--fg-2);
  transition:color .2s;
}
.studio-tag:hover{color:var(--accent)}
.studio-sep{color:var(--fg-3);font-size:18px}
@keyframes studios-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
@media (max-width:880px){
  .studios-label{position:static;display:block;margin:0 22px 12px;transform:none}
  .studios-track{padding-left:22px;animation-duration:22s}
  .studio-tag{font-size:18px}
}

/* FEATURED reorganization (16:10, cleaner) */
.featured{align-items:start;gap:56px}
.featured-clip{aspect-ratio:16/10}
.featured-info{justify-content:space-between;gap:0}
.featured-head{display:flex;flex-direction:column;gap:14px}
.featured-foot{
  display:flex;align-items:end;justify-content:space-between;gap:24px;
  padding-top:28px;border-top:1px solid var(--line-2);margin-top:28px;
}
.featured-foot .role{margin:0;border:0;padding:0;flex:1;min-width:0}
.featured-foot .open{align-self:end;flex:0 0 auto}
.featured .meta{display:flex;flex-wrap:wrap;gap:0 14px;align-items:baseline;font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500}
.featured .meta .studio-name{color:var(--accent-2);font-weight:700}
.featured .meta .year{color:var(--fg-3)}
.featured .meta .year b{color:var(--accent);font-weight:700}
.featured-clip .featured-overlay{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  transition:transform .25s;
}
.featured-clip .featured-overlay .play{
  position:static;transform:none;
}
.featured-clip:hover .featured-overlay{transform:translate(-50%,-50%) scale(1.04)}
.featured-clip:hover .featured-overlay .play{background:var(--accent);border-color:var(--accent);box-shadow:0 0 30px var(--accent-glow)}
.featured-clip .watch-hint{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  color:rgba(255,255,255,.9);
  padding:5px 10px;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.45);
}

/* SHOWREEL wrapper */
.showreel-wrap{padding:0 56px 80px;max-width:1320px;margin:0 auto}
@media (max-width:880px){ .showreel-wrap{padding:0 22px 56px} }

/* BREAKDOWNS MAJOR (top 3) */
.breakdowns-major{
  padding:0 56px 64px;max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
}
@media (max-width:980px){
  .breakdowns-major{grid-template-columns:1fr;padding:0 22px 32px;gap:18px}
}
.bd-major{
  position:relative;padding:32px 26px;
  border:1px solid var(--line);background:linear-gradient(180deg,var(--bg-2),var(--bg));
  display:flex;flex-direction:column;gap:18px;
  overflow:hidden;
}
.bd-major::before{
  content:"";position:absolute;top:0;left:0;width:48px;height:2px;background:var(--accent);
}
.bd-meta{
  display:flex;align-items:start;justify-content:space-between;gap:18px;
}
.bd-meta .num{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);font-weight:500;padding-top:8px}
.bd-meta .num b{color:var(--accent);font-weight:700}
.bd-num-big{
  font-family:var(--display);font-size:64px;line-height:1;color:transparent;
  -webkit-text-stroke:1.5px var(--line-2);opacity:.85;
}
.bd-body{display:flex;flex-direction:column;gap:14px;flex:1}
.bd-body h3{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:26px;line-height:.95;letter-spacing:-.01em}
.bd-body h3 .red{color:var(--accent)}
.bd-body p{font-size:13.5px;color:var(--fg-2);font-weight:300;line-height:1.6;margin:0}
.bd-body .viz{
  position:relative;aspect-ratio:16/10;border:1px solid var(--line);
  background:#0a0a0d;overflow:hidden;margin-top:4px;
}
.bd-body .viz::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(180deg, transparent 0 2px, rgba(255,255,255,.02) 2px 3px);
}
.bd-body .viz svg{position:absolute;inset:0;width:100%;height:100%}
.bd-body .viz .tag-mini{position:absolute;left:10px;top:10px;font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--fg-3);text-transform:uppercase;z-index:5;font-weight:600}
.bd-body .viz .tag-mini b{color:var(--accent);font-weight:700}
.bd-body .tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto;padding-top:8px}
.bd-body .tags span{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;padding:4px 9px;border:1px solid var(--line-2);color:var(--fg-2);font-weight:500}

/* BREAKDOWNS MINOR (chip row) */
.breakdowns-minor{
  padding:0 56px 96px;max-width:1320px;margin:0 auto;
}
@media (max-width:980px){ .breakdowns-minor{padding:0 22px 56px} }
.bm-head{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);
  margin-bottom:18px;font-weight:600;
  padding-bottom:14px;border-bottom:1px solid var(--line);
}
.bm-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
@media (max-width:880px){ .bm-grid{grid-template-columns:1fr;gap:12px} }
.bm-card{
  display:flex;align-items:flex-start;gap:14px;
  padding:20px 22px;border:1px solid var(--line);background:var(--bg-2);
  transition:border-color .2s,background .2s;
}
.bm-card:hover{border-color:var(--line-2);background:var(--bg-3)}
.bm-icon{
  color:var(--accent);flex-shrink:0;width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--accent);background:rgba(168,32,32,.08);
}
.bm-title{
  font-family:var(--display);font-size:18px;text-transform:uppercase;letter-spacing:-.005em;
  margin-bottom:4px;
}
.bm-card p{font-size:12.5px;color:var(--fg-2);font-weight:300;line-height:1.55;margin:0}

/* PCARD: wide variant (last item when grid leaves 1 hole) - 2-col card with bigger image */
.pcard.pcard-wide{grid-column:span 2}
@media (max-width:980px){ .pcard.pcard-wide{grid-column:span 1} }
.pcard.pcard-wide .thumb{aspect-ratio:21/9}

/* PCARD: no-video variant - image gets contain layout (no awkward crop) */
.pcard.pcard-no-video .thumb{background:#0a0a0d}
.pcard.pcard-no-video .thumb img{object-fit:contain;padding:6% 10%;opacity:.92;mix-blend-mode:screen}
.pcard.pcard-no-video .thumb::before{
  background:
    radial-gradient(60% 80% at 50% 50%, rgba(168,32,32,.12), transparent 70%),
    repeating-linear-gradient(180deg, transparent 0 2px, rgba(255,255,255,.025) 2px 3px);
}


/* =====================================================================
   v5.0.1 AUDIT FIXES
   Adjustments after on-screen audit of the rendered theme.
===================================================================== */

/* --- 1. SECTION-HEAD: better balance on wide desktops ---
   Original: 240px 1fr auto with align-items:end leaves the eyebrow
   floating bottom-left far from the centered title on 1440px+.
   Fix: align-items:start, pull eyebrow up to title baseline. */
.section-head{align-items:start;padding-top:120px;padding-bottom:56px}
.section-head .section-num{padding-top:6px}
.section-head .section-link{align-self:end;padding-bottom:6px}
@media (min-width:1280px){
  .section-head{grid-template-columns:200px 1fr 200px}
}

/* --- 2. CONTACT: bigger lateral padding so the giant H2 breathes --- */
@media (min-width:1280px){
  .contact{padding:120px 96px 140px}
  .contact h2{max-width:16ch}
}

/* --- 3. CONTACT bottom padding reduced (was 160px) --- */
.contact{padding-bottom:120px}

/* --- 4. MOBILE NAV: hide community CTA already covered above ---
   See @media (max-width:880px) earlier in the file. */

/* --- 5. HERO META on mobile: single-line wrap, tighter --- */
@media (max-width:880px){
  .hero{padding:88px 0 40px;min-height:auto}
  .hero-eyebrow{font-size:9.5px;letter-spacing:.22em}
  .hero-meta{font-size:9.5px;gap:14px 18px;padding-top:18px}
  .hero-content{gap:32px}
  .hero-sub{font-size:14.5px}
  .vp-frame{max-width:100%}
}

/* --- 6. WATCH SHOWREEL: reposition on mobile so it does not overlap viewport --- */
@media (max-width:1080px){
  .hero{flex-wrap:wrap}
  .hero-content{flex:1 0 100%}
  .hero-watch{
    position:relative;left:auto;bottom:auto;transform:none;
    flex:0 0 auto;margin:24px auto 8px;
    padding:10px 16px 10px 12px;
    display:inline-flex;
  }
  .hero-watch span:not(.play){font-size:10.5px}
}

/* --- 7. PROJECT CARDS on mobile --- */
@media (max-width:640px){
  .pcard{gap:0}
  .pcard .info{padding:14px 16px 20px}
  .pcard .info h3{font-size:24px}
  .pcard .info .desc{font-size:13px}
  .pcard .info .top{flex-direction:column;align-items:flex-start;gap:4px}
  .pcard .info .top .role-mini{max-width:100%;text-align:left;white-space:normal}
  .proj-grid{gap:18px;padding-bottom:48px}
}

/* --- 8. PORTFOLIO archive: same shorter aspect on mobile --- */
@media (max-width:640px){
  .portfolio-archive{gap:32px 0}
}

/* --- 9. SECTION-HEAD on mobile: tighten vertical spacing --- */
@media (max-width:880px){
  .section-head{padding:56px 22px 24px;gap:18px}
  .section-head .section-title{font-size:clamp(40px,11vw,72px)}
  .section-head .section-link{align-self:start}
}

/* --- 10. FEATURED on mobile: tighter --- */
@media (max-width:880px){
  .featured{padding:8px 22px 48px;gap:24px}
  .featured-info h3{font-size:clamp(32px,9vw,56px)}
}

/* --- 11. BREAKDOWNS on mobile: smaller padding, no double gaps --- */
@media (max-width:980px){
  .breakdowns{margin:0 22px;padding:0 0 56px}
  .bd{padding:24px 18px 28px}
}

/* --- 12. ABOUT on mobile: tighter and smaller heading --- */
@media (max-width:980px){
  .about{padding:64px 22px;gap:28px}
  .about .head{font-size:clamp(36px,9vw,64px)}
}

/* --- 13. CONTACT on mobile: lots smaller H2 so it does not overflow --- */
@media (max-width:880px){
  .contact{padding:72px 22px 88px}
  .contact h2{font-size:clamp(54px,15vw,96px);max-width:100%}
  .contact .num{margin-bottom:24px}
  .contact .links{margin-top:36px;gap:10px}
  .contact .links a{padding:13px 18px;font-size:11px}
}

/* --- 14. PAGE WRAP titles on mobile --- */
@media (max-width:880px){
  .page-title{font-size:clamp(44px,12vw,84px)}
  .page-wrap{padding:96px 22px 56px}
  .page-lead{font-size:15px}
}

/* --- 15. PROJECT DETAIL on mobile --- */
@media (max-width:880px){
  .pd-hero{height:auto;min-height:420px;padding-top:72px}
  .pd-hero-content{padding:32px 22px 36px}
  .pd-title{font-size:clamp(44px,12vw,84px)}
  .pd-back{margin-bottom:20px}
  .pd-meta{padding:22px 22px;gap:14px}
  .pd-meta .item .v{font-size:14px}
  .pd-section{padding:40px 22px}
  .pd-section h2{font-size:clamp(28px,8vw,48px)}
  .pd-next{padding:48px 22px}
}

/* --- 16. STATS on mobile: less vertical air --- */
@media (max-width:880px){
  .stat{padding:22px 18px}
  .stat .v.small{font-size:26px}
  .stat .d{font-size:12px}
}

/* --- 17. COMMUNITY topics on mobile: more compact --- */
@media (max-width:880px){
  .community-topics{margin-top:48px}
  .topic-item{padding:22px 22px}
  .topic-item .topic-label{font-size:18px}
}


/* =====================================================================
   v5.4 FLUID RESPONSIVE LAYER
   Uses clamp() and viewport-relative units so the site scales smoothly
   across every screen size (320px to 4K+) instead of jumping at fixed
   breakpoints. This block overrides the static values above.
===================================================================== */

/* --- 1. Container width: aprovecha ultrawide sin estirar --- */
.hero-content,
.section-head,
.featured,
.breakdowns-major,
.breakdowns-minor,
.about,
.contact,
.proj-grid,
.portfolio-archive,
.showreel-wrap,
.page-wrap,
.community-topics-wrap{
  max-width: min(1480px, 94vw);
}

/* --- 2. Lateral padding fluido (en lugar de 56px fijo) --- */
.hero-content{
  padding-left: clamp(20px, 4vw, 56px);
  padding-right: clamp(20px, 4vw, 56px);
}
.featured,
.proj-grid,
.section-head,
.breakdowns-major,
.breakdowns-minor,
.about,
.showreel-wrap{
  padding-left: clamp(20px, 4vw, 56px);
  padding-right: clamp(20px, 4vw, 56px);
}
.contact{
  padding-left: clamp(22px, 6vw, 96px);
  padding-right: clamp(22px, 6vw, 96px);
}

/* --- 3. Hero h1 fluido (de muy chico a muy grande, sin saltos) --- */
.hero h1{
  font-size: clamp(48px, 9vw, 144px);
  line-height: .92;
}

/* --- 4. Section titles fluido --- */
.section-title{
  font-size: clamp(48px, 10vw, 180px);
}
.section-head{
  padding-top: clamp(64px, 8vw, 120px);
  padding-bottom: clamp(28px, 4vw, 56px);
}

/* --- 5. About head fluido --- */
.about .head{
  font-size: clamp(36px, 7vw, 120px);
}

/* --- 6. Contact h2 fluido --- */
.contact h2{
  font-size: clamp(52px, 12vw, 200px);
}

/* --- 7. Featured project title fluido --- */
.featured-info h3{
  font-size: clamp(36px, 5.5vw, 88px);
}

/* --- 8. Project card title fluido --- */
.pcard .info h3{
  font-size: clamp(22px, 2.4vw, 34px);
}

/* --- 9. Breakdown card title fluido --- */
.bd-body h3{
  font-size: clamp(22px, 2.2vw, 30px);
}
.bd-num-big{
  font-size: clamp(48px, 5vw, 76px);
}

/* --- 10. Stats numbers fluido (eran 84px) --- */
.stat .v:not(.small){
  font-size: clamp(56px, 9vw, 120px);
}
.stat{
  padding: clamp(24px, 3vw, 48px);
}

/* --- 11. Page title fluido --- */
.page-title{
  font-size: clamp(48px, 11vw, 156px);
}

/* --- 12. PD title fluido --- */
.pd-title{
  font-size: clamp(48px, 12vw, 200px);
}

/* --- 13. Studio tag size fluido en marquee --- */
.studio-tag{
  font-size: clamp(16px, 2vw, 26px);
}

/* --- 14. Marquee speed: proportional al ancho (no a breakpoints) ---
   Cuanto mas estrecha la pantalla, mas rapida la animacion para que la
   velocidad visual sea la misma. */
.studios-track{
  animation-duration: clamp(18s, 5vw, 50s);
}

/* --- 15. Hero stack breakpoint: bajado de 1080 a 900 para que iPad
   landscape (1024) mantenga las 2 columnas --- */
@media (min-width:901px){
  .hero-content{grid-template-columns: 1fr 1fr; gap: clamp(40px, 5vw, 96px)}
}
@media (max-width:900px){
  .hero-content{grid-template-columns: 1fr; gap: 40px; padding-left:22px; padding-right:22px}
}

/* --- 16. Hero left max-width fluido --- */
.hero-left{
  max-width: min(640px, 100%);
}

/* --- 17. Eyebrow: se reduce en pantallas muy estrechas para no romper --- */
.hero-eyebrow{
  font-size: clamp(9px, 1.2vw, 12px);
  letter-spacing: .22em;
}
@media (max-width:380px){
  .hero-eyebrow{font-size: 8.5px; letter-spacing:.18em}
}

/* --- 18. Hero sub fluido --- */
.hero-sub{
  font-size: clamp(13px, 1.3vw, 17px);
  line-height: 1.55;
}

/* --- 19. Hero meta fluido --- */
.hero-meta{
  font-size: clamp(9px, 1vw, 11px);
  gap: clamp(12px, 2vw, 28px);
  flex-wrap: wrap;
}

/* --- 20. CTAs fluidos --- */
.hero-cta{
  font-size: clamp(10px, 1vw, 12px);
  padding: clamp(11px, 1.2vw, 14px) clamp(14px, 1.8vw, 22px);
}

/* --- 21. Viewport / blendspace fluido en tablet portrait y desktop --- */
.vp-frame{
  width: 100%;
  max-width: min(560px, 100%);
  aspect-ratio: 1 / 1;
}

/* --- 22. Grid de proyectos: respeta 2 columnas en tablet portrait --- */
@media (min-width:600px) and (max-width:980px){
  .proj-grid{grid-template-columns: repeat(2, 1fr)}
  .pcard.pcard-wide{grid-column: span 2}
}

/* --- 23. Featured: en tablet portrait se ve mas balanceado --- */
@media (max-width:880px){
  .featured{grid-template-columns: 1fr; gap: 28px}
}
@media (min-width:881px) and (max-width:1100px){
  .featured{grid-template-columns: 1.2fr 1fr; gap: 32px}
}

/* --- 24. Breakdowns: en tablet hace 2 columnas en vez de 1 o 3 --- */
@media (min-width:760px) and (max-width:1100px){
  .breakdowns-major{grid-template-columns: repeat(2, 1fr)}
  .breakdowns-major .bd-major:last-child{grid-column: span 2}
}
@media (min-width:760px) and (max-width:1100px){
  .bm-grid{grid-template-columns: repeat(3, 1fr)}
}

/* --- 25. Studios marquee mobile: mas rapido proporcionalmente --- */
@media (max-width:600px){
  .studios-track{animation-duration: 18s}
}

/* --- 26. Stats: 4 columnas en wide, 2 en tablet, 1 en mobile chico --- */
.stats{display:grid; grid-template-columns: repeat(4, 1fr)}
@media (max-width:980px){
  .stats{grid-template-columns: repeat(2, 1fr)}
}
@media (max-width:480px){
  .stats{grid-template-columns: 1fr}
}

/* --- 27. Section-head: en wide, columnas mas balanceadas --- */
@media (min-width:1200px){
  .section-head{grid-template-columns: clamp(140px, 14vw, 220px) 1fr clamp(140px, 14vw, 220px)}
}

/* --- 28. Body min-width prevention (zoom out on very narrow) --- */
body{min-width: 320px}


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