/* ui_kits/website/kit.css — component styles for the Macsiimacsito portfolio kit
   Relies on tokens from ../../colors_and_type.css */

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg-0);color:var(--ink);font-family:var(--font-body);-webkit-font-smoothing:none;font-size:21px}
button{font:inherit}
::selection{background:var(--pink);color:var(--black)}

.k-app{min-height:100vh;display:flex;flex-direction:column;position:relative}
.k-wrap{width:100%;max-width:1120px;margin:0 auto;padding:0 32px}
.k-screen{flex:1;padding-top:64px;padding-bottom:64px}
.k-eyebrow{font-family:var(--font-label);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.k-h1{font-family:var(--font-display);font-size:40px;line-height:1.5;color:var(--ink);text-shadow:4px 4px 0 var(--black);margin:0}
.k-h2{font-family:var(--font-display);font-size:26px;line-height:1.5;color:var(--ink);text-shadow:3px 3px 0 var(--black);margin:0}
.k-h3{font-family:var(--font-display);font-size:15px;line-height:1.5;color:var(--ink);margin:0}
.k-lead{font-size:27px;line-height:1.4;color:var(--ink-dim);margin:0}
.k-body{font-size:21px;line-height:1.55;color:var(--ink-dim);margin:0}
.k-mono{font-family:var(--font-mono)}

/* ---------- nav ---------- */
.k-nav{position:sticky;top:0;z-index:50;background:var(--bg-1);border-bottom:4px solid var(--black)}
.k-nav-inner{display:flex;align-items:center;gap:24px;height:74px}
.k-logo{display:flex;align-items:center;gap:12px;cursor:pointer;background:none;border:none;padding:0}
.k-logo img{width:40px;height:40px;image-rendering:pixelated}
.k-logo-txt{font-family:var(--font-display);font-size:15px;color:var(--ink);text-shadow:2px 2px 0 var(--black)}
.k-navlinks{display:flex;gap:2px;margin-left:auto}
.k-navlink{font-family:var(--font-label);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim);background:none;border:none;padding:11px 15px;cursor:pointer;border:3px solid transparent}
.k-navlink:hover{color:var(--gold)}
.k-navlink.is-active{color:var(--black);background:var(--gold)}

/* ---------- buttons ---------- */
.k-btn{font-family:var(--font-label);font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;border:3px solid var(--black);box-shadow:4px 4px 0 var(--black);padding:15px 20px;color:var(--black);background:var(--bg-2);cursor:pointer;display:inline-flex;align-items:center;gap:10px;transition:transform 90ms steps(2),box-shadow 90ms steps(2);text-decoration:none;border-radius:0}
.k-btn:hover{transform:translate(-1px,-1px);box-shadow:5px 5px 0 var(--black)}
.k-btn:active{transform:translate(4px,4px);box-shadow:0 0 0 var(--black)}
.k-btn--primary{background:var(--pink)}
.k-btn--secondary{background:var(--gold)}
.k-btn--ghost{background:transparent;color:var(--ink);border-color:var(--bg-3);box-shadow:4px 4px 0 var(--black)}
.k-btn--lg{padding:18px 26px;font-size:14px}

/* ---------- panel / card ---------- */
.k-panel{background:var(--bg-1);border:4px solid var(--black);box-shadow:6px 6px 0 var(--black);border-radius:0}
.k-tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-label);font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:5px 9px;border:2px solid currentColor;background:transparent}
.t-cyan{color:var(--cyan)} .t-green{color:var(--green)} .t-gold{color:var(--gold)} .t-pink{color:var(--pink)} .t-purple{color:var(--purple)}

/* project cards */
.k-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.k-proj{background:var(--bg-1);border:4px solid var(--black);box-shadow:6px 6px 0 var(--black);cursor:pointer;display:flex;flex-direction:column;transition:transform 90ms steps(2),box-shadow 90ms steps(2)}
.k-proj:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--black)}
.k-proj:active{transform:translate(4px,4px);box-shadow:0 0 0 var(--black)}
.k-proj-cover{height:120px;border-bottom:4px solid var(--black);display:flex;align-items:center;justify-content:center;font-size:48px;position:relative;overflow:hidden}
.k-proj-body{padding:20px;display:flex;flex-direction:column;gap:10px}
.k-proj-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto;padding-top:8px}

/* HUD strip */
.k-hud{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.k-hud-item{display:flex;align-items:center;gap:8px;font-size:22px;color:var(--ink-dim)}
.k-hud-item img{width:26px;height:26px;image-rendering:pixelated}

/* stat tiles */
.k-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.k-stat{background:var(--bg-1);border:4px solid var(--black);box-shadow:5px 5px 0 var(--black);padding:18px;text-align:center}
.k-stat-num{font-family:var(--font-display);font-size:24px;color:var(--gold);text-shadow:2px 2px 0 var(--black)}
.k-stat-label{font-family:var(--font-label);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-top:8px}

/* skill / power-up bars */
.k-skill{display:flex;flex-direction:column;gap:6px}
.k-skill-top{display:flex;justify-content:space-between;align-items:baseline}
.k-skill-name{font-size:20px;color:var(--ink)}
.k-skill-lvl{font-family:var(--font-label);font-size:11px;letter-spacing:.1em;color:var(--ink-faint)}
.k-bar{height:18px;border:3px solid var(--black);background:var(--black);display:flex;gap:3px;padding:3px}
.k-bar-cell{flex:1;background:var(--bg-3)}
.k-bar-cell.on{background:var(--green)}

/* inputs */
.k-field{display:flex;flex-direction:column;gap:7px}
.k-label{font-family:var(--font-label);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}
.k-input,.k-textarea{font-family:var(--font-body);font-size:21px;color:var(--ink);background:var(--black);border:3px solid var(--bg-3);padding:12px 14px;border-radius:0;outline:none}
.k-input:focus,.k-textarea:focus{border-color:var(--cyan)}
.k-textarea{resize:vertical;min-height:120px}
.k-input::placeholder,.k-textarea::placeholder{color:var(--ink-faint)}

/* avatar frame */
.k-avatar{width:200px;height:200px;border:4px solid var(--black);box-shadow:6px 6px 0 var(--black);background:var(--bg-2);position:relative;overflow:hidden}
.k-avatar image-slot{display:block;width:100%;height:100%}

/* footer */
.k-footer{border-top:4px solid var(--black);background:var(--bg-1);padding:24px 0;margin-top:48px}
.k-footer-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.k-foot-sprites{display:flex;gap:8px}
.k-foot-sprites img{width:22px;height:22px;image-rendering:pixelated}

/* modal */
.k-modal-scrim{position:fixed;inset:0;background:rgba(7,6,15,.82);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px}
.k-modal{width:100%;max-width:560px;background:var(--bg-1);border:4px solid var(--black);box-shadow:8px 8px 0 var(--black)}
.k-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:4px solid var(--black);background:var(--bg-2)}
.k-iconbtn{background:none;border:3px solid var(--bg-3);color:var(--ink);cursor:pointer;width:38px;height:38px;display:flex;align-items:center;justify-content:center;padding:0}
.k-iconbtn:hover{border-color:var(--pink);color:var(--pink)}

/* scanline + starfield hero */
.k-hero{position:relative;background:var(--bg-0);overflow:hidden;border-bottom:4px solid var(--black)}
.k-hero-stars{position:absolute;inset:0;background:url('assets/bg-stars.png') repeat;background-size:160px;opacity:.9}
.k-hero-scan{position:absolute;inset:0;pointer-events:none;background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 2px,rgba(0,0,0,.16) 3px,transparent 4px)}
.k-hero-inner{position:relative;padding-top:84px;padding-bottom:92px}

.k-cursor{display:inline-block;width:14px;height:26px;background:var(--green);vertical-align:-3px;margin-left:4px}
@keyframes blink{0%,49%{opacity:1}50%,100%{opacity:0}}
.blink{animation:blink 1s steps(1) infinite}

.k-divider{height:4px;background:var(--black);border:0;margin:0}
.section-head{display:flex;flex-direction:column;gap:12px;margin-bottom:40px}

@media (max-width:880px){
  .k-grid{grid-template-columns:1fr 1fr}
  .k-h1{font-size:30px}
}
@media (max-width:620px){
  .k-grid,.k-stats{grid-template-columns:1fr}
  .k-navlinks{display:none}
}