/* ============================================================
   NGP — nicholasgpadil.la · shared styles
   Palette: ink / paper / grey / tan + highlighter #71F14A (only accent)
   Type: Archivo (display) · Hanken Grotesk (body) · system mono (technical)
   ============================================================ */

/* ---- self-hosted fonts ---- */
@font-face{font-family:'Archivo';font-style:normal;font-weight:700;font-display:swap;src:url("../fonts/archivo-700.woff2") format("woff2")}
@font-face{font-family:'Archivo';font-style:normal;font-weight:800;font-display:swap;src:url("../fonts/archivo-800.woff2") format("woff2")}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:300;font-display:swap;src:url("../fonts/hanken-300.woff2") format("woff2")}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url("../fonts/hanken-400.woff2") format("woff2")}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url("../fonts/hanken-500.woff2") format("woff2")}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url("../fonts/hanken-700.woff2") format("woff2")}

:root{
  --ink:#0C0C0C; --paper:#F2F1EC; --grey:#D8D7D2; --mid:#67655C;
  --tan:#C9BDA4; --hl:#71F14A; --line:#0c0c0c;
  --display:'Archivo',"Helvetica Neue",Helvetica,Arial,sans-serif;
  --body:'Hanken Grotesk',"Helvetica Neue",Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--body);font-weight:400;
  line-height:1.4;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit}
.mono{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--mid)}
.wrap{max-width:1280px;margin:0 auto;padding:0 30px}
.gutter{padding-left:max(30px,calc((100vw - 1280px)/2 + 30px))}
:focus-visible{outline:2px solid var(--ink);outline-offset:3px}
.reg{font-family:var(--mono);color:var(--mid)}

/* ---- top hairline ---- */
.topbar{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);padding:7px 30px;font-size:10px}
.topbar .mono{color:var(--ink)}
.marks{letter-spacing:.4em;color:var(--ink)}

/* ---- nav ---- */
nav{position:sticky;top:0;z-index:40;background:rgba(242,241,236,.9);backdrop-filter:blur(7px);border-bottom:1px solid var(--line)}
nav .row{position:relative;display:flex;justify-content:space-between;align-items:center;padding:16px 30px;max-width:1280px;margin:0 auto}
nav .name{font-family:var(--display);font-weight:800;letter-spacing:.02em;font-size:14px;text-transform:uppercase;text-decoration:none}
nav ul{display:flex;gap:22px;list-style:none}
nav a.lnk{text-decoration:none;font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;padding-bottom:3px;border-bottom:2px solid transparent;transition:.2s}
nav a.lnk:hover{border-color:var(--hl)}
nav a.lnk.active{border-color:var(--hl)}
nav a.it{font-style:italic}
nav a.it::before{content:"";display:inline-block;width:7px;height:7px;background:var(--hl);margin-right:7px;vertical-align:1px}
.navtoggle{display:none;background:none;border:1px solid var(--line);font-size:13px;line-height:1;padding:7px 11px;cursor:pointer;font-family:var(--mono);letter-spacing:.1em}

/* ---- HERO (home) ---- */
.hero{position:relative;min-height:88vh;display:grid;grid-template-columns:1.15fr .85fr;gap:0;align-items:end;border-bottom:1px solid var(--line);overflow:hidden}
.hero .left{padding:48px 0 56px;position:relative;z-index:5}
.kicker{display:flex;gap:18px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.kicker .pill{background:var(--hl);color:#0c0c0c;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:3px 8px;font-weight:700}
.logotype{font-family:var(--display);font-size:clamp(90px,20vw,260px);font-weight:800;line-height:.8;letter-spacing:-.05em;text-transform:lowercase}
.logotype .dot{color:var(--hl)}
.fullname{margin-top:48px;font-size:clamp(13px,1.5vw,17px);font-weight:700;letter-spacing:.02em;text-transform:uppercase}
.roles{margin-top:8px;font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:#2b2b2b;text-transform:uppercase}
.roles b{color:var(--ink)}
.idxnum{position:absolute;left:0;bottom:40px;font-family:var(--display);font-weight:800;font-size:clamp(60px,11vw,150px);line-height:.8;letter-spacing:-.04em;color:var(--ink);opacity:.10;writing-mode:vertical-rl;transform:rotate(180deg);z-index:-1}
.arrowbtn{display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;background:var(--ink);color:var(--paper);margin-top:34px;text-decoration:none;font-size:20px;transition:.2s}
.arrowbtn:hover{background:var(--hl);color:#0c0c0c}
.hero .right{position:relative;align-self:stretch;min-height:88vh;overflow:hidden;background:var(--grey);border-left:1px solid var(--line)}
.photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;filter:grayscale(1) contrast(1.03);mix-blend-mode:multiply;z-index:2}
.band{position:absolute;left:0;right:0;top:44%;height:34px;background:var(--hl);transform:translateX(-120%);animation:bandscan 1.4s cubic-bezier(.2,.8,.2,1) .3s forwards;z-index:1}
@keyframes bandscan{0%{transform:translateX(-120%)}70%{transform:translateX(2%)}100%{transform:translateX(0)}}
.scanline{position:absolute;left:0;right:0;top:0;height:2px;background:var(--hl);z-index:6;box-shadow:0 0 16px rgba(113,241,74,.8);animation:scan 1.7s ease-in-out .2s 1 forwards;opacity:0}
@keyframes scan{0%{transform:translateY(0);opacity:1}90%{opacity:1}100%{transform:translateY(92vh);opacity:0}}
.capbox{position:absolute;top:15%;right:16px;z-index:8;border:1px solid var(--ink);padding:8px 10px;writing-mode:vertical-rl;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;background:rgba(242,241,236,.78);color:var(--ink)}

/* ---- statement ---- */
.statement{padding:90px 0;border-bottom:1px solid var(--line)}
.statement p{font-size:clamp(24px,4vw,46px);font-weight:300;line-height:1.22;max-width:21ch;letter-spacing:-.015em}
.statement .g{color:var(--ink);background:var(--hl);padding:0 .12em;font-weight:400;-webkit-box-decoration-break:clone;box-decoration-break:clone}
.statement .tick{display:inline-block;width:110px;height:4px;background:var(--hl);margin-bottom:30px}

/* ---- reveal (progressive enhancement) ---- */
.reveal{transition:opacity .7s,transform .7s}
.js .reveal{opacity:0;transform:translateY(26px)}
.js .reveal.in{opacity:1;transform:none}

/* ---- index rows (home) ---- */
.index{padding:6px 0}
.r{position:relative;display:grid;grid-template-columns:78px 1fr auto;gap:24px;align-items:baseline;padding:40px 0;border-bottom:1px solid var(--line);text-decoration:none;color:inherit;overflow:hidden}
.r .bg{position:absolute;inset:0;background:var(--hl);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.2,.8,.2,1);z-index:0;mix-blend-mode:multiply;opacity:0}
.r:hover .bg{transform:scaleX(1);opacity:.16}
.r>*{position:relative;z-index:1}
.r .no{font-family:var(--mono);font-size:13px;color:var(--mid)}
.r h2{font-family:var(--display);font-size:clamp(34px,6vw,80px);font-weight:800;text-transform:uppercase;letter-spacing:-.03em;line-height:.9}
.r:hover h2{font-style:italic}
.r:hover .no{color:var(--ink)}
.r .meta{font-size:14px;color:#33322c;max-width:50ch;margin-top:14px;line-height:1.5}
.r .meta em{font-style:normal;color:var(--mid)}
.tags{margin-top:11px}
.tag{display:inline-block;border:1px solid var(--line);padding:3px 9px;margin:6px 7px 0 0;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase}
.r .go{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;white-space:nowrap;color:var(--mid)}
.r:hover .go{color:var(--ink)}

/* ---- topic page header ---- */
.back{display:inline-block;margin:30px 0 0;font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;border-bottom:2px solid transparent}
.back:hover{border-color:var(--hl)}
.pagehead{padding:30px 0 34px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:1fr minmax(0,42ch);gap:30px;align-items:end}
.pagehead .kick{display:block;font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);margin-bottom:14px}
.pagehead h1{font-family:var(--display);font-size:clamp(44px,9vw,104px);font-weight:800;line-height:.88;text-transform:uppercase;letter-spacing:-.03em}
.pagehead .intro{color:#33322c;font-size:15px;line-height:1.55}

/* ---- card grid (the "release card" system) ---- */
.cardgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;padding:40px 0 20px}
.card{display:flex;flex-direction:column;border:1px solid var(--line);background:var(--paper);text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s}
.card:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--ink)}
.card .cover{position:relative;aspect-ratio:16/10;background:linear-gradient(160deg,var(--tan),#2b2a26);overflow:hidden}
.card .cover .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:10px;letter-spacing:.3em;color:rgba(255,255,255,.6)}
.card .cover .cno{position:absolute;top:11px;left:13px;font-family:var(--mono);font-weight:700;font-size:12px;color:#fff;mix-blend-mode:difference}
.card .cover .strip{position:absolute;left:0;right:0;bottom:0;background:var(--hl);color:#0c0c0c;font-family:var(--mono);font-weight:700;font-size:11px;line-height:1;letter-spacing:.16em;text-transform:uppercase;padding:8px;text-align:center}
.card .b{padding:20px 22px;display:flex;flex-direction:column;flex:1}
.card .t{font-family:var(--display);font-weight:800;font-size:19px;line-height:1.05;text-transform:uppercase;letter-spacing:-.01em}
.card .code{font-family:var(--mono);font-size:10px;letter-spacing:.14em;color:var(--mid);margin-top:6px;text-transform:uppercase}
.card .sp{margin-top:16px;display:grid;grid-template-columns:auto 1fr;gap:8px 14px;font-family:var(--mono);font-size:12px}
.card .sp b{color:var(--mid);font-weight:400;letter-spacing:.06em}
.card .foot{margin-top:auto;padding-top:20px;display:flex;justify-content:space-between;align-items:center}
.card .bar{height:28px;width:84px;background:repeating-linear-gradient(90deg,#0c0c0c 0 2px,transparent 2px 4px,#0c0c0c 4px 5px,transparent 5px 8px,#0c0c0c 8px 11px,transparent 11px 13px)}
.card .arr{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--mid)}
.card:hover .arr{color:var(--ink)}

/* ---- clients ticker ---- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.clients{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:24px 0 28px;margin-top:8px}
.clients-lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--mid);margin-bottom:18px}
.ticker{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.track{display:flex;align-items:center;gap:46px;width:max-content;animation:marq 42s linear infinite}
.track img{height:32px;width:auto;display:block;flex:none;filter:brightness(0);opacity:.55;transition:opacity .2s}
.track img:hover{opacity:1}
.clients:hover .track{animation-play-state:paused}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* placeholder card (press — to be filled) */
.card.placeholder{border-style:dashed;opacity:.62;cursor:default}
.card.placeholder:hover{transform:none;box-shadow:none}
.card.placeholder .cover{background:repeating-linear-gradient(45deg,#e6e4dd 0 10px,#dedcd4 10px 20px)}
.card.placeholder .cover .ph{color:var(--mid)}

/* ---- show history list ---- */
.shows-head{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin:52px 0 0}
.shows-head a{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;border-bottom:2px solid transparent;white-space:nowrap}
.shows-head a:hover{border-color:var(--hl)}
.showlist{border-top:1px solid var(--line);margin-top:14px}
.showrow{display:grid;grid-template-columns:64px 1fr auto;gap:18px;align-items:baseline;padding:15px 0;border-bottom:1px solid var(--line)}
.showrow .yr{font-family:var(--mono);font-size:12px;color:var(--mid)}
.showrow .ev{font-family:var(--display);font-weight:700;font-size:clamp(15px,2.2vw,19px);text-transform:uppercase;letter-spacing:-.01em;line-height:1.05}
.showrow .ev small{display:block;font-family:var(--body);font-weight:400;font-size:12.5px;text-transform:none;letter-spacing:0;color:var(--mid);margin-top:4px}
.showrow .vn{font-family:var(--mono);font-size:10.5px;color:var(--mid);text-transform:uppercase;letter-spacing:.1em;text-align:right;white-space:nowrap}
a.showrow{text-decoration:none;color:inherit;transition:padding-left .2s}
a.showrow:hover{padding-left:8px}
a.showrow:hover .ev{font-style:italic}
a.showrow .ev::after{content:" →";color:var(--mid);font-size:.7em;vertical-align:1px}
@media(max-width:600px){.showrow{grid-template-columns:46px 1fr}.showrow .vn{display:none}}

/* ---- advisory (dark funnel) ---- */
.advisory{background:var(--ink);color:var(--paper);margin:70px 0;padding:60px 48px;position:relative;overflow:hidden}
.advisory .corner{position:absolute;top:14px;right:18px;font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--hl)}
.advisory .mono{color:var(--hl)}
.advisory h3{font-family:var(--display);font-size:clamp(30px,5vw,60px);font-weight:800;text-transform:uppercase;letter-spacing:-.03em;margin:14px 0 18px;max-width:15ch}
.advisory h3 .em{font-style:italic;color:var(--hl)}
.advisory p{max-width:54ch;color:#cfcfc7;font-size:15px;line-height:1.55}
.cta{display:inline-flex;align-items:center;gap:12px;margin-top:30px;background:var(--hl);color:#0c0c0c;text-decoration:none;padding:16px 30px;font-weight:800;font-size:13px;letter-spacing:.12em;text-transform:uppercase;font-family:var(--display)}
.cta:hover{filter:brightness(1.07);box-shadow:0 0 34px rgba(113,241,74,.4)}

/* ---- footer ---- */
footer{border-top:1px solid var(--line);padding:40px 0 16px}
.frow{display:flex;flex-wrap:wrap;gap:18px 28px;justify-content:space-between;align-items:center}
.links{display:flex;flex-wrap:wrap;gap:16px}
.links a{text-decoration:none;font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding-bottom:2px;border-bottom:2px solid transparent;transition:.2s}
.links a:hover{border-color:var(--hl)}
.footmarks{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:28px;border-top:1px solid var(--line);padding-top:14px}
.barcode.sm{height:30px;width:120px;background:repeating-linear-gradient(90deg,#0c0c0c 0 2px,transparent 2px 4px,#0c0c0c 4px 5px,transparent 5px 8px,#0c0c0c 8px 11px,transparent 11px 13px)}

/* ---- responsive ---- */
@media(max-width:980px){
  .navtoggle{display:block}
  nav ul{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--paper);border-bottom:1px solid var(--line);padding:6px 30px 16px}
  nav.open ul{display:flex}
  nav ul li{padding:9px 0;border-top:1px solid rgba(0,0,0,.08)}
}
@media(max-width:820px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero .right{min-height:62vh;border-left:0;border-top:1px solid var(--line)}
  .r{grid-template-columns:44px 1fr}.r .go{display:none}
  .pagehead{grid-template-columns:1fr}
  .cardgrid{grid-template-columns:1fr}
  .idxnum{display:none}
}
@media(max-width:560px){
  .topbar{font-size:8.5px;padding:6px 16px}
  .topbar .mono:nth-child(2){display:none}
  .advisory{padding:36px 22px;margin:50px 0}
  .footmarks{flex-wrap:wrap}
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .band{animation:none;transform:none}
  .scanline{display:none}
  .js .reveal{opacity:1;transform:none;transition:none}
  .r .bg{transition:none}
  .card{transition:none}
  .track{animation:none}
}
