/* =========================================================
   KEYCODEFX — long-scroll portfolio
   ========================================================= */
:root{
  --bg:#0a0a0a; --bg2:#0d0c0b; --surface:#141311; --surface2:#1b1916;
  --line:#262421; --line2:#332f2a;
  --text:#f4f2ef; --muted:#827d75; --faint:#4a4742;
  --accent:#ff5e2e; --accent-dim:#c4441f;
  --display:"Archivo",sans-serif;
  --exp:"Archivo Expanded","Archivo",sans-serif;
  --mono:"Space Mono",monospace;
  --gut:clamp(20px,4.5vw,72px);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto}
body{
  background:var(--bg);color:var(--text);font-family:var(--display);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
::selection{background:var(--accent);color:#0a0a0a}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.mono{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase}
.accent{color:var(--accent)}

/* film grain + scanline overlay */
.grain{position:fixed;inset:0;pointer-events:none;z-index:90;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* reel placeholder shared */
.reel{position:absolute;inset:0;
  background:repeating-linear-gradient(155deg,#221e1a 0 24px,#181512 24px 48px)}
.reel.h{background:repeating-linear-gradient(115deg,#221e1a 0 24px,#181512 24px 48px)}
.reel-label{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:#3a3733;text-transform:uppercase;text-align:center}
.vignette{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 95% at 50% 38%,transparent 32%,rgba(0,0,0,.6) 100%)}
.scanline{position:absolute;left:0;right:0;height:2px;top:0;z-index:3;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.55;
  animation:scan 6s linear infinite}
@keyframes scan{0%{top:-2%}100%{top:102%}}

/* ============ NAV ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px var(--gut);transition:background .4s,border-color .4s,padding .4s;
  border-bottom:1px solid transparent}
.nav.solid{background:rgba(10,10,10,.72);backdrop-filter:blur(10px);border-color:var(--line);padding:14px var(--gut)}
.nav .brand{font-family:var(--exp);font-weight:800;font-size:18px;letter-spacing:.02em;text-transform:uppercase}
.nav .brand em{font-style:normal;color:var(--accent)}
.nav .links{display:flex;gap:26px;align-items:center}
.nav .links a{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;
  transition:color .25s;position:relative}
.nav .links a:hover{color:var(--text)}
.nav .links a::after{content:"";position:absolute;left:0;right:100%;bottom:-5px;height:1px;background:var(--accent);transition:right .3s}
.nav .links a:hover::after{right:0}
.nav .status{display:none}
@media(min-width:760px){.nav .status{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--muted)}}
.nav .status .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:blink 1.6s steps(1) infinite}
@keyframes blink{50%{opacity:.2}}

/* ============ HERO ============ */
.hero{position:relative;min-height:100vh;display:grid;grid-template-columns:1.15fr .85fr}
.hero-left{padding:124px var(--gut) 76px;display:flex;flex-direction:column;justify-content:center;
  border-right:1px solid var(--line);position:relative;gap:32px}
.ticker{position:absolute;top:72px;left:0;right:0;height:36px;border-bottom:1px solid var(--line);
  border-top:1px solid var(--line);overflow:hidden;display:flex;align-items:center}
.ticker .track{display:flex;gap:42px;white-space:nowrap;animation:marq 24s linear infinite;
  font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.2em;padding-left:42px}
.ticker .track b{color:var(--accent)}
@keyframes marq{to{transform:translateX(-50%)}}
.hero-idx{font-family:var(--mono);font-size:12px;letter-spacing:.22em;color:var(--accent)}
.hero-title{font-family:var(--exp);font-weight:800;font-size:clamp(58px,9.5vw,128px);line-height:.82;
  letter-spacing:-.025em;text-transform:uppercase}
.hero-title em{font-style:normal;color:var(--accent)}
.disc{display:flex;flex-direction:column;border-top:1px solid var(--line);max-width:540px}
.disc a{display:flex;justify-content:space-between;align-items:center;padding:15px 0;
  border-bottom:1px solid var(--line);font-family:var(--mono);font-size:13px;letter-spacing:.12em;
  color:var(--muted);text-transform:uppercase;transition:color .3s,padding .3s}
.disc a .n{color:var(--accent);margin-right:18px}
.disc a .r{color:var(--faint)}
.disc a:hover{color:var(--text);padding-left:14px}
.disc a:hover .r{color:var(--text)}
.hero-right{position:relative;overflow:hidden}
.hero-right .reel-inner{position:absolute;inset:-8%;will-change:transform}
.hero-hud{position:absolute;inset:0;padding:80px 28px 28px;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}
.hero-hud .top{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--muted)}
.hero-hud .rec{display:inline-flex;align-items:center;gap:7px}
.hero-hud .rec .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:blink 1.4s steps(1) infinite}
.hero-hud .bottom{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--muted)}
.hero-scrub{position:absolute;left:28px;right:28px;bottom:24px;height:2px;background:#2a2724}
.hero-scrub i{position:absolute;left:0;top:0;height:100%;background:var(--accent);box-shadow:0 0 10px var(--accent);width:2%}
.scrollcue{position:absolute;left:var(--gut);bottom:26px;font-family:var(--mono);font-size:11px;
  letter-spacing:.2em;color:var(--muted);display:flex;align-items:center;gap:10px}
.scrollcue .bar{width:1px;height:30px;background:linear-gradient(var(--accent),transparent);animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

@media(max-width:860px){
  .hero{grid-template-columns:1fr}
  .hero-left{border-right:none;padding-top:120px;padding-bottom:40px;gap:28px}
  .hero-right{min-height:62vh;border-top:1px solid var(--line)}
  .scrollcue{display:none}
}

/* ============ STRIP MARQUEE ============ */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;
  background:var(--bg2);padding:18px 0}
.strip .track{display:flex;gap:44px;white-space:nowrap;will-change:transform}
.strip .track span{font-family:var(--exp);font-weight:800;font-size:clamp(20px,2.6vw,34px);
  text-transform:uppercase;letter-spacing:-.01em;color:var(--text);opacity:.18}
.strip .track b{color:var(--accent);opacity:1;font-weight:800}

/* ============ ABOUT ============ */
.about{padding:clamp(90px,14vh,180px) var(--gut);position:relative}
.section-tag{font-family:var(--mono);font-size:12px;letter-spacing:.24em;color:var(--accent);
  text-transform:uppercase;display:flex;align-items:center;gap:14px;margin-bottom:50px}
.section-tag::before{content:"";width:34px;height:1px;background:var(--accent)}
.statement{font-family:var(--exp);font-weight:700;font-size:clamp(30px,4.6vw,68px);line-height:1.04;
  letter-spacing:-.02em;max-width:18ch}
/* masked line reveal */
.reveal-line{display:block;overflow:hidden}
.reveal-line>span{display:block;transform:translateY(110%);transition:transform .9s cubic-bezier(.16,1,.3,1)}
.reveal-line.in>span{transform:translateY(0)}
.statement .dim{color:var(--faint)}
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,6vw,90px);margin-top:90px;align-items:start}
.portrait{position:relative;aspect-ratio:3/4;background:repeating-linear-gradient(155deg,#161412 0 24px,#100f0e 24px 48px);
  overflow:hidden;border:1px solid var(--line)}
.portrait .reel-label{font-size:10px}
.bio p{font-size:clamp(16px,1.5vw,20px);line-height:1.65;color:#cfccc6;max-width:46ch}
.bio p+p{margin-top:22px}
.bio .lead{color:var(--text)}
.caps{margin-top:46px;border-top:1px solid var(--line)}
.caps .row{display:flex;justify-content:space-between;align-items:baseline;padding:16px 0;border-bottom:1px solid var(--line)}
.caps .row .k{font-family:var(--exp);font-weight:700;font-size:clamp(18px,2vw,26px);text-transform:uppercase;letter-spacing:-.01em}
.caps .row .v{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}
@media(max-width:860px){.about-grid{grid-template-columns:1fr;gap:46px}}

/* ============ WORKS (horizontal pin) ============ */
.works-head{padding:clamp(70px,10vh,120px) var(--gut) 40px;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px}
.works-head h2{font-family:var(--exp);font-weight:800;font-size:clamp(38px,6vw,92px);text-transform:uppercase;letter-spacing:-.025em;line-height:.9}
.works-head .meta{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--muted);text-align:right}
.h-wrap{position:relative}
.h-pin{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center}
.h-track{display:flex;gap:clamp(20px,3vw,46px);padding:0 var(--gut);will-change:transform}
.card{position:relative;flex:0 0 auto;width:min(60vw,560px);height:66vh;background:var(--surface);
  border:1px solid var(--line2);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;
  box-shadow:0 30px 70px rgba(0,0,0,.5)}
.card .media{position:absolute;inset:0}
.card .media .reel-inner{position:absolute;inset:-6%;will-change:transform}
.card .num{position:absolute;top:22px;left:22px;font-family:var(--mono);font-size:12px;letter-spacing:.2em;color:var(--accent);z-index:2}
.card .tag{position:absolute;top:22px;right:22px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--muted);z-index:2;
  border:1px solid var(--line2);padding:5px 10px;border-radius:2px}
.card .info{position:relative;z-index:2;padding:26px;background:linear-gradient(transparent,rgba(10,10,10,.85) 55%)}
.card .info h3{font-family:var(--exp);font-weight:800;font-size:clamp(22px,2.6vw,34px);text-transform:uppercase;letter-spacing:-.01em;line-height:.95}
.card .info .sub{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;margin-top:10px;display:flex;gap:14px;flex-wrap:wrap}
.card .info .sub .accent{color:var(--accent)}
.card:hover .scanline{opacity:.8}
.h-progress{position:absolute;left:var(--gut);right:var(--gut);bottom:46px;height:2px;background:#241f1c;z-index:5}
.h-progress i{position:absolute;left:0;top:0;height:100%;background:var(--accent);box-shadow:0 0 10px var(--accent);width:0}
@media(max-width:860px){
  .h-pin{height:auto;position:static;display:block;padding:10px 0 40px}
  .h-track{flex-direction:column;transform:none!important}
  .card{width:auto;height:74vw;max-height:520px}
  .h-progress{display:none}
}

/* ============ FOOTER / CONTACT ============ */
.foot{padding:clamp(80px,14vh,170px) var(--gut) 60px;border-top:1px solid var(--line);position:relative;overflow:hidden}
.foot .cta{font-family:var(--exp);font-weight:800;font-size:clamp(40px,9vw,150px);line-height:.86;text-transform:uppercase;letter-spacing:-.03em}
.foot .cta a{transition:color .3s}
.foot .cta a:hover{color:var(--accent)}
.foot .frow{display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px;margin-top:70px;
  padding-top:26px;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--muted);text-transform:uppercase}
.foot .frow a:hover{color:var(--accent)}

/* generic scroll-reveal */
.fade{opacity:0;transform:translateY(30px);transition:opacity .9s ease,transform .9s cubic-bezier(.16,1,.3,1)}
.fade.in{opacity:1;transform:none}
.fade.d1{transition-delay:.08s}.fade.d2{transition-delay:.16s}.fade.d3{transition-delay:.24s}

/* ============ TWEAK HOOKS ============ */
body.no-grain .grain{display:none}
body.no-scan .scanline{display:none}
body.title-inline .hero-title br{display:none}
body.title-inline .hero-title{font-size:clamp(40px,7.4vw,108px);line-height:.86}
body.reduce-motion .fade{opacity:1!important;transform:none!important}
body.reduce-motion .reveal-line>span{transform:none!important}
body.reduce-motion .scanline,
body.reduce-motion .ticker .track,
body.reduce-motion .scrollcue .bar,
body.reduce-motion .hero-hud .dot,
body.reduce-motion .nav .status .dot{animation:none!important}

/* ============ CONTACT FORM ============ */
.contact-form-wrap{max-width:680px;margin:3rem auto 4rem;padding:0 clamp(20px,5vw,60px)}
.contact-form{display:flex;flex-direction:column;gap:1.2rem}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
@media(max-width:600px){.cf-row{grid-template-columns:1fr}}
.cf-field{display:flex;flex-direction:column;gap:.5rem}
.cf-field label{font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--fg3)}
.cf-field input,.cf-field textarea{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:var(--fg1);font-family:var(--mono);font-size:.85rem;padding:.75rem 1rem;border-radius:3px;outline:none;transition:border-color .2s;resize:vertical}
.cf-field input:focus,.cf-field textarea:focus{border-color:rgba(255,255,255,.35)}
.cf-submit{align-self:flex-start;background:transparent;border:1px solid rgba(255,255,255,.25);color:var(--fg1);font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;padding:.75rem 2rem;cursor:pointer;transition:border-color .2s,color .2s}
.cf-submit:hover{border-color:var(--fg1);color:#fff}
.contact-sent{font-family:var(--mono);font-size:.75rem;letter-spacing:.1em;color:rgba(200,255,100,.8);padding:.75rem 0}
.contact-err{font-family:var(--mono);font-size:.75rem;letter-spacing:.08em;color:rgba(255,100,100,.8);margin-bottom:.5rem}
