/* ═══════════════════════════════════════════
   style.css  v4
═══════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;height:100%;scroll-padding-top:54px}
body{font-family:'DM Sans',sans-serif;min-height:100%;overflow-x:hidden;transition:background .8s,color .5s}
a{text-decoration:none;color:inherit}
button{font-family:inherit;border:none;background:none;cursor:pointer}
img{display:block;max-width:100%}

/* ── THEMES ── */
[data-theme="void"]{--bg:#05020a;--bg2:#0a0414;--surface:rgba(255,255,255,.04);--surface2:rgba(255,255,255,.07);--border:rgba(255,255,255,.08);--border2:rgba(255,255,255,.12);--shine:rgba(255,255,255,.1);--text:#f2ebfc;--text2:#b098d6;--accent:#e233ff;--accent2:#00f0ff;--glow:rgba(226,51,255,.18);--glow2:rgba(0,240,255,.12);--orb1:rgba(180,20,255,.22);--orb2:rgba(0,150,255,.16);--orb3:rgba(255,0,150,.12);--shadow:0 8px 40px rgba(0,0,0,.6);--glass-bg:rgba(5,2,10,.55);--glass-border:rgba(255,255,255,.1);--peach:#ffaa82}
[data-theme="apple"]{--bg:#f0f4f9;--bg2:#e4eaf2;--surface:rgba(255,255,255,.55);--surface2:rgba(255,255,255,.8);--border:rgba(0,0,0,.07);--border2:rgba(0,0,0,.12);--shine:rgba(255,255,255,.9);--text:#1a1d26;--text2:rgba(40,50,80,.55);--accent:#0071e3;--accent2:#30b0c7;--glow:rgba(0,113,227,.1);--glow2:rgba(48,176,199,.1);--orb1:rgba(100,180,255,.3);--orb2:rgba(160,210,255,.25);--orb3:rgba(48,176,199,.2);--shadow:0 4px 30px rgba(0,0,0,.1);--glass-bg:rgba(240,244,249,.6);--glass-border:rgba(0,0,0,.08);--peach:#c85f30}
[data-theme="aurora"]{--bg:#020f12;--bg2:#04161a;--surface:rgba(0,255,213,.04);--surface2:rgba(0,255,213,.07);--border:rgba(0,255,213,.1);--border2:rgba(0,255,213,.2);--shine:rgba(0,255,213,.15);--text:#e0fbfc;--text2:#8bb6ba;--accent:#00ffd5;--accent2:#ff00a0;--glow:rgba(0,255,213,.15);--glow2:rgba(255,0,160,.12);--orb1:rgba(0,200,180,.2);--orb2:rgba(200,0,150,.2);--orb3:rgba(0,100,255,.1);--shadow:0 8px 40px rgba(0,0,0,.6);--glass-bg:rgba(2,15,18,.6);--glass-border:rgba(0,255,213,.12);--peach:#ffb38a}
[data-theme="ember"]{--bg:#120404;--bg2:#1a0606;--surface:rgba(255,42,42,.05);--surface2:rgba(255,42,42,.09);--border:rgba(255,42,42,.1);--border2:rgba(255,42,42,.2);--shine:rgba(255,100,100,.15);--text:#ffebe8;--text2:#cc827e;--accent:#ff2a2a;--accent2:#ff7b00;--glow:rgba(255,42,42,.18);--glow2:rgba(255,123,0,.12);--orb1:rgba(200,20,20,.25);--orb2:rgba(220,90,0,.2);--orb3:rgba(150,0,0,.15);--shadow:0 8px 40px rgba(0,0,0,.65);--glass-bg:rgba(18,4,4,.6);--glass-border:rgba(255,42,42,.12);--peach:#ffc49a}
[data-theme="obsidian"]{--bg:#000000;--bg2:#090909;--surface:rgba(255,255,255,.03);--surface2:rgba(255,255,255,.06);--border:rgba(255,255,255,.08);--border2:rgba(255,255,255,.12);--shine:rgba(255,215,0,.1);--text:#f5f5f5;--text2:#8a8a8a;--accent:#ffd700;--accent2:#ffffff;--glow:rgba(255,215,0,.12);--glow2:rgba(255,255,255,.08);--orb1:rgba(150,120,0,.15);--orb2:rgba(50,50,50,.2);--orb3:rgba(200,160,0,.1);--shadow:0 8px 40px rgba(0,0,0,.7);--glass-bg:rgba(0,0,0,.65);--glass-border:rgba(255,215,0,.15);--peach:#ffad80}
[data-theme="chrome"]{--bg:#14161a;--bg2:#1c1f26;--surface:rgba(255,255,255,.04);--surface2:rgba(255,255,255,.08);--border:rgba(255,255,255,.1);--border2:rgba(255,255,255,.15);--shine:rgba(255,255,255,.15);--text:#eef1f7;--text2:#939eb5;--accent:#00e5ff;--accent2:#ff0055;--glow:rgba(0,229,255,.16);--glow2:rgba(255,0,85,.16);--orb1:rgba(0,180,255,.2);--orb2:rgba(200,0,80,.18);--orb3:rgba(0,229,255,.1);--shadow:0 8px 40px rgba(0,0,0,.5);--glass-bg:rgba(20,22,26,.6);--glass-border:rgba(255,255,255,.1);--peach:#ffa882}
[data-theme="reactor"]{--bg:#060a06;--bg2:#0c140c;--surface:rgba(255,255,255,.03);--surface2:rgba(120,220,60,.06);--border:rgba(120,220,60,.1);--border2:rgba(120,220,60,.2);--shine:rgba(180,255,100,.13);--text:#efffdc;--text2:#7ab854;--accent:#96e030;--accent2:#00c8b4;--glow:rgba(150,224,48,.16);--glow2:rgba(0,200,180,.1);--orb1:rgba(80,180,20,.2);--orb2:rgba(0,140,100,.18);--orb3:rgba(160,240,40,.08);--shadow:0 8px 40px rgba(0,0,0,.6);--glass-bg:rgba(6,10,6,.6);--glass-border:rgba(120,220,60,.1);--peach:#ff9e72}
[data-theme="dusk"]{--bg:#110b1a;--bg2:#1a1025;--surface:rgba(255,136,102,.04);--surface2:rgba(255,136,102,.07);--border:rgba(255,136,102,.1);--border2:rgba(255,136,102,.18);--shine:rgba(255,200,180,.12);--text:#fcf0f5;--text2:#c0a2b9;--accent:#ff8866;--accent2:#b366ff;--glow:rgba(255,136,102,.16);--glow2:rgba(179,102,255,.12);--orb1:rgba(200,80,60,.22);--orb2:rgba(120,50,180,.2);--orb3:rgba(255,100,80,.1);--shadow:0 8px 40px rgba(0,0,0,.6);--glass-bg:rgba(17,11,26,.6);--glass-border:rgba(255,136,102,.12);--peach:#ffc4a0}
body{background:var(--bg);color:var(--text)}

/* ── ANIMATION KILL-SWITCH ── */
body.no-anim *{animation:none!important;transition:none!important}
body.no-anim *::before,body.no-anim *::after{animation:none!important;transition:none!important}
body.no-anim .reveal{opacity:1!important;transform:none!important;transition:none!important}
body.no-anim .char-gif{animation:none!important;content-visibility:auto}
body.no-anim .cv-dl-btn-full{animation:none;background-image:none}

/* ── ORB WRAPPER ── */
#orb-wrap {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(100px);
  will-change: transform;
  opacity: 0.6; /* Base visibility */
}

/* ── ORB 1 (Large & Slow) ── */
.orb1 {
  width: 80vw;
  height: 80vw;
  top: -10%;
  left: -10%;
  background: radial-gradient(circle, var(--orb1), transparent 70%);
  animation: move1 40s linear infinite alternate;
}

/* ── ORB 2 (Medium & Faster) ── */
.orb2 {
  width: 60vw;
  height: 60vw;
  bottom: -10%;
  right: -10%;
  background: radial-gradient(circle, var(--orb2), transparent 70%);
  animation: move2 35s linear infinite alternate;
}

/* ── ORB 3 (Small & Fastest) ── */
.orb3 {
  width: 50vw;
  height: 50vw;
  top: 20%;
  left: 20%;
  background: radial-gradient(circle, var(--orb3), transparent 70%);
  animation: move3 25s linear infinite alternate;
}

/* ── "RANDOM" PATHS USING VIEWPORT UNITS ── */

@keyframes move1 {
  0%   { transform: translate(0, 0) scale(1); }
  33%  { transform: translate(30vw, 20vh) scale(1.2); }
  66%  { transform: translate(-10vw, 50vh) scale(0.9); }
  100% { transform: translate(50vw, -10vh) scale(1.1); }
}

@keyframes move2 {
  0%   { transform: translate(0, 0) scale(1); }
  50%  { transform: translate(-40vw, -60vh) scale(1.3); }
  100% { transform: translate(-10vw, -20vh) scale(1); }
}

@keyframes move3 {
  0%   { transform: translate(0, 0) scale(1); }
  25%  { transform: translate(40vw, 10vh) scale(0.8); }
  50%  { transform: translate(10vw, -40vh) scale(1.2); }
  75%  { transform: translate(-30vw, 20vh) scale(0.9); }
  100% { transform: translate(20vw, 50vh) scale(1.1); }
}

/* ── GRAIN ── */
#grain {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: .025;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 128px;
  display: none;
}
[data-theme="apple"] #grain { display: block; }

/* ════════════════════════════════════════════
   SPLASH
════════════════════════════════════════════ */
#splash{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--bg);pointer-events:all;transition:opacity .5s ease,visibility .5s ease}
#splash.done{opacity:0;visibility:hidden;pointer-events:none}
.splash-inner{display:flex;flex-direction:column;align-items:center;gap:1rem;animation:splashFadeIn .5s ease forwards}
@keyframes splashFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.splash-avatar{width:128px;height:128px;border-radius:50%;background:var(--surface2);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:1.6rem;position:relative;overflow:hidden;animation:splashAvatarIn .6s .1s ease both}
.splash-avatar::before{content:'';position:absolute;inset:-3px;border-radius:50%;background:conic-gradient(var(--accent),var(--accent2),var(--accent));z-index:-1;animation:spinr 3s linear infinite;filter:blur(1px);opacity:.6}
@keyframes splashAvatarIn{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
.splash-name{font-size:clamp(2.8rem,7vw,5.5rem);font-weight:700;letter-spacing:-.04em;line-height:.95;background:linear-gradient(135deg,var(--text) 40%,var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:splashTextIn .5s .2s ease both}
.splash-role{font-family:'DM Mono',monospace;font-size:.58rem;letter-spacing:.2em;color:var(--accent);text-transform:uppercase;opacity:.8;animation:splashTextIn .5s .3s ease both}
@keyframes splashTextIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.splash-bar{width:120px;height:2px;border-radius:2px;background:var(--border2);overflow:hidden;margin-top:.5rem;animation:splashTextIn .5s .35s ease both}
.splash-bar-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:2px;animation:splashLoad 1.4s .4s cubic-bezier(.4,0,.2,1) forwards}
@keyframes splashLoad{0%{width:0%}60%{width:75%}100%{width:100%}}
@keyframes spinr{to{transform:rotate(360deg)}}

/* ── FAB BAR ── */
.lang-btn{font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.1em;padding:.28rem .6rem;border-radius:6px;border:1px solid var(--border);color:var(--text2);transition:all .3s}
.lang-btn.active,.lang-btn:hover{border-color:var(--accent);color:var(--accent)}
.theme-picker{position:relative}
.theme-btn-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);transition:background .4s}
.theme-dropdown{position:absolute;background:color-mix(in srgb,var(--bg2) 88%,transparent);backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);border:1px solid var(--border2);border-radius:14px;padding:.45rem;min-width:165px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity .22s,transform .22s;z-index:400}
.theme-dropdown.open{opacity:1;pointer-events:all;transform:translateY(0)}
.theme-opt{display:flex;align-items:center;gap:.7rem;padding:.55rem .8rem;border-radius:9px;font-size:.76rem;font-weight:500;color:var(--text2);transition:all .22s;cursor:pointer}
.theme-opt:hover{background:var(--surface2);color:var(--text)}
.theme-opt.active{color:var(--accent)}
.t-sw{width:9px;height:9px;border-radius:50%;flex-shrink:0}
#fab-bar{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:300;display:flex;align-items:center;gap:.45rem;padding:.4rem .5rem;border-radius:100px;border:1px solid var(--border2);background:color-mix(in srgb,var(--bg) 75%,transparent);backdrop-filter:blur(28px) saturate(180%);-webkit-backdrop-filter:blur(28px) saturate(180%);box-shadow:var(--shadow)}
.fab-btn{font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.1em;padding:.32rem .72rem;border-radius:100px;border:1px solid transparent;color:var(--text2);background:none;transition:all .25s;display:flex;align-items:center;gap:.4rem;white-space:nowrap}
.fab-btn:hover{border-color:var(--border2);color:var(--text);background:var(--surface2)}
.fab-btn.active{border-color:var(--accent);color:var(--accent)}
.fab-btn#console-fab.active{border-color:var(--accent2);color:var(--accent2)}
.fab-divider{width:1px;height:18px;background:var(--border);margin:0 .1rem;flex-shrink:0}
.theme-fab-btn{font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.1em;padding:.32rem .72rem;border-radius:100px;border:1px solid var(--border);color:var(--text2);background:none;transition:all .25s;display:flex;align-items:center;gap:.4rem}
.theme-fab-btn:hover{border-color:var(--border2);color:var(--text)}
.fab-theme .theme-dropdown{bottom:calc(100% + .6rem);top:auto;right:auto;left:50%;transform:translateX(-50%) translateY(6px)}
.fab-theme .theme-dropdown.open{transform:translateX(-50%) translateY(0)}
.console-dot{width:6px;height:6px;border-radius:50%;background:var(--accent2);animation:blink 1.4s step-end infinite}
.anim-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);transition:background .3s}
.fab-btn.anim-btn:not(.active) .anim-dot{background:var(--text2)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}

/* ════════════════════════════════════════════
   FLOATING TOC
════════════════════════════════════════════ */
.floating-toc{position:fixed;top:50%;transform:translateY(-50%);right:0;z-index:250;display:flex;flex-direction:row;align-items:center;pointer-events:auto}
.ftoc-lines{display:flex;flex-direction:column;align-items:flex-end;gap:10px;padding:12px 10px 12px 20px;cursor:pointer}
.ftoc-line{height:2px;border-radius:2px;background:var(--border2);transition:background .2s,box-shadow .2s,width .2s;width:16px}
.ftoc-line:nth-child(n+2){width:12px;margin-inline-start:4px}
.ftoc-line.active{background:var(--accent);box-shadow:0 0 6px var(--accent);width:20px!important;margin-inline-start:0!important}
.floating-toc:hover .ftoc-line{background:color-mix(in srgb,var(--accent) 50%,var(--border2))}
.ftoc-popup{position:absolute;right:calc(100%);top:50%;transform:translateY(-50%) translateX(8px);opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease}
.ftoc-popup.open{opacity:1;pointer-events:all;transform:translateY(-50%) translateX(0)}
.ftoc-popup-inner{background:color-mix(in srgb,var(--bg2) 90%,transparent);backdrop-filter:blur(32px) saturate(180%);-webkit-backdrop-filter:blur(32px) saturate(180%);border:1px solid var(--border2);border-radius:14px;padding:.4rem .45rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.1rem;min-width:170px}
.ftoc-item{display:flex;align-items:center;gap:.65rem;padding:.5rem .75rem;border-radius:9px;font-size:.76rem;font-weight:500;color:var(--text2);transition:all .18s;text-align:left;width:100%;background:none;white-space:nowrap}
.ftoc-item:hover{background:var(--surface2);color:var(--text)}
.ftoc-item.active{color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent)}
.ftoc-lbl{flex:1}

/* ── MISC ── */
.stats-grid{display:none!important}
.s-sublabel{font-family:'DM Mono',monospace;font-size:.54rem;letter-spacing:.22em;color:var(--text2);text-transform:uppercase;margin:1.6rem 0 .85rem;opacity:.7}
.s-sublabel:first-of-type{margin-top:0}
.interests-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.1rem;
  perspective: 1000px; /* Gives the 3D depth */
}

.interest-item {
  height: calc(180px + 1lh); /* content + one empty line at bottom */
  background: transparent;
}

.interest-item.is-clickable {
  cursor: pointer;
}

.interest-inner {
  position: relative;
  width: 100%;
  height: 100%;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  transform-style: preserve-3d;
}

/* Toggle Class */
.interest-item.is-flipped .interest-inner {
  transform: rotateY(180deg);
}

.interest-front, .interest-back {
  position: absolute;
  width: 100%;
  height: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  border-radius: 12px;
  border: 1px solid var(--border);
  overflow: hidden;
}

/* FRONT: Text Layout */
.interest-front {
  background: var(--surface2);
  display: flex;
  flex-direction: column;
  padding: 1rem;
  gap: 0.5rem;
}

.interest-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.interest-ico { font-size: 1.1rem; }
.interest-label { font-weight: 600; font-size: 0.85rem; }

.interest-details {
  font-size: 0.75rem;
  line-height: 1.4;
  color: var(--text2)z;
  margin: 0;
  padding-left:.5rem;
  padding-right:.5rem;
}

/* BACK: Image Layout */
.interest-back {
  transform: rotateY(180deg);
  background: #000;
}

.interest-flip-img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* This makes the image fill the card perfectly */
}

/* ── MAIN LAYOUT ── */
#page{position:relative;z-index:2;padding-top:2.5rem}
main{max-width:1360px;margin:0 auto;padding:0 0 5rem;display:flex;gap:0;align-items:flex-start}

/* ═══════════════════════════════════════════
   SIDEBAR
═══════════════════════════════════════════ */
#sidebar{width:300px;flex-shrink:0;position:sticky;top:0;/*height:100vh!important;*/display:flex;flex-direction:column;overflow:hidden;align-self:flex-start}
.side-banner-wrap{width:100%;height:180px;overflow:hidden;flex-shrink:0;position:absolute;border-radius:15px !important}
.char-stage{width:100%;height:100%;position:relative}
.char-gif{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;opacity:0;transition:opacity .6s ease;border-radius:15px;z-index:0}
.char-gif.active{opacity:1}
.char-stage.fallback::after{content:'';position:absolute;inset:0;background:linear-gradient(50deg,color-mix(in srgb,var(--bg) 80%,transparent) 0%,color-mix(in srgb,var(--bg) 40%,transparent) 35%,transparent 60%);pointer-events:none;z-index:1}
.side-banner-gif{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.side-inner{flex:1;overflow-y:auto;padding:.5rem 0 1.5rem;display:flex;flex-direction:column;gap:.35rem;scrollbar-width:none;position:relative;z-index:1}
.side-inner::-webkit-scrollbar{display:none}
.side-profile{padding:.75rem 1.1rem .8rem;position:relative;z-index:2;}
.side-name{font-size:.9rem;margin-top:110px;font-weight:700;letter-spacing:-.02em;margin-bottom:.2rem;line-height:1.2}
.side-title{font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.14em;color:var(--accent);text-transform:uppercase}
/* .side-name, .side-title{text-shadow: 0 0 2px black, 0 0 2px black, 0 0 2px black, 0 0 2px black;} */
.side-section-btn{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;border-radius:12px;font-size:.78rem;font-weight:500;color:var(--text2);transition:all .28s;position:relative;text-align:left;width:100%;background:none}
.side-bar-indicator{width:3px;height:16px;border-radius:2px;background:var(--accent);opacity:0;flex-shrink:0}
.side-num{font-family:'DM Mono',monospace;font-size:.55rem;letter-spacing:.12em;color:var(--text2);opacity:.5}
.side-divider{height:1px;background:linear-gradient(90deg,transparent 2%,var(--border2) 50%,transparent 98%);margin:1rem 0rem}

/* ── CONTENT COL ── */
#content-col{flex:1;display:flex;flex-direction:column;gap:1.75rem;min-width:0;padding:0 3rem 0 2rem}

/* ── GLASS CARD ── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:20px;backdrop-filter:blur(32px) saturate(160%);-webkit-backdrop-filter:blur(32px) saturate(160%);position:relative;overflow:hidden;transition:border-color .4s,box-shadow .4s,background .8s}
.card::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 5%,var(--shine) 40%,var(--shine) 60%,transparent 95%);pointer-events:none;opacity:.7}
.card.p-md{padding:2rem 2.5rem}

/* ── SECTION LABEL ── */
.s-label{font-family:'DM Mono',monospace;font-weight:500;font-size:.7rem;letter-spacing:.3em;color:var(--accent);text-transform:uppercase;margin-bottom:1.6rem;display:flex;align-items:center;gap:.75rem;transition:color .4s}
.s-label::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--border2),transparent)}
.s-label-row{display:flex;align-items:center;gap:.5rem;margin-bottom:1.4rem}
.s-label-row .s-label{margin-bottom:0;flex:1}
.cv-dl-btn{flex-shrink:0;width:24px;height:24px;border-radius:100px;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);display:flex;align-items:center;justify-content:center;transition:all .25s}
.cv-dl-btn:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}

/* ── ABOUT ── */
#about.card{margin:0 .75rem;padding-bottom:1.5rem;border-top-left-radius: 0rem;border-top-right-radius: 0rem;}
.prof-bio{font-size:.82rem;line-height:1.8;color:var(--text2);font-weight:300;    margin-bottom: 1rem;}
.tags{display:flex;flex-wrap:wrap;gap:.5rem;/*margin-bottom:1.2rem*/}
.tag{font-family:'DM Mono',monospace;font-size:.56rem;letter-spacing:.07em;padding:.22rem .55rem;border-radius:4px;background:color-mix(in srgb,var(--peach) 12%,transparent);border:1px solid color-mix(in srgb,var(--peach) 40%,transparent);color:var(--peach);text-transform:uppercase;transition:all .3s}
.tag.hi{border-color:var(--accent2);color:var(--accent2);background:color-mix(in srgb,var(--accent2) 8%,transparent)}

/* ── SOCIALS ── */
.socials{position:absolute;top:0;right:0;z-index:10;display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;padding:.6rem .5rem}
.soc-btn{font-size:1rem;font-weight:500;height:35px;padding: 0 5px;border-radius:100px;border:1px solid var(--border2);color:var(--text2);display:flex;align-items:center;justify-content:flex-end;gap:.4rem;transition:max-width .25s ease,border-color .25s,color .25s,background .25s;background:color-mix(in srgb,var(--bg) 60%,transparent);backdrop-filter:blur(8px);overflow:hidden;white-space:nowrap;max-width:35px}
.soc-btn:hover{max-width:140px;border-color:var(--accent);color:var(--accent);}
.soc-label{opacity:0;font-size:.7rem;transition:opacity .15s ease;pointer-events:none;padding-left: .5rem;}
.soc-btn:hover .soc-label{opacity:1}

/* Stats */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(70px,1fr));gap:.5rem;margin-bottom:1.2rem}
.stat{padding:.75rem .5rem;border-radius:11px;background:var(--surface2);border:1px solid var(--border);text-align:center;transition:all .3s}
.stat:hover{border-color:var(--border2);transform:translateY(-1px)}
.stat-n{font-size:1.2rem;font-weight:700;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.2rem}
.stat-l{font-family:'DM Mono',monospace;font-size:.48rem;letter-spacing:.12em;color:var(--text2);text-transform:uppercase}

/* ── CV DOWNLOAD BUTTON ── */
.cv-dl-btn-full {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  width: 100%;
  padding: .75rem 1rem;
  border-radius: 100px;
  border: 1px solid var(--border2);
  color: var(--text2);
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .04em;
  transition: all .25s;
  margin-top: .5rem;
  text-decoration: none;

  /* ENHANCED GRADIENT */
  background-size: 200% 100%;
  background-image: linear-gradient(
    -145deg, 
    transparent 25%, 
    color-mix(in srgb, var(--accent) 25%, transparent) 50%, 
    transparent 75%
  );
  background-color: var(--surface2);
  animation: anime-slash 3s cubic-bezier(0.1, 0.8, 0.3, 1) infinite;
}

.cv-dl-btn-full:hover {
  border-color: var(--accent);
  color: var(--accent);
  background-image: none;
  background-color: color-mix(in srgb, var(--accent) 12%, var(--surface2));
}

@keyframes anime-slash {
  0% {
    background-position: 200% 0;
  }
  60% {
    background-position: -100% 0;
  }
  100% {
    background-position: -100% 0;
  }
}

/* ════════════════════════════════════════════
   EXP — VIEW SWITCHING
════════════════════════════════════════════ */
.exp-gantt{display:block}
.exp-timeline{display:none}

/* ── EXP LEGEND + SPINE ── */
.exp-legend{display:flex;gap:1.25rem;margin-bottom:1.5rem;flex-wrap:wrap}
.legend-item{display:flex;align-items:center;gap:.45rem;font-size:.72rem;color:var(--text2);font-weight:500}
.legend-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.spine-wrap{margin-left:200px;margin-bottom:.35rem}
.spine-yr{font-family:'DM Mono',monospace;font-size:.58rem;color:var(--text2);text-align:center;position:relative;padding-bottom:.3rem}
.spine-yr::before{content:'';position:absolute;bottom:0;left:50%;width:1px;height:6px;background:var(--border2)}

/* ── EXP GANTT GRID ROWS ── */
.grid-rows{display:flex;flex-direction:column;gap:.55rem;margin-left:-1rem}
.grid-row{display:flex;align-items:center;opacity:0;transform:translateY(10px);transition:opacity .45s ease,transform .45s ease}
.grid-row.visible{opacity:1;transform:translateY(0)}
.row-meta{width:200px;flex-shrink:0;padding-right:1.25rem;text-align:right}
.row-type-badge{display:none;;;;;;font-family:'DM Mono',monospace;font-size:.48rem;letter-spacing:.1em;text-transform:uppercase;padding:.18rem .5rem;border-radius:100px;width:fit-content;margin-left:auto;margin-bottom:.2rem}
.row-role{font-size:.85rem;font-weight:700;letter-spacing:-.015em;line-height:1.2}
.row-org{font-family:'DM Mono',monospace;font-size:.63rem;color:var(--text2);margin-top:.1rem}
.row-org-wrap{display:flex;align-items:center;justify-content:flex-end;gap:.4rem}
.row-cat-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.row-track{flex:1;position:relative;height:40px;display:flex;align-items:center;cursor:pointer}
.row-track::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent calc(100%/8 - .5px),var(--border) calc(100%/8 - .5px),var(--border) calc(100%/8));opacity:.35;pointer-events:none}
.row-bar{position:absolute;height:26px;border-radius:6px;min-width:5px;transition:height .2s,box-shadow .2s;overflow:hidden}
.row-bar::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:rgba(255,255,255,.28)}
.grid-row:hover .row-bar,.grid-row.active .row-bar{height:32px;box-shadow:0 4px 18px var(--glow)}
.bar-tooltip{position:absolute;bottom:calc(100% + 8px);transform:translateX(-50%) translateY(4px);background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border2);border-radius:9px;padding:.45rem .8rem;white-space:nowrap;font-size:.74rem;font-weight:600;color:var(--text);pointer-events:none;opacity:0;transition:opacity .15s ease,transform .15s ease;z-index:10;box-shadow:var(--shadow)}
.bar-tooltip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--border2)}
.row-track:hover .bar-tooltip{opacity:1;transform:translateX(-50%) translateY(0)}
.detail-wrap{max-height:0;overflow:hidden;transition:max-height .42s cubic-bezier(.4,0,.2,1),opacity .3s;opacity:0;padding-left:200px}
.detail-wrap.open{max-height:60rem;opacity:1}
.detail-card{margin:.4rem 0 .5rem;padding:1.2rem 1.5rem;border-radius:14px;background:var(--surface2);border:1px solid var(--border2);position:relative;overflow:hidden}
.detail-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 7%,transparent),transparent 55%);pointer-events:none}
.dc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem}
.dc-title{font-size:1rem;font-weight:700;letter-spacing:-.02em}
.dc-close{font-family:'DM Mono',monospace;font-size:.58rem;color:var(--text2);cursor:pointer;padding:.2rem .45rem;border-radius:4px;border:1px solid var(--border);transition:all .2s;flex-shrink:0}
.dc-close:hover{color:var(--text);border-color:var(--border2)}
.dc-desc{font-size:.84rem;line-height:1.8;color:var(--text2);font-weight:300;margin-bottom:.7rem}
.dc-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}
.dc-bottom .tags{flex:1}
.dc-logo{height:2rem;width:auto;max-width:6rem;object-fit:contain;opacity:.7;flex-shrink:0;filter:var(--logo-filter,none)}

/* ── EXP VERTICAL TIMELINE (mobile) ── */
.tl{display:flex;flex-direction:column}
.tl-row{display:grid;grid-template-columns:66px 28px 1fr;gap:0;opacity:0;transform:translateY(10px);transition:opacity .45s ease,transform .45s ease}
.tl-row.tl-visible{opacity:1;transform:translateY(0)}
.tl-row.tl-concurrent .tl-date{visibility:hidden}
.tl-row.tl-concurrent .tl-spine-top{background:transparent}
.tl-date{padding-top:18px;padding-right:.75rem;text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:.15rem}
.tl-date-start{font-family:'DM Mono',monospace;font-size:.68rem;font-weight:500;color:var(--text);letter-spacing:.02em;line-height:1}
.tl-date-end{font-family:'DM Mono',monospace;font-size:.58rem;color:var(--text2)}
.tl-date-dur{font-family:'DM Mono',monospace;font-size:.5rem;color:var(--accent2);letter-spacing:.06em;margin-top:.15rem}
.tl-spine{display:flex;flex-direction:column;align-items:center}
.tl-spine-top{width:2px;height:20px;background:color-mix(in srgb,var(--border2) 60%,transparent)}
.tl-dot{width:13px;height:13px;border-radius:50%;flex-shrink:0;border:2px solid var(--bg);transition:transform .25s,box-shadow .25s;cursor:pointer;z-index:1}
.tl-row:hover .tl-dot,.tl-row.tl-active .tl-dot{transform:scale(1.3)}
.tl-spine-bot{flex:1;width:2px;min-height:16px;background:color-mix(in srgb,var(--border2) 45%,transparent)}
.tl-row:last-child .tl-spine-bot{background:transparent}
.tl-card-wrap{padding:.2rem 0 .7rem .8rem}
.tl-card{background:var(--surface2);border:1px solid var(--border);border-radius:14px;overflow:hidden;cursor:pointer;transition:border-color .25s,box-shadow .2s,transform .2s}
.tl-row:hover .tl-card{border-color:var(--border2);box-shadow:0 4px 16px var(--glow);transform:translateX(3px)}
.tl-row.tl-active .tl-card{border-color:color-mix(in srgb,var(--accent) 40%,transparent);box-shadow:0 4px 16px var(--glow);transform:translateX(3px)}
.tl-card-accent{height:3px}
.tl-card-top{padding:.8rem 1rem .7rem;display:grid;grid-template-columns:1fr auto;gap:.5rem;align-items:start}
.tl-card-role{font-size:.88rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin-bottom:.18rem}
.tl-card-org{font-family:'DM Mono',monospace;font-size:.56rem;color:var(--text2);letter-spacing:.04em}
.tl-card-badge{font-family:'DM Mono',monospace;font-size:.44rem;letter-spacing:.08em;text-transform:uppercase;padding:.16rem .45rem;border-radius:100px;white-space:nowrap;height:fit-content}
.tl-card-title{padding:.55rem 1rem .8rem;font-size:.76rem;color:var(--text2);font-weight:300;line-height:1.5;border-top:1px solid var(--border)}
.tl-expand{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s;opacity:0}
.tl-row.tl-active .tl-expand{max-height:280px;opacity:1}
.tl-expand-inner{padding:.1rem 1rem 1rem;border-top:1px dashed var(--border)}
.tl-desc{font-size:.8rem;line-height:1.8;color:var(--text2);font-weight:300;margin:.6rem 0 .7rem}
.tl-concurrent-note{font-family:'DM Mono',monospace;font-size:.5rem;letter-spacing:.1em;color:var(--accent2);text-transform:uppercase;padding:.2rem 0 .35rem .8rem;display:flex;align-items:center;gap:.35rem;grid-column:3}
.tl-concurrent-note::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--accent2);flex-shrink:0}

/* ── PROJECTS ── */
.proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media(max-width:700px){.proj-grid{grid-template-columns:1fr}}
.proj-card{cursor:pointer;border-radius:16px;overflow:hidden;border:1px solid var(--border);background:var(--surface);transition:all .4s;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);position:relative}
.proj-card:hover{border-color:var(--border2);transform:translateY(-3px);box-shadow:0 12px 36px var(--glow)}
.proj-img{width:100%;aspect-ratio:16/9;object-fit:cover;opacity:.72;transition:opacity .4s,transform .5s;filter:saturate(.75)}
.proj-card:hover .proj-img{opacity:.9;transform:scale(1.04);filter:saturate(1)}
.proj-body{padding:1.2rem 1.4rem 1.4rem}
.proj-tags{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:.6rem}
.proj-badge{font-family:'DM Mono',monospace;font-size:.52rem;letter-spacing:.08em;padding:.18rem .5rem;border-radius:4px;text-transform:uppercase;font-weight:700}
.pb-blue{background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 32%,transparent)}
.pb-highlight {
  background: color-mix(in srgb, orange 20%, transparent); /* warm highlight */
  color: color-mix(in srgb, orange 80%, var(--accent)); /* blends with your accent slightly */
  border: 1px solid color-mix(in srgb, orange 50%, transparent);
}
.pb-teal{background:color-mix(in srgb,var(--accent2) 12%,transparent);color:var(--accent2);border:1px solid color-mix(in srgb,var(--accent2) 28%,transparent)}
.proj-title{font-size:.9rem;font-weight:700;margin-top:.6rem;margin-bottom:.3rem;letter-spacing:-.015em}
.proj-desc{font-size:.76rem;line-height:1.65;color:var(--text2);margin-bottom:.8rem;font-weight:300}
.proj-footer{display:flex;justify-content:space-between;align-items:center}
.proj-tech{font-family:'DM Mono',monospace;font-size:.54rem;color:var(--text2);letter-spacing:.04em}
.proj-link{visibility:hidden;font-size:.66rem;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:.28rem;padding:.28rem .65rem;border-radius:100px;border:1px solid color-mix(in srgb,var(--accent) 32%,transparent);background:color-mix(in srgb,var(--accent) 6%,transparent);transition:all .3s}
.proj-link:hover{background:color-mix(in srgb,var(--accent) 14%,transparent)}

/* ── TOOLS ── */
.tool-list{display:flex;flex-direction:column;gap:.8rem}
.tool-item{cursor:pointer;display:flex;align-items:flex-start;gap:1rem;padding:1.2rem 1.4rem;border-radius:14px;border:1px solid var(--border);background:var(--surface);transition:all .32s;position:relative;overflow:hidden;backdrop-filter:blur(20px)}
.tool-item::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,var(--glow),transparent 60%);opacity:0;transition:opacity .4s}
.tool-item:hover::before{opacity:1}
.tool-item:hover{border-color:var(--border2);transform:translateX(3px);box-shadow:0 4px 18px var(--glow)}
.tool-ico{width:36px;height:36px;border-radius:10px;background:var(--surface2);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.tool-info{flex:1;min-width:0}
.tool-name{font-size:.82rem;font-weight:700;margin-bottom:.2rem;letter-spacing:-.01em}
.tool-desc{font-size:.73rem;line-height:1.6;color:var(--text2);font-weight:300}
.tool-right{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;flex-shrink:0}
.tool-tech{font-family:'DM Mono',monospace;font-size:.52rem;color:var(--text2);letter-spacing:.05em;text-align:right}
.tool-arrow{visibility:hidden;font-size:.82rem;color:var(--accent);opacity:0;transform:translateX(-4px);transition:all .28s}
.tool-item:hover .tool-arrow{opacity:1;transform:translateX(0)}

/* ── HOMELAB ── */
.hl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:1rem}
.hl-item{padding:1.1rem;border-radius:13px;text-align:center;border:1px solid var(--border);background:var(--surface);transition:all .32s;backdrop-filter:blur(20px)}
.hl-item:hover{border-color:var(--border2);background:color-mix(in srgb,var(--accent2) 5%,transparent);transform:translateY(-2px);box-shadow:0 6px 18px var(--glow2)}
.hl-ico{font-size:1.25rem;margin-bottom:.4rem}
.hl-name{font-size:.74rem;font-weight:600;margin-bottom:.12rem;letter-spacing:-.01em}
.hl-desc{font-family:'DM Mono',monospace;font-size:.52rem;color:var(--text2);letter-spacing:.06em}
.hl-link{font-size:.62rem;font-weight:600;color:var(--accent2);border:1px solid color-mix(in srgb,var(--accent2) 30%,transparent);background:color-mix(in srgb,var(--accent2) 8%,transparent);padding:.3rem .65rem;border-radius:100px;white-space:nowrap;flex-shrink:0;display:none;transform:translateX(8px);transition:opacity .3s ease,transform .3s ease;text-decoration:none}
.hl-item:hover .hl-link{display:block;transform:translateX(0)}
.hl-item:hover .hl-name,.hl-item:hover .hl-desc{display:none}

/* ── NOW PLAYING ── */
@property --angle{syntax:'<angle>';initial-value:0deg;inherits:false}

.clear-glass-card{
  position:relative;border-radius:16px;overflow:hidden;height:120px;
  border:none;
}

/* Fake border via box-shadow + pseudo for the scanning red line */
.clear-glass-card::before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:16px;
  padding:1px;
  background:conic-gradient(
    from var(--angle),
    rgba(255,255,255,.12) 0deg,
    rgba(255,255,255,.12) 150deg,
    #ff2200 165deg,
    #ff6644 180deg,
    #ff2200 195deg,
    rgba(255,255,255,.12) 210deg,
    rgba(255,255,255,.12) 360deg
  );
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  animation:border-spin 3s linear infinite;
  z-index:5;pointer-events:none;
}
@keyframes border-spin{to{--angle:360deg}}

.game-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:saturate(60%) brightness(.4);transform:scale(1.04);transition:background-image .4s ease;z-index:0}
.game-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  backdrop-filter:blur(.07rem);-webkit-backdrop-filter:blur(.07rem);
  background:linear-gradient(
    to right,
    color-mix(in srgb,var(--bg) 92%,var(--accent)) 0%,
    color-mix(in srgb,var(--bg) 65%,var(--accent)) 20%,
    color-mix(in srgb,var(--bg) 25%,transparent)   50%,
    transparent 60%
  );
}
.game-content{position:relative;z-index:2;display:flex;align-items:center;height:100%;padding:0 1.4rem;gap:1.1rem}
.game-badge-vert{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);font-size:.6rem;font-family:'DM Mono',monospace;letter-spacing:.18em;text-transform:uppercase;color:#4ade80;display:flex;align-items:center;gap:6px;white-space:nowrap;flex-shrink:0}
.game-divider{width:1px;height:60px;background:rgba(255,255,255,.12);flex-shrink:0}
.game-main{display:flex;flex-direction:column;gap:6px}
.game-logo{max-width:150px;max-height:65px;object-fit:contain;filter:drop-shadow(0 2px 12px rgba(0,0,0,.8))}
.game-platform{font-size:.6rem;font-family:'DM Mono',monospace;letter-spacing:.05em;text-transform:uppercase}
#badge-playing{display:none}
.pulse-dot{width:10px;height:10px;background:#ff0000;border-radius:50%;position:relative;display:inline-block;flex-shrink:0;animation:pulse-red 2s infinite}
@keyframes pulse-red{
  0%  {transform:scale(.95);box-shadow:0 0 0 0 rgba(255,0,0,.7)}
  70% {transform:scale(1);  box-shadow:0 0 0 10px rgba(255,0,0,0)}
  100%{transform:scale(.95);box-shadow:0 0 0 0 rgba(255,0,0,0)}
}

/* ── CONSOLE ── */
#console-panel{position:fixed;bottom:5rem;left:50%;transform:translateX(-50%) translateY(20px) scale(.97);width:520px;max-width:calc(100vw - 2rem);z-index:300;border-radius:18px;overflow:hidden;border:1px solid var(--border2);box-shadow:var(--shadow),0 0 60px var(--glow);background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);opacity:0;pointer-events:none;transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .28s}
#console-panel.open{transform:translateX(-50%) translateY(0) scale(1);opacity:1;pointer-events:all}
.con-header{padding:.7rem 1rem;background:var(--surface2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.con-dots{display:flex;gap:.3rem}
.dot{width:10px;height:10px;border-radius:50%}
.dr{background:#ff5f56}.dy{background:#ffbd2e}.dg{background:#27c93f}
.con-title{font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.14em;color:var(--text2)}
.con-close{font-size:.75rem;color:var(--text2);transition:color .2s;padding:.1rem .3rem;border-radius:4px}
.con-close:hover{color:var(--text)}
.con-output{height:200px;overflow-y:auto;padding:.85rem 1.1rem;font-family:'DM Mono',monospace;font-size:.7rem;line-height:1.85;display:flex;flex-direction:column}
.con-output::-webkit-scrollbar{width:3px}
.con-output::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
.con-line{color:var(--text2);white-space:pre-wrap;word-break:break-word}
.con-line.cmd{color:var(--accent2)}
.con-line.out{color:color-mix(in srgb,var(--text2) 70%,transparent)}
.con-line.err{color:#ff6b6b}
.con-line.ok{color:var(--accent)}
.con-line.info{color:var(--accent2)}
.con-line.blank{height:.5rem;flex-shrink:0}
.con-hints{padding:.35rem 1rem;border-top:1px solid var(--border);display:flex;gap:.4rem;flex-wrap:wrap}
.con-hint{font-family:'DM Mono',monospace;font-size:.55rem;letter-spacing:.06em;padding:.18rem .55rem;border-radius:4px;border:1px solid var(--border);color:var(--text2);background:var(--surface2);transition:all .2s;cursor:pointer}
.con-hint:hover{border-color:var(--accent2);color:var(--accent2)}
.con-input-row{display:flex;align-items:center;padding:.7rem 1rem;border-top:1px solid var(--border);gap:.5rem}
.con-prompt-label{font-family:'DM Mono',monospace;font-size:.7rem;color:var(--accent);flex-shrink:0}
.con-input{flex:1;background:none;border:none;outline:none;font-family:'DM Mono',monospace;font-size:.7rem;color:var(--text);caret-color:var(--accent2)}
.con-input::placeholder{color:color-mix(in srgb,var(--text2) 35%,transparent)}

/* ── MODAL ── */
body.modal-open{overflow:hidden}
#modal-bg{position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.52);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);opacity:0;pointer-events:none;transition:opacity .32s;display:flex;align-items:center;justify-content:center;padding:1.5rem}
#modal-bg.open{opacity:1;pointer-events:all}
#modal{padding:2rem;background:color-mix(in srgb,var(--bg2) 92%,transparent);border:1px solid var(--border2);border-radius:22px;backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);width:100%;max-width:860px;max-height:85vh;overflow-y:auto;overflow-x:hidden;position:relative;transform:scale(.95) translateY(18px);transition:transform .32s ease;box-shadow:var(--shadow);scrollbar-width:thin;scrollbar-color:var(--border2) transparent}
#modal::-webkit-scrollbar{width:4px}
#modal::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
#modal-bg.open #modal{transform:scale(1) translateY(0)}
.modal-close{position:absolute;top:.9rem;right:.9rem;width:26px;height:26px;border-radius:50%;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--text2);transition:all .3s;z-index:1}
.modal-close:hover{color:var(--text);border-color:var(--border2)}
.modal-header{padding:2rem 2rem 0}
.modal-badge{font-family:'DM Mono',monospace;font-size:.58rem;letter-spacing:.15em;color:var(--accent);text-transform:uppercase;margin-bottom:.6rem}
.modal-title{font-size:1.4rem;font-weight:700;margin-bottom:.75rem;letter-spacing:-.025em}
.modal-body{display:grid;grid-template-columns:1fr 280px;gap:1.5rem;padding:1.25rem 2rem 2rem}
.modal-body-left{display:flex;flex-direction:column;gap:.75rem;min-width:0}
.modal-body-right{display:flex;flex-direction:column;gap:.75rem;min-width:0}
.modal-desc{font-size:.84rem;line-height:1.8;color:var(--text2);font-weight:300}
.modal-desc p{margin-bottom:.75rem}
.modal-desc p:last-child{margin-bottom:0}
.modal-contrib-title{font-size:.72rem;font-family:'DM Mono',monospace;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.4rem!important}
.modal-contrib-list{padding-left:1.1rem;display:flex;flex-direction:column;gap:.3rem}
.modal-contrib-list li{font-size:.82rem;line-height:1.7;color:var(--text2);font-weight:300}
.modal-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top: .5rem;margin-bottom: .5rem;}
.modal-links{display:flex;gap:.6rem;flex-wrap:wrap}
.modal-lnk{font-size:.73rem;font-weight:600;padding:.45rem 1rem;border-radius:100px;border:1px solid var(--border2);color:var(--text2);transition:all .3s;background:var(--surface)}
.modal-lnk:hover,.modal-lnk.primary{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent)}
.modal-images{display:flex;flex-direction:column;gap:.5rem;margin-bottom:0}
.modal-img{width:100%;height:160px;object-fit:cover;border-radius:10px;border:1px solid var(--border);cursor:zoom-in;background:var(--surface2);transition:border-color .2s,box-shadow .2s}
.modal-img:hover{border-color:var(--border2);box-shadow:0 4px 16px var(--glow)}
.modal-videos{display:flex;flex-direction:column;gap:.75rem;margin-bottom:0}
.modal-video-wrap{position:relative;width:100%;aspect-ratio:16/9;border-radius:10px;overflow:hidden;border:1px solid var(--border);background:#000}
.modal-video-wrap iframe,.modal-video-wrap .yt-placeholder{position:absolute;inset:0;width:100%;height:100%;border:none}
.modal-video-wrap video{position:absolute;inset:0;width:100%;height:100%;object-fit:contain}
/* block YouTube logo (bottom-left) — modestbranding was deprecated 2023 */
.yt-wrap::after{content:'';position:absolute;bottom:0;left:0;width:80px;height:40px;background:#000;pointer-events:none;z-index:1}

/* ── LIGHTBOX ── */
#lightbox{position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.88);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s ease;cursor:zoom-out;padding:2rem}
#lightbox.open{opacity:1;pointer-events:all}
#lightbox-img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:10px;box-shadow:0 8px 60px rgba(0,0,0,.6);transform:scale(.95);transition:transform .25s ease}
#lightbox.open #lightbox-img{transform:scale(1)}

/* ── LANG WIPE ── */
#lang-wipe{position:fixed;inset:0;z-index:9000;pointer-events:none;overflow:hidden}
#lang-wipe::before{content:'';position:absolute;width:140%;height:100%;top:0;left:-140%;background:var(--accent);opacity:.18;transform:skewX(-18deg);transform-origin:top left;transition:none}
#lang-wipe.run::before{animation:wipe-slide .52s cubic-bezier(.76,0,.24,1) forwards}
@keyframes wipe-slide{0%{left:-140%;opacity:.22}45%{left:10%;opacity:.28}100%{left:160%;opacity:0}}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(8px);transition:opacity .15s ease,transform .15s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
::selection{background:color-mix(in srgb,var(--accent) 25%,transparent);color:var(--accent)}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .tool-item{flex-wrap:wrap}
  .tool-right{width:100%;flex-direction:row;justify-content:space-between;align-items:center}
  #sidebar{display:block;width:100%;height:auto!important;position:relative;top:auto}
  /*.side-banner-wrap{display:none}*/
  .side-inner{padding:.5rem 0 1rem}
  #about.card{margin:0 1rem}
  main{flex-direction:column;padding:0 0 4rem}
  #content-col{width:100%;padding:1rem 1rem 0;box-sizing:border-box}
  #content-col section{width:100%;box-sizing:border-box;overflow:hidden}
  .floating-toc{display:none}
  .proj-grid{grid-template-columns:1fr}
  .hl-grid{grid-template-columns:repeat(1,1fr)}
  .game-overlay{background:linear-gradient(to right,var(--bg2) 0%,var(--bg2) 15%,color-mix(in srgb,var(--bg2) 70%,transparent) 25%,color-mix(in srgb,var(--bg2) 40%,transparent) 45%,color-mix(in srgb,var(--bg2) 15%,transparent) 62%,transparent 65%)}
  .soc-btn{max-width:140px}
  .soc-label{opacity:1}
  .exp-gantt{display:none}
  .exp-timeline{display:block;margin-left:-1rem}
  .tl-row{grid-template-columns:60px 26px 1fr}
  .tl-date-start{font-size:.6rem}
  .tl-date-end{font-size:.52rem}
  .tl-date-dur{display:none}
  .tl-card-role{font-size:.82rem}
  .spine-wrap{margin-left:80px}
  .row-meta{width:80px;padding-right:.6rem}
  .row-type-badge{display:none}
  .row-role{font-size:.7rem}
  .row-org{font-size:.5rem}
  .detail-wrap{padding-left:80px}
  .modal-body{grid-template-columns:1fr;padding:1rem 1.25rem 1.5rem}
  .modal-header{padding:1.5rem 1.25rem 0}
  .modal-body-right{order:2}
  .modal-body-left{order:1}
  .modal-images{flex-direction:row;flex-wrap:wrap;justify-content:center}
  .modal-img{width:auto;height:120px;object-fit:contain}
  #splash{padding:1rem;text-align:center}
  .splash-inner{width:100%;align-items:center;justify-content:center}
  .splash-name{font-size:clamp(2rem,10vw,4rem)}
}

/* ── MISC ── */
.dr{cursor:pointer}
.other-cards-row{display:flex;flex-direction:column;gap:.75rem}

/* ── PIKACHU ── */
#pikachu-hint{position:fixed;bottom:4.2rem;left:50%;transform:translateX(100px) translateY(43.7px);z-index:299;pointer-events:none;opacity:0;transition:opacity .3s ease;width:80px;height:100px}
#pikachu-hint.visible{opacity:1;animation:pikachu-run 3.8s linear infinite}
#pikachu-hint img{width:100%}
@keyframes thunderbolt-discreet{0%,100%{background-color:#fbd50044;box-shadow:0 0 5px #fbd50065;transform:scale(1)}50%{background-color:#f7eb017e;box-shadow:0 0 15px #fbd500aa;transform:scale(1.03)}}
.pikachu-effect{animation:thunderbolt-discreet 1s ease-in-out infinite;border:1px solid #fbd50088!important;position:relative;transition:all .5s ease}
@keyframes pikachu-run{0%,100%{transform:translateX(100px) translateY(43.7px) scaleX(-1)}45%{transform:translateX(-100px) translateY(43.7px) scaleX(-1)}50%{transform:translateX(-100px) translateY(43.7px) scaleX(1)}95%{transform:translateX(100px) translateY(43.7px) scaleX(1)}}

/* ── LANGUAGES ── */
.lang-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}

.lang-item{
  display:flex;flex-direction:column;align-items:center;
  gap:.5rem;padding:.75rem 1rem;
  border-radius:12px;border:1px solid var(--border);
  background:var(--surface2);transition:border-color .25s;
  text-align:center;
}
.lang-item:hover{border-color:var(--border2)}

.lang-script{
  display:none;
  font-size:1.4rem;font-weight:500;line-height:1;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.lang-name{    
  font-size: .84rem;
  font-weight: 500;
  letter-spacing: .01em;
  color: var(--text);
  margin-right: .2rem;}
.lang-level{
  font-family:'DM Mono',monospace;font-size:.5rem;letter-spacing:.1em;
  text-transform:uppercase;padding:.2rem .6rem;border-radius:4px;
  background:color-mix(in srgb,var(--accent) 10%,transparent);
  border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);
  color:var(--accent);
  vertical-align: middle;
  display: inline-block;      /* Allows width/overflow control */
  white-space: nowrap;       /* Keeps text on one line */
  overflow: hidden;          /* Hides text that exceeds max-width */
  text-overflow: ellipsis;   /* Adds the ... */
  max-width: 8rem;
}

@media(max-width:900px){
  .lang-grid{grid-template-columns:1fr}
  .lang-item{flex-direction:row;text-align:left}
  .lang-script{
    display:none;
    width:38px;height:38px;font-size:.85rem;
    border-radius:50%;flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    background:color-mix(in srgb,var(--accent) 12%,var(--surface2));
    -webkit-text-fill-color:var(--accent);
    border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);
  }
  .lang-info{display:flex;gap:.2rem;flex:1}
}

/* ── RECO ── */
.reco-item{padding:1.4rem 1.6rem;border-radius:15px;border:1px solid var(--border);background:var(--surface2);margin-bottom:1rem;transition:border-color .3s}
.reco-item:hover{border-color:var(--border2)}
.reco-author{display:flex;flex-direction:column;gap:.2rem;margin-top:.65rem;align-items:flex-start}
.reco-name{font-size:.78rem;font-weight:700;color:var(--accent);text-decoration:none}
.reco-name:hover{text-decoration:underline}
.reco-role{font-family:'DM Mono',monospace;font-size:.55rem;letter-spacing:.08em;color:var(--text2);text-transform:uppercase}
.reco-quote {
  font-size: .82rem;
  line-height: 1.8;
  color: var(--text2);
  font-weight: 300;
  font-style: italic;
  display: block; 
  overflow: hidden;
  max-height: 7.2rem; 
  transition: max-height 0.35s cubic-bezier(0, 1, 0, 1);
  padding: .5rem;
  mask-image: linear-gradient(to top, transparent 0%, black 10%, black 90%);
}

.reco-quote.expanded {
  max-height: 60rem; 
  -webkit-line-clamp: unset; 
  transition: max-height 0.5s ease-in-out;
  mask-image:none;
}
.reco-expand-btn{display:none;padding:.5rem!important;margin-top:.5rem;font-family:'DM Mono',monospace;font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:none;border:none;cursor:pointer;padding:0;opacity:.7;transition:opacity .2s;float:right}
.reco-expand-btn:hover{opacity:1}
.reco-expand-btn.visible{display:block}

/* ── ORG LINK ── */
.org-link{color:inherit;text-decoration:none;border-bottom:1px solid var(--border2);transition:border-color .2s,color .2s}
.org-link:hover{color:var(--accent);border-bottom-color:var(--accent)}

/* ── COLLABORATORS ── */
.collab-carousel-wrap{
  position:relative;
  /* fades sit inside this, needs to be a block that contains its absolute children */
}
.collab-carousel-fade-left,
.collab-carousel-fade-right{
  position:absolute;
  top:0;bottom:0;width:80px;
  pointer-events:none;z-index:2;
  transition:opacity .25s;
}
.collab-carousel-fade-left{ left:0; background:linear-gradient(to right,color-mix(in srgb, var(--accent), transparent 80%) 0%,transparent 100%); }
.collab-carousel-fade-right{ right:0; background:linear-gradient(to left,color-mix(in srgb, var(--accent), transparent 80%) 0%,transparent 100%); }
.collab-carousel-fade-left.hidden,.collab-carousel-fade-right.hidden{ opacity:0; }

.collab-carousel-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:3;width:28px;height:28px;border-radius:50%;
  background:var(--text2);border:1px solid var(--border2);
  font-size:.85rem;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s;box-shadow:var(--shadow);
  backdrop-filter:blur(.07rem);-webkit-backdrop-filter:blur(.07rem);
}
.collab-carousel-btn:hover{ border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent); }
.collab-carousel-btn.hidden{ opacity:0;pointer-events:none; }
.collab-carousel-btn-left{ left:8px; }
.collab-carousel-btn-right{ right:8px; }

/* JS sets height and position:relative — this is the base */
.collab-grid{
  position:relative;
  overflow:hidden;
  display:block;
  cursor:grab;
  mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
}
.collab-grid:active{ cursor:grabbing; }

.collab-card{
  /* JS sets position:absolute, top:0, left:0, transform */
  display:flex;
  align-items:stretch;
  gap:1rem;
  padding:1.1rem 1.2rem;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--surface2);
  transition:border-color .25s;
  width:280px;
  box-sizing:border-box;
}
.collab-card:hover{ border-color:var(--border2); }

.collab-avatar{ width:52px;height:52px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--border2); }
.collab-avatar-placeholder{ width:52px;height:52px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;color:#fff;border:2px solid var(--border2); }

.collab-info{ flex:1;min-width:0;display:flex;flex-direction:column; }
.collab-name{ font-size:.88rem;font-weight:700;letter-spacing:-.015em;margin-bottom:.15rem; }
.collab-role{ font-family:'DM Mono',monospace;font-size:.55rem;letter-spacing:.08em;color:var(--accent);text-transform:uppercase;margin-bottom:.4rem; }
.collab-desc{ font-size:.76rem;line-height:1.6;color:var(--text2);font-weight:300;margin-bottom:.5rem; }
.collab-spacer{ flex:1; }
.collab-links{ display:flex;gap:.4rem;flex-wrap:wrap;margin-top:auto; }

.collab-link{ position:relative;font-size:.9rem;text-decoration:none;opacity:.65;transition:opacity .2s; }
.collab-link:hover{ opacity:1; }
.collab-link::after{
  content:attr(data-label);
  position:absolute;bottom:calc(100% + 8px);
  left:50%;transform:translateX(-50%) translateY(4px);
  background:color-mix(in srgb,var(--bg) 92%,transparent);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border2);border-radius:9px;
  padding:.45rem .8rem;white-space:nowrap;
  font-family:'DM Mono',monospace;font-size:.74rem;font-weight:600;color:var(--text);
  pointer-events:none;opacity:0;
  transition:opacity .15s ease,transform .15s ease;
  z-index:20;box-shadow:var(--shadow);
}
.collab-link::before{
  content:'';position:absolute;bottom:calc(100% + 3px);
  left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:var(--border2);
  pointer-events:none;opacity:0;transition:opacity .15s ease;z-index:21;
}
.collab-link:hover::after{ opacity:1;transform:translateX(-50%) translateY(0); }
.collab-link:hover::before{ opacity:1; }

/* ── MOBILE ── */
@media(max-width:900px){
   #page {padding-top:0rem;}
   .interests-grid {
    grid-template-columns: repeat(1, 1fr);
  }
  .collab-carousel-btn{ display:none; }
  .collab-carousel-fade-left,
  .collab-carousel-fade-right{ display:none; }

  /* reset JS-driven layout */
  .collab-grid{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    overflow:visible !important;
    height:auto !important;
    cursor:default !important;
    gap:1rem;
    mask-image: none;
  }
  .collab-card{
    position:relative !important;
    transform:none !important;
    left:auto !important;
    top:auto !important;
    width:100% !important;
    max-width:360px;
    height:auto !important;
  }
}