/* ═══════════════════════════════════════════════
   ewxy · minimalist — style.css  v4
   + Audio Visualizer · Overclock · New Gadgets
   + Perf: content-visibility · will-change · contain
   ═══════════════════════════════════════════════ */

:root {
  --black:#000;--white:#fff;
  --grey-100:#f0f0f0;--grey-200:#d0d0d0;--grey-400:#888;
  --grey-600:#444;--grey-700:#2a2a2a;--grey-800:#181818;--grey-900:#0d0d0d;
  --accent-dim:rgba(255,255,255,.06);
  --border:rgba(255,255,255,.08);--border-hover:rgba(255,255,255,.18);
  --green:#57F287;--discord:#5865F2;--spotify:#1DB954;--insta:#E1306C;
  --font-display:'Syne',sans-serif;--font-mono:'Space Mono',monospace;--font-body:'DM Sans',sans-serif;
  --radius:14px;--radius-sm:8px;
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --sidebar-w:300px;
  --transition-dur:.55s;
}

/* ══ LIGHT THEME ══ */
[data-theme="light"] body { filter: invert(1) hue-rotate(180deg); }
[data-theme="light"] body * { border-color: rgba(255,255,255,.12); }
[data-theme="light"] img, [data-theme="light"] canvas, [data-theme="light"] video, [data-theme="light"] .grain, [data-theme="light"] .scanlines, [data-theme="light"] .bg-grid, [data-theme="light"] .ambient-orbs, [data-theme="light"] .orb { filter: invert(1) hue-rotate(180deg); }
[data-theme="light"] .card-back-photo { filter: invert(1) hue-rotate(180deg) brightness(.75) saturate(.9); }
[data-theme="light"] .sb-pfp, [data-theme="light"] .avatar, [data-theme="light"] .dc-avatar, [data-theme="light"] .sb-gh-avatar { filter: none; }
[data-theme="light"] .sb-cd-date { color-scheme: light; }

/* OVERCLOCK — le JS injecte #oc-style qui gère les animations
   Ici on garde juste ce qui ne peut pas être overridé en JS */
body.overclock { --ease-spring:ease; --transition-dur:.05s; }
body.overclock .perf-badge { opacity:1; }
body.overclock .hamburger { border-color:rgba(255,208,0,.4); box-shadow:0 0 10px rgba(255,208,0,.12); }

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { background:var(--black); color:var(--white); font-family:var(--font-body); font-size:15px; line-height:1.6; overflow-x:hidden; cursor:none; min-height:100vh; }
a { text-decoration:none; color:inherit; }
button { background:none; border:none; color:inherit; font:inherit; cursor:none; }

::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-track { background:var(--black); }
::-webkit-scrollbar-thumb { background:var(--grey-700); border-radius:2px; }

/* ── CURSOR ── */
.cursor { position:fixed; width:8px; height:8px; background:var(--white); border-radius:50%; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:width .2s var(--ease-spring),height .2s var(--ease-spring),opacity .2s; mix-blend-mode:difference; will-change:left,top; }
.cursor.hover { width:36px; height:36px; opacity:.5; }
.cursor-trail { position:fixed; width:26px; height:26px; border:1px solid rgba(255,255,255,.25); border-radius:50%; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:left .12s ease-out,top .12s ease-out; mix-blend-mode:difference; will-change:left,top; }
@media(hover:none){.cursor,.cursor-trail{display:none!important}body{cursor:auto}button,a{cursor:pointer}}

/* ── BG LAYERS ── */
.grain { position:fixed; inset:0; width:100%; height:100%; pointer-events:none; z-index:997; opacity:.03; mix-blend-mode:screen; }
.scanlines { position:fixed; inset:0; pointer-events:none; z-index:996; background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.025) 2px,rgba(0,0,0,.025) 4px); }
.bg-grid { position:fixed; inset:0; pointer-events:none; z-index:0; background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px); background-size:64px 64px; mask-image:radial-gradient(ellipse at 50% 25%,black 0%,transparent 72%); }
.ambient-orbs { position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden; contain:layout size; }
.orb { position:absolute; border-radius:50%; filter:blur(80px); opacity:.04; animation:orbDrift 20s ease-in-out infinite alternate; }
.orb-1{width:600px;height:600px;background:#fff;top:-200px;left:-100px;animation-duration:22s}
.orb-2{width:400px;height:400px;background:#8888ff;top:50%;right:-150px;animation-duration:18s;animation-delay:-6s}
.orb-3{width:300px;height:300px;background:#fff;bottom:-100px;left:40%;animation-duration:25s;animation-delay:-12s}
@keyframes orbDrift{from{transform:translate(0,0) scale(1)}to{transform:translate(40px,30px) scale(1.1)}}

/* ── PERF BADGE ── */
.perf-badge { position:fixed; top:60px; left:50%; transform:translateX(-50%); z-index:1200; background:rgba(0,0,0,.9); border:1px solid rgba(255,220,0,.3); color:#FFD700; font-family:var(--font-mono); font-size:9px; letter-spacing:.2em; padding:4px 14px; border-radius:99px; opacity:0; pointer-events:none; transition:opacity .3s; }
body.overclock .perf-badge { opacity:1; }

/* ══════════ HAMBURGER ══════════ */
.hamburger { position:fixed; top:14px; left:20px; z-index:1100; width:40px; height:40px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:5px; border-radius:var(--radius-sm); border:1px solid var(--border); background:rgba(0,0,0,.85); backdrop-filter:blur(20px); transition:border-color .2s,background .2s,box-shadow .2s; contain:layout style; }
.hamburger:hover { border-color:var(--border-hover); background:rgba(255,255,255,.05); }
body.overclock .hamburger { border-color:rgba(255,208,0,.4); box-shadow:0 0 12px rgba(255,208,0,.15); }
.ham-bar { display:block; width:16px; height:1.5px; background:var(--white); border-radius:2px; transition:transform .35s var(--ease-spring),opacity .2s,width .3s; }
.hamburger.open .ham-bar:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open .ham-bar:nth-child(2){opacity:0;width:0}
.hamburger.open .ham-bar:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ══════════ SIDEBAR ══════════ */
.sidebar-overlay { position:fixed; inset:0; background:rgba(0,0,0,.65); backdrop-filter:blur(6px); z-index:1050; opacity:0; pointer-events:none; transition:opacity .35s ease; }
.sidebar-overlay.show { opacity:1; pointer-events:auto; }
.sidebar { position:fixed; top:0; left:0; width:var(--sidebar-w); max-width:92vw; height:100dvh; z-index:1060; background:#070707; border-right:1px solid var(--border); display:flex; flex-direction:column; transform:translateX(-100%); transition:transform .45s var(--ease-spring); contain:layout style; }
.sidebar.open { transform:translateX(0); }
.sidebar-header { display:flex; align-items:center; justify-content:space-between; padding:14px 18px; border-bottom:1px solid var(--border); flex-shrink:0; height:56px; }
.sidebar-brand { display:flex; align-items:center; }
.sb-name { font-family:var(--font-display); font-weight:800; font-size:15px; letter-spacing:2px; }
.sb-sep { color:var(--grey-700); margin:0 4px; }
.sb-tag { font-family:var(--font-mono); font-size:9px; color:var(--grey-600); letter-spacing:.15em; }
.sidebar-close { width:28px; height:28px; border-radius:6px; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--grey-400); transition:all .2s; }
.sidebar-close:hover { border-color:var(--border-hover); color:var(--white); background:var(--accent-dim); }
.sidebar-scroll { flex:1; overflow-y:auto; overflow-x:hidden; padding:8px 0; scrollbar-width:thin; scrollbar-color:var(--grey-700) transparent; }
.sidebar-scroll::-webkit-scrollbar{width:2px}.sidebar-scroll::-webkit-scrollbar-thumb{background:var(--grey-700)}
.sb-block { padding:10px 15px; border-bottom:1px solid rgba(255,255,255,.04); }
.sb-block:last-child{border-bottom:none}
.sb-section-label { font-family:var(--font-mono); font-size:8px; color:var(--grey-600); letter-spacing:.22em; text-transform:uppercase; margin-bottom:9px; display:flex; align-items:center; gap:6px; }
.sb-api-badge { font-size:7px; letter-spacing:.06em; color:var(--grey-700); border:1px solid rgba(255,255,255,.06); padding:1px 5px; border-radius:99px; text-transform:none; }

/* profile */
.sb-profile-block { display:flex; align-items:center; gap:10px; }
.sb-pfp { width:34px; height:34px; border-radius:50%; object-fit:cover; border:1px solid var(--border); flex-shrink:0; }
.sb-profile-info { flex:1; min-width:0; }
.sb-uname { font-family:var(--font-display); font-weight:700; font-size:13px; }
.sb-ustatus { display:flex; align-items:center; gap:5px; font-family:var(--font-mono); font-size:8px; color:var(--grey-400); margin-top:2px; }
.sb-live-badge { display:flex; align-items:center; gap:4px; font-family:var(--font-mono); font-size:7px; letter-spacing:.12em; color:var(--spotify); border:1px solid rgba(29,185,84,.25); padding:2px 6px; border-radius:99px; background:rgba(29,185,84,.06); flex-shrink:0; }

/* ══ OVERCLOCK BUTTON ══ */
.sb-overclock-btn { width:100%; display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:var(--radius-sm); border:1px solid rgba(255,208,0,.15); background:rgba(255,208,0,.03); transition:all .25s; }
.sb-overclock-btn:hover { border-color:rgba(255,208,0,.35); background:rgba(255,208,0,.06); }
.sb-oc-icon { font-size:18px; flex-shrink:0; }
.sb-oc-info { flex:1; text-align:left; }
.sb-oc-title { font-family:var(--font-mono); font-size:10.5px; color:var(--grey-200); font-weight:700; letter-spacing:.04em; }
.sb-oc-desc { font-family:var(--font-mono); font-size:8px; color:var(--grey-600); margin-top:1px; }
.sb-oc-pill { font-family:var(--font-mono); font-size:8px; font-weight:700; letter-spacing:.15em; padding:3px 9px; border-radius:99px; background:rgba(255,255,255,.04); color:var(--grey-600); border:1px solid var(--border); transition:all .25s; flex-shrink:0; }
.sb-overclock-btn.active .sb-oc-pill { background:rgba(255,208,0,.15); color:#FFD700; border-color:rgba(255,208,0,.35); }
.sb-overclock-btn.active { border-color:rgba(255,208,0,.3); }

/* nav */
.sb-nav { display:flex; flex-direction:column; gap:2px; }
.sb-link { display:flex; align-items:center; gap:9px; font-family:var(--font-mono); font-size:10px; color:var(--grey-400); padding:8px 10px; border-radius:var(--radius-sm); border:1px solid transparent; transition:all .2s; letter-spacing:.04em; }
.sb-link:hover { color:var(--white); background:var(--accent-dim); border-color:var(--border); }

/* socials */
.sb-socials { display:flex; flex-direction:column; gap:4px; }
.sb-social-btn { display:flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size:9.5px; color:var(--grey-400); padding:8px 10px; border-radius:var(--radius-sm); border:1px solid var(--border); background:rgba(255,255,255,.018); transition:all .2s; }
.sb-ext { margin-left:auto; opacity:0; transition:opacity .2s; flex-shrink:0; }
.sb-social-btn:hover .sb-ext { opacity:1; }
.sb-discord:hover{color:#7289da;border-color:rgba(88,101,242,.3);background:rgba(88,101,242,.06)}
.sb-spotify:hover{color:var(--spotify);border-color:rgba(29,185,84,.3);background:rgba(29,185,84,.06)}
.sb-instagram:hover{color:var(--insta);border-color:rgba(225,48,108,.3);background:rgba(225,48,108,.06)}

/* spotify widget */
.sb-sp-widget { display:flex; align-items:center; gap:9px; background:rgba(29,185,84,.04); border:1px solid rgba(29,185,84,.12); border-radius:var(--radius-sm); padding:9px 10px; }
.sb-sp-art { width:30px; height:30px; border-radius:5px; background:var(--grey-800); flex-shrink:0; display:flex; align-items:center; justify-content:center; overflow:hidden; border:1px solid rgba(255,255,255,.08); background-size:cover; background-position:center; }
.sb-vinyl-mini { width:14px; height:14px; border-radius:50%; background:conic-gradient(#222 0deg,#333 90deg,#1a1a1a 180deg,#333 270deg); animation:spin 3s linear infinite; border:2px solid #3a3a3a; }
.sb-sp-text { flex:1; min-width:0; }
.sb-sp-track { font-size:10px; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sb-sp-artist { font-family:var(--font-mono); font-size:7.5px; color:var(--grey-400); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sb-minibar { display:flex; align-items:flex-end; gap:2px; height:12px; flex-shrink:0; }
.sb-minibar span { display:block; width:2px; background:var(--spotify); border-radius:1px; animation:bars .7s ease-in-out infinite alternate; opacity:.8; }
.sb-minibar span:nth-child(1){height:4px}.sb-minibar span:nth-child(2){height:10px;animation-delay:.1s}
.sb-minibar span:nth-child(3){height:7px;animation-delay:.2s}.sb-minibar span:nth-child(4){height:12px;animation-delay:.3s}

/* discord widget */
.sb-dc-widget { display:flex; flex-direction:column; gap:3px; }
.sb-dc-row { display:flex; justify-content:space-between; align-items:center; padding:4px 8px; background:rgba(88,101,242,.04); border:1px solid rgba(88,101,242,.1); border-radius:6px; }
.sb-dc-k { font-family:var(--font-mono); font-size:7.5px; color:var(--grey-600); }
.sb-dc-v { font-family:var(--font-mono); font-size:8.5px; color:var(--grey-200); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:140px; }

/* ══ ACTIVITY FEED ══ */
.sb-feed { display: flex; flex-direction: column; gap: 3px; max-height: 140px; overflow-y: auto; scrollbar-width: thin; }
.sb-feed-empty { font-family: var(--font-mono); font-size: 8px; color: var(--grey-700); text-align: center; padding: 8px; }
.sb-feed-item {
  display: flex; align-items: center; gap: 7px;
  padding: 5px 8px; border-radius: 6px;
  background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.04);
  animation: feedIn .3s ease-out;
}
@keyframes feedIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }
.sb-feed-emoji { font-size: 12px; flex-shrink: 0; }
.sb-feed-text { flex: 1; min-width: 0; }
.sb-feed-name { font-family: var(--font-mono); font-size: 8.5px; color: var(--grey-200); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sb-feed-time { font-family: var(--font-mono); font-size: 7px; color: var(--grey-700); flex-shrink: 0; }

/* weather */
.sb-weather-loading { display:flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size:9px; color:var(--grey-600); }
.sb-spinner { width:12px; height:12px; border:1.5px solid var(--grey-700); border-top-color:var(--white); border-radius:50%; animation:spin .8s linear infinite; flex-shrink:0; }
.sb-weather-main { display:flex; align-items:center; gap:12px; margin-bottom:7px; padding:9px 11px; background:rgba(255,255,255,.03); border:1px solid var(--border); border-radius:var(--radius-sm); }
.sb-weather-icon { font-size:26px; line-height:1; }
.sb-weather-temp { font-family:var(--font-display); font-size:26px; font-weight:800; letter-spacing:-1px; }
.sb-weather-details { display:flex; flex-direction:column; gap:2px; }
.sb-weather-row { display:flex; justify-content:space-between; align-items:center; padding:3px 7px; border-bottom:1px solid rgba(255,255,255,.04); }
.sb-weather-row:last-child{border-bottom:none}
.sb-wk,.sb-wv { font-family:var(--font-mono); }
.sb-wk { font-size:7.5px; color:var(--grey-600); }
.sb-wv { font-size:8.5px; color:var(--grey-200); }

/* github */
.sb-github-cfg,.sb-github-data { display:flex; flex-direction:column; gap:6px; }
.sb-input { background:rgba(255,255,255,.03); border:1px solid var(--border); border-radius:var(--radius-sm); color:var(--white); font-family:var(--font-mono); font-size:9px; padding:7px 10px; outline:none; transition:border-color .2s; width:100%; }
.sb-input::placeholder{color:var(--grey-700)}
.sb-input:focus{border-color:rgba(255,255,255,.2)}
.sb-small-btn { font-family:var(--font-mono); font-size:9px; color:var(--black); background:var(--white); padding:7px 12px; border-radius:var(--radius-sm); transition:opacity .2s,transform .2s; white-space:nowrap; font-weight:700; }
.sb-small-btn:hover{opacity:.85;transform:translateY(-1px)}
.sb-gh-header{display:flex;align-items:center;gap:9px}
.sb-gh-avatar{width:30px;height:30px;border-radius:50%;border:1px solid var(--border)}
.sb-gh-name{font-size:11.5px;font-weight:600}
.sb-gh-handle{font-family:var(--font-mono);font-size:8px;color:var(--grey-600)}
.sb-gh-stats{display:flex;gap:5px}
.sb-gh-stat{flex:1;text-align:center;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 4px}
.sb-gh-num{font-family:var(--font-mono);font-size:13px;font-weight:700}
.sb-gh-lbl{font-family:var(--font-mono);font-size:7px;color:var(--grey-600);margin-top:2px}
.sb-gh-reset{background:none;color:var(--grey-600);font-size:8px;padding:4px 0;border:none;align-self:flex-start}

/* système */
.sb-sys{display:flex;flex-direction:column;gap:4px}
.sb-sys-row{display:flex;align-items:center;gap:8px;padding:5px 9px;background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:6px}
.sb-sys-label{display:flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:7.5px;color:var(--grey-600);min-width:68px;letter-spacing:.04em}
.sb-sys-right{flex:1;display:flex;align-items:center;gap:6px;justify-content:flex-end;font-family:var(--font-mono);font-size:8.5px;color:var(--grey-200)}
.sb-batt-bar{width:38px;height:4px;background:var(--grey-800);border-radius:99px;overflow:hidden}
.sb-batt-fill{height:100%;background:var(--green);border-radius:99px;transition:width .8s ease}
.sb-batt-pct{font-size:8.5px}

/* pomodoro */
.sb-pomodoro{display:flex;flex-direction:column;align-items:center;gap:8px}
.sb-pomo-ring-wrap{position:relative;width:80px;height:80px}
.sb-pomo-ring{width:80px;height:80px}
.sb-pomo-track{stroke:var(--grey-800)}
.sb-pomo-progress{stroke:var(--white);stroke-linecap:round;transition:stroke-dashoffset .5s ease}
.sb-pomo-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.sb-pomo-time{font-family:var(--font-mono);font-size:14px;font-weight:700;line-height:1}
.sb-pomo-mode{font-family:var(--font-mono);font-size:6px;color:var(--grey-600);letter-spacing:.15em;margin-top:2px}
.sb-pomo-controls{display:flex;gap:7px}
.sb-pomo-btn{width:27px;height:27px;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(255,255,255,.03);font-size:11px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.sb-pomo-btn:hover{border-color:var(--border-hover);background:var(--accent-dim)}
.sb-pomo-modes{display:flex;gap:4px}
.sb-pomo-mode-btn{font-family:var(--font-mono);font-size:7.5px;padding:3px 7px;border-radius:99px;border:1px solid var(--border);color:var(--grey-600);transition:all .2s}
.sb-pomo-mode-btn.active{color:var(--white);border-color:rgba(255,255,255,.3);background:var(--accent-dim)}
.sb-pomo-sessions{font-family:var(--font-mono);font-size:8px;color:var(--grey-700)}

/* ══ REACTION TIME ══ */
.sb-reaction{display:flex;flex-direction:column;gap:8px}
.sb-react-zone{
  height:56px;display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius-sm);border:1px solid var(--border);
  font-family:var(--font-mono);font-size:10px;color:var(--grey-400);
  cursor:pointer;transition:background .15s,border-color .15s,color .15s;
  user-select:none;
}
.sb-react-zone:hover{border-color:var(--border-hover);color:var(--grey-200)}
.sb-react-zone[data-state="waiting"]{background:rgba(255,50,50,.07);border-color:rgba(255,50,50,.25);color:#ff6b6b}
.sb-react-zone[data-state="go"]{background:rgba(87,242,135,.1);border-color:rgba(87,242,135,.35);color:var(--green);animation:reactPulse .2s ease}
@keyframes reactPulse{0%{transform:scale(1)}50%{transform:scale(1.02)}100%{transform:scale(1)}}
.sb-react-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.sb-react-stat{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:6px;padding:5px 6px;text-align:center}
.sb-rk{display:block;font-family:var(--font-mono);font-size:7px;color:var(--grey-600);margin-bottom:2px}
.sb-rv{display:block;font-family:var(--font-mono);font-size:10px;color:var(--white);font-weight:700}

/* ══ AIM TRAINER ══ */
.sb-aim{display:flex;flex-direction:column;gap:7px}
.sb-aim-header{display:flex;align-items:center;justify-content:space-between}
.sb-aim-clicks{font-family:var(--font-display);font-size:32px;font-weight:900;line-height:1;letter-spacing:-1px}
.sb-aim-lbl{font-family:var(--font-mono);font-size:8px;color:var(--grey-600)}
.sb-aim-bar-wrap{height:4px;background:var(--grey-800);border-radius:99px;overflow:hidden}
.sb-aim-bar{height:100%;width:0%;background:var(--white);border-radius:99px;transition:width .1s linear}
.sb-aim-best{font-family:var(--font-mono);font-size:8px;color:var(--grey-700)}

/* ══ CURSOR SPEED ══ */
.sb-cspeed{display:flex;flex-direction:column;gap:5px}
.sb-cs-main{display:flex;align-items:baseline;gap:4px}
.sb-cs-val{font-family:var(--font-display);font-size:28px;font-weight:900;letter-spacing:-1px;line-height:1;transition:color .15s}
.sb-cs-unit{font-family:var(--font-mono);font-size:9px;color:var(--grey-600)}
.sb-cs-bar-wrap{height:3px;background:var(--grey-800);border-radius:99px;overflow:hidden}
.sb-cs-track{height:100%;width:100%;position:relative}
.sb-cs-fill{height:100%;width:0%;background:var(--white);border-radius:99px;transition:width .1s ease}
.sb-cs-meta{font-family:var(--font-mono);font-size:8px;color:var(--grey-700)}

/* ══ NOTES RAPIDES ══ */
.sb-notes-wrap{display:flex;flex-direction:column;gap:5px}
.sb-notes{width:100%;height:80px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--white);font-family:var(--font-mono);font-size:9.5px;padding:9px 10px;outline:none;resize:none;line-height:1.5;transition:border-color .2s}
.sb-notes::placeholder{color:var(--grey-700)}
.sb-notes:focus{border-color:rgba(255,255,255,.2)}
.sb-notes-footer{display:flex;justify-content:space-between;align-items:center}
.sb-notes-chars{font-family:var(--font-mono);font-size:7.5px;color:var(--grey-700)}
.sb-notes-clear{font-family:var(--font-mono);font-size:8px;color:var(--grey-600);border:1px solid var(--border);padding:3px 8px;border-radius:99px;transition:all .2s}
.sb-notes-clear:hover{color:var(--white);border-color:var(--border-hover)}

/* gadgets */
.sb-gadget{margin-bottom:6px;padding:9px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:rgba(255,255,255,.018)}
.sb-gadget:last-child{margin-bottom:0}
.sb-gadget-lbl{font-family:var(--font-mono);font-size:7.5px;color:var(--grey-600);letter-spacing:.15em;text-transform:uppercase;margin-bottom:4px}
.sb-clock{text-align:center}
.sb-clock-time{font-family:var(--font-mono);font-size:19px;color:var(--white);letter-spacing:.1em}
.sb-clock-date{font-family:var(--font-mono);font-size:8px;color:var(--grey-600);margin-top:1px}
.sb-uptime-val{font-family:var(--font-mono);font-size:16px;color:var(--white);letter-spacing:.08em}
.sb-polling-row{display:flex;align-items:center;gap:8px;margin-top:3px}
.sb-bar-track{flex:1;height:4px;background:var(--grey-800);border-radius:99px;overflow:hidden}
.sb-bar-fill{height:100%;width:100%;background:linear-gradient(90deg,var(--grey-600),var(--white));border-radius:99px;animation:barPulse 2s ease-in-out infinite alternate}
@keyframes barPulse{from{opacity:.6}to{opacity:1}}
.sb-polling-label{font-family:var(--font-mono);font-size:9px;color:var(--grey-200);white-space:nowrap}
.sb-quote-txt{font-family:var(--font-mono);font-size:9px;color:var(--grey-400);line-height:1.5;margin-bottom:6px;font-style:italic;transition:opacity .25s}
.sb-quote-btn{font-family:var(--font-mono);font-size:8.5px;color:var(--grey-600);border:1px solid var(--border);padding:4px 10px;border-radius:99px;transition:all .2s}
.sb-quote-btn:hover{color:var(--white);border-color:var(--border-hover)}

/* ══ STREAK COUNTER ══ */
.sb-streak-val { display: flex; align-items: center; gap: 5px; }
.sb-streak-fire { font-size: 16px; }
.sb-streak-val #sb-streak-num {
  font-family: var(--font-display); font-size: 20px;
  font-weight: 800; color: var(--white);
}
.sb-streak-days { font-family: var(--font-mono); font-size: 9px; color: var(--grey-600); }

/* ══ SHARE BUTTON ══ */
.sb-share-btn {
  width: 100%; display: flex; align-items: center; justify-content: center;
  gap: 7px; padding: 8px 12px; border-radius: var(--radius-sm);
  border: 1px solid var(--border); background: rgba(255,255,255,.03);
  font-family: var(--font-mono); font-size: 9px; color: var(--grey-400);
  transition: all .2s;
}
.sb-share-btn:hover { border-color: var(--border-hover); color: var(--white); background: var(--accent-dim); }

/* ══ GLITCH EFFECT ON NAME ══ */
.hero-name { position: relative; }
.name-char { position: relative; display: inline-block; }
.name-char::before, .name-char::after {
  content: attr(data-char); position: absolute; top: 0; left: 0;
  width: 100%; height: 100%; overflow: hidden;
  opacity: 0; pointer-events: none;
}
.name-char::before { color: #ff0040; z-index: -1; }
.name-char::after { color: #00ffff; z-index: -1; }
.name-char:hover::before {
  animation: glitchTop .3s ease-in-out;
  clip-path: polygon(0 0, 100% 0, 100% 45%, 0 45%);
  opacity: .8;
}
.name-char:hover::after {
  animation: glitchBottom .3s ease-in-out .05s;
  clip-path: polygon(0 55%, 100% 55%, 100% 100%, 0 100%);
  opacity: .8;
}
@keyframes glitchTop {
  0% { transform: translate(0); }
  20% { transform: translate(-3px, -2px); }
  40% { transform: translate(3px, 1px); }
  60% { transform: translate(-1px, -1px); }
  80% { transform: translate(2px, 2px); }
  100% { transform: translate(0); }
}
@keyframes glitchBottom {
  0% { transform: translate(0); }
  20% { transform: translate(2px, 2px); }
  40% { transform: translate(-3px, -1px); }
  60% { transform: translate(1px, 1px); }
  80% { transform: translate(-2px, -2px); }
  100% { transform: translate(0); }
}

/* ══ BACKGROUND PARTICLES ══ */
.particles-canvas {
  position: fixed; inset: 0; width: 100%; height: 100%;
  pointer-events: none; z-index: 0; opacity: .4;
}

/* favicon picker */
.sb-favicon-grid{display:flex;flex-wrap:wrap;gap:5px}
.sb-fav-option{width:38px;height:38px;border-radius:var(--radius-sm);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;background:rgba(255,255,255,.02)}
.sb-fav-option:hover{border-color:var(--border-hover);transform:scale(1.08)}
.sb-fav-option.active{border-color:var(--white);box-shadow:0 0 0 1px var(--white)}
.sb-fav-option svg,.sb-fav-option img{width:24px;height:24px;pointer-events:none}

/* toggles */
.sb-toggles{display:flex;flex-direction:column;gap:3px}
.sb-toggle-row{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:rgba(255,255,255,.018);font-family:var(--font-mono);font-size:9.5px;color:var(--grey-400);transition:all .2s}
.sb-toggle-row:hover{border-color:var(--border-hover);color:var(--grey-200)}
.sb-tog-icon{display:flex;align-items:center;flex-shrink:0}
.sb-tog-name{flex:1;text-align:left}
.sb-tog-pill{font-size:7.5px;letter-spacing:.12em;font-weight:700;padding:2px 7px;border-radius:99px;background:rgba(87,242,135,.12);color:var(--green);border:1px solid rgba(87,242,135,.25);transition:all .2s}
.sb-toggle-row:not(.active) .sb-tog-pill{background:rgba(255,255,255,.04);color:var(--grey-600);border-color:var(--border)}
.sb-toggle-row:not(.active){opacity:.4}

/* secrets */
.sb-konami{display:flex;flex-direction:column;gap:7px}
.sb-konami-keys{display:flex;flex-wrap:wrap;gap:3px}
.sb-konami-keys kbd{font-family:var(--font-mono);font-size:8px;padding:3px 5px;border-radius:4px;background:var(--grey-900);border:1px solid var(--border);color:var(--grey-400)}
.sb-konami-hint{font-family:var(--font-mono);font-size:8px;color:var(--grey-700)}
.sidebar-footer{padding:10px 15px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}

/* ══════════ DYNAMIC ISLAND + VISUALIZER ══════════ */
.island-wrapper{position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:1000}
.island{background:#111;border-radius:40px;border:1px solid rgba(255,255,255,.1);overflow:hidden;cursor:pointer;transition:all var(--transition-dur) var(--ease-spring);box-shadow:0 0 0 1px rgba(255,255,255,.04),0 8px 40px rgba(0,0,0,.9);backdrop-filter:blur(24px);width:120px;height:32px;position:relative}
.island.expanded{width:300px;height:58px;border-radius:28px;background:#0d0d0d;box-shadow:0 0 0 1px rgba(255,255,255,.1),0 20px 60px rgba(0,0,0,.95)}

/* VISUALIZER CANVAS */
.island-viz{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:0;transition:opacity .4s;pointer-events:none}
.island.expanded .island-viz{opacity:1}

.island-dot-state{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:1;transition:opacity .15s;z-index:2}
.island.expanded .island-dot-state{opacity:0;pointer-events:none}
.island-mic{width:8px;height:8px;background:#1a1a1a;border-radius:50%;border:1px solid rgba(255,255,255,.12)}
.island-expanded-state{position:absolute;inset:0;display:flex;align-items:center;gap:10px;padding:0 12px;opacity:0;transition:opacity .25s .2s;pointer-events:none;z-index:2}
.island.expanded .island-expanded-state{opacity:1;pointer-events:auto}
.island-album{width:34px;height:34px;border-radius:6px;background:var(--grey-800);overflow:hidden;flex-shrink:0;border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center}
.album-vinyl{width:18px;height:18px;border-radius:50%;background:conic-gradient(#222 0deg,#333 90deg,#1a1a1a 180deg,#333 270deg);animation:spin 3s linear infinite;border:2px solid #3a3a3a}
@keyframes spin{to{transform:rotate(360deg)}}
.island-text{flex:1;min-width:0}
.island-track{font-size:10.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.island-artist{font-family:var(--font-mono);font-size:8.5px;color:var(--grey-400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.island-bars{display:flex;align-items:flex-end;gap:2px;height:14px}
.island-bars span{display:block;width:2px;background:var(--white);border-radius:1px;animation:bars .7s ease-in-out infinite alternate;opacity:.6}
.island-bars span:nth-child(1){height:5px}.island-bars span:nth-child(2){height:12px;animation-delay:.1s}
.island-bars span:nth-child(3){height:9px;animation-delay:.2s}.island-bars span:nth-child(4){height:14px;animation-delay:.3s}
.island-bars span:nth-child(5){height:7px;animation-delay:.4s}
@keyframes bars{from{transform:scaleY(.25)}to{transform:scaleY(1)}}
.island-spotify-icon{color:var(--spotify);flex-shrink:0}

/* ── CORNER LABELS ── */
.corner-label{position:fixed;z-index:100;opacity:.35}
.corner-tl{top:18px;left:72px}
.corner-tr{top:18px;right:24px}
.mono-xs{font-family:var(--font-mono);font-size:9px;color:var(--grey-400);letter-spacing:.15em;text-transform:uppercase}

/* ── WRAPPER — content-visibility pour perf ── */
.wrapper{position:relative;z-index:1;max-width:1160px;margin:0 auto;padding:0 40px 60px}

/* ── HERO ── */
.hero{display:grid;grid-template-columns:1fr auto 1fr;gap:48px;align-items:center;margin-bottom:80px}
.hero-left{display:flex;flex-direction:column;gap:18px}
.tag-line{display:flex;align-items:center;gap:8px}
.tag-dot{width:6px;height:6px;border-radius:50%;background:var(--white);animation:pulseDot 2.5s ease-in-out infinite}
@keyframes pulseDot{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(255,255,255,.4)}50%{opacity:.4;box-shadow:0 0 0 5px transparent}}
.tag-text{font-family:var(--font-mono);font-size:9.5px;color:var(--grey-400);letter-spacing:.18em;text-transform:uppercase}
.hero-name{font-family:var(--font-display);font-weight:900;font-size:clamp(60px,9vw,110px);line-height:.88;letter-spacing:-3px;display:flex;align-items:flex-end}
.name-char{display:inline-block;animation:nameIn .7s var(--ease-spring) both;animation-delay:calc(var(--i)*.08s + .2s);transition:transform .3s var(--ease-spring),color .2s}
.name-char:hover{transform:translateY(-12px) skewX(-6deg)!important}
@keyframes nameIn{from{transform:translateY(50px) skewX(8deg);opacity:0}to{transform:translateY(0) skewX(0);opacity:1}}
.cursor-blink{display:inline-block;animation:blink 1.1s step-end infinite;color:rgba(255,255,255,.35);margin-left:2px}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.hero-desc{font-size:13.5px;color:var(--grey-400);line-height:1.75;max-width:260px}
.hero-desc .mono{font-family:var(--font-mono);font-size:10px;color:var(--grey-600)}
.hero-tags{display:flex;gap:8px;flex-wrap:wrap}
.badge{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;color:var(--grey-400);border:1px solid var(--border);padding:4px 10px;border-radius:99px;transition:color .2s,border-color .2s,background .2s}
.badge:hover{color:var(--white);border-color:rgba(255,255,255,.25);background:var(--accent-dim)}
.hero-socials{display:flex;gap:8px;flex-wrap:wrap}
.social-link{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;color:var(--grey-400);border:1px solid var(--border);padding:7px 13px;border-radius:var(--radius-sm);transition:all .2s}
.social-link:hover{color:var(--white);border-color:var(--border-hover);background:var(--accent-dim);transform:translateY(-2px)}

/* ═══ HERO GREETING ═══ */
.hero-greeting {
  font-family: var(--font-display);
  font-size: clamp(14px, 2vw, 18px);
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--grey-600);
  margin-bottom: 4px;
  opacity: 0;
  animation: fadeSlideUp .6s var(--ease-spring) .1s forwards;
}
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ═══ HERO LIVE BAR ═══ */
.hero-live-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
  padding: 6px 14px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.04);
  opacity: 0;
  animation: fadeSlideUp .6s var(--ease-spring) .5s forwards;
}
.hlb-clock {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--white);
  letter-spacing: .08em;
}
.hlb-sep { color: var(--grey-700); }
.hlb-date {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--grey-600);
}

/* ═══ TECH STACK ═══ */
.techstack {
  padding: 40px 0 60px;
  max-width: 800px;
  margin: 0 auto;
}
.techstack-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
.tech-item {
  padding: 12px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.04);
  cursor: default;
  transition: all .3s var(--ease-spring);
  opacity: 0;
  transform: translateY(16px);
}
.tech-item.visible {
  opacity: 1;
  transform: translateY(0);
}
.tech-item:hover {
  border-color: rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  transform: translateY(-2px);
}
.tech-icon {
  font-size: 20px;
  margin-bottom: 6px;
}
.tech-name {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--grey-400);
  margin-bottom: 6px;
}
.tech-bar {
  height: 3px;
  border-radius: 2px;
  background: rgba(255,255,255,.06);
  overflow: hidden;
}
.tech-bar-fill {
  height: 100%;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--discord), var(--green));
  width: 0;
  transition: width 1.2s var(--ease-spring);
}
.tech-item.visible .tech-bar-fill {
  /* width set inline */
}
@media(max-width:600px) { .techstack-grid { grid-template-columns: repeat(3, 1fr); } }
@media(max-width:400px) { .techstack-grid { grid-template-columns: repeat(2, 1fr); } }

/* ═══ SECTION INDICATOR ═══ */
.section-indicator {
  position: fixed;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1100;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.si-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.1);
  transition: all .3s var(--ease-spring);
  cursor: pointer;
}
.si-dot:hover {
  background: rgba(255,255,255,.3);
  transform: scale(1.3);
}
.si-dot.active {
  background: var(--white);
  box-shadow: 0 0 12px rgba(255,255,255,.3);
  transform: scale(1.2);
}
@media(pointer:coarse) { .section-indicator { display: none; } }
@media(max-width:900px) { .section-indicator { right: 12px; } }

/* PROFILE CARD */
.profile-scene{perspective:1200px;width:230px;height:310px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:14px}
.profile-card{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .9s cubic-bezier(.34,1.15,.64,1);cursor:pointer}
.profile-card.flipped{transform:rotateY(180deg)}
.card-face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--radius);border:1px solid var(--border);background:var(--grey-900);overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:20px 18px;transition:border-color .3s;contain:layout style}
.card-face:hover{border-color:var(--border-hover)}
.card-face.back{transform:rotateY(180deg);background:#090909}
.card-inner-glow{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(255,255,255,.035) 0%,transparent 65%);pointer-events:none}
.card-noise{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' 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)' opacity='0.04'/%3E%3C/svg%3E");opacity:.5;pointer-events:none}
.card-corner{position:absolute;width:12px;height:12px;pointer-events:none}
.card-corner::before,.card-corner::after{content:'';position:absolute;background:rgba(255,255,255,.2)}
.card-corner::before{width:100%;height:1px;top:0}.card-corner::after{height:100%;width:1px;top:0}
.c-tl{top:10px;left:10px}.c-tr{top:10px;right:10px;transform:scaleX(-1)}.c-bl{bottom:10px;left:10px;transform:scaleY(-1)}.c-br{bottom:10px;right:10px;transform:scale(-1)}
.avatar-wrap{position:relative;width:88px;height:88px}
.avatar{width:88px;height:88px;border-radius:50%;object-fit:cover;object-position:center top;display:block;position:relative;z-index:1}
.avatar-ring-outer{position:absolute;inset:-5px;border-radius:50%;border:1px solid rgba(255,255,255,.12);animation:ringPulse 3s ease-in-out infinite}
.avatar-ring-inner{position:absolute;inset:-10px;border-radius:50%;border:1px solid rgba(255,255,255,.05);animation:ringPulse 3s ease-in-out infinite .6s}
@keyframes ringPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.06);opacity:.4}}
.card-name{font-family:var(--font-display);font-weight:800;font-size:26px;letter-spacing:2px}
.card-status{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:9.5px;color:var(--grey-400)}
.status-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:statusBlink 2.5s ease-in-out infinite}
@keyframes statusBlink{0%,100%{opacity:1}50%{opacity:.4}}
.card-flip-hint{position:absolute;bottom:12px;display:flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:8.5px;color:var(--grey-600);opacity:.5;transition:opacity .2s,color .2s}
.profile-card:hover .card-flip-hint{opacity:1;color:var(--grey-400)}
.discord-back-header{display:flex;align-items:center;gap:6px;color:var(--discord);font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.06em;align-self:flex-start;width:100%}
.dc-user-row{display:flex;align-items:center;gap:10px;width:100%}
.dc-avatar-wrap{position:relative;width:36px;height:36px;flex-shrink:0}
.dc-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover}
.dc-status-dot{position:absolute;bottom:0;right:0;width:9px;height:9px;border-radius:50%;background:var(--green);border:2px solid var(--grey-900)}
.dc-user-info{display:flex;flex-direction:column;gap:1px}
.dc-username{font-size:13px;font-weight:600}.dc-tag{font-family:var(--font-mono);font-size:9px;color:var(--grey-600)}
.discord-activity{display:flex;gap:10px;align-items:flex-start;width:100%;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px}
.activity-emoji{font-size:22px;flex-shrink:0;line-height:1}
.activity-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.activity-label{font-family:var(--font-mono);font-size:7.5px;color:var(--grey-600);letter-spacing:.15em;margin-bottom:2px}
.activity-name{font-size:11.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.activity-detail{font-family:var(--font-mono);font-size:9px;color:var(--grey-400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.activity-timer{font-family:var(--font-mono);font-size:8.5px;color:var(--grey-600)}
.discord-badges{display:flex;gap:6px;align-self:flex-start}
.dc-badge{width:26px;height:26px;border-radius:6px;border:1px solid var(--border);background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;color:var(--grey-400);cursor:default;transition:background .2s,color .2s}
.dc-badge:hover{background:rgba(255,255,255,.08);color:var(--white)}
.profile-name-tag{font-family:var(--font-display);font-weight:800;font-size:13px;letter-spacing:4px;color:var(--grey-600);text-transform:uppercase}
.cursor-blink-sm{animation:blink 1.1s step-end infinite}

/* HERO RIGHT */
.hero-right{display:flex;flex-direction:column;gap:16px}
.specs-block{border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;background:rgba(255,255,255,.018);backdrop-filter:blur(4px);contain:layout style}
.specs-label{font-family:var(--font-mono);font-size:9px;color:var(--grey-600);margin-bottom:12px;letter-spacing:.18em}
.spec-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.035)}
.spec-row:last-child{border-bottom:none;padding-bottom:0}
.spec-key{font-family:var(--font-mono);font-size:9px;color:var(--grey-600);text-transform:uppercase;letter-spacing:.1em}
.spec-val{font-size:11.5px;font-weight:500;color:var(--grey-200);display:flex;align-items:center;gap:6px}
.inline-dot{display:inline-block;width:6px;height:6px;border-radius:50%}
.inline-dot.online{background:var(--green);box-shadow:0 0 6px var(--green);animation:statusBlink 2.5s ease-in-out infinite}
.uptime-block{border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;background:rgba(255,255,255,.018);text-align:center}
.uptime-label{font-family:var(--font-mono);font-size:8.5px;color:var(--grey-600);letter-spacing:.18em;text-transform:uppercase;margin-bottom:6px}
.uptime-value{font-family:var(--font-mono);font-size:24px;color:var(--white);letter-spacing:.08em}

/* DIVIDER */
.section-divider{display:flex;align-items:center;gap:20px;margin:64px 0 48px}
.divider-line{flex:1;height:1px;background:var(--border)}
.divider-text{font-family:var(--font-mono);font-size:9.5px;color:var(--grey-600);letter-spacing:.3em;white-space:nowrap}

/* PERIPHERALS — content-visibility pour les sections hors viewport */
.peripherals{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:80px;content-visibility:auto;contain-intrinsic-size:0 600px}
.periph-card{position:relative;border:1px solid var(--border);border-radius:var(--radius);background:rgba(255,255,255,.018);overflow:hidden;display:flex;flex-direction:column;transition:border-color .3s,transform .4s var(--ease-spring),box-shadow .4s;transform-style:preserve-3d;contain:layout style}
.periph-card:hover{border-color:var(--border-hover);box-shadow:0 24px 64px rgba(0,0,0,.6)}
.periph-card.featured{border-color:rgba(255,255,255,.13)}
.periph-number{position:absolute;top:14px;left:14px;font-family:var(--font-mono);font-size:9.5px;color:var(--grey-700);letter-spacing:.1em;z-index:2}
.featured-badge{position:absolute;top:14px;right:14px;font-family:var(--font-mono);font-size:7.5px;letter-spacing:.2em;color:var(--black);background:var(--white);padding:3px 8px;border-radius:99px;z-index:2;font-weight:700}
.periph-image-wrap{position:relative;height:220px;overflow:hidden;background:var(--grey-900)}
.periph-image-bg{position:absolute;inset:0;background:radial-gradient(circle at 50% 60%,rgba(255,255,255,.04) 0%,transparent 70%)}
.mouse-bg{background:radial-gradient(circle at 50% 60%,rgba(136,100,255,.06) 0%,transparent 70%)}
.periph-glow{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .4s}
.kb-glow{background:radial-gradient(circle at 50% 70%,rgba(255,255,255,.07) 0%,transparent 60%)}
.mouse-glow{background:radial-gradient(circle at 50% 70%,rgba(136,100,255,.1) 0%,transparent 60%)}
.periph-card:hover .periph-glow{opacity:1}
.periph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:24px;transition:transform var(--transition-dur) var(--ease-spring),filter .4s;filter:drop-shadow(0 10px 28px rgba(0,0,0,.7))}
.periph-card:hover .periph-img{transform:scale(1.07) translateY(-6px);filter:drop-shadow(0 16px 40px rgba(0,0,0,.8))}
.periph-image-overlay{position:absolute;bottom:0;left:0;right:0;height:90px;background:linear-gradient(to top,var(--grey-900),transparent)}
.periph-info{padding:18px 20px;flex:1;display:flex;flex-direction:column;gap:8px}
.periph-type{font-family:var(--font-mono);font-size:8.5px;color:var(--grey-600);letter-spacing:.22em;text-transform:uppercase}
.periph-name{font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:.5px;color:var(--white);line-height:1.2}
.periph-name em{font-style:italic;font-weight:400;color:var(--grey-400)}.periph-name strong{color:var(--white)}
.periph-specs-row{display:flex;flex-wrap:wrap;gap:5px}
.pspec{font-family:var(--font-mono);font-size:8.5px;padding:3px 8px;border-radius:4px;border:1px solid var(--border);color:var(--grey-400);background:rgba(255,255,255,.02)}
.periph-rating{display:flex;align-items:center;gap:5px;margin-top:2px}
.star{font-size:12px;color:rgba(255,255,255,.2)}.star.filled{color:var(--white)}.star.dim{color:rgba(255,255,255,.15)}
.rating-num{font-family:var(--font-mono);font-size:10px;color:var(--grey-600);margin-left:4px}
.periph-hover-details{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.95) 80%,transparent);padding:30px 20px 20px;transform:translateY(100%);transition:transform .4s var(--ease-spring);z-index:3}
.periph-card:hover .periph-hover-details{transform:translateY(0)}
.d-row{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.d-row:last-child{border-bottom:none}
.dk{font-family:var(--font-mono);font-size:8.5px;color:var(--grey-600)}.dv{font-family:var(--font-mono);font-size:8.5px;color:var(--grey-200)}

/* CONFIG */
.config-section{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:80px;content-visibility:auto;contain-intrinsic-size:0 200px}
.config-block{border:1px solid var(--border);border-radius:var(--radius);padding:24px;background:rgba(255,255,255,.018);display:flex;flex-direction:column;gap:16px;transition:border-color .3s}
.config-block:hover{border-color:rgba(255,255,255,.12)}
.config-icon{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.config-icon svg{width:16px;height:16px}
.spotify-icon{color:var(--spotify);background:rgba(29,185,84,.08);border-color:rgba(29,185,84,.2)}
.discord-icon{color:var(--discord);background:rgba(88,101,242,.08);border-color:rgba(88,101,242,.2)}
.config-head{display:flex;flex-direction:column;gap:4px}
.config-title{font-family:var(--font-mono);font-size:11px;color:var(--grey-200);letter-spacing:.05em}
.config-desc{font-size:11.5px;color:var(--grey-600);line-height:1.6}
.config-fields{display:flex;flex-direction:column;gap:8px}
.lanyard-status{gap:8px}
.lanyard-info-row{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--accent-dim);border:1px solid var(--border);border-radius:var(--radius-sm)}
.lanyard-label{font-family:var(--font-mono);font-size:9px;color:var(--grey-400);text-transform:uppercase;letter-spacing:.1em;min-width:50px}
.lanyard-val{font-family:var(--font-mono);font-size:11px;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.live-dot-inline{display:inline-block;width:6px;height:6px;background:var(--spotify);border-radius:50%;animation:pulseLive 1.5s ease-in-out infinite;vertical-align:middle;margin:0 1px}
@keyframes pulseLive{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

/* FOOTER */
.footer{display:flex;align-items:center;justify-content:space-between;padding:24px 0;border-top:1px solid var(--border);gap:16px}
.footer-left{display:flex;align-items:center;gap:10px}
.footer-name{font-family:var(--font-display);font-weight:800;font-size:16px;letter-spacing:3px}
.footer-sep{color:var(--grey-700)}.footer-year{font-family:var(--font-mono);font-size:11px;color:var(--grey-600)}
.footer-center{font-family:var(--font-mono);font-size:9px;color:var(--grey-700);letter-spacing:.15em}
.footer-right{font-family:var(--font-mono);font-size:10px;color:var(--grey-600)}

/* ANIMATIONS */
[data-anim]{opacity:0;transform:translateY(22px);transition:opacity .75s ease,transform .75s ease;transition-delay:var(--delay,0s)}
[data-anim].visible{opacity:1;transform:translateY(0)}

/* ══ TOAST + EASTER EGG ══ */

/* ══ SCROLL TO TOP ══ */
.scroll-top {
  position: fixed; bottom: 24px; right: 24px; z-index: 1100;
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(0,0,0,.85); border: 1px solid var(--border);
  color: var(--white); display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(12px);
  opacity: 0; transform: translateY(16px);
  transition: all .3s var(--ease-spring);
  pointer-events: none;
  cursor: pointer;
}
.scroll-top.visible {
  opacity: 1; transform: translateY(0); pointer-events: auto;
}
.scroll-top:hover {
  border-color: var(--border-hover); background: rgba(255,255,255,.1);
  transform: translateY(-2px);
}
@media(pointer:coarse) {
  .scroll-top { bottom: 20px; right: 16px; width: 44px; height: 44px; }
}

/* ══ COMMAND PALETTE ══ */
.cmd-overlay {
  position: fixed; inset: 0; z-index: 5000;
  background: rgba(0,0,0,.7); backdrop-filter: blur(8px);
  opacity: 0; pointer-events: none;
  transition: opacity .2s ease;
}
.cmd-overlay.open { opacity: 1; pointer-events: auto; }
.cmd-palette {
  position: fixed; top: 20%; left: 50%; transform: translateX(-50%) translateY(8px);
  z-index: 5001; width: 480px; max-width: 92vw;
  background: #0e0e0e; border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px; overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,.8), 0 0 0 1px rgba(255,255,255,.05);
  opacity: 0; pointer-events: none;
  transition: opacity .2s ease, transform .2s var(--ease-spring);
}
.cmd-palette.open { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
.cmd-search {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px; border-bottom: 1px solid rgba(255,255,255,.08);
  color: var(--grey-400);
}
.cmd-input {
  flex: 1; background: none; border: none; outline: none;
  color: var(--white); font-family: var(--font-mono); font-size: 13px;
  caret-color: var(--white);
}
.cmd-input::placeholder { color: var(--grey-700); }
.cmd-esc {
  font-family: var(--font-mono); font-size: 9px; padding: 2px 6px;
  border-radius: 4px; background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1); color: var(--grey-600);
}
.cmd-results {
  max-height: 320px; overflow-y: auto; padding: 6px;
  scrollbar-width: thin; scrollbar-color: var(--grey-700) transparent;
}
.cmd-results::-webkit-scrollbar { width: 2px; }
.cmd-results::-webkit-scrollbar-thumb { background: var(--grey-700); }
.cmd-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: 8px; cursor: pointer;
  transition: background .12s;
}
.cmd-item:hover, .cmd-item.active { background: rgba(255,255,255,.06); }
.cmd-item-icon {
  width: 28px; height: 28px; border-radius: 6px;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.06);
  display: flex; align-items: center; justify-content: center;
  color: var(--grey-400); flex-shrink: 0;
}
.cmd-item-text { flex: 1; min-width: 0; }
.cmd-item-name { font-size: 12.5px; color: var(--white); font-weight: 500; }
.cmd-item-desc { font-family: var(--font-mono); font-size: 9px; color: var(--grey-600); margin-top: 1px; }
.cmd-item-shortcut { font-family: var(--font-mono); font-size: 9px; color: var(--grey-700); flex-shrink: 0; }
.cmd-item-shortcut kbd {
  padding: 1px 5px; border-radius: 3px; background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08); margin-left: 3px;
}
.cmd-section { padding: 6px 12px 4px; font-family: var(--font-mono); font-size: 8px; color: var(--grey-700); letter-spacing: .15em; text-transform: uppercase; }

/* ══ MATRIX CANVAS ══ */
.matrix-canvas {
  position: fixed; inset: 0; width: 100%; height: 100%;
  z-index: 9999; pointer-events: none; opacity: 0;
  transition: opacity .5s;
}
.matrix-canvas.active { opacity: 1; }

/* ══ CURSOR GLOW ══ */
.cursor-glow {
  position: fixed; width: 300px; height: 300px;
  border-radius: 50%; pointer-events: none; z-index: 0;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(255,255,255,.03) 0%, transparent 70%);
  opacity: 0; transition: opacity .4s;
  will-change: left, top;
}
.cursor-glow.visible { opacity: 1; }
@media(pointer:coarse) { .cursor-glow { display: none; } }
.easter-egg{position:fixed;bottom:24px;right:24px;background:var(--grey-900);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 16px;font-family:var(--font-mono);font-size:10px;z-index:2000;transform:translateY(80px);opacity:0;transition:all .5s var(--ease-spring);pointer-events:none}
.easter-egg.show{transform:translateY(0);opacity:1}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:rgba(10,10,10,.95);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 18px;font-family:var(--font-mono);font-size:9.5px;z-index:3000;opacity:0;transition:all .4s var(--ease-spring);pointer-events:none;white-space:nowrap;backdrop-filter:blur(20px)}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}

/* ══ RESPONSIVE — Mobile-first approach ══ */

/* ── TABLETTE (≤1100px) ── */
@media(max-width:1100px) {
  .hero { grid-template-columns: 1fr auto; }
  .hero-right { display: none; }
}

/* ── MOBILE LANDSCAPE / TABLETTE PETIT (≤900px) ── */
@media(max-width:900px) {
  .hero { grid-template-columns: 1fr; justify-items: center; text-align: center; gap: 36px; }
  .hero-left { align-items: center; }
  .hero-desc { text-align: center; }
  .hero-socials, .hero-tags { justify-content: center; }
  .peripherals { grid-template-columns: 1fr 1fr; }
  .config-section { grid-template-columns: 1fr 1fr; }
  .projects { grid-template-columns: 1fr 1fr; }
  :root { --sidebar-w: 280px; }
  .island { width: 100px; height: 28px; }
  .island.expanded { width: 260px; height: 52px; }
  .island-track { font-size: 9.5px; }
  .island-artist { font-size: 8px; }
}

/* ── MOBILE PORTRAIT (≤700px) ── */
@media(max-width:700px) {
  .wrapper { padding: 80px 16px 40px; }
  .hero-name { font-size: clamp(48px, 14vw, 80px); letter-spacing: -2px; }
  .profile-scene { width: 180px; height: 250px; }
  .avatar-wrap { width: 72px; height: 72px; }
  .avatar { width: 72px; height: 72px; }
  .card-name { font-size: 22px; }
  .corner-label { display: none; }
  .peripherals { grid-template-columns: 1fr; }
  .config-section { grid-template-columns: 1fr; }
  .projects { grid-template-columns: 1fr; }
  .footer { flex-direction: column; gap: 8px; text-align: center; }
  .footer-center { display: none; }
  .section-divider { margin: 40px 0 32px; }
  .hero { margin-bottom: 50px; }
  .periph-image-wrap { height: 180px; }
  .periph-name { font-size: 17px; }
  .config-block { padding: 18px 16px; }
  .project-card { padding: 18px 16px; }
  .project-name { font-size: 14px; }
  .project-desc { font-size: 12px; }

  /* Island mobile */
  .island-wrapper { top: 10px; }
  .island { width: 80px; height: 26px; border-radius: 20px; }
  .island.expanded { width: 240px; height: 48px; border-radius: 22px; padding: 0 10px; }
  .island-album { width: 28px; height: 28px; border-radius: 5px; }
  .island-bars { height: 12px; }
  .island-spotify-icon svg { width: 12px; height: 12px; }

  /* Hamburger mobile */
  .hamburger { top: 10px; left: 14px; width: 36px; height: 36px; }

  /* Sidebar mobile */
  :root { --sidebar-w: 260px; }
  .sb-block { padding: 8px 12px; }
  .sb-section-label { font-size: 7.5px; }

  /* Calculator mobile */
  .sb-calc-btn { padding: 10px 4px; font-size: 13px; }

  /* Countdown mobile */
  .sb-cd-num { font-size: 18px; }

  /* Periph hover details — always show on touch */
  .periph-hover-details { transform: translateY(0); background: linear-gradient(to top,rgba(0,0,0,.9) 60%,transparent); padding: 16px 16px 14px; }
  .periph-card:hover .periph-hover-details { transform: translateY(0); }
}

/* ── MOBILE PETIT (≤480px) ── */
@media(max-width:480px) {
  .wrapper { padding: 72px 12px 32px; }
  .hero-name { font-size: clamp(42px, 16vw, 64px); letter-spacing: -1px; }
  .hero-desc { font-size: 12.5px; }
  .hero-socials { flex-direction: column; align-items: center; gap: 6px; }
  .social-link { width: 100%; max-width: 200px; justify-content: center; }
  .hero-tags { gap: 5px; }
  .badge { font-size: 8px; padding: 3px 8px; }
  .profile-scene { width: 160px; height: 226px; gap: 10px; }
  .profile-name-tag { font-size: 11px; letter-spacing: 3px; }
  .tag-line { gap: 6px; }
  .tag-text { font-size: 8.5px; }

  /* Periph cards compact */
  .periph-image-wrap { height: 150px; }
  .periph-info { padding: 14px 14px; gap: 6px; }
  .periph-type { font-size: 7.5px; }
  .periph-name { font-size: 15px; }
  .periph-specs-row { gap: 3px; }
  .pspec { font-size: 7.5px; padding: 2px 6px; }

  /* Project cards compact */
  .project-card { padding: 14px; gap: 8px; }
  .project-icon { width: 28px; height: 28px; }
  .project-name { font-size: 13px; }
  .project-tags { gap: 3px; }

  /* Island ultra compact */
  .island { width: 70px; height: 24px; }
  .island.expanded { width: 220px; height: 44px; }
  .island-track { font-size: 9px; }
  .island-artist { font-size: 7.5px; }
  .island-album { width: 24px; height: 24px; }

  /* Footer mobile */
  .footer { padding: 16px 0; }
  .footer-name { font-size: 14px; }
}

/* ── MOBILE TRÈS PETIT (≤360px) ── */
@media(max-width:360px) {
  .hero-name { font-size: 38px; }
  .profile-scene { width: 140px; height: 200px; }
  .avatar-wrap { width: 60px; height: 60px; }
  .avatar { width: 60px; height: 60px; }
  .card-name { font-size: 18px; }
  .island { width: 60px; height: 22px; }
  .island.expanded { width: 200px; height: 40px; }
}

/* ── TOUCH DEVICES ── */
@media(pointer:coarse) {
  .cursor, .cursor-trail { display: none !important; }
  body { cursor: auto; }
  button, a { cursor: pointer; }
  /* Bigger touch targets */
  .sb-link { padding: 10px 12px; }
  .sb-social-btn { padding: 10px 12px; }
  .sb-toggle-row { padding: 10px 12px; }
  .sb-calc-btn { min-height: 44px; }
  .sb-pomo-btn { width: 32px; height: 32px; }
  .sb-small-btn { padding: 9px 14px; }
  .badge { padding: 5px 12px; }
  .social-link { padding: 9px 16px; }
  /* Hide hover effects on touch */
  .periph-hover-details { transform: translateY(0) !important; opacity: 1 !important; }
  .periph-card:hover { transform: none !important; box-shadow: none !important; }
  .periph-card:hover .periph-img { transform: none !important; }
  .periph-card:hover .periph-glow { opacity: 0 !important; }
}

/* ── LANDSCAPE MOBILE ── */
@media(max-height:500px) and (orientation:landscape) {
  .wrapper { padding: 60px 20px 30px; }
  .hero { grid-template-columns: auto 1fr; gap: 24px; margin-bottom: 30px; }
  .hero-left { text-align: left; align-items: flex-start; }
  .hero-socials, .hero-tags { justify-content: flex-start; }
  .profile-scene { width: 140px; height: 200px; }
  .section-divider { margin: 24px 0 20px; }
  .live-dashboard, .currently, .live-stats, .techstack { padding: 0 0 20px; }
}

/* ── NEW SECTIONS MOBILE ── */
@media(max-width:900px) {
  .dash-grid { grid-template-columns: repeat(2, 1fr); }
  .dash-card-wide { grid-column: span 2; }
  .curr-grid { grid-template-columns: repeat(2, 1fr); }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .techstack-grid { grid-template-columns: repeat(3, 1fr); }
  .hero-live-bar { flex-wrap: wrap; justify-content: center; }
}
@media(max-width:700px) {
  .dash-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .dash-card { padding: 12px; }
  .dash-icon { font-size: 16px; margin-bottom: 4px; }
  .dash-value { font-size: 11px; }
  .curr-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .curr-item { padding: 12px; }
  .curr-icon { font-size: 16px; margin-bottom: 4px; }
  .stats-grid { grid-template-columns: repeat(4, 1fr); gap: 8px; }
  .stat-item { padding: 14px 6px; }
  .stat-num { font-size: 22px; }
  .stat-label { font-size: 7px; }
  .techstack-grid { grid-template-columns: repeat(3, 1fr); gap: 6px; }
  .tech-item { padding: 10px 8px; }
  .tech-icon { font-size: 16px; margin-bottom: 4px; }
  .tech-name { font-size: 9px; }
  .hero-greeting { font-size: 12px; }
  .hlb-clock { font-size: 11px; }
  .hlb-date { font-size: 9px; }
  .hero-live-bar { padding: 5px 10px; gap: 8px; }
}
@media(max-width:480px) {
  .dash-grid { grid-template-columns: 1fr; }
  .dash-card-wide { grid-column: span 1; }
  .curr-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .techstack-grid { grid-template-columns: repeat(2, 1fr); }
  .stat-num { font-size: 20px; }
  .section-indicator { display: none !important; }
  .wpm-display { bottom: 12px; left: 12px; }
  .heatmap-toggle { bottom: 60px; left: 12px; }
}
@media(max-width:360px) {
  .dash-grid { gap: 6px; }
  .techstack-grid { grid-template-columns: repeat(2, 1fr); gap: 4px; }
  .tech-item { padding: 8px 6px; }
  .stat-num { font-size: 18px; }
}

/* ── DARK MODE HIGH CONTRAST ── */
@media(prefers-contrast:high) {
  :root {
    --border: rgba(255,255,255,.2);
    --border-hover: rgba(255,255,255,.4);
  }
}

/* ── REDUCED MOTION ── */
@media(prefers-reduced-motion:reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-delay: 0ms !important;
    transition-duration: 0.15s !important;
  }
  [data-anim] { opacity: 1; transform: none; }
  .profile-card { transition: none !important; }
}

/* ── SAFE AREA (notch phones) ── */
@supports(padding: env(safe-area-inset-top)) {
  .hamburger { top: calc(10px + env(safe-area-inset-top)); }
  .island-wrapper { top: calc(10px + env(safe-area-inset-top)); }
  .corner-tr { top: calc(18px + env(safe-area-inset-top)); }
  .sidebar { padding-top: env(safe-area-inset-top); }
  .wrapper { padding-bottom: calc(40px + env(safe-area-inset-bottom)); }
}

/* ══════════════════════════════════════════════
   PERF — optimisations globales supplémentaires
══════════════════════════════════════════════ */

/* GPU layers uniquement sur ce qui en a besoin */
.island, .cursor, .cursor-trail { will-change: transform; }

.grain { will-change: contents; }

/* Évite les repaints sur les éléments fixes */
.corner-label, .hamburger, .island-wrapper, .perf-badge,
.cursor, .cursor-trail { contain: layout style; }

/* Évite le layout thrash dans les listes */
.sb-block { contain: layout style; }
.periph-card { contain: layout style paint; }
.config-block { contain: layout style; }

/* Font display swap pour éviter FOUT */
@font-face { font-display: swap; }

/* Optimise les images */
img { content-visibility: auto; }
.avatar, .dc-avatar, .sb-pfp, .sb-gh-avatar, .periph-img {
  image-rendering: auto;
  decoding: async;
}

/* Scrollbar thin partout pour perf */
* { scrollbar-width: thin; }

/* Prevent reflow on hover for social links */
.social-link, .sb-social-btn, .badge { backface-visibility: hidden; }

/* ══ MICRO-INTERACTIONS ══ */
/* Smooth hover lift for all interactive cards */
.periph-card, .project-card, .config-block, .specs-block, .uptime-block {
  transition: transform .35s var(--ease-spring), border-color .3s, box-shadow .4s;
}
.periph-card:hover, .project-card:hover {
  transform: translateY(-4px);
}
.config-block:hover, .specs-block:hover {
  border-color: rgba(255,255,255,.15);
}

/* Button press effect */
.sb-small-btn:active, .sb-overclock-btn:active, .sb-share-btn:active, .sb-quote-btn:active {
  transform: scale(.96);
}

/* Badge hover glow */
.badge:hover {
  box-shadow: 0 0 12px rgba(255,255,255,.06);
}

/* Social link icon bounce on hover */
.social-link:hover svg, .sb-social-btn:hover svg {
  animation: iconBounce .4s ease;
}
@keyframes iconBounce {
  0%, 100% { transform: translateY(0); }
  40% { transform: translateY(-3px); }
  60% { transform: translateY(-1px); }
}

/* Island micro-interaction */
.island:hover { box-shadow: 0 0 0 1px rgba(255,255,255,.15), 0 8px 40px rgba(0,0,0,.9); }

/* Card corner glow on hover */
.card-face:hover .card-inner-glow { opacity: 1.5; }

/* Smooth status dot pulse */
.status-dot { transition: background .4s, box-shadow .4s; }

/* ══════════════════════════════════════════════
   CARD BACK — Image + Discord overlay
══════════════════════════════════════════════ */
.card-back-img {
  padding: 0 !important;
  overflow: hidden;
  background: #000 !important;
}
.card-back-photo {
  position: absolute; inset: 0;
  background: url('card-back.jpg') center/cover no-repeat;
  transform: rotateY(180deg); /* compensate for parent backface */
  z-index: 0;
  filter: brightness(.75) saturate(.9);
}
.card-back-overlay {
  position: absolute; inset: 0;
  z-index: 1;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,.72) 0%,
    rgba(0,0,0,.35) 30%,
    rgba(0,0,0,.3) 60%,
    rgba(0,0,0,.82) 100%
  );
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; padding: 20px 18px;
  backdrop-filter: blur(1px);
}
/* Keep existing Discord elements readable over photo */
.card-back-overlay .discord-back-header { color: #7289da; }
.card-back-overlay .discord-activity {
  background: rgba(0,0,0,.45);
  border-color: rgba(255,255,255,.12);
  backdrop-filter: blur(8px);
}
.card-back-overlay .dc-badge {
  background: rgba(0,0,0,.5);
  backdrop-filter: blur(4px);
}

/* ══ SPOTIFY ACTIVE ON CARD ══ */
.dc-spotify-active {
  background: rgba(29,185,84,.15) !important;
  border-color: rgba(29,185,84,.3) !important;
}
.dc-spotify-bars {
  display: flex; align-items: flex-end; gap: 2px; height: 16px; margin-left: auto;
}
.dc-spotify-bars span {
  display: block; width: 3px; background: #1DB954; border-radius: 1px;
  animation: bars .7s ease-in-out infinite alternate;
}
.dc-spotify-bars span:nth-child(1) { height: 5px; }
.dc-spotify-bars span:nth-child(2) { height: 12px; animation-delay: .1s; }
.dc-spotify-bars span:nth-child(3) { height: 8px; animation-delay: .2s; }
.dc-spotify-bars span:nth-child(4) { height: 14px; animation-delay: .3s; }

/* ══ IDLE / OFFLINE BLOCK ══ */
.discord-idle {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 12px; opacity: .7;
}
.dc-idle-icon { font-size: 24px; }
.dc-idle-text {
  font-family: var(--font-mono); font-size: 9px;
  color: var(--grey-400); letter-spacing: .1em;
}

/* ══ CURSOR RIPPLE ══ */
.cursor-ripple {
  position: fixed; width: 10px; height: 10px;
  border-radius: 50%; pointer-events: none; z-index: 9997;
  transform: translate(-50%, -50%) scale(1);
  animation: rippleOut .6s ease-out forwards;
  mix-blend-mode: difference;
}
@keyframes rippleOut {
  0% { transform: translate(-50%, -50%) scale(1); opacity: .5; border: 2px solid var(--white); }
  100% { transform: translate(-50%, -50%) scale(12); opacity: 0; border: 1px solid var(--white); }
}

/* ══ HOLOGRAPHIC CARD EFFECT ══ */
.profile-card::before {
  content: ''; position: absolute; inset: 0;
  border-radius: var(--radius); z-index: 10; pointer-events: none;
  background: linear-gradient(
    125deg,
    rgba(255,0,0,.06) 0%,
    rgba(255,154,0,.06) 15%,
    rgba(208,222,33,.06) 30%,
    rgba(79,220,74,.06) 45%,
    rgba(63,218,216,.06) 60%,
    rgba(47,201,226,.06) 75%,
    rgba(28,127,238,.06) 85%,
    rgba(95,21,242,.06) 100%
  );
  opacity: 0; transition: opacity .4s;
  background-size: 200% 200%;
  animation: holoShift 4s ease-in-out infinite alternate;
}
.profile-card:hover::before { opacity: 1; }
@keyframes holoShift {
  0% { background-position: 0% 50%; }
  100% { background-position: 100% 50%; }
}

/* ══ AMBIENT STATUS GLOW — card gets colored by Discord status ══ */
.profile-card.status-online { box-shadow: 0 0 40px rgba(35,165,90,.12); }
.profile-card.status-idle { box-shadow: 0 0 40px rgba(240,178,50,.12); }
.profile-card.status-dnd { box-shadow: 0 0 40px rgba(242,63,67,.12); }
.profile-card.status-offline { box-shadow: none; }

/* ══════════════════════════════════════════════
   SCROLL PROGRESS BAR
══════════════════════════════════════════════ */

/* ══════════════════════════════════════════════
   PROJECTS SECTION
══════════════════════════════════════════════ */
.projects {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 80px;
}
.project-card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px 20px;
  background: rgba(255,255,255,.018);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: border-color .3s, transform .4s var(--ease-spring), box-shadow .4s;
  contain: layout style;
}
.project-card:hover {
  border-color: var(--border-hover);
  transform: translateY(-4px);
  box-shadow: 0 20px 50px rgba(0,0,0,.5);
}
.project-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.project-icon {
  width: 32px; height: 32px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  display: flex; align-items: center; justify-content: center;
  color: var(--grey-400);
}
.project-badge {
  font-family: var(--font-mono); font-size: 7.5px;
  letter-spacing: .15em; color: var(--green);
  border: 1px solid rgba(87,242,135,.25);
  background: rgba(87,242,135,.08);
  padding: 2px 8px; border-radius: 99px;
}
.project-name {
  font-family: var(--font-display); font-weight: 700;
  font-size: 16px; letter-spacing: .5px; color: var(--white);
}
.project-desc {
  font-size: 12.5px; color: var(--grey-400); line-height: 1.65;
}
.project-tags {
  display: flex; flex-wrap: wrap; gap: 4px;
}
.project-links {
  margin-top: auto; padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,.04);
}
.project-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 9.5px;
  color: var(--grey-400); transition: color .2s;
}
.project-link:hover { color: var(--white); }
.project-link-primary {
  color: var(--white); background: rgba(255,255,255,.08);
  padding: 6px 12px; border-radius: var(--radius-sm);
  border: 1px solid rgba(255,255,255,.15);
  transition: all .25s;
}
.project-link-primary:hover {
  background: rgba(255,255,255,.15); border-color: rgba(255,255,255,.3);
  transform: translateY(-1px);
}
.project-featured {
  border-color: rgba(255,255,255,.15);
  position: relative; overflow: hidden;
}
.project-featured:hover { border-color: rgba(255,255,255,.3); }
.project-glow {
  position: absolute; bottom: -40px; left: 50%; transform: translateX(-50%);
  width: 200px; height: 80px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(255,255,255,.06) 0%, transparent 70%);
  pointer-events: none; opacity: 0; transition: opacity .4s;
}
.project-featured:hover .project-glow { opacity: 1; }

/* ══════════════════════════════════════════════
   KEYBOARD SHORTCUTS
══════════════════════════════════════════════ */
.sb-shortcuts { display: flex; flex-direction: column; gap: 3px; }
.sb-sc-row {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 8px; border-radius: 6px;
  transition: background .2s;
}
.sb-sc-row:hover { background: rgba(255,255,255,.03); }
.sb-sc-row kbd {
  font-family: var(--font-mono); font-size: 9px;
  padding: 2px 6px; border-radius: 4px;
  background: var(--grey-900); border: 1px solid var(--border);
  color: var(--grey-200); min-width: 22px; text-align: center;
}
.sb-sc-row span {
  font-family: var(--font-mono); font-size: 8.5px; color: var(--grey-600);
}

/* ══════════════════════════════════════════════
   NOTES EXPORT BUTTON
══════════════════════════════════════════════ */
.sb-notes-actions { display: flex; gap: 6px; }

/* ══════════════════════════════════════════════
   COUNTDOWN TIMER
══════════════════════════════════════════════ */
.sb-countdown { display: flex; flex-direction: column; gap: 8px; }
.sb-cd-inputs { display: flex; flex-direction: column; gap: 5px; }
.sb-cd-input {
  background: rgba(255,255,255,.03); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--white);
  font-family: var(--font-mono); font-size: 9px; padding: 7px 10px;
  outline: none; transition: border-color .2s; width: 100%;
}
.sb-cd-input::placeholder { color: var(--grey-700); }
.sb-cd-input:focus { border-color: rgba(255,255,255,.2); }
.sb-cd-date { color-scheme: dark; }
.sb-cd-display {
  text-align: center; padding: 10px;
  background: rgba(255,255,255,.03); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.sb-cd-text {
  font-family: var(--font-mono); font-size: 9px;
  color: var(--grey-400); margin-bottom: 6px;
}
.sb-cd-time {
  display: flex; align-items: center; justify-content: center; gap: 4px;
}
.sb-cd-unit { display: flex; flex-direction: column; align-items: center; }
.sb-cd-num {
  font-family: var(--font-mono); font-size: 22px;
  font-weight: 700; letter-spacing: .05em; line-height: 1;
}
.sb-cd-lbl {
  font-family: var(--font-mono); font-size: 7px;
  color: var(--grey-600); margin-top: 2px;
}
.sb-cd-sep {
  font-family: var(--font-mono); font-size: 18px;
  color: var(--grey-700); margin: 0 2px;
  align-self: flex-start; margin-top: 2px;
}
.sb-cd-actions { display: flex; gap: 6px; }
.scroll-progress-bar {
  position: fixed; top: 0; left: 0;
  height: 2px; width: 0%;
  background: linear-gradient(90deg, rgba(255,255,255,.5), rgba(255,255,255,.9));
  z-index: 9997;
  transition: width .05s linear;
  transform-origin: left;
  pointer-events: none;
}

/* ══════════════════════════════════════════════
   FPS COUNTER
══════════════════════════════════════════════ */
.sb-fps-wrap { display: flex; flex-direction: column; gap: 5px; }
.sb-fps-main { display: flex; align-items: baseline; gap: 4px; }
.sb-fps-val { font-family: var(--font-display); font-size: 30px; font-weight: 900; letter-spacing: -1px; line-height: 1; transition: color .3s; }
.sb-fps-unit { font-family: var(--font-mono); font-size: 9px; color: var(--grey-600); }
.sb-fps-bars { display: flex; align-items: flex-end; gap: 3px; height: 28px; }
.sb-fps-bar { width: 100%; background: rgba(255,255,255,.15); border-radius: 1px; transition: height .15s ease, background .3s; flex: 1; }
.sb-fps-meta { font-family: var(--font-mono); font-size: 8px; color: var(--grey-700); }

/* ══════════════════════════════════════════════
   CALCULATOR
══════════════════════════════════════════════ */
.sb-calc { display: flex; flex-direction: column; gap: 6px; }
.sb-calc-screen {
  background: rgba(255,255,255,.04); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 10px 12px;
  font-family: var(--font-display); font-size: 22px; font-weight: 700;
  text-align: right; letter-spacing: -0.5px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  min-height: 46px; display: flex; align-items: center; justify-content: flex-end;
  transition: background .15s;
}
.sb-calc-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px;
}
.sb-calc-btn {
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.07);
  border-radius: 7px; padding: 9px 4px;
  font-family: var(--font-mono); font-size: 12px; color: var(--white);
  transition: background .12s, transform .08s; cursor: pointer;
  line-height: 1;
}
.sb-calc-btn:hover { background: rgba(255,255,255,.12); }
.sb-calc-btn:active { transform: scale(.94); background: rgba(255,255,255,.18); }
.sb-calc-btn.op { color: var(--grey-200); background: rgba(255,255,255,.04); }
.sb-calc-btn.eq { background: rgba(255,255,255,.88); color: #000; font-weight: 700; }
.sb-calc-btn.eq:hover { background: rgba(255,255,255,.95); }
.sb-calc-btn.span2 { grid-column: span 2; }

/* ══════════════════════════════════════════════
   AMBIENT SOUND
══════════════════════════════════════════════ */
.sb-sound { display: flex; flex-direction: column; gap: 8px; }
.sb-sound-btns { display: grid; grid-template-columns: repeat(4,1fr); gap: 4px; }
.sb-sound-btn {
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 8px 4px; border-radius: var(--radius-sm);
  border: 1px solid var(--border); background: rgba(255,255,255,.02);
  font-family: var(--font-mono); font-size: 7.5px; color: var(--grey-400);
  transition: all .18s; line-height: 1;
}
.sb-sound-btn:hover { border-color: var(--border-hover); color: var(--white); background: var(--accent-dim); }
.sb-sound-btn.active { border-color: rgba(255,255,255,.3); color: var(--white); background: rgba(255,255,255,.08); }
.sb-snd-icon { font-size: 16px; }
.sb-sound-vol { display: flex; align-items: center; gap: 8px; }
.sb-snd-lbl { font-family: var(--font-mono); font-size: 8px; color: var(--grey-600); white-space: nowrap; }
.sb-vol-slider {
  flex: 1; -webkit-appearance: none; height: 3px;
  background: var(--grey-800); border-radius: 99px; outline: none;
  cursor: pointer;
}
.sb-vol-slider::-webkit-slider-thumb {
  -webkit-appearance: none; width: 12px; height: 12px;
  border-radius: 50%; background: var(--white); cursor: pointer;
  transition: transform .15s;
}
.sb-vol-slider::-webkit-slider-thumb:hover { transform: scale(1.25); }

/* ══════════════════════════════════════════════
   WORLD CLOCK
══════════════════════════════════════════════ */
.sb-worldclock { display: flex; flex-direction: column; gap: 3px; }
.sb-wc-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 5px 8px; border-radius: 6px; background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.04);
  transition: background .2s;
}
.sb-wc-row:hover { background: rgba(255,255,255,.04); }
.sb-wc-city { font-family: var(--font-mono); font-size: 8.5px; color: var(--grey-400); }
.sb-wc-time { font-family: var(--font-mono); font-size: 10px; color: var(--white); font-weight: 700; letter-spacing: .05em; }

/* ══════════════════════════════════════════════
   COLOR PALETTE GENERATOR
══════════════════════════════════════════════ */
.sb-palette-wrap { display: flex; flex-direction: column; gap: 8px; }
.sb-palette-swatches { display: flex; gap: 4px; height: 44px; border-radius: var(--radius-sm); overflow: hidden; }
.sb-swatch {
  flex: 1; cursor: pointer; transition: flex .3s var(--ease-spring), filter .2s;
  border-radius: 0; position: relative;
}
.sb-swatch:first-child { border-radius: 6px 0 0 6px; }
.sb-swatch:last-child { border-radius: 0 6px 6px 0; }
.sb-swatch:hover { flex: 1.8; filter: brightness(1.1); }
.sb-palette-actions { display: flex; justify-content: space-between; align-items: center; }
.sb-palette-hex { font-family: var(--font-mono); font-size: 9px; color: var(--grey-600); letter-spacing: .06em; }

/* ══════════════════════════════════════════════
   CLICK / SESSION COUNTER
══════════════════════════════════════════════ */
.sb-clicks-wrap { display: flex; flex-direction: column; gap: 6px; }
.sb-clicks-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 4px; }
.sb-click-stat {
  text-align: center; padding: 7px 4px;
  background: rgba(255,255,255,.02); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.sb-click-num { font-family: var(--font-mono); font-size: 13px; font-weight: 700; color: var(--white); }
.sb-click-lbl { font-family: var(--font-mono); font-size: 7px; color: var(--grey-600); margin-top: 1px; }

/* ══════════════════════════════════════════════
   IP INFO
══════════════════════════════════════════════ */
.sb-ip-loading { display: flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 9px; color: var(--grey-600); }
.sb-ip-data { display: flex; flex-direction: column; gap: 3px; }
.sb-ip-row { display: flex; justify-content: space-between; padding: 4px 8px; background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.04); border-radius: 5px; }
.sb-ipk { font-family: var(--font-mono); font-size: 7.5px; color: var(--grey-600); }
.sb-ipv { font-family: var(--font-mono); font-size: 8.5px; color: var(--grey-200); max-width: 150px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ══════════════════════════════════════════════
   STEAM WIDGET
═══════════════════════════════════════════════ */
.sb-steam-widget { display: flex; flex-direction: column; gap: 8px; }
.sb-steam-loading { display: flex; flex-direction: column; gap: 6px; }
.sb-steam-loading .sb-input { width: 100%; }
.sb-steam-header { display: flex; align-items: center; gap: 8px; }
.sb-steam-avatar {
  width: 36px; height: 36px; border-radius: 8px; object-fit: cover;
  border: 2px solid rgba(170,200,255,.2);
}
.sb-steam-info { flex: 1; min-width: 0; }
.sb-steam-name { font-family: var(--font-mono); font-size: 10px; color: var(--white); font-weight: 600; }
.sb-steam-status { font-family: var(--font-mono); font-size: 8px; color: var(--grey-400); }
.sb-steam-level {
  font-family: var(--font-mono); font-size: 8px; color: #66c0f4;
  padding: 2px 6px; border-radius: 4px;
  background: rgba(102,192,244,.1); border: 1px solid rgba(102,192,244,.2);
}
.sb-steam-now {
  padding: 6px 8px; border-radius: var(--radius-sm);
  background: rgba(102,192,244,.04); border: 1px solid rgba(102,192,244,.08);
}
.sb-steam-now-label, .sb-steam-recent-label {
  font-family: var(--font-mono); font-size: 7px; color: var(--grey-600);
  letter-spacing: .12em; text-transform: uppercase; margin-bottom: 4px;
}
.sb-steam-game { font-family: var(--font-mono); font-size: 10px; color: #66c0f4; font-weight: 600; }
.sb-steam-game-hours { font-family: var(--font-mono); font-size: 8px; color: var(--grey-600); margin-top: 2px; }
.sb-steam-recent { display: flex; flex-direction: column; gap: 4px; }
.sb-steam-recent-item {
  display: flex; align-items: center; gap: 6px; padding: 3px 0;
  font-family: var(--font-mono); font-size: 8px; color: var(--grey-400);
}
.sb-steam-recent-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sb-steam-recent-hours { color: var(--grey-600); flex-shrink: 0; }
.sb-steam-stats { display: flex; gap: 6px; }
.sb-steam-stat {
  flex: 1; text-align: center; padding: 5px 4px;
  background: rgba(102,192,244,.03); border: 1px solid rgba(102,192,244,.06);
  border-radius: var(--radius-sm);
}
.sb-ss-num { font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: #66c0f4; display: block; }
.sb-ss-lbl { font-family: var(--font-mono); font-size: 7px; color: var(--grey-600); }
.sb-steam-reset { margin-top: 4px; align-self: flex-end; }

/* ══════════════════════════════════════════════
   INSTAGRAM WIDGET
═══════════════════════════════════════════════ */
.sb-ig-widget { display: flex; flex-direction: column; gap: 8px; }
.sb-ig-loading { display: flex; flex-direction: column; gap: 6px; }
.sb-ig-loading .sb-input { width: 100%; }
.sb-ig-header { display: flex; align-items: center; gap: 8px; }
.sb-ig-avatar {
  width: 36px; height: 36px; border-radius: 50%; object-fit: cover;
  border: 2px solid transparent;
  background-image: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
  background-origin: border-box;
  background-clip: padding-box, border-box;
}
.sb-ig-info { flex: 1; min-width: 0; }
.sb-ig-username { font-family: var(--font-mono); font-size: 10px; color: var(--white); font-weight: 600; }
.sb-ig-fullname { font-family: var(--font-mono); font-size: 8px; color: var(--grey-400); }
.sb-ig-stats { display: flex; gap: 6px; }
.sb-ig-stat {
  flex: 1; text-align: center; padding: 5px 4px;
  background: linear-gradient(135deg, rgba(240,148,51,.04), rgba(220,39,67,.04));
  border: 1px solid rgba(220,39,67,.06);
  border-radius: var(--radius-sm);
}
.sb-is-num { font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: #E1306C; display: block; }
.sb-is-lbl { font-family: var(--font-mono); font-size: 7px; color: var(--grey-600); }
.sb-ig-bio {
  font-family: var(--font-mono); font-size: 8px; color: var(--grey-400);
  padding: 4px 8px; border-radius: var(--radius-sm);
  background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.04);
  line-height: 1.4; max-height: 40px; overflow: hidden;
}
.sb-ig-recent { display: flex; flex-direction: column; gap: 4px; }
.sb-ig-recent-label {
  font-family: var(--font-mono); font-size: 7px; color: var(--grey-600);
  letter-spacing: .12em; text-transform: uppercase;
}
.sb-ig-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 3px; }
.sb-ig-thumb {
  aspect-ratio: 1; border-radius: 4px; object-fit: cover;
  border: 1px solid rgba(255,255,255,.06);
  transition: transform .2s, border-color .2s;
}
.sb-ig-thumb:hover { transform: scale(1.05); border-color: #E1306C; }
.sb-ig-link {
  font-family: var(--font-mono); font-size: 8px; color: #E1306C;
  text-decoration: none; text-align: right;
  transition: color .2s;
}
.sb-ig-link:hover { color: #ff6b9d; }
═══════════════════════════════════════════════ */
.music-bg {
  position: fixed; inset: 0; z-index: -1;
  display: flex; align-items: flex-end; justify-content: center;
  gap: 3px; padding: 0 10%;
  pointer-events: none; opacity: 0;
  transition: opacity .8s;
  mix-blend-mode: screen;
  contain: layout size;
}
.music-bg.active { opacity: .12; }
.music-bar {
  width: 3px; border-radius: 2px;
  background: linear-gradient(to top, var(--spotify), var(--discord), var(--green));
  transition: height .15s ease-out;
  transform-origin: bottom;
}
@keyframes musicPulse {
  0%,100% { transform: scaleY(1); }
  50% { transform: scaleY(1.3); }
}

/* ══════════════════════════════════════════════
   RAINBOW CURSOR TRAIL
═══════════════════════════════════════════════ */
.rainbow-trail {
  position: fixed; inset: 0; z-index: 9998;
  pointer-events: none; overflow: hidden;
}
.trail-dot {
  position: absolute; border-radius: 50%;
  pointer-events: none;
  animation: trailFade .8s ease-out forwards;
}
@keyframes trailFade {
  0% { transform: scale(1); opacity: .8; }
  100% { transform: scale(0); opacity: 0; }
}

/* ══════════════════════════════════════════════
   PARALLAX FLOATING SHAPES
═══════════════════════════════════════════════ */
.parallax-shapes {
  position: fixed; inset: 0; z-index: -1;
  pointer-events: none; overflow: hidden;
  contain: layout size;
}
.p-shape {
  position: absolute;
  border-radius: 50%;
  background: rgba(255,255,255,.015);
  border: 1px solid rgba(255,255,255,.03);
  animation: pFloat 20s ease-in-out infinite;
}
.p-shape-1 { width: 300px; height: 300px; top: 10%; left: 5%; animation-delay: 0s; animation-duration: 25s; }
.p-shape-2 { width: 200px; height: 200px; top: 60%; right: 10%; animation-delay: -5s; animation-duration: 18s; border-radius: 30%; }
.p-shape-3 { width: 150px; height: 150px; top: 30%; right: 30%; animation-delay: -10s; animation-duration: 22s; }
.p-shape-4 { width: 100px; height: 100px; bottom: 20%; left: 20%; animation-delay: -3s; animation-duration: 15s; border-radius: 40%; }
.p-shape-5 { width: 80px; height: 80px; top: 50%; left: 50%; animation-delay: -7s; animation-duration: 30s; }
@keyframes pFloat {
  0%,100% { transform: translate(0, 0) rotate(0deg) scale(1); }
  25% { transform: translate(30px, -40px) rotate(90deg) scale(1.1); }
  50% { transform: translate(-20px, 20px) rotate(180deg) scale(.9); }
  75% { transform: translate(40px, 30px) rotate(270deg) scale(1.05); }
}

/* ══════════════════════════════════════════════
   TYPING SPEED LIVE — WPM
═══════════════════════════════════════════════ */
.wpm-display {
  position: fixed; bottom: 24px; left: 24px; z-index: 1100;
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 10px 14px; border-radius: 12px;
  background: rgba(0,0,0,.8); border: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(12px);
  opacity: 0; transform: translateY(12px);
  transition: all .3s var(--ease-spring);
  pointer-events: none;
}
.wpm-display.visible {
  opacity: 1; transform: translateY(0); pointer-events: auto;
}
.wpm-label {
  font-family: var(--font-mono); font-size: 7px; color: var(--grey-600);
  letter-spacing: .2em; text-transform: uppercase;
}
.wpm-value {
  font-family: var(--font-mono); font-size: 22px; font-weight: 700;
  color: var(--white); line-height: 1;
  text-shadow: 0 0 20px rgba(88,101,242,.4);
}
.wpm-bar {
  width: 60px; height: 3px; border-radius: 2px;
  background: rgba(255,255,255,.06); overflow: hidden;
}
.wpm-bar-fill {
  height: 100%; width: 0%;
  background: linear-gradient(90deg, var(--discord), var(--green));
  border-radius: 2px;
  transition: width .3s;
}
@media(pointer:coarse) { .wpm-display { bottom: 16px; left: 16px; } }

/* ══════════════════════════════════════════════
   KEYBOARD HEATMAP
═══════════════════════════════════════════════ */
.heatmap-toggle {
  position: fixed; bottom: 80px; left: 24px; z-index: 1100;
  width: 36px; height: 36px; border-radius: 10px;
  background: rgba(0,0,0,.8); border: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; cursor: pointer;
  opacity: 0; transform: translateY(12px);
  transition: all .3s var(--ease-spring);
}
.heatmap-toggle.visible { opacity: 1; transform: translateY(0); }
.heatmap-toggle:hover { border-color: var(--border-hover); transform: translateY(-2px); }
.heatmap-panel {
  position: fixed; bottom: 124px; left: 24px; z-index: 1100;
  width: 320px; padding: 14px;
  background: rgba(0,0,0,.92); border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius); backdrop-filter: blur(20px);
  opacity: 0; pointer-events: none;
  transform: translateY(8px) scale(.96);
  transition: all .25s var(--ease-spring);
}
.heatmap-panel.open { opacity: 1; pointer-events: auto; transform: translateY(0) scale(1); }
.heatmap-header {
  font-family: var(--font-mono); font-size: 9px; color: var(--grey-400);
  letter-spacing: .1em; text-transform: uppercase; margin-bottom: 10px;
}
.heatmap-grid {
  display: flex; flex-direction: column; gap: 3px;
  font-family: var(--font-mono); font-size: 8px;
}
.hm-row { display: flex; gap: 3px; justify-content: center; }
.hm-key {
  min-width: 22px; height: 24px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 4px; border: 1px solid rgba(255,255,255,.06);
  color: var(--grey-400); transition: all .2s;
  position: relative;
}
.hm-key.wide { min-width: 32px; }
.hm-key.space { min-width: 120px; }
.hm-key .hm-count {
  position: absolute; top: 1px; right: 2px;
  font-size: 5px; color: var(--grey-700);
}
@media(pointer:coarse) {
  .heatmap-toggle { bottom: 72px; left: 16px; }
  .heatmap-panel { left: 16px; width: calc(100vw - 32px); }
}

/* ══════════════════════════════════════════════
   AURA RING — profil card glow orbit
═══════════════════════════════════════════════ */
.aura-ring {
  position: fixed; top: 50%; left: 50%;
  width: 500px; height: 500px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none; z-index: 0;
  opacity: 0;
  background: conic-gradient(
    from 0deg,
    transparent 0%,
    rgba(88,101,242,.15) 10%,
    transparent 20%,
    rgba(233,69,96,.1) 30%,
    transparent 40%,
    rgba(87,242,135,.1) 50%,
    transparent 60%,
    rgba(29,185,84,.12) 70%,
    transparent 80%,
    rgba(255,200,50,.08) 90%,
    transparent 100%
  );
  filter: blur(40px);
  animation: auraSpin 12s linear infinite;
  transition: opacity 1s;
}
.aura-ring.visible { opacity: 1; }
@keyframes auraSpin {
  0% { transform: translate(-50%, -50%) rotate(0deg); }
  100% { transform: translate(-50%, -50%) rotate(360deg); }
}

/* ══════════════════════════════════════════════
   SCANLINES ENHANCED
═══════════════════════════════════════════════ */
.scanlines {
  position: fixed; inset: 0; z-index: 1;
  pointer-events: none;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0,0,0,.03) 2px,
    rgba(0,0,0,.03) 4px
  );
  animation: scanShift 8s linear infinite;
}
@keyframes scanShift {
  0% { background-position: 0 0; }
  100% { background-position: 0 4px; }
}

/* ══════════════════════════════════════════════
   LIVE ACTIVITY DASHBOARD
   Ce que 3wxy fait EN CE MOMENT
═══════════════════════════════════════════════ */
.live-dashboard {
  padding: 0 0 40px;
  max-width: 900px;
  margin: 0 auto;
}
.dash-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.dash-card {
  padding: 16px;
  border-radius: var(--radius);
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.05);
  transition: all .3s var(--ease-spring);
  cursor: default;
}
.dash-card:hover {
  border-color: rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  transform: translateY(-2px);
}
.dash-card-wide {
  grid-column: span 2;
}
.dash-icon {
  font-size: 18px;
  margin-bottom: 8px;
}
.dash-label {
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--grey-600);
  letter-spacing: .15em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.dash-value {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--white);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dash-sub {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--grey-600);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dash-card.active {
  border-color: rgba(87,242,135,.2);
  box-shadow: 0 0 20px rgba(87,242,135,.05);
}
.dash-card.listening {
  border-color: rgba(29,185,84,.2);
  box-shadow: 0 0 20px rgba(29,185,84,.05);
}
.dash-card.playing {
  border-color: rgba(88,101,242,.2);
  box-shadow: 0 0 20px rgba(88,101,242,.05);
}
@media(max-width:600px) { .dash-grid { grid-template-columns: repeat(2, 1fr); } .dash-card-wide { grid-column: span 2; } }
@media(max-width:400px) { .dash-grid { grid-template-columns: 1fr; } .dash-card-wide { grid-column: span 1; } }

/* ═══ VISUALISER ═══ */
.dash-viz {
  height: 40px;
  display: flex;
  align-items: flex-end;
  gap: 2px;
  margin-top: 8px;
}
.viz-bars {
  display: flex;
  align-items: flex-end;
  gap: 2px;
  width: 100%;
  height: 100%;
}
.viz-bar {
  flex: 1;
  border-radius: 2px 2px 0 0;
  background: linear-gradient(to top, var(--discord), var(--green));
  transition: height .15s ease-out;
  min-height: 2px;
}

/* ══════════════════════════════════════════════
   CURRENTLY — ce que 3wxy fait maintenant
═══════════════════════════════════════════════ */
.currently {
  padding: 0 0 50px;
  max-width: 900px;
  margin: 0 auto;
}
.curr-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.curr-item {
  padding: 16px;
  border-radius: var(--radius);
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.04);
  transition: all .3s var(--ease-spring);
}
.curr-item:hover {
  border-color: rgba(255,255,255,.1);
  background: rgba(255,255,255,.03);
}
.curr-icon {
  font-size: 20px;
  margin-bottom: 8px;
}
.curr-label {
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--grey-600);
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.curr-value {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--white);
  font-weight: 500;
}
@media(max-width:600px) { .curr-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:400px) { .curr-grid { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════════════
   AMBIENT MOOD — background qui change
═══════════════════════════════════════════════ */
.ambient-mood {
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  transition: opacity 2s;
  contain: layout size;
}
.mood-gradient {
  position: absolute;
  inset: 0;
  opacity: .08;
  transition: background 3s ease;
}
.mood-particles {
  position: absolute;
  inset: 0;
  overflow: hidden;
  contain: layout size;
}
.mood-particle {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  animation: moodFloat 20s linear infinite;
}
@keyframes moodFloat {
  0% { transform: translateY(100vh) rotate(0deg); opacity: 0; }
  10% { opacity: .6; }
  90% { opacity: .6; }
  100% { transform: translateY(-10vh) rotate(720deg); opacity: 0; }
}

/* ══════════════════════════════════════════════
   LIVE STATS — compteurs animés
═══════════════════════════════════════════════ */
.live-stats {
  padding: 30px 0 50px;
  max-width: 700px;
  margin: 0 auto;
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.stat-item {
  text-align: center;
  padding: 20px 10px;
  border-radius: var(--radius);
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.04);
  transition: all .3s var(--ease-spring);
}
.stat-item:hover {
  border-color: rgba(255,255,255,.1);
  transform: translateY(-2px);
}
.stat-num {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 900;
  color: var(--white);
  line-height: 1;
  margin-bottom: 6px;
}
.stat-label {
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--grey-600);
  letter-spacing: .12em;
  text-transform: uppercase;
}
@media(max-width:500px) { .stats-grid { grid-template-columns: repeat(2, 1fr); } }

/* ══════════════════════════════════════════════
   MULTI-THEME — presets de couleurs
═══════════════════════════════════════════════ */
.theme-dot {
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.15);
  cursor: pointer;
  transition: all .2s;
}
.theme-dot:hover { transform: scale(1.2); border-color: rgba(255,255,255,.4); }
.theme-dot.active { border-color: var(--white); box-shadow: 0 0 8px rgba(255,255,255,.3); }
body.theme-midnight { --accent: #5865F2; }
body.theme-neon { --accent: #00ff88; }
body.theme-sunset { --accent: #ff6b35; }
body.theme-forest { --accent: #2ecc71; }
body.theme-rose { --accent: #e84393; }

/* ══════════════════════════════════════════════
   FLOATING NOW PLAYING — mini widget scroll
═══════════════════════════════════════════════ */
.floating-np {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(80px);
  z-index: 1100;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px 8px 8px;
  border-radius: 99px;
  background: rgba(10,10,10,.92);
  border: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(20px);
  opacity: 0;
  transition: all .4s var(--ease-spring);
  pointer-events: none;
  cursor: pointer;
}
.floating-np.visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
.floating-np:hover {
  border-color: rgba(29,185,84,.3);
  background: rgba(10,10,10,.96);
}
.fnp-album {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  flex-shrink: 0;
  animation: npSpin 4s linear infinite paused;
}
.floating-np.playing .fnp-album { animation-play-state: running; }
@keyframes npSpin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
.fnp-info { min-width: 0; }
.fnp-track {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--white);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 160px;
}
.fnp-artist {
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--grey-600);
}
.fnp-bars {
  display: flex;
  align-items: flex-end;
  gap: 2px;
  height: 16px;
  flex-shrink: 0;
}
.fnp-bars span {
  width: 2px;
  background: var(--spotify);
  border-radius: 1px;
  height: 4px;
  transition: height .15s;
}
.floating-np.playing .fnp-bars span {
  animation: npBar .6s ease-in-out infinite alternate;
}
.floating-np.playing .fnp-bars span:nth-child(2) { animation-delay: .15s; }
.floating-np.playing .fnp-bars span:nth-child(3) { animation-delay: .3s; }
.floating-np.playing .fnp-bars span:nth-child(4) { animation-delay: .45s; }
@keyframes npBar {
  0% { height: 4px; }
  100% { height: 14px; }
}
@media(pointer:coarse) {
  .floating-np { bottom: 16px; padding: 6px 14px 6px 6px; }
  .fnp-album { width: 28px; height: 28px; }
}

/* ══════════════════════════════════════════════
   WEEKLY ACTIVITY CHART
═══════════════════════════════════════════════ */
.weekly-chart {
  padding: 0 0 50px;
  max-width: 700px;
  margin: 0 auto;
}
.weekly-container {
  padding: 20px;
  border-radius: var(--radius);
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.04);
}
.weekly-bars {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  height: 120px;
  padding-bottom: 4px;
}
.weekly-bar-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  height: 100%;
}
.weekly-bar {
  width: 100%;
  border-radius: 4px 4px 0 0;
  background: linear-gradient(to top, rgba(88,101,242,.3), rgba(88,101,242,.7));
  transition: height .8s var(--ease-spring);
  min-height: 4px;
  position: relative;
}
.weekly-bar.today {
  background: linear-gradient(to top, rgba(87,242,135,.4), rgba(87,242,135,.8));
}
.weekly-bar:hover {
  filter: brightness(1.2);
}
.weekly-bar-val {
  position: absolute;
  top: -16px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--grey-400);
  white-space: nowrap;
}
.weekly-labels {
  display: flex;
  gap: 8px;
  margin-top: 6px;
}
.weekly-label {
  flex: 1;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--grey-600);
}
.weekly-label.today { color: var(--green); }
.weekly-summary {
  display: flex;
  gap: 16px;
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.04);
  justify-content: center;
}
.ws-item { text-align: center; }
.ws-num {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 800;
  color: var(--white);
  display: block;
}
.ws-lbl {
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--grey-600);
}
@media(max-width:500px) {
  .weekly-bars { gap: 4px; height: 80px; }
  .weekly-labels { gap: 4px; }
  .weekly-summary { gap: 10px; flex-wrap: wrap; }
}

/* ══════════════════════════════════════════════
   FOOTER QUOTE
═══════════════════════════════════════════════ */
.footer-quote {
  text-align: center;
  padding: 40px 0 20px;
  max-width: 500px;
  margin: 0 auto;
}
.fq-text {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 700;
  color: var(--grey-400);
  font-style: italic;
  line-height: 1.5;
}
.fq-author {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--grey-700);
  margin-top: 8px;
}
@media(max-width:500px) { .fq-text { font-size: 14px; } }
