/*
Copyright (c) 2024 Keko (مرتضى)
All rights reserved.
*/

#services h2{margin:0 0 16px;color:var(--text);font-size:2rem;font-weight:700;text-align:center}
#services .trust-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:10px 0 18px}
.trust-chip{background:var(--surface-2);border:1px solid var(--hair);color:var(--text);padding:6px 10px;border-radius:999px;font-size:.85rem;font-weight:600}

.reasons-card{background:var(--surface);border:1px solid var(--hair);border-radius:14px;padding:10px 12px;margin:0 0 16px}
.reasons-toggle{display:flex;align-items:center;gap:10px;width:100%;background:transparent;border:0;color:var(--text);font-weight:700;font-size:1rem;cursor:pointer}
.toggle-arrow{margin-left:auto;transition:transform .25s ease}
.reasons-toggle[aria-expanded="true"] .toggle-arrow{transform:rotate(180deg)}
.reasons-body{padding:8px 4px 0}
.reasons-list{margin:0;padding-left:18px;color:var(--muted);line-height:1.6}
.reasons-list strong{color:var(--text)}
#services ul{list-style:none;padding:0;margin:0 0 28px;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px}
#services ul li{background:var(--surface);border:1px solid var(--hair);border-radius:14px;padding:14px 16px;line-height:1.6;color:var(--text);transition:all .25s ease}
#services ul li strong{color:var(--accent)}
#services ul li:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(0,0,0,.08);border-color:var(--accent)}

.cta-row{display:flex;justify-content:center;margin:8px 0 12px}
.btn{display:inline-flex;align-items:center;gap:10px;padding:12px 20px;border-radius:12px;text-decoration:none;font-weight:600;border:1px solid var(--hair);transition:all .25s ease}
.btn--primary{background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;border-color:transparent;box-shadow:0 10px 24px rgba(0,0,0,.12)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(0,0,0,.16)}

@media (max-width:480px){
  #services ul{grid-template-columns:1fr}
  .btn{padding:12px 16px}
}

.ubuntu-mode #services h2{background:linear-gradient(90deg,#2c001e,#dd4814);-webkit-background-clip:text;background-clip:text;color:transparent}
.ubuntu-mode #services ul li{border-color:rgba(221,72,20,.35)}
.ubuntu-mode #services ul li strong{color:#dd4814}
.ubuntu-mode .btn--primary{background:linear-gradient(135deg,#dd4814,#ff7a3b)}

.ubuntu-egg{display:none;margin:-6px 0 18px}
.ubuntu-egg__badge{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#2c001e,#4b002f);color:#ffd4c2;border:1px solid rgba(221,72,20,.4);padding:6px 10px;border-radius:999px;font-weight:700;font-size:.85rem}
.ubuntu-egg__text{margin:10px auto 0;max-width:760px;color:var(--muted);text-align:center;font-size:.95rem}

.ubuntu-terminal{position:fixed;top:12vh;left:50%;transform:translateX(-50%);width:min(880px,92vw);background:#2c001e;border:1px solid rgba(221,72,20,.5);border-radius:12px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.35);z-index:1200;animation:storySlideIn .25s ease-out}
.ubuntu-terminal__title{display:flex;align-items:center;gap:10px;background:linear-gradient(180deg,#3a062a,#2c001e);padding:10px 12px;color:#ffd4c2;font-weight:600;cursor:move}
.ubuntu-traffic{display:flex;gap:8px;margin-right:8px}
.ubuntu-dot{width:12px;height:12px;border-radius:50%}
.ubuntu-dot--close{background:#ff5f57}
.ubuntu-dot--min{background:#ffbd2e}
.ubuntu-dot--max{background:#28c840}
.ubuntu-terminal__body{background:#190015;padding:14px 16px;color:#ffe9e1;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,"Liberation Mono","Ubuntu Mono",monospace;font-size:13px;line-height:1.6;max-height:60vh;overflow:auto}
.ubuntu-line{opacity:.95}
.ubuntu-prompt{color:#ff7a3b}
.ubuntu-caret{display:inline-block;width:10px;height:1em;background:#ff7a3b;vertical-align:-2px;animation:blink 1.2s step-end infinite}
@keyframes blink{50%{opacity:0}}
.ubuntu-terminal__footer{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#220019;color:#ffb599;font-size:12px}
.ubuntu-terminal__btn{background:transparent;border:1px solid rgba(255,214,205,.25);color:#ffd4c2;border-radius:8px;padding:6px 10px;font-size:12px;cursor:pointer}
.ubuntu-terminal__btn:hover{background:rgba(255,214,205,.08)}

@media (max-width:480px){
  .ubuntu-terminal{top:8vh;width:94vw}
  .ubuntu-terminal__body{max-height:56vh}
}

.server-monitor{position:fixed;bottom:6vh;right:4vw;width:min(360px,92vw);background:var(--surface);border:1px solid var(--hair);border-radius:12px;box-shadow:0 16px 40px rgba(0,0,0,.25);z-index:1200;overflow:hidden}
.server-monitor__title{display:flex;align-items:center;gap:8px;background:var(--surface-2);padding:10px 12px;color:var(--text);font-weight:600;cursor:move;border-bottom:1px solid var(--hair)}
.server-monitor__body{padding:12px}
.metric{margin:10px 0}
.metric__label{display:flex;justify-content:space-between;margin-bottom:6px;color:var(--muted);font-size:.9rem}
.metric__bar{position:relative;height:10px;background:var(--surface-2);border:1px solid var(--hair);border-radius:999px;overflow:hidden}
.metric__fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));width:0%}
.metric__value{font-weight:700;color:var(--text)}
.server-monitor__footer{display:flex;justify-content:space-between;gap:8px;padding:8px 12px;border-top:1px solid var(--hair);background:var(--surface-2)}
.server-monitor__btn{background:transparent;border:1px solid var(--hair);color:var(--text);border-radius:8px;padding:6px 10px;font-size:12px;cursor:pointer}
.server-monitor__btn:hover{background:var(--surface)}

@media (max-width:480px){
  .server-monitor{left:0!important;right:0!important;bottom:0!important;top:auto!important;width:100vw!important;border-radius:16px 16px 0 0}
  .server-monitor .server-monitor__title{justify-content:center;cursor:grab}
  .server-monitor .server-monitor__body{max-height:48vh;overflow:auto}
}

.cap-tip{position:fixed;left:50%;bottom:14px;transform:translateX(-50%) translateY(20px);opacity:0;background:var(--header-bg);border:1px solid var(--hair);backdrop-filter:blur(8px);color:var(--text);padding:10px 12px;border-radius:10px;box-shadow:var(--shadow-md);z-index:1400;font-size:0.9rem;transition:opacity .2s ease, transform .2s ease}
.cap-tip.show{opacity:1;transform:translateX(-50%) translateY(0)}

.floating-trigger{position:fixed;z-index:1500;display:grid;place-items:center;width:28px;height:28px;border-radius:50%;background:var(--surface);border:1px dashed var(--hair);box-shadow:var(--shadow-sm);opacity:.16;backdrop-filter:blur(6px);cursor:pointer;transition:opacity .2s ease,transform .2s ease, filter .2s ease}
.floating-trigger:hover{opacity:.75;transform:scale(1.08)}
.floating-trigger:focus-visible{opacity:.9;transform:scale(1.1);outline:2px solid var(--accent);outline-offset:2px}
.floating-trigger__icon{font-size:.95rem;line-height:1;filter:grayscale(0.2);opacity:.9}
#home.hero:hover .floating-trigger{opacity:.28}
@keyframes drift{0%{transform:translate(0,0)}25%{transform:translate(8px,-6px)}50%{transform:translate(-6px,6px)}75%{transform:translate(6px,4px)}100%{transform:translate(0,0)}}
.floating-trigger{animation:drift 6s ease-in-out infinite}
:root{
  --bg:#0b0b0f;
  --surface:#121218;
  --surface-2:#0e0e14;
  --text:#ededed;
  --muted:#a9afb8;
  --hair:#22232a;
  --accent:#7c5cff;
  --header-bg:rgba(18,18,24,.7);
  --shadow-sm:0 1px 2px rgba(0,0,0,.25);
  --shadow-md:0 10px 30px rgba(0,0,0,.35);
  --radius:12px;
  --font-sans:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --dur:240ms;
  --dur-long:600ms
}
body.light{
  --bg:#f7f8fb;
  --surface:#ffffff;
  --surface-2:#f3f4f7;
  --text:#111318;
  --muted:#5f6673;
  --hair:#e6e8ec;
  --header-bg:rgba(255,255,255,.65);
  --shadow-md:0 10px 30px rgba(17,19,24,.08)
  ;--accent-light:#cbbdff
}

#themeToggle{
  background:var(--surface);
  border:1px solid var(--hair);
  border-radius:var(--radius);
  color:var(--text);
  cursor:pointer;
  font-size:1.2rem;
  padding:8px 12px;
  transition:var(--ease) var(--dur);
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:44px;
  min-height:44px;
  position:relative;
  overflow:hidden;
}

#themeToggle:hover{
  background:var(--surface-2);
  border-color:var(--accent);
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(124,92,255,0.15);
}

#themeToggle:active{
  transform:translateY(0);
  transition-duration:100ms;
}

#themeToggle::before{
  content:'';
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient(90deg,transparent,rgba(124,92,255,0.1),transparent);
  transition:left 0.5s ease;
}

#themeToggle:hover::before{
  left:100%;
}

*{
  transition:background-color var(--dur) var(--ease),border-color var(--dur) var(--ease),color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}

body.light .code-block{
  box-shadow:0 4px 6px rgba(0,0,0,0.1);
}

body.light .code-block:hover{
  box-shadow:0 8px 25px rgba(0,0,0,0.15);
}

body.light .lang-btn{
  box-shadow:0 2px 4px rgba(0,0,0,0.1);
}

body.light .lang-btn:hover{
  box-shadow:0 4px 12px rgba(124,92,255,0.15);
}

body.light .run-code-btn{
  box-shadow:0 2px 8px rgba(124,92,255,0.2);
}

body.light .run-code-btn:hover{
  box-shadow:0 4px 12px rgba(124,92,255,0.3);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
::selection{background:var(--accent);color:#000}
body{margin:0;background:var(--bg);color:var(--text);font:16px/1.65 var(--font-sans);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"kern" 1,"liga" 1;--accent-light:#a892ff}
.site-header,.site-footer,.card,.btn,.nav a,.pill-grid li,section{transition:background-color var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.container{max-width:1120px;margin:0 auto;padding:0 max(20px, env(safe-area-inset-right)) 0 max(20px, env(safe-area-inset-left))}

@supports (padding: max(0px)) {
  .site-header .container {
    padding-left: max(20px, env(safe-area-inset-left));
    padding-right: max(20px, env(safe-area-inset-right));
  }
  
  .site-footer .container {
    padding-left: max(20px, env(safe-area-inset-left));
    padding-right: max(20px, env(safe-area-inset-right));
    padding-bottom: max(12px, env(safe-area-inset-bottom));
  }
  
  .back-to-top {
    right: max(16px, env(safe-area-inset-right));
    bottom: max(16px, env(safe-area-inset-bottom));
  }
  
  @media (max-width: 768px) {
    .nav {
      padding-left: max(24px, env(safe-area-inset-left));
      padding-right: max(24px, env(safe-area-inset-right));
    }
  }
}
.row{display:flex;gap:16px}
.between{justify-content:space-between}
.center{align-items:center}

.egg-toast{position:fixed;left:50%;top:-100px;transform:translateX(-50%);background:var(--accent);color:#000;padding:10px 14px;border-radius:10px;box-shadow:var(--shadow-md);font-weight:600;z-index:9999;transition:transform .35s ease, top .35s ease, opacity .35s ease;opacity:.98}
.egg-toast.show{top:12px}
@media (max-width:600px){.egg-toast{padding:12px 16px;font-size:14px;max-width:calc(100% - 24px);left:12px;right:12px;transform:none}}


.confetti{position:fixed;width:8px;height:12px;pointer-events:none;opacity:0.95;transform:translate(-50%,-50%);will-change:transform, opacity}
@keyframes confetti-fall{0%{transform:translate(var(--x),var(--y)) rotate(0deg)}100%{transform:translate(calc(var(--x) + var(--dx)),calc(var(--y) + var(--dy))) rotate(720deg);opacity:0}}


body.deep-web{--bg:#020203;--surface:#06070a;--text:#e5e5ea;--muted:#9aa0a6;--hair:#1a1c20;--accent:#00ff9c;--accent-2:#ff0033;--shadow-sm:0 2px 8px rgba(0,0,0,.6);--shadow-md:0 8px 24px rgba(0,0,0,.7);background:radial-gradient(1200px 800px at 50% -200px,#0b0d10 0%,#07080b 40%,#020203 100%) fixed;color:var(--text)}
body.deep-web .site-header{background:rgba(2,2,3,.7);backdrop-filter:saturate(180%) blur(8px)}
body.deep-web .brand{color:var(--accent)}
body.deep-web a:hover{color:var(--accent)}
body.deep-web .hero-title{color:#e9fffb;text-shadow:0 0 12px rgba(0,255,156,.25)}
body.deep-web .lede{color:#c6f7e2}
body.deep-web .card, body.deep-web .panel{background:linear-gradient(180deg,rgba(10,12,14,.6),rgba(6,7,10,.8));border:1px solid rgba(0,255,156,.12)}
body.deep-web .btn, body.deep-web button{background:linear-gradient(180deg,#0b291f,#051d16);border:1px solid rgba(0,255,156,.3);color:#b7ffe7}
body.deep-web .btn:hover, body.deep-web button:hover{box-shadow:0 0 0 2px rgba(0,255,156,.2)}
body.deep-web .egg-toast{background:var(--accent);color:#001a11}

body.deep-web::before{content:"";position:fixed;inset:0;pointer-events:none;background:repeating-linear-gradient(0deg,rgba(0,0,0,.0),rgba(0,0,0,.0) 2px,rgba(0,0,0,.12) 3px,rgba(0,0,0,.12) 4px);opacity:.35;mix-blend-mode:multiply;z-index:999}
@media (prefers-reduced-motion: no-preference){
  body.deep-web{animation:deepWebPulse 6s ease-in-out infinite}
  @keyframes deepWebPulse{0%,100%{filter:saturate(110%) contrast(105%)}50%{filter:saturate(120%) contrast(115%)}}
}


.deepweb-intro{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(1400px 900px at 50% 20%,#060507 0%,#020203 55%);color:#00ff9c;z-index:10000;opacity:0;pointer-events:none;transition:opacity .35s ease}
.deepweb-intro.show{opacity:1;pointer-events:auto}
.deepweb-intro__panel{max-width:min(900px,92vw);padding:38px 28px;border:1px solid rgba(255,0,51,.35);border-radius:14px;box-shadow:0 20px 80px rgba(0,0,0,.75), inset 0 0 40px rgba(255,0,51,.08);text-align:center;background:rgba(5,3,4,.85);backdrop-filter:saturate(160%) blur(6px);position:relative;overflow:hidden}
.deepweb-intro__panel::after{content:"";position:absolute;inset:-40px;background:radial-gradient(1000px 300px at 50% -60px,rgba(255,0,51,.25),rgba(255,0,51,0));mix-blend-mode:screen;pointer-events:none}
.deepweb-intro__title{font-size:clamp(28px,5vw,56px);margin:0 0 12px;color:#ff0033;text-shadow:0 0 20px rgba(255,0,51,.5),0 0 2px rgba(255,0,51,.9);letter-spacing:.08em;animation:glitch 2.2s infinite}
.deepweb-intro__subtitle{font-size:clamp(14px,2.6vw,20px);color:#e9e9e9;margin:0 0 18px;opacity:.9}
.deepweb-intro__count{font-variant-numeric:tabular-nums;font-weight:900;font-size:clamp(34px,6vw,68px);color:#ff0033;text-shadow:0 0 22px rgba(255,0,51,.45);animation:heartbeat 1s infinite}
.deepweb-intro__hint{margin-top:16px;font-size:12px;color:#9aa0a6;opacity:.8}
.deepweb-intro.vignette{box-shadow:inset 0 0 200px rgba(0,0,0,.9)}
@keyframes glitch {0%{transform:none} 10%{transform:skew(-2deg)} 11%{transform:skew(2deg) translateX(-2px)} 12%{transform:none} 30%{transform:skew(2deg)} 31%{transform:skew(-1deg) translateX(1px)} 32%{transform:none} 55%{transform:skew(-1deg)} 56%{transform:skew(1deg) translateX(1px)} 57%{transform:none} 80%{transform:skew(1deg)} 81%{transform:skew(-2deg) translateX(-1px)} 82%{transform:none} }
@keyframes heartbeat {0%{transform:scale(1)} 20%{transform:scale(1.06)} 25%{transform:scale(1)} 40%{transform:scale(1.05)} 60%{transform:scale(1)} }
@keyframes flicker {0%,100%{opacity:1} 90%{opacity:.96} 92%{opacity:.8} 95%{opacity:.98} 97%{opacity:.7}}
@keyframes shake {0%,100%{transform:translateX(0)} 20%{transform:translateX(-2px)} 40%{transform:translateX(2px)} 60%{transform:translateX(-1px)} 80%{transform:translateX(1px)}}
@media (max-width:600px){.deepweb-intro__panel{padding:24px 16px}}


body.deep-web .egg-output{position:fixed;right:16px;bottom:16px;width:min(520px,calc(100% - 32px));max-height:40vh;overflow:auto;background:rgba(2,2,3,.85);border:1px solid rgba(0,255,156,.25);box-shadow:0 12px 40px rgba(0,0,0,.6), inset 0 0 30px rgba(0,255,156,.06);border-radius:12px;padding:12px 14px;font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;color:#b7ffe7;z-index:12000;backdrop-filter:saturate(140%) blur(4px);cursor:grab}
body.deep-web .egg-output.dragging{cursor:grabbing;box-shadow:0 16px 60px rgba(0,0,0,.75), 0 0 0 2px rgba(0,255,156,.12) inset}
@media (min-width:1024px){body.deep-web .egg-output{top:16px;bottom:auto;max-height:50vh}}
body.deep-web .egg-output__header{display:flex;align-items:center;justify-content:space-between;margin:0 0 8px}
body.deep-web .egg-output__title{font-weight:700;color:#00ff9c;font-size:12px;letter-spacing:.12em;text-transform:uppercase;opacity:.9}
body.deep-web .egg-output__close{background:transparent;border:0;color:#b7ffe7;font-size:14px;line-height:1;padding:4px 6px;border-radius:6px;cursor:pointer}
body.deep-web .egg-output__close:hover{background:rgba(0,255,156,.08)}
body.deep-web .egg-output__log{font-size:12px;line-height:1.6}
body.deep-web .egg-output__log .line{opacity:.9}
body.deep-web .egg-output__log .line.warn{color:#ffd32a}
body.deep-web .egg-output__log .line.err{color:#ff6b81}
body.deep-web .egg-output__log .caret{color:#00ff9c;animation:blink 1s step-end infinite}
@keyframes blink{50%{opacity:0}}


body.deep-web #home.hero{position:relative}
body.deep-web #home .matrix-output{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5}
a{color:var(--text);text-decoration:none;transition:color 0.2s ease}
a:hover{color:var(--accent)}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-color:var(--accent)}

button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

@media (prefers-contrast: high) {
  :root {
    --hair: #444;
    --muted: #888;
  }
  body.light {
    --hair: #ccc;
    --muted: #666;
  }
}


.brand{font-weight:700;letter-spacing:.3px}
.site-header{position:sticky;top:0;z-index:1000;background:var(--header-bg);backdrop-filter:blur(8px);border-bottom:1px solid var(--hair);padding:12px 0;--header-h:56px}
.site-footer{margin-top:40px;padding:12px 0;border-top:1px solid var(--hair);background:var(--surface);position:static}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.nav{display:flex;gap:8px;align-items:center}
.nav a{position:relative;padding:6px 8px;border-radius:8px}
.nav a:hover{background:var(--surface-2);color:var(--text)}
.nav a::after{content:"";position:absolute;left:10%;right:10%;bottom:4px;height:2px;background:var(--accent);opacity:0;transform:scaleX(.6);transform-origin:center;transition:transform .2s var(--ease),opacity .2s var(--ease)}
.nav a:hover::after,.nav a.active::after{opacity:1;transform:scaleX(1)}
.nav a.active{color:var(--accent);}
.nav button{background:transparent;border:1px solid var(--hair);color:var(--text);border-radius:10px;padding:6px 10px;cursor:pointer}
.nav button:hover{border-color:var(--accent);color:var(--accent)}
.menu-toggle{display:none;background:transparent;border:1px solid var(--hair);color:var(--text);border-radius:10px;padding:6px 10px;cursor:pointer;position:relative;transition:all 0.3s ease}
.menu-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--surface-2)}
.menu-toggle[aria-expanded="true"]{border-color:var(--accent);color:var(--accent);background:var(--surface-2)}


.hamburger{display:flex;flex-direction:column;gap:3px;width:18px;height:14px;justify-content:space-between}
.hamburger-line{display:block;width:100%;height:2px;background:currentColor;border-radius:1px;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);transform-origin:center}
.menu-toggle[aria-expanded="true"] .hamburger-line:nth-child(1){transform:translateY(5px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] .hamburger-line:nth-child(2){opacity:0;transform:scaleX(0)}
.menu-toggle[aria-expanded="true"] .hamburger-line:nth-child(3){transform:translateY(-5px) rotate(-45deg)}


.hero{padding:96px 0 56px;position:relative;overflow:hidden;z-index:0;min-height:80vh;display:flex;align-items:center}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:-1;background:
  radial-gradient(600px 300px at 10% -10%, rgba(124,92,255,.15), transparent 40%),
  radial-gradient(400px 200px at 90% 0%, rgba(124,92,255,.08), transparent 50%),
  repeating-linear-gradient(0deg, transparent, transparent 24px, rgba(255,255,255,.03) 24px, rgba(255,255,255,.03) 25px),
  repeating-linear-gradient(90deg, transparent, transparent 24px, rgba(255,255,255,.03) 24px, rgba(255,255,255,.03) 25px);
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.7), rgba(0,0,0,0));
}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;background:
  repeating-linear-gradient(to bottom, rgba(255,255,255,.06), rgba(255,255,255,.06) 1px, transparent 1px, transparent 3px);
  mix-blend-mode:overlay;opacity:.03;animation:crtFlicker 6s linear infinite}

@keyframes crtFlicker{
  0%{opacity:.05}
  20%{opacity:.07}
  40%{opacity:.06}
  60%{opacity:.08}
  80%{opacity:.05}
  100%{opacity:.06}
}
.hero__content{max-width:820px}
h1.hero-title{font-size:clamp(36px,6vw,64px);line-height:1.1;margin:0 0 16px;font-weight:700;letter-spacing:-0.02em}
h1{font-size:clamp(32px,4.5vw,48px);line-height:1.15;margin:0 0 16px;letter-spacing:-0.02em;font-weight:600}
h2{font-size:clamp(24px,3.5vw,32px);margin:0 0 16px;font-weight:600;letter-spacing:-0.01em}
h2{position:relative}
h2::after{content:"";display:block;width:48px;height:3px;background:linear-gradient(90deg,var(--accent),#a892ff);border-radius:2px;margin-top:6px;opacity:.9}
h3{font-size:clamp(18px,2.5vw,22px);margin:0 0 8px;font-weight:600}
h4{font-size:clamp(16px,2vw,18px);margin:0 0 8px;font-weight:600}
.lede{color:var(--muted);font-size:clamp(16px,2.5vw,18px);line-height:1.65;margin-bottom:24px}
p{line-height:1.65;margin-bottom:16px}
li{line-height:1.6}


.hero-story{margin:20px 0;padding:16px;background:var(--surface);border-left:4px solid var(--accent);border-radius:8px}
.story-hook{font-style:italic;color:var(--text);font-size:1.05rem;margin:0;position:relative}
.story-hook::before{content:'"';font-size:1.5em;color:var(--accent);position:absolute;left:-8px;top:-4px}
.story-hook::after{content:'"';font-size:1.5em;color:var(--accent);position:absolute;right:-8px;bottom:-4px}

.story-intro{margin-bottom:32px;padding:20px;background:linear-gradient(135deg,var(--surface),var(--surface-2));border-radius:12px;border:1px solid var(--hair)}
.story-intro p{font-size:1.1rem;line-height:1.6;margin:0;color:var(--text)}

.story-timeline{display:grid;gap:24px;margin:32px 0}
.timeline-item{padding:20px;background:var(--surface);border-radius:12px;border:1px solid var(--hair);position:relative;transition:transform 0.3s ease,box-shadow 0.3s ease}
.timeline-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.timeline-item h3{margin:0 0 12px;font-size:1.2rem;color:var(--accent);display:flex;align-items:center;gap:8px}
.timeline-item p{margin:0;line-height:1.6;color:var(--muted)}

.personal-philosophy{margin-top:32px;padding:24px;background:linear-gradient(135deg,var(--accent),#a892ff);color:#000;border-radius:12px;text-align:center}
.personal-philosophy h3{margin:0 0 12px;font-size:1.3rem;color:#000}
.personal-philosophy p{margin:0;font-size:1.1rem;line-height:1.6;font-weight:500}


.section-intro{font-size:1.1rem;line-height:1.6;color:var(--muted);margin-bottom:32px;text-align:center;max-width:800px;margin-left:auto;margin-right:auto}

.project-story{font-size:1.05rem;line-height:1.6;color:var(--text);margin-bottom:16px;font-style:italic}

.project-impact{display:flex;gap:12px;flex-wrap:wrap;margin:16px 0;padding:12px;background:var(--surface-2);border-radius:8px}
.impact-stat{background:var(--accent);color:#000;padding:6px 12px;border-radius:20px;font-size:0.9rem;font-weight:600}

.project-link{display:inline-block;margin-top:16px;color:var(--accent);text-decoration:none;font-weight:600;transition:color 0.2s ease}
.project-link:hover{color:var(--text);text-decoration:underline}

.project-details{margin-top:20px;padding-top:20px;border-top:1px solid var(--hair)}
.project-details h4{margin:16px 0 8px;font-size:1rem;color:var(--accent);font-weight:600}
.project-details h4:first-child{margin-top:0}
.project-details p{margin:0 0 12px;color:var(--muted);line-height:1.5}


.cta-row{display:flex;gap:16px;margin-top:32px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border:1px solid var(--hair);border-radius:var(--radius);color:var(--text);background:transparent;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);text-decoration:none;font-weight:500;font-size:1rem;position:relative;overflow:hidden;min-height:44px;touch-action:manipulation;cursor:pointer}
.btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.1),transparent);transition:left 0.5s ease}
.btn:hover::before{left:100%}
.btn:hover{transform:translateY(-2px);border-color:var(--accent);color:var(--accent);box-shadow:0 8px 25px rgba(124,92,255,0.15)}
.btn:active{transform:translateY(0);transition-duration:0.1s}
.btn--primary{background:var(--accent);color:#000;border:none;box-shadow:0 4px 15px rgba(124,92,255,0.3);font-weight:600}
.btn--primary:hover{filter:brightness(1.05);transform:translateY(-2px);box-shadow:0 8px 25px rgba(124,92,255,0.4)}
.btn--primary:active{transform:translateY(0);filter:brightness(0.95)}
.btn--ghost{background:transparent;border:1px solid var(--hair);color:var(--text)}
.btn--ghost:hover{background:var(--surface-2);color:var(--accent)}
button,.btn{touch-action:manipulation;cursor:pointer}


.hero__grid{display:grid;grid-template-columns:1.2fr 1fr;gap:28px;align-items:center}
.hero__content{position:relative}
.hero__content::before{content:"";position:absolute;inset:-10px -14px -10px -14px;pointer-events:none;border-radius:16px;background:radial-gradient(600px 300px at 0% 0%, rgba(0,0,0,.28), transparent 60%)}
body.light .hero__content::before{background:radial-gradient(600px 300px at 0% 0%, rgba(0,0,0,.10), transparent 60%)}

.hero__visual .interactive-terminal{border:1px solid var(--hair);background:var(--surface);border-radius:16px;box-shadow:var(--shadow-md);overflow:hidden;transition:transform 0.3s ease,box-shadow 0.3s ease;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}
.hero__visual .interactive-terminal:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,0.15)}

.terminal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--hair);background:var(--surface-2)}
.terminal-controls{display:flex;gap:6px}
.control-dot{width:12px;height:12px;border-radius:50%}
.control-dot.red{background:#ff5f56}
.control-dot.yellow{background:#ffbd2e}
.control-dot.green{background:#27ca3f}
.terminal-title{color:var(--muted);font-size:0.9rem;font-weight:500}

.terminal-body{padding:16px;background:#0a0a0f;color:#00ff00;min-height:200px}
.terminal-line{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.prompt{color:#00ff00;font-weight:bold}
.command{color:#ffffff}
.command.typing{animation:typing 2s steps(20,end),blink 1s infinite}
.terminal-output{margin-left:24px;margin-bottom:16px}
.output-line{color:#00ff00;margin-bottom:4px;opacity:0;animation:fadeInUp 0.5s ease forwards}
.output-line:nth-child(1){animation-delay:0.5s}
.output-line:nth-child(2){animation-delay:0.7s}
.output-line:nth-child(3){animation-delay:0.9s}

.progress-bar{width:100%;height:4px;background:var(--hair);border-radius:2px;margin-top:8px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#00ff00);width:0;animation:progressFill 3s ease-in-out forwards;animation-delay:1.5s}

@keyframes typing{from{width:0}to{width:100%}}
@keyframes blink{0%,50%{border-right:2px solid #00ff00}51%,100%{border-right:2px solid transparent}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes progressFill{from{width:0}to{width:100%}}


body.light .terminal-body{background:#f0f3f9;color:#0a0a0f}
body.light .prompt{color:#7c5cff}
body.light .command{color:#0a0a0f}
body.light .output-line{color:#0a0a0f}
body.light .progress-bar{background:#e6e8ec}
body.light .progress-fill{background:linear-gradient(90deg,#7c5cff,#4caf50)}


@media (max-width:390px){
  html{font-size:15px}
  h1{font-size:clamp(22px,8vw,28px)}
  h2{font-size:clamp(18px,7vw,24px)}
  p,li{font-size:.95rem}
  .btn{padding:10px 14px;font-size:.95rem;gap:8px}
  .cta-buttons .btn{width:100%}
  .social-pills li a{padding:8px 12px}
  .pill-grid li{padding:5px 10px;font-size:.85rem}
  .chat-window{width:96vw}
  .chat-body{max-height:48vh}
}

@media (max-width:340px){
  html{font-size:14px}
  .btn{padding:9px 12px;font-size:.9rem}
  .tg-title .tg-name{font-size:.95rem}
}


.echo-overlay{position:fixed;inset:0;z-index:1600;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);display:grid;place-items:center;opacity:0;transition:opacity .2s ease}
.echo-overlay.show{opacity:1}
.echo-count{font-size:3rem;color:#fff;text-shadow:0 6px 24px rgba(0,0,0,.6);animation:pulse 0.6s ease}
@keyframes pulse{0%{transform:scale(.8);opacity:.6}60%{transform:scale(1.08);opacity:1}100%{transform:scale(1);opacity:.9}}
.echo-rocket{position:fixed;left:10vw;bottom:10vh;font-size:2.2rem;filter:drop-shadow(0 8px 22px rgba(0,0,0,.4));opacity:0}
.echo-rocket.fly{animation:rocketPath 1.6s cubic-bezier(.22,.61,.36,1) forwards}
@keyframes rocketPath{0%{transform:translate(0,0) rotate(-15deg);opacity:1}40%{transform:translate(30vw, -20vh) rotate(-5deg)}70%{transform:translate(60vw, -55vh) rotate(0deg)}100%{transform:translate(92vw, -110vh) rotate(10deg);opacity:0}}
.echo-confetti{position:fixed;top:-10px;left:0;right:0;pointer-events:none;z-index:1650}
.echo-piece{position:absolute;top:-10px;width:8px;height:14px;border-radius:2px;opacity:.9;transform:translateY(-20px) rotate(0deg)}
@keyframes confettiFall{to{transform:translateY(110vh) rotate(540deg);opacity:0}}


.echo-warp{position:fixed;inset:0;z-index:1620;pointer-events:none;overflow:hidden}
.echo-warp__tunnel{position:absolute;inset:-20%;background:radial-gradient(circle at center, rgba(255,255,255,.15) 0%, rgba(124,92,255,.12) 20%, rgba(0,0,0,0) 60%);filter:blur(10px);animation:warpZoom 1.2s ease-out forwards;opacity:.9}
@keyframes warpZoom{0%{transform:scale(0.6) rotate(0.5turn)}70%{transform:scale(1.6) rotate(1turn)}100%{transform:scale(2.2) rotate(1.4turn);opacity:0}}
.echo-star{position:absolute;width:2px;height:14px;background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(255,255,255,0));opacity:.9;transform:translate3d(0,0,0);will-change:transform}
@keyframes starTravel{to{transform:translateY(110vh);opacity:0}}


.interactive-code-section{margin:32px 0}

.code-intro{text-align:center;margin-bottom:32px;padding:24px;background:linear-gradient(135deg,var(--surface),var(--surface-2));border-radius:16px;border:1px solid var(--hair)}
.code-intro h3{margin:0 0 12px;color:var(--text);font-size:1.4rem;font-weight:600}
.code-intro p{margin:0;color:var(--muted);font-size:1rem;line-height:1.6;max-width:600px;margin:0 auto}

.language-selector{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:24px;padding:20px;background:var(--surface-2);border-radius:16px;border:1px solid var(--hair)}
.lang-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 20px;background:var(--surface);border:2px solid var(--hair);border-radius:12px;color:var(--text);cursor:pointer;transition:all 0.3s ease;min-width:100px;position:relative;overflow:hidden}
.lang-btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(124,92,255,0.1),transparent);transition:left 0.5s ease}
.lang-btn:hover::before{left:100%}
.lang-btn:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 8px 25px rgba(124,92,255,0.15)}
.lang-btn:active{transform:translateY(0);transition-duration:0.1s}
.lang-btn.active{background:var(--accent);color:#000;border-color:var(--accent);box-shadow:0 4px 15px rgba(124,92,255,0.3)}
.lang-btn.active:hover{filter:brightness(1.05);transform:translateY(-2px);box-shadow:0 8px 25px rgba(124,92,255,0.4)}

.lang-icon{font-size:2rem;display:block;margin-bottom:4px}
.lang-name{font-weight:600;font-size:0.9rem;text-align:center}

.code-block{border:1px solid var(--hair);background:var(--surface);border-radius:16px;overflow:hidden;margin-bottom:24px;box-shadow:var(--shadow-md);transition:transform 0.3s ease,box-shadow 0.3s ease}
.code-block:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(0,0,0,0.15)}

.code-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--surface-2);border-bottom:1px solid var(--hair)}
.code-title{color:var(--text);font-weight:600;font-size:1rem;display:flex;align-items:center;gap:8px}
.code-title::before{font-size:1.2rem}

.code-controls{display:flex;gap:8px;align-items:center}
.run-code-btn,.reset-code-btn{display:flex;align-items:center;gap:6px;border:none;padding:8px 16px;border-radius:8px;font-size:0.85rem;font-weight:600;cursor:pointer;transition:all 0.3s ease;min-height:36px}
.run-code-btn{background:var(--accent);color:#000;box-shadow:0 2px 8px rgba(124,92,255,0.3)}
.run-code-btn:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 12px rgba(124,92,255,0.4)}
.run-code-btn:active{transform:translateY(0);filter:brightness(0.95)}
.run-code-btn:disabled{opacity:0.6;cursor:not-allowed;transform:none;filter:none}

.reset-code-btn{background:var(--surface);color:var(--text);border:1px solid var(--hair)}
.reset-code-btn:hover{background:var(--surface-2);border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.reset-code-btn:active{transform:translateY(0)}

.btn-icon{font-size:0.9rem}
.btn-text{font-weight:600}

.code-content{background:var(--surface);padding:20px;overflow-x:auto;position:relative;border:1px solid var(--hair)}
.code-content pre{margin:0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:0.9rem;line-height:1.6;color:var(--text)}
.code-content .comment{color:#6a9955;font-style:italic}
.code-content .keyword{color:#569cd6;font-weight:600}
.code-content .function{color:#dcdcaa}
.code-content .variable{color:#9cdcfe}
.code-content .string{color:#ce9178}
.code-content .number{color:#b5cea8}


body.light .code-content{background:#f8f9fa;border:1px solid var(--hair)}
body.light .code-content pre{color:var(--text)}
body.light .code-content .comment{color:#6a9955}
body.light .code-content .keyword{color:#0000ff;font-weight:600}
body.light .code-content .function{color:#795e26}
body.light .code-content .variable{color:#001080}
body.light .code-content .string{color:#a31515}
body.light .code-content .number{color:#098658}


.code-output{background:var(--surface-2);border-top:1px solid var(--hair);padding:0}
.output-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--surface-3);border-bottom:1px solid var(--hair)}
.output-title{color:var(--text);font-weight:600;font-size:0.9rem;display:flex;align-items:center;gap:8px}
.output-title::before{content:"📟";font-size:1rem}
.output-status{color:var(--muted);font-size:0.8rem;padding:4px 8px;background:var(--surface-2);border-radius:4px;border:1px solid var(--hair)}
.output-status.running{color:#f0a020;background:rgba(240,160,32,0.1);border-color:#f0a020}
.output-status.completed{color:#28a745;background:rgba(40,167,69,0.1);border-color:#28a745}
.output-status.error{color:#dc3545;background:rgba(220,53,69,0.1);border-color:#dc3545}

.output-content{padding:16px 20px;min-height:120px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:0.85rem;line-height:1.5;color:#e6e6e6}
.output-line{margin-bottom:8px;opacity:0;animation:fadeInUp 0.5s ease forwards;position:relative;padding-left:20px}
.output-line::before{content:">";position:absolute;left:0;color:#7c5cff;font-weight:bold}
.output-line:nth-child(1){animation-delay:0.1s}
.output-line:nth-child(2){animation-delay:0.2s}
.output-line:nth-child(3){animation-delay:0.3s}
.output-line:nth-child(4){animation-delay:0.4s}
.output-line:nth-child(5){animation-delay:0.5s}
.output-line:nth-child(6){animation-delay:0.6s}
.output-line:nth-child(7){animation-delay:0.7s}
.output-line:nth-child(8){animation-delay:0.8s}
.output-line:nth-child(9){animation-delay:0.9s}
.output-line:nth-child(10){animation-delay:1.0s}

.output-line.success{color:#28a745}
.output-line.info{color:#17a2b8}
.output-line.warning{color:#ffc107}
.output-line.error{color:#dc3545}


.code-executing{position:relative}
.code-executing::after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(124,92,255,0.1),transparent);animation:codeScan 2s ease-in-out infinite}

@keyframes codeScan{
  0%{transform:translateX(-100%)}
  100%{transform:translateX(100%)}
}


.code-content .highlight{background:rgba(124,92,255,0.2);border-radius:2px;padding:1px 2px;animation:highlightPulse 0.5s ease-in-out}
@keyframes highlightPulse{
  0%,100%{background:rgba(124,92,255,0.2)}
  50%{background:rgba(124,92,255,0.4)}
}


.timeline-item.interactive{cursor:pointer;position:relative;transition:all 0.3s ease}
.timeline-item.interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.timeline-item.interactive:active{transform:scale(0.98)}
.timeline-detail{max-height:0;overflow:hidden;transition:max-height 0.3s ease;margin-top:12px;padding-top:12px;border-top:1px solid var(--hair)}
.timeline-item.interactive.active .timeline-detail{max-height:200px}


.coding-game{padding:40px 0}
.game-intro{text-align:center;color:var(--muted);font-size:1.1rem;margin-bottom:32px}
.game-container{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px}
.game-controls{display:flex;flex-direction:column;gap:12px}
.game-btn{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--surface);border:1px solid var(--hair);border-radius:12px;color:var(--text);cursor:pointer;transition:all 0.3s ease;text-align:left}
.game-btn:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow-md)}
.game-btn:active{transform:scale(0.98)}
.game-btn.active{background:var(--accent);color:#000;border-color:var(--accent)}
.btn-icon{font-size:1.5rem}
.btn-text{font-weight:600;font-size:1rem}

.game-output{background:var(--surface);border:1px solid var(--hair);border-radius:12px;overflow:hidden}
.output-terminal{background:#0a0a0f;color:#00ff00;min-height:200px}
.output-terminal .terminal-header{padding:12px 16px;background:var(--surface-2);border-bottom:1px solid var(--hair)}
.output-terminal .terminal-title{color:var(--text);font-size:0.9rem;font-weight:600}
.terminal-content{padding:16px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:0.9rem;line-height:1.5}
.terminal-content .output-line{margin-bottom:8px;opacity:0;animation:fadeInUp 0.5s ease forwards}
.terminal-content .output-line:nth-child(1){animation-delay:0.2s}
.terminal-content .output-line:nth-child(2){animation-delay:0.4s}
.terminal-content .output-line:nth-child(3){animation-delay:0.6s}
.terminal-content .output-line:nth-child(4){animation-delay:0.8s}

.achievement-badges{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.achievement-badges .badge{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--surface);border:1px solid var(--hair);border-radius:20px;transition:all 0.3s ease;opacity:0.6;transform:scale(0.9)}
.achievement-badges .badge.earned{opacity:1;transform:scale(1);border-color:var(--accent);background:linear-gradient(135deg,var(--surface),var(--surface-2))}
.achievement-badges .badge.earned .badge-icon{filter:drop-shadow(0 2px 4px rgba(124,92,255,0.3))}
.badge-icon{font-size:1.2rem}
.badge-text{font-weight:600;font-size:0.9rem}


section{padding:48px 0;scroll-margin-top:80px}
section+section{border-top:1px solid var(--hair)}


.stats{padding-top:0;position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(800px 400px at 50% 0%, rgba(124,92,255,.08), transparent 60%);opacity:0.6}
.stats__header{text-align:center;margin-bottom:48px;position:relative;z-index:1}
.stats__header h2{margin-bottom:12px;color:var(--text);font-size:clamp(28px,4vw,36px);font-weight:700}
.stats__subtitle{color:var(--muted);font-size:1.1rem;line-height:1.6;max-width:600px;margin:0 auto}

.stats__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;position:relative;z-index:1}
.stat{background:var(--surface);border:1px solid var(--hair);border-radius:20px;padding:24px;text-align:center;position:relative;overflow:hidden;transition:all 0.4s cubic-bezier(0.4, 0, 0.2, 1);box-shadow:0 4px 20px rgba(0,0,0,0.1)}
.stat::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg, rgba(124,92,255,0.05), rgba(124,92,255,0.02));opacity:0;transition:opacity 0.3s ease;pointer-events:none}
.stat:hover{transform:translateY(-8px);box-shadow:0 12px 40px rgba(0,0,0,0.15);border-color:var(--accent)}
.stat:hover::before{opacity:1}

.stat--primary{border-left:4px solid #7c5cff}
.stat--secondary{border-left:4px solid #4ecdc4}
.stat--tertiary{border-left:4px solid #ff6b6b}
.stat--quaternary{border-left:4px solid #feca57}

.stat__icon{font-size:2.5rem;margin-bottom:16px;display:block;animation:statIconFloat 3s ease-in-out infinite}
.stat__content{position:relative;z-index:1}
.stat__num{font-size:clamp(28px,4vw,36px);font-weight:800;letter-spacing:-0.02em;margin-bottom:8px;background:linear-gradient(135deg, var(--accent), #a892ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 4px rgba(124,92,255,0.1)}
.stat__label{color:var(--text);font-weight:600;font-size:1.1rem;margin-bottom:8px}
.stat__description{color:var(--muted);font-size:0.9rem;line-height:1.4;opacity:0.8}
.stat__insight{color:var(--accent);font-size:0.8rem;line-height:1.3;margin-top:8px;opacity:0.9;font-style:italic;border-top:1px solid rgba(124,92,255,0.2);padding-top:8px}


.curiosity-hook{margin-top:24px;padding:20px;background:linear-gradient(135deg, rgba(124,92,255,0.1), rgba(124,92,255,0.05));border-radius:16px;border:1px solid rgba(124,92,255,0.2);backdrop-filter:blur(10px);position:relative;overflow:hidden}
.curiosity-hook::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg, var(--accent), #ff6b6b, #4ecdc4, #feca57);animation:shimmer 3s ease-in-out infinite}
.hook-text{margin:0;color:var(--text);font-size:1rem;line-height:1.6;position:relative;z-index:1}

@keyframes shimmer{
  0%, 100%{opacity:0.5}
  50%{opacity:1}
}


.impact-title{cursor:pointer;transition:all 0.3s ease;position:relative}
.impact-title:hover{color:var(--accent);transform:scale(1.02);text-shadow:0 0 20px rgba(124,92,255,0.3)}
.impact-title:active{transform:scale(0.98)}


.impact-easter-eggs{position:relative;margin-top:32px}
.story-reveal{animation:storySlideIn 0.6s ease-out forwards}
.story-card{background:var(--surface);border:2px solid var(--accent);border-radius:20px;padding:32px;box-shadow:0 20px 60px rgba(0,0,0,0.2);backdrop-filter:blur(20px);position:relative;overflow:hidden}
.story-card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg, rgba(124,92,255,0.1), rgba(124,92,255,0.05));pointer-events:none}
.story-card h3{margin:0 0 24px;color:var(--accent);font-size:1.5rem;text-align:center;position:relative;z-index:1}


.story-timeline{display:flex;flex-direction:column;gap:20px;position:relative;z-index:1;margin-bottom:24px}
.story-moment{display:flex;gap:16px;align-items:flex-start;padding:20px;background:var(--surface-2);border:1px solid var(--hair);border-radius:16px;transition:all 0.3s ease;position:relative}
.story-moment:hover{transform:translateX(8px);box-shadow:0 8px 25px rgba(0,0,0,0.1);border-color:var(--accent)}
.story-moment::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg, var(--accent), #a892ff);border-radius:0 2px 2px 0;opacity:0;transition:opacity 0.3s ease}
.story-moment:hover::before{opacity:1}

.moment-icon{font-size:2rem;flex-shrink:0;margin-top:4px;animation:iconPulse 2s ease-in-out infinite}
.moment-content{flex:1}
.moment-content h4{margin:0 0 8px;color:var(--text);font-size:1.1rem;font-weight:600}
.moment-content p{margin:0;color:var(--muted);font-size:0.95rem;line-height:1.5}

.story-moral{background:linear-gradient(135deg, var(--accent), #a892ff);color:#000;padding:20px;border-radius:16px;text-align:center;position:relative;z-index:1;margin-top:16px}
.story-moral p{margin:0;font-size:1.1rem;font-weight:600;line-height:1.5}


.psychology-reveal{animation:psychologySlideIn 0.6s ease-out forwards}
.psychology-card{background:var(--surface);border:2px solid var(--accent);border-radius:20px;padding:32px;box-shadow:0 20px 60px rgba(0,0,0,0.2);backdrop-filter:blur(20px);position:relative;overflow:hidden}
.psychology-card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg, rgba(124,92,255,0.1), rgba(124,92,255,0.05));pointer-events:none}
.psychology-card h3{margin:0 0 24px;color:var(--accent);font-size:1.5rem;text-align:center;position:relative;z-index:1}
.psychology-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;position:relative;z-index:1}
.psych-trait{background:var(--surface-2);border:1px solid var(--hair);border-radius:12px;padding:20px;transition:all 0.3s ease}
.psych-trait:hover{transform:translateY(-4px);box-shadow:0 8px 25px rgba(0,0,0,0.1);border-color:var(--accent)}
.psych-trait h4{margin:0 0 12px;color:var(--text);font-size:1.1rem;font-weight:600}
.psych-trait p{margin:0;color:var(--muted);font-size:0.95rem;line-height:1.5}


.hidden-psychology-triggers{position:absolute;inset:0;pointer-events:none;z-index:10}
.psych-trigger{position:absolute;width:30px;height:30px;border-radius:50%;opacity:0;cursor:pointer;pointer-events:auto;transition:all 0.3s ease;display:flex;align-items:center;justify-content:center;font-size:1.2rem;background:rgba(124,92,255,0.1);backdrop-filter:blur(5px);border:1px solid rgba(124,92,255,0.3);animation:psychPulse 3s ease-in-out infinite}
.psych-trigger:hover{opacity:0.8;transform:scale(1.3);background:rgba(124,92,255,0.2);box-shadow:0 0 20px rgba(124,92,255,0.4)}
.psych-trigger:active{transform:scale(0.9)}

.psych-trigger-1{top:20%;left:10%;animation-delay:0s}
.psych-trigger-2{top:20%;right:10%;animation-delay:0.5s}
.psych-trigger-3{bottom:20%;left:10%;animation-delay:1s}
.psych-trigger-4{bottom:20%;right:10%;animation-delay:1.5s}

@keyframes statIconFloat{
  0%, 100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-4px) rotate(2deg)}
}

@keyframes storySlideIn{
  0%{opacity:0;transform:translateY(30px) scale(0.95)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}

@keyframes storyGlow{
  0%, 100%{text-shadow:0 0 20px rgba(124,92,255,0.3);color:var(--text)}
  50%{text-shadow:0 0 30px rgba(124,92,255,0.6);color:var(--accent)}
}

@keyframes iconPulse{
  0%, 100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.1);opacity:0.8}
}

@keyframes psychologySlideIn{
  0%{opacity:0;transform:translateY(30px) scale(0.95)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}

@keyframes psychPulse{
  0%, 100%{transform:scale(1);opacity:0}
  50%{transform:scale(1.1);opacity:0.3}
}


.cap-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin:12px 0 28px}
.cap{background:var(--surface);border:1px solid var(--hair);border-radius:16px;padding:18px;transition:all .25s ease}
.cap h4{margin:0 0 8px;font-size:1.05rem;color:var(--text)}
.cap p{margin:0;color:var(--muted);line-height:1.55}
.cap:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(0,0,0,.1);border-color:var(--accent)}
@media (hover:none){.cap:hover{transform:none;box-shadow:none}}
.cap:active{transform:scale(0.995)}


.hud{position:fixed;top:10px;right:10px;z-index:1300;background:var(--header-bg);border:1px solid var(--hair);backdrop-filter:blur(8px);border-radius:12px;padding:6px 8px;min-width:80px;box-shadow:var(--shadow-sm);opacity:0.7;transition:opacity 0.3s ease}
.hud:hover{opacity:1}
.hud__row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.hud__label{color:var(--muted);font-size:.75rem}
.hud__value{font-weight:600;font-size:.85rem}
.hud__bar{height:4px;background:var(--surface-2);border:1px solid var(--hair);border-radius:999px;overflow:hidden}
.hud__barFill{height:100%;background:linear-gradient(90deg,var(--accent),#a892ff)}


.toast{position:fixed;top:64px;left:50%;transform:translate(-50%,-10px);background:var(--header-bg);border:1px solid var(--hair);backdrop-filter:blur(8px);color:var(--text);padding:8px 12px;border-radius:8px;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity 0.3s ease,transform 0.3s ease;z-index:1250;font-size:0.9rem}
.toast.show{opacity:1;transform:translate(-50%,0)}


.floaters{position:absolute;inset:0;pointer-events:none}
.floater{position:absolute;opacity:.2;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2));animation:floatY 12s var(--ease) infinite alternate}
.floaters .floater:nth-child(1){left:58%;top:20%;animation-duration:15s}
.floaters .floater:nth-child(2){left:78%;top:18%;animation-duration:13s}
.floaters .floater:nth-child(3){left:65%;top:70%;animation-duration:14s}
.floaters .floater:nth-child(4){left:90%;top:65%;animation-duration:12s}
.floaters .floater:nth-child(5){left:55%;top:38%;animation-duration:16s}
.floaters .floater:nth-child(6){left:82%;top:52%;animation-duration:11s}
.floaters .floater:nth-child(7){left:45%;top:25%;animation-duration:18s}
.floaters .floater:nth-child(8){left:85%;top:35%;animation-duration:14s}
.floaters .floater:nth-child(9){left:35%;top:60%;animation-duration:16s}
.floaters .floater:nth-child(10){left:75%;top:80%;animation-duration:13s}
.floaters .floater:nth-child(11){left:25%;top:45%;animation-duration:17s}
.floaters .floater:nth-child(12){left:95%;top:15%;animation-duration:15s}
@keyframes floatY{from{transform:translateY(0)}to{transform:translateY(-8px)}}


.section-floaters{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.mini-floater{position:absolute;font-size:1.2rem;opacity:0.1;animation:miniFloat 20s linear infinite;pointer-events:none}
.mini-floater:nth-child(1){left:10%;animation-delay:0s;animation-duration:25s}
.mini-floater:nth-child(2){left:20%;animation-delay:2s;animation-duration:22s}
.mini-floater:nth-child(3){left:30%;animation-delay:4s;animation-duration:28s}
.mini-floater:nth-child(4){left:40%;animation-delay:1s;animation-duration:24s}
.mini-floater:nth-child(5){left:50%;animation-delay:3s;animation-duration:26s}
.mini-floater:nth-child(6){left:60%;animation-delay:5s;animation-duration:23s}
.mini-floater:nth-child(7){left:70%;animation-delay:2s;animation-duration:27s}
.mini-floater:nth-child(8){left:80%;animation-delay:4s;animation-duration:25s}
.mini-floater:nth-child(9){left:90%;animation-delay:1s;animation-duration:24s}
.mini-floater:nth-child(10){left:15%;animation-delay:3s;animation-duration:26s}

@keyframes miniFloat{
  0%{transform:translateY(100vh) rotate(0deg);opacity:0}
  10%{opacity:0.1}
  90%{opacity:0.1}
  100%{transform:translateY(-100px) rotate(360deg);opacity:0}
}


.particles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}
.particle{position:absolute;width:4px;height:4px;background:var(--accent);border-radius:50%;opacity:0.3;animation:particleFloat 8s linear infinite}

@keyframes particleFloat{
  0%{transform:translateY(100vh) translateX(0);opacity:0}
  10%{opacity:0.3}
  90%{opacity:0.3}
  100%{transform:translateY(-100px) translateX(50px);opacity:0}
}


.cursor-trail{position:fixed;pointer-events:none;z-index:9999}
.trail-dot{position:absolute;width:6px;height:6px;background:var(--accent);border-radius:50%;opacity:0.6;animation:trailFade 0.5s ease-out forwards}

@keyframes trailFade{
  0%{opacity:0.6;transform:scale(1)}
  100%{opacity:0;transform:scale(0.3)}
}


.floating-text{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2}
.floating-msg{position:absolute;font-size:0.9rem;color:var(--accent);opacity:0.1;font-weight:600;animation:floatingText 15s linear infinite}
.floating-msg:nth-child(1){left:15%;animation-delay:0s;animation-duration:20s}
.floating-msg:nth-child(2){left:35%;animation-delay:3s;animation-duration:18s}
.floating-msg:nth-child(3){left:55%;animation-delay:6s;animation-duration:22s}
.floating-msg:nth-child(4){left:75%;animation-delay:9s;animation-duration:16s}
.floating-msg:nth-child(5){left:85%;animation-delay:12s;animation-duration:19s}

@keyframes floatingText{
  0%{transform:translateY(100vh) rotate(0deg);opacity:0}
  10%{opacity:0.1}
  90%{opacity:0.1}
  100%{transform:translateY(-100px) rotate(5deg);opacity:0}
}



.control-dot{cursor:pointer;transition:all 0.3s ease}
.control-dot:hover{transform:scale(1.2);box-shadow:0 0 10px currentColor}
.control-dot:active{transform:scale(0.9)}

.easter-egg-output{animation:fadeInUp 0.5s ease forwards}
.easter-egg-output .output-line{color:#00ff00;margin-bottom:4px;opacity:0;animation:fadeInUp 0.5s ease forwards}
.easter-egg-output .output-line:nth-child(1){animation-delay:0.2s}
.easter-egg-output .output-line:nth-child(2){animation-delay:0.4s}
.easter-egg-output .output-line:nth-child(3){animation-delay:0.6s}
.easter-egg-output .output-line:nth-child(4){animation-delay:0.8s}


.matrix-rain{position:relative;width:100%;height:200px;overflow:hidden;background:#000}
.matrix-column{position:absolute;top:-100%;color:#00ff00;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:14px;line-height:14px;animation:matrixFall linear infinite}

@keyframes matrixFall{
  0%{top:-100%;opacity:1}
  100%{top:100%;opacity:0}
}


.easter-egg-areas{position:absolute;inset:0;pointer-events:none;z-index:10}
.secret-area{position:absolute;width:30px;height:30px;border-radius:50%;opacity:0;cursor:pointer;pointer-events:auto;transition:all 0.3s ease}
.secret-area:hover{opacity:0.1;background:var(--accent);transform:scale(1.5)}
.secret-area:nth-child(1){top:20%;left:15%;animation:pulse 3s ease-in-out infinite}
.secret-area:nth-child(2){top:60%;right:20%;animation:pulse 3s ease-in-out infinite 1s}
.secret-area:nth-child(3){bottom:30%;left:50%;animation:pulse 3s ease-in-out infinite 2s}

@keyframes pulse{
  0%,100%{transform:scale(1);opacity:0}
  50%{transform:scale(1.2);opacity:0.05}
}


.konami-indicator{position:absolute;top:10px;right:10px;background:var(--surface);border:1px solid var(--hair);border-radius:6px;padding:4px 8px;font-size:0.7rem;color:var(--muted);opacity:0;transition:opacity 0.3s ease;z-index:1000;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}
.konami-indicator.show{opacity:1}
.konami-indicator span{color:var(--accent);font-weight:600}


.terminal-body.matrix-mode{background:#000;color:#00ff00}
.terminal-body.rainbow-mode{background:linear-gradient(45deg,#ff0000,#ff7f00,#ffff00,#00ff00,#0000ff,#4b0082,#9400d3);animation:rainbowShift 2s linear infinite}
.terminal-body.shake-mode{animation:terminalShake 0.5s ease-in-out}

@keyframes rainbowShift{
  0%{filter:hue-rotate(0deg)}
  100%{filter:hue-rotate(360deg)}
}

@keyframes terminalShake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-5px)}
  75%{transform:translateX(5px)}
}


.hidden-prompt{position:absolute;bottom:10px;left:10px;opacity:0;transition:opacity 0.3s ease;font-size:0.8rem;color:var(--muted)}
.hidden-prompt.show{opacity:1}
.hidden-prompt input{background:transparent;border:none;color:var(--accent);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:0.8rem;outline:none;width:200px}


/* .achievement-unlock{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--surface);border:2px solid var(--accent);border-radius:12px;padding:20px;text-align:center;opacity:0;pointer-events:none;transition:all 0.5s ease;z-index:2000;box-shadow:0 20px 40px rgba(0,0,0,0.3)}
.achievement-unlock.show{opacity:1;transform:translate(-50%,-50%) scale(1.1)}
.achievement-unlock h3{margin:0 0 10px;color:var(--accent);font-size:1.2rem}
.achievement-unlock p{margin:0;color:var(--text);font-size:0.9rem} */


.name-clickable{cursor:pointer;position:relative;transition:all 0.3s ease;display:inline-block;padding:2px 4px;border-radius:4px}
.name-clickable:hover{color:var(--accent);transform:scale(1.05);text-shadow:0 0 10px currentColor}
.name-clickable:active{transform:scale(0.95)}
.name-clickable::before{content:'';position:absolute;inset:-2px;background:linear-gradient(45deg,var(--accent),#ff6b6b,#4ecdc4,#45b7d1,#96ceb4,#feca57);border-radius:6px;opacity:0;transition:opacity 0.3s ease;z-index:-1;animation:rainbowShift 2s linear infinite}
.name-clickable:hover::before{opacity:0.1}
.name-clickable:active::before{opacity:0.2}


.name-konami-active{animation:nameKonamiPulse 0.5s ease-in-out}
.name-konami-glow{box-shadow:0 0 20px var(--accent),0 0 40px var(--accent),0 0 60px var(--accent)}

@keyframes nameKonamiPulse{
  0%{transform:scale(1)}
  50%{transform:scale(1.2)}
  100%{transform:scale(1)}
}


.crazy-easter-eggs{position:absolute;inset:0;pointer-events:none;z-index:1000}



.dancing-cursor{position:fixed;font-size:2rem;opacity:0;pointer-events:none;z-index:9999;animation:danceMove 3s ease-in-out infinite}
.dancing-cursor.active{opacity:1}

@keyframes danceMove{
  0%,100%{transform:translate(0,0) rotate(0deg)}
  25%{transform:translate(100px,50px) rotate(90deg)}
  50%{transform:translate(200px,0) rotate(180deg)}
  75%{transform:translate(100px,-50px) rotate(270deg)}
}


.flying-unicorn{position:fixed;font-size:3rem;opacity:0;pointer-events:none;z-index:9999;animation:flyAcross 4s ease-in-out infinite}
.flying-unicorn.active{opacity:1}

@keyframes flyAcross{
  0%{transform:translateX(-200px) translateY(100px) rotate(0deg)}
  25%{transform:translateX(25vw) translateY(50px) rotate(90deg)}
  50%{transform:translateX(50vw) translateY(0) rotate(180deg)}
  75%{transform:translateX(75vw) translateY(50px) rotate(270deg)}
  100%{transform:translateX(calc(100vw + 200px)) translateY(100px) rotate(360deg)}
}


.disco-ball{position:fixed;font-size:4rem;opacity:0;pointer-events:none;z-index:9999;top:50%;left:50%;transform:translate(-50%,-50%);animation:discoSpin 1s linear infinite}
.disco-ball.active{opacity:1}

@keyframes discoSpin{
  0%{transform:translate(-50%,-50%) rotate(0deg) scale(1)}
  25%{transform:translate(-50%,-50%) rotate(90deg) scale(1.2)}
  50%{transform:translate(-50%,-50%) rotate(180deg) scale(1)}
  75%{transform:translate(-50%,-50%) rotate(270deg) scale(1.2)}
  100%{transform:translate(-50%,-50%) rotate(360deg) scale(1)}
}


.disco-mode{animation:discoLights 0.5s linear infinite}
@keyframes discoLights{
  0%{filter:hue-rotate(0deg) brightness(1.2)}
  20%{filter:hue-rotate(72deg) brightness(1.4)}
  40%{filter:hue-rotate(144deg) brightness(1.2)}
  60%{filter:hue-rotate(216deg) brightness(1.4)}
  80%{filter:hue-rotate(288deg) brightness(1.2)}
  100%{filter:hue-rotate(360deg) brightness(1.2)}
}


.gravity-elements{position:fixed;inset:0;pointer-events:none;z-index:9999}
.gravity-element{position:absolute;width:20px;height:20px;background:var(--accent);border-radius:50%;animation:gravityFall 3s ease-in infinite}

@keyframes gravityFall{
  0%{transform:translateY(-100px) rotate(0deg);opacity:1}
  100%{transform:translateY(calc(100vh + 100px)) rotate(720deg);opacity:0}
}


.text-scrambler{position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:0;transition:opacity 0.3s ease}
.text-scrambler.active{opacity:1}
.scrambled-text{position:absolute;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:1.5rem;color:#ff0000;text-shadow:0 0 10px #ff0000;animation:scrambleFlicker 0.1s linear infinite}

@keyframes scrambleFlicker{
  0%,100%{opacity:1}
  50%{opacity:0.3}
}




.music-note{position:fixed;font-size:2rem;opacity:0;pointer-events:none;z-index:9999;animation:musicFloat 3s ease-out forwards}
.music-note.active{opacity:1}

@keyframes musicFloat{
  0%{transform:translateY(0) rotate(0deg);opacity:1}
  100%{transform:translateY(-200px) rotate(360deg);opacity:0}
}


.crazy-button{animation:crazyBounce 0.5s ease-in-out infinite}
@keyframes crazyBounce{
  0%,100%{transform:translateY(0) rotate(0deg)}
  25%{transform:translateY(-10px) rotate(5deg)}
  50%{transform:translateY(0) rotate(0deg)}
  75%{transform:translateY(-5px) rotate(-5deg)}
}


.rainbow-text{background:linear-gradient(45deg,#ff0000,#ff7f00,#ffff00,#00ff00,#0000ff,#4b0082,#9400d3);background-size:400% 400%;animation:rainbowShift 2s linear infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}


.glitch{position:relative;animation:glitch 0.3s ease-in-out infinite}
.glitch::before,.glitch::after{content:attr(data-text);position:absolute;top:0;left:0;width:100%;height:100%}
.glitch::before{animation:glitch-1 0.3s ease-in-out infinite;color:#ff0000;z-index:-1}
.glitch::after{animation:glitch-2 0.3s ease-in-out infinite;color:#00ff00;z-index:-2}

@keyframes glitch{
  0%,100%{transform:translate(0)}
  20%{transform:translate(-2px,2px)}
  40%{transform:translate(-2px,-2px)}
  60%{transform:translate(2px,2px)}
  80%{transform:translate(2px,-2px)}
}

@keyframes glitch-1{
  0%,100%{transform:translate(0)}
  20%{transform:translate(2px,-2px)}
  40%{transform:translate(-2px,2px)}
  60%{transform:translate(-2px,-2px)}
  80%{transform:translate(2px,2px)}
}

@keyframes glitch-2{
  0%,100%{transform:translate(0)}
  20%{transform:translate(-2px,2px)}
  40%{transform:translate(2px,-2px)}
  60%{transform:translate(2px,2px)}
  80%{transform:translate(-2px,-2px)}
}


@keyframes speedLine{
  0%{transform:translateX(-100px) scaleX(0);opacity:0}
  50%{transform:translateX(0) scaleX(1);opacity:1}
  100%{transform:translateX(100px) scaleX(0);opacity:0}
}

@keyframes zenFloat{
  0%{transform:translateY(0) rotate(0deg);opacity:0}
  20%{transform:translateY(-20px) rotate(10deg);opacity:0.7}
  50%{transform:translateY(-40px) rotate(0deg);opacity:1}
  80%{transform:translateY(-60px) rotate(-10deg);opacity:0.7}
  100%{transform:translateY(-80px) rotate(0deg);opacity:0}
}

@keyframes bounceIn{
  0%{transform:translateX(-50%) scale(0.3);opacity:0}
  50%{transform:translateX(-50%) scale(1.1);opacity:1}
  100%{transform:translateX(-50%) scale(1);opacity:1}
}

@keyframes zigzagBounce{
  0%{transform:translateY(0) rotate(0deg);opacity:0}
  25%{transform:translateY(-30px) rotate(45deg);opacity:1}
  50%{transform:translateY(-60px) rotate(0deg);opacity:0.8}
  75%{transform:translateY(-30px) rotate(-45deg);opacity:1}
  100%{transform:translateY(0) rotate(0deg);opacity:0}
}

@keyframes spiralOut{
  0%{transform:translate(-50%,-50%) scale(0) rotate(0deg);opacity:1}
  50%{transform:translate(-50%,-50%) scale(1) rotate(180deg);opacity:0.8}
  100%{transform:translate(-50%,-50%) scale(2) rotate(360deg);opacity:0}
}


.hidden-triggers{position:fixed;inset:0;pointer-events:none;z-index:1000}

.hidden-trigger{position:absolute;width:30px;height:30px;border-radius:50%;opacity:0;cursor:pointer;pointer-events:auto;transition:all 0.3s ease;display:flex;align-items:center;justify-content:center;font-size:1.2rem;background:rgba(255,255,255,0.1);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,0.2)}

.hidden-trigger:hover{opacity:0.8;transform:scale(1.2);background:rgba(255,255,255,0.2);box-shadow:0 0 20px rgba(255,255,255,0.3)}

.hidden-trigger:active{transform:scale(0.9)}


.dancing-trigger{top:15%;left:10%;animation:pulse 4s ease-in-out infinite}
.scramble-trigger{top:25%;right:15%;animation:pulse 4s ease-in-out infinite 0.5s}
.disco-trigger{top:45%;left:20%;animation:pulse 4s ease-in-out infinite 1s}
.gravity-trigger{top:65%;right:25%;animation:pulse 4s ease-in-out infinite 1.5s}

.glitch-trigger{top:55%;left:5%;animation:pulse 4s ease-in-out infinite 3s}
.rainbow-trigger{top:75%;right:10%;animation:pulse 4s ease-in-out infinite 3.5s}


.mini-trigger{position:absolute;top:10px;right:10px;width:20px;height:20px;font-size:0.8rem;opacity:0.3}
.mini-trigger:hover{opacity:0.7;transform:scale(1.3)}


.stat-trigger{position:absolute;top:5px;right:5px;width:25px;height:25px;font-size:1rem;opacity:0.2}
.stat-trigger:hover{opacity:0.6;transform:scale(1.4)}


.badge-trigger{position:absolute;top:2px;right:2px;width:20px;height:20px;font-size:0.9rem;opacity:0.2}
.badge-trigger:hover{opacity:0.7;transform:scale(1.5)}


.footer-trigger{position:absolute;top:10px;right:10px;width:25px;height:25px;font-size:1rem;opacity:0.2}
.footer-trigger:hover{opacity:0.6;transform:scale(1.4)}
.footer-trigger:nth-child(2){top:10px;right:40px}


.random-easter-countdown{position:fixed;top:20px;left:50%;transform:translateX(-50%);background:var(--surface);border:2px solid var(--accent);border-radius:12px;padding:12px 20px;opacity:0;transition:all 0.5s ease;z-index:2000;box-shadow:0 8px 32px rgba(0,0,0,0.3);backdrop-filter:blur(10px)}

.random-easter-countdown.show{opacity:1;transform:translateX(-50%) translateY(0)}

.random-easter-countdown.hide{opacity:0;transform:translateX(-50%) translateY(-20px)}

.countdown-text{font-size:0.9rem;color:var(--text);text-align:center;margin-bottom:8px;font-weight:600}

.countdown-text span{color:var(--accent);font-weight:bold;font-size:1.1rem}

.countdown-bar{width:200px;height:4px;background:var(--hair);border-radius:2px;overflow:hidden}

.countdown-fill{height:100%;background:linear-gradient(90deg,var(--accent),#ff6b6b,#4ecdc4);border-radius:2px;width:100%;animation:countdownProgress 10s linear forwards}

@keyframes countdownProgress{
  0%{width:100%}
  100%{width:0%}
}


@media (max-width: 768px){
  .hidden-trigger{width:35px;height:35px;font-size:1.4rem}
  .mini-trigger{width:25px;height:25px;font-size:1rem}
  .stat-trigger{width:30px;height:30px;font-size:1.2rem}
  .badge-trigger{width:25px;height:25px;font-size:1.1rem}
  .random-easter-countdown{top:10px;padding:10px 16px}
  .countdown-text{font-size:0.8rem}
  .countdown-bar{width:150px}
}

@media (max-width: 480px){
  .hidden-trigger{width:40px;height:40px;font-size:1.6rem}
  .mini-trigger{width:30px;height:30px;font-size:1.2rem}
  .stat-trigger{width:35px;height:35px;font-size:1.4rem}
  .badge-trigger{width:30px;height:30px;font-size:1.3rem}
  .random-easter-countdown{top:5px;padding:8px 12px}
  .countdown-text{font-size:0.7rem}
  .countdown-bar{width:120px}
}

.ico{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}


.factory .belt{position:relative;height:96px;margin-top:8px}
.factory .belt__track{position:absolute;left:0;right:0;top:50%;height:28px;transform:translateY(-50%);background:repeating-linear-gradient(90deg, var(--surface-2), var(--surface-2) 20px, var(--hair) 20px, var(--hair) 24px);border:1px solid var(--hair);border-radius:8px;overflow:hidden}
.factory .belt__items{position:absolute;left:-10%;right:-10%;top:50%;transform:translateY(-50%);display:flex;gap:40px;align-items:center}
.factory .bot{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:8px;background:var(--surface);border:1px solid var(--hair);box-shadow:var(--shadow-sm);opacity:.9;transform:translateX(-100vw)}
.factory.is-running .bot{animation:botMove 6s linear infinite}
.factory.is-running .bot:nth-child(odd){animation-delay:1.5s}
.factory.is-running .bot:nth-child(3n){animation-delay:.8s}
@keyframes botMove{from{transform:translateX(-20vw)}to{transform:translateX(120vw)}}


.badge-grid{display:flex;flex-wrap:wrap;gap:10px;margin:8px 0 0}
.badge{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--hair);background:var(--surface);border-radius:999px;padding:6px 12px;opacity:.6;transform:scale(.96);transition:transform var(--dur) var(--ease),opacity var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.badge__emoji{filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}
.badge.unlocked{opacity:1;transform:scale(1);border-color:var(--accent)}


.story-progress{position:fixed;top:0;left:0;right:0;height:2px;background:transparent;z-index:1400;pointer-events:none}
.story-progress__fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent),#a892ff);box-shadow:0 0 8px rgba(124,92,255,.3)}


.card-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin-top:12px}
.card{background:var(--surface);padding:16px;border-radius:14px;border:1px solid var(--hair);box-shadow:none;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.card__body a{color:var(--accent);text-decoration:none}
.card__body a:hover{text-decoration:underline}
.meta-list{margin:8px 0 0;color:var(--muted);padding-left:18px}
.meta-list li{margin:4px 0}
.meta-list ul{margin:6px 0 0 14px;padding-left:14px}
code{background:var(--surface-2);border:1px solid var(--hair);padding:0 6px;border-radius:6px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:.95em}



.pill-grid{display:flex;flex-wrap:wrap;gap:8px;list-style:none;padding:0;margin:8px 0 0}
.pill-grid li{border:1px solid var(--hair);padding:6px 12px;border-radius:999px;color:var(--muted);background:var(--surface-2)}





.contact-card{display:grid;gap:24px;padding:24px;border:1px solid var(--hair);border-radius:16px;background:var(--surface-1)}
.contact-primary{display:grid;gap:10px}
.contact-note{opacity:.9}
.contact-sub{font-size:.95rem;opacity:.9}
.contact-cta{display:flex;gap:12px;flex-wrap:wrap}
.quiet-note{font-size:.92rem;color:var(--muted);background:var(--surface-2);border:1px dashed var(--hair);padding:10px 12px;border-radius:10px}


.social-pills{display:flex;flex-wrap:wrap;gap:10px}
.social-pills li{list-style:none}
.social-pills li a{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--hair);border-radius:999px;background:var(--surface-2);text-decoration:none}
.social-pills li a:hover,.social-pills li a:focus{transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,0.12);border-color:var(--accent)}
.pill-icon{font-size:1.05rem}
.pill-text{font-weight:600}


.egg{animation:eggPulse .9s ease-in-out 1}
@keyframes eggPulse{0%{transform:scale(1)}50%{transform:scale(1.06)}100%{transform:scale(1)}}


.chat-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1600}
.chat-window{width:min(560px,92vw);background:var(--surface);border:1px solid var(--hair);border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;transform:translateY(12px);opacity:0;animation:chatIn .25s ease forwards}
@keyframes chatIn{to{transform:none;opacity:1}}
.chat-header{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--hair)}
.tg-avatar{width:32px;height:32px;border-radius:50%;display:inline-grid;place-items:center;background:var(--surface-2);border:1px solid var(--hair);font-size:1.1rem}
.tg-title{display:flex;flex-direction:column;line-height:1.1}
.tg-name{font-weight:700}
.tg-status{font-size:.8rem;color:var(--muted)}
.tg-status.online::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:#34c759;margin-right:6px;vertical-align:middle}
.chat-close{margin-left:auto;background:transparent;border:0;font-size:1rem;cursor:pointer;color:var(--text)}
.chat-body{max-height:56vh;overflow:auto;padding:14px 12px;display:grid;gap:8px;background:linear-gradient(180deg,rgba(0,0,0,0.02),transparent)}
.chat-msg{max-width:78%;display:grid;gap:4px;animation:msgIn .24s ease both}
.chat-msg:nth-child(2n){animation-duration:.28s}
@keyframes msgIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.msg-text{padding:10px 12px;border-radius:16px;position:relative}
.msg-meta{font-size:.72rem;opacity:.7;display:flex;gap:6px;align-items:center}
.ticks{font-size:.8rem}
.chat-msg.you{justify-self:start}
.chat-msg.you .msg-text{background:var(--surface-2);border:1px solid var(--hair);color:var(--text);border-bottom-left-radius:4px}
.chat-msg.you .msg-text::after{content:"";position:absolute;left:0;bottom:0;transform:translate(-4px,0);width:10px;height:10px;background:var(--surface-2);border-left:1px solid var(--hair);border-bottom:1px solid var(--hair);border-bottom-left-radius:2px}
.chat-msg.me{justify-self:end}
.chat-msg.me .msg-text{background:var(--accent);color:white;border-bottom-right-radius:4px}
.chat-msg.me .msg-text::after{content:"";position:absolute;right:0;bottom:0;transform:translate(4px,0);width:10px;height:10px;background:var(--accent);border-bottom-right-radius:2px}
.chat-msg.me .msg-meta{justify-content:flex-end}
.chat-footer{padding:10px 12px;border-top:1px solid var(--hair);display:flex;gap:8px;align-items:center}
.chat-input{flex:1;background:var(--surface-2);border:1px solid var(--hair);border-radius:999px;padding:10px 14px;color:var(--muted)}
.chat-input[disabled]{opacity:.8}
.chat-link{color:white;text-decoration:underline}
.typing{display:inline-flex;gap:4px;align-items:center;background:var(--surface-2);border:1px solid var(--hair);border-radius:16px;padding:8px 10px}
.dot{width:6px;height:6px;border-radius:50%;background:var(--muted);opacity:.8;animation:bounce 1.2s infinite}
.dot:nth-child(2){animation-delay:.2s}
.dot:nth-child(3){animation-delay:.4s}
@keyframes bounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-4px)}}


.reactions{display:flex;gap:6px;margin-top:2px;opacity:0;transform:translateY(4px) scale(.98);transition:opacity .2s ease,transform .2s ease}
.reactions.show{opacity:1;transform:none}
.reaction{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:4px 8px;border:1px solid var(--hair);border-radius:999px;background:var(--surface-2);cursor:pointer;user-select:none;transition:transform .1s ease, box-shadow .2s ease, border-color .2s ease}
.reaction:active{transform:scale(.95)}
.reaction.active{border-color:var(--accent);box-shadow:0 4px 14px rgba(0,0,0,.12)}
.reaction .count{font-size:.78rem;color:var(--muted)}
.chat-msg.me .reactions{justify-content:flex-end}


[data-reveal]{opacity:0;transform:translateY(8px);filter:blur(6px);transition:transform var(--dur-long) var(--ease),opacity var(--dur-long) var(--ease),filter var(--dur) var(--ease)}
[data-reveal].is-visible{opacity:1;transform:none;filter:none}


@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1!important;transform:none!important;filter:none!important}
  .floater{animation:none!important}
  .factory .bot{animation:none!important}
  .btn:hover{transform:none!important}
  .card:hover{transform:none!important}
}

.hero__visual,.floaters,.factory{will-change:transform}
.btn,.card{will-change:transform,box-shadow}

.hud,.toast,.nav{transform:translateZ(0)}


@media (max-width:768px){
  .container{padding:0 24px}
  .hero{padding:96px 0 64px}
  section{padding:40px 0}
  .hero__grid{grid-template-columns:1fr;gap:40px}
  .hero__visual{order:2}
  .hero__content{order:1}
  .nav a{padding:10px 8px;font-size:0.95rem}
  .menu-toggle{display:inline-flex;padding:10px 14px;font-size:1.1rem;min-height:44px;min-width:44px}
  .nav{position:fixed;left:0;right:0;top:calc(var(--header-h, 56px));z-index:1200;flex-direction:column;gap:12px;padding:24px;background:var(--surface);border-bottom:1px solid var(--hair);box-shadow:var(--shadow-md);transform:translateY(-100%);opacity:0;pointer-events:none;transition:transform 0.3s cubic-bezier(0.4, 0, 0.2, 1),opacity 0.3s ease;backdrop-filter:blur(12px)}
  .nav.open{transform:none;opacity:1;pointer-events:auto}
  .nav a{width:100%;text-align:center;padding:16px 20px;border-radius:12px;transition:background-color 0.2s ease;min-height:44px;display:flex;align-items:center;justify-content:center}
  .nav a:hover{background:var(--surface-2)}
  .cta-row{flex-direction:column;gap:16px;margin-top:40px}
  .cta-row .btn{width:100%;padding:16px 20px;font-size:1.1rem;min-height:48px}
  .stats__grid{grid-template-columns:1fr;gap:20px}
  .stats__header{margin-bottom:32px}
  .stats__header h2{font-size:clamp(24px,6vw,32px)}
  .stats__subtitle{font-size:1rem;padding:0 16px}
  .stat{padding:20px}
  .stat__icon{font-size:2rem;margin-bottom:12px}
  .stat__num{font-size:clamp(24px,5vw,32px)}
  .stat__label{font-size:1rem}
  .stat__description{font-size:0.85rem}
  .stat__insight{font-size:0.75rem;margin-top:6px;padding-top:6px}
  .curiosity-hook{padding:16px;margin-top:20px}
  .hook-text{font-size:0.9rem}
  .story-card{padding:24px}
  .story-timeline{gap:16px;margin-bottom:20px}
  .story-moment{padding:16px;flex-direction:column;text-align:center;gap:12px}
  .story-moment:hover{transform:translateY(-4px)}
  .moment-icon{font-size:1.8rem;margin-top:0}
  .moment-content h4{font-size:1rem}
  .moment-content p{font-size:0.9rem}
  .story-moral{padding:16px}
  .story-moral p{font-size:1rem}
  
  .psychology-card{padding:24px}
  .psychology-grid{grid-template-columns:1fr;gap:16px}
  .psych-trait{padding:16px}
  .psych-trait h4{font-size:1rem}
  .psych-trait p{font-size:0.9rem}
  .cap-grid{grid-template-columns:1fr;gap:16px}
  .card-grid{grid-template-columns:1fr;gap:20px}
  .hud{top:12px;right:12px;padding:8px 10px;min-width:80px}
  .hud__label{font-size:0.7rem}
  .hud__value{font-size:0.8rem}
  .hud__bar{height:3px}
  .story-timeline{grid-template-columns:1fr;gap:20px}
  .timeline-item{padding:20px}
  .personal-philosophy{padding:24px;margin-top:40px}
  .hero-story{padding:16px;margin:24px 0}
  .project-impact{flex-direction:column;gap:12px}
  .impact-stat{text-align:center;padding:8px 16px}
  .section-intro{font-size:1.05rem;margin-bottom:32px;padding:0 8px}
  .personal-stats{flex-direction:column;gap:16px}
  .journey-map{flex-direction:column;gap:12px;text-align:center;padding:16px}
  .journey-line{width:2px;height:24px;margin:8px auto}
  .personal-traits{justify-content:center;gap:10px}
  .personal-card{margin:0 8px}
  section{padding:32px 0}
  .card{padding:20px}
  
  .contact-card{padding:20px}
  .contact-cta .btn{flex:1}
  .btn{padding:16px 20px;font-size:1.05rem;min-height:48px}
  .stats{padding-top:16px}
  .stat{padding:20px}
  .game-container{grid-template-columns:1fr;gap:20px}
  .game-controls{gap:16px}
  .game-btn{padding:20px;min-height:60px}
  .achievement-badges{flex-direction:column;gap:12px;align-items:center}
  .terminal-body{min-height:160px;padding:12px}
  .code-content{padding:12px}
  .code-content pre{font-size:0.8rem}
  
  
  .code-intro{padding:20px;margin-bottom:24px}
  .code-intro h3{font-size:1.2rem}
  .code-intro p{font-size:0.9rem}
  .language-selector{padding:16px;gap:8px}
  .lang-btn{padding:12px 16px;min-width:80px}
  .lang-icon{font-size:1.5rem}
  .lang-name{font-size:0.8rem}
  .code-header{padding:12px 16px}
  .code-title{font-size:0.9rem}
  .code-controls{gap:6px}
  .run-code-btn,.reset-code-btn{padding:6px 12px;font-size:0.8rem;min-height:32px}
  .code-content{padding:16px}
  .code-content pre{font-size:0.8rem;line-height:1.5}
  .output-header{padding:10px 16px}
  .output-content{padding:12px 16px;min-height:100px;font-size:0.8rem}
  .output-line{padding-left:16px;margin-bottom:6px}
}

@media (max-width:480px){
  .container{padding:0 20px}
  .hero{padding:80px 0 56px}
  section{padding:36px 0}
  
  .floaters,.section-floaters,.particles,.floating-text{display:none!important}
  .hero__visual .interactive-terminal:hover{transform:none;box-shadow:var(--shadow-md)}
  .story-card,.psychology-card,.private-projects-card,.star-project,.public-showcase,.learning-projects,.skills-showcase{box-shadow:none}
  
  .episodes-row{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:8px}
  .episode-card{scroll-snap-align:start}
  
  .story-section{padding:16px;background:var(--surface);border:1px solid var(--hair);border-radius:12px}
  
  .project-showcase{grid-template-columns:1fr;gap:16px}
  .project-story{gap:12px}
  .project-metrics{gap:12px}
  .project-metrics .metric-card{padding:14px}
  .metric-card{border:1px solid var(--hair);border-radius:12px}
  .metric-content{min-width:0}
  .hero-title{font-size:clamp(32px,8vw,44px);line-height:1.15}
  .lede{font-size:1.05rem;line-height:1.7;margin-bottom:28px}
  .stats__grid{grid-template-columns:1fr;gap:16px}
  .stats__header{margin-bottom:24px}
  .stats__header h2{font-size:clamp(22px,7vw,28px)}
  .stats__subtitle{font-size:0.95rem;padding:0 8px}
  .stat{padding:16px}
  .stat__icon{font-size:1.8rem;margin-bottom:10px}
  .stat__num{font-size:clamp(20px,6vw,28px)}
  .stat__label{font-size:0.95rem}
  .stat__description{font-size:0.8rem}
  .stat__insight{font-size:0.7rem;margin-top:4px;padding-top:4px}
  .curiosity-hook{padding:12px;margin-top:16px}
  .hook-text{font-size:0.85rem}
  .story-card{padding:20px}
  .story-timeline{gap:12px;margin-bottom:16px}
  .story-moment{padding:12px;gap:8px}
  .moment-icon{font-size:1.6rem}
  .moment-content h4{font-size:0.95rem}
  .moment-content p{font-size:0.85rem}
  .story-moral{padding:12px}
  .story-moral p{font-size:0.95rem}
  
  .psychology-card{padding:20px}
  
  
  .skills-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .skill-category {
    padding: 16px;
  }
  
  .skill-category h4 {
    font-size: 1rem;
    margin-bottom: 12px;
  }
  
  .pill-grid {
    gap: 6px;
  }
  
  .pill-grid li {
    font-size: 0.8rem;
    padding: 4px 8px;
  }
  
  
  .projects-intro h2 {
    font-size: clamp(24px, 6vw, 32px);
  }
  
  .private-stats {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .private-stat {
    padding: 16px;
  }
  
  .stat-number {
    font-size: 2rem;
  }
  
  .project-showcase {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  
  .project-metrics {
    gap: 10px;
    display: none;
  }
  
  .metric-card {
    padding: 14px;
  }
  
  .metric-icon {
    font-size: 1.5rem;
    width: 40px;
    height: 40px;
  }
  
  .metric-number {
    font-size: 1.1rem;
  }
  .metric-label{font-size:0.85rem}
  .project-showcase, .project-story, .project-metrics{max-width:100%;overflow-wrap:break-word}
  
  .tech-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  
  .learning-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  
  .learning-item {
    padding: 16px;
  }
  
  .learning-icon {
    font-size: 1.5rem;
    width: 40px;
    height: 40px;
  }
  .psychology-grid{grid-template-columns:1fr;gap:12px}
  .psych-trait{padding:12px}
  .psych-trait h4{font-size:0.95rem}
  .psych-trait p{font-size:0.85rem}
  .cap-grid{grid-template-columns:1fr;gap:16px}
  .card{padding:20px;margin-bottom:8px}
  .nav{padding:20px}
  .nav a{padding:16px 20px;font-size:1.05rem;min-height:48px}
  .btn{padding:16px 20px;font-size:1.05rem;min-height:48px}
  .hud{display:none}
  .hero__grid{gap:48px}
  .personal-card{margin:0 4px}
  .story-intro{padding:20px;margin-bottom:40px}
  .timeline-item{padding:20px;margin-bottom:8px}
  .personal-philosophy{padding:24px;margin-top:48px}
  .hero-story{padding:20px;margin:32px 0}
  .section-intro{padding:0 4px;margin-bottom:40px}
  
  section{padding:40px 0}
  .site-header{padding:16px 0}
  .cta-row{gap:20px;margin-top:48px}
  h2{margin-bottom:20px}
  h3{margin-bottom:12px}
  .meta-list{margin-top:12px}
  .pill-grid{margin-top:16px;gap:10px}
  .pill-grid li{padding:8px 14px;font-size:0.95rem}
  
  
  .code-intro{padding:16px;margin-bottom:20px}
  .code-intro h3{font-size:1.1rem}
  .code-intro p{font-size:0.85rem}
  .language-selector{padding:12px;gap:6px}
  .lang-btn{padding:10px 12px;min-width:70px}
  .lang-icon{font-size:1.3rem}
  .lang-name{font-size:0.75rem}
  .code-header{padding:10px 12px}
  .code-title{font-size:0.85rem}
  .code-controls{gap:4px}
  .run-code-btn,.reset-code-btn{padding:5px 10px;font-size:0.75rem;min-height:28px}
  .code-content{padding:12px}
  .code-content pre{font-size:0.75rem;line-height:1.4}
  .output-header{padding:8px 12px}
  .output-content{padding:10px 12px;min-height:80px;font-size:0.75rem}
  .output-line{padding-left:12px;margin-bottom:4px}
  
  
  .github-intro{padding:24px;margin-bottom:32px}
  .github-intro h2{font-size:clamp(24px,6vw,32px)}
  .github-subtitle{font-size:1rem;padding:0 8px}
  .github-content{gap:32px}
  .github-psychology{padding:24px}
  .psychology-header h3{font-size:1.4rem}
  .psychology-grid{grid-template-columns:1fr;gap:16px}
  .psych-point{padding:16px;flex-direction:column;text-align:center;gap:12px}
  .psych-icon{font-size:1.8rem;margin-top:0}
  .psych-content h4{font-size:1.1rem}
  .psych-content p{font-size:0.9rem}
  .public-showcase{padding:24px}
  .public-showcase h3{font-size:1.3rem}
  .showcase-grid{grid-template-columns:1fr;gap:16px}
  .showcase-item{padding:20px}
  .showcase-icon{font-size:2rem;margin-bottom:12px}
  .showcase-content h4{font-size:1.1rem}
  .showcase-content p{font-size:0.85rem}
  .skills-showcase{padding:24px}
  .skills-showcase h3{font-size:1.3rem;margin-bottom:24px}
  .skills-grid{grid-template-columns:1fr;gap:24px}
  .skill-category h4{font-size:1rem}
  .github-cta{padding:24px}
  .cta-content h3{font-size:1.4rem}
  .cta-content p{font-size:1rem}
  .cta-buttons{flex-direction:column;gap:12px}
  .cta-buttons .btn{min-width:auto;width:100%;padding:14px 20px;font-size:1rem}
}


.story-player{background:var(--surface);border:1px solid var(--hair);border-radius:16px;padding:18px;box-shadow:0 8px 24px rgba(0,0,0,.08)}
.story-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.story-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.story-badge{background:var(--surface-2);border:1px solid var(--hair);color:var(--text);padding:6px 10px;border-radius:999px;font-weight:700;font-size:.8rem}
.story-title{color:var(--text);font-weight:700}
.story-controls{display:flex;gap:8px}
.story-btn{background:var(--surface-2);border:1px solid var(--hair);color:var(--text);border-radius:12px;padding:10px 12px;cursor:pointer;min-width:40px}
.story-btn:active{transform:scale(0.98)}
.story-screen{position:relative;background:linear-gradient(180deg,var(--surface-2),rgba(0,0,0,.04));border:1px solid var(--hair);border-radius:14px;min-height:200px;max-height:50vh;overflow:auto;padding:18px;line-height:1.75;color:var(--text)}
.story-screen.story-hit{box-shadow:0 0 0 2px var(--accent) inset, 0 0 24px rgba(124,92,255,.25);animation:hitFlash .6s ease}
@keyframes hitFlash{0%{box-shadow:0 0 0 0 var(--accent) inset, 0 0 0 rgba(0,0,0,0)}50%{box-shadow:0 0 0 2px var(--accent) inset, 0 0 24px rgba(124,92,255,.25)}100%{box-shadow:0 0 0 0 var(--accent) inset, 0 0 0 rgba(0,0,0,0)}}
.type-caret{display:inline-block;width:10px;height:1em;background:var(--accent);vertical-align:-3px;animation:blink 1.2s step-end infinite}
.story-line{white-space:pre-wrap}
.story-line{font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji"}
.story-line code, .story-line pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}
.story-line pre{background:var(--surface);border:1px solid var(--hair);border-radius:10px;padding:10px;margin:10px 0;overflow:auto}
.story-line .dev-block{display:block;padding:12px;border-left:4px solid var(--accent);background:var(--surface);border-radius:8px;margin:10px 0}
.story-line .diff-add{color:#22c55e}
.story-line .diff-del{color:#ef4444}

.story-line::cue, .story-line .sep{display:block;text-align:center;color:var(--muted);margin:8px 0}
.story-progress{position:relative;height:10px;background:var(--surface-2);border:1px solid var(--hair);border-radius:999px;margin-top:12px;overflow:hidden;cursor:pointer}
.story-progress__bar{height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-light));transition:width .1s linear}
.story-progress__label{position:absolute;top:-22px;right:0;color:var(--muted);font-size:.8rem}


.story-effect{position:absolute;pointer-events:none;z-index:5;opacity:0;animation:effectFloat 1.2s ease-out forwards}
@keyframes effectFloat{0%{transform:translateY(6px) scale(.8);opacity:0}30%{opacity:1}100%{transform:translateY(-24px) scale(1);opacity:0}}
.story-confetti{position:absolute;width:6px;height:10px;border-radius:2px;opacity:.9;animation:confettiFall 900ms linear forwards}
@keyframes confettiFall{from{transform:translateY(-10px) rotate(0)}to{transform:translateY(40px) rotate(180deg);opacity:0}}



@media (max-width:480px){
  .story-player{padding:14px;border-radius:14px}
  .story-screen{min-height:220px;max-height:60vh}
}


.stories-layout{display:grid;grid-template-columns:1fr;gap:16px}
.container #stories h2,.container section#stories h2,#stories h2{display:block;text-align:center;padding-top:16px}
.episodes-row{display:flex;gap:10px;overflow:auto;padding-bottom:6px}
.episode-card{display:flex;align-items:center;gap:10px;min-width:280px;background:linear-gradient(180deg,var(--surface),rgba(0,0,0,0));border:1px solid var(--hair);border-radius:14px;padding:12px;cursor:pointer;transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;position:relative}
.episode-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(0,0,0,.12);border-color:var(--accent)}
.episode-card.is-active{box-shadow:0 0 0 2px var(--accent) inset, 0 10px 24px rgba(0,0,0,.18)}
.episode-thumb{width:48px;height:48px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800}
.light .episode-thumb{color:#000}
.episode-info{display:flex;flex-direction:column}
.episode-title{color:var(--text);font-weight:700}
.episode-meta{color:var(--muted);font-size:.85rem}

@media (max-width:480px){
  .episode-card{min-width:240px}
}


.github-intro {
  text-align: center;
  margin-bottom: 48px;
  padding: 32px;
  background: linear-gradient(135deg, var(--surface), var(--surface-2));
  border-radius: 20px;
  border: 1px solid var(--hair);
  position: relative;
  overflow: hidden;
}

.github-intro::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent), #ff6b6b, #4ecdc4, #feca57);
  animation: shimmer 3s ease-in-out infinite;
}

.github-intro h2 {
  margin-bottom: 16px;
  color: var(--text);
  font-size: clamp(28px, 4vw, 36px);
  font-weight: 700;
  background: linear-gradient(135deg, var(--accent), #a892ff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.github-subtitle {
  font-size: 1.2rem;
  color: var(--muted);
  line-height: 1.6;
  max-width: 600px;
  margin: 0 auto;
}

.github-content {
  display: flex;
  flex-direction: column;
  gap: 40px;
}


.github-psychology {
  background: var(--surface);
  border: 2px solid var(--accent);
  border-radius: 24px;
  padding: 40px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.1);
  position: relative;
  overflow: hidden;
}

.github-psychology::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(124,92,255,0.05), rgba(124,92,255,0.02));
  pointer-events: none;
}

.psychology-header {
  text-align: center;
  margin-bottom: 32px;
  position: relative;
  z-index: 1;
}

.psychology-header h3 {
  margin: 0 0 12px;
  color: var(--accent);
  font-size: 1.8rem;
  font-weight: 700;
}

.psychology-subtitle {
  margin: 0;
  color: var(--muted);
  font-size: 1.1rem;
  font-style: italic;
}

.psychology-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  position: relative;
  z-index: 1;
}

.psych-point {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 24px;
  background: var(--surface-2);
  border: 1px solid var(--hair);
  border-radius: 16px;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.psych-point::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, var(--accent), #a892ff);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.psych-point:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.1);
  border-color: var(--accent);
}

.psych-point:hover::before {
  opacity: 1;
}

.psych-icon {
  font-size: 2rem;
  flex-shrink: 0;
  margin-top: 4px;
  animation: iconPulse 2s ease-in-out infinite;
}

.psych-content h4 {
  margin: 0 0 8px;
  color: var(--text);
  font-size: 1.2rem;
  font-weight: 600;
}

.psych-content p {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.5;
}


.public-showcase {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: 20px;
  padding: 40px;
  position: relative;
  overflow: hidden;
}

.public-showcase::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, #4ecdc4, #45b7d1, #96ceb4);
  animation: shimmer 4s ease-in-out infinite;
}

.public-showcase h3 {
  margin: 0 0 12px;
  color: var(--text);
  font-size: 1.6rem;
  font-weight: 600;
  text-align: center;
}

.showcase-subtitle {
  text-align: center;
  color: var(--muted);
  font-size: 1rem;
  margin: 0 0 32px;
  line-height: 1.6;
}

.showcase-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 24px;
}

.showcase-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 24px;
  background: var(--surface-2);
  border: 1px solid var(--hair);
  border-radius: 16px;
  transition: all 0.3s ease;
}

.showcase-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 25px rgba(0,0,0,0.1);
  border-color: var(--accent);
}

.showcase-icon {
  font-size: 2.5rem;
  margin-bottom: 16px;
  animation: iconPulse 2s ease-in-out infinite;
}

.showcase-content h4 {
  margin: 0 0 12px;
  color: var(--text);
  font-size: 1.2rem;
  font-weight: 600;
}

.showcase-content p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.5;
}


.projects-intro {
  text-align: center;
  margin-bottom: 60px;
}

.projects-intro h2 {
  margin: 0 0 20px;
  color: var(--text);
  font-size: 2.2rem;
  font-weight: 700;
}

.projects-intro .section-intro {
  font-size: 1.1rem;
  color: var(--muted);
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.6;
}


.private-projects-card {
  background: var(--surface);
  border: 2px solid var(--accent);
  border-radius: 24px;
  padding: 40px;
  margin-bottom: 60px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.1);
  position: relative;
  overflow: hidden;
}

.private-projects-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--accent), var(--accent-light));
}

.private-projects-header {
  text-align: center;
  margin-bottom: 40px;
}

.private-projects-header h3 {
  margin: 0 0 12px;
  color: var(--text);
  font-size: 1.8rem;
  font-weight: 600;
}

.private-subtitle {
  margin: 0;
  color: var(--muted);
  font-size: 1rem;
}

.private-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 32px;
  margin-bottom: 32px;
}

.private-stat {
  text-align: center;
  padding: 24px;
  background: var(--surface-2);
  border-radius: 16px;
  border: 1px solid var(--hair);
  transition: all 0.3s ease;
}

.private-stat:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 25px rgba(0,0,0,0.1);
  border-color: var(--accent);
}

.stat-number {
  display: block;
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 8px;
}

.stat-label {
  display: block;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 8px;
}

.stat-description {
  display: block;
  font-size: 0.9rem;
  color: var(--muted);
  line-height: 1.4;
}

.private-explanation {
  text-align: center;
  padding: 24px;
  background: var(--surface-2);
  border-radius: 16px;
  border: 1px solid var(--hair);
}

.private-explanation p {
  margin: 0;
  color: var(--text);
  font-size: 1rem;
  line-height: 1.6;
}


.star-project {
  background: var(--surface);
  border: 2px solid var(--accent);
  border-radius: 24px;
  padding: 40px;
  margin-bottom: 60px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.1);
  position: relative;
  overflow: hidden;
}

.star-project::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, #ffd700, #ffed4e);
}

.star-project-header {
  text-align: center;
  margin-bottom: 40px;
}

.project-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, #ffd700, #ffed4e);
  color: #333;
  padding: 8px 16px;
  border-radius: 20px;
  font-size: 0.9rem;
  font-weight: 600;
  margin-bottom: 20px;
  cursor: pointer;
  user-select: none;
}

.badge-icon {
  font-size: 1.1rem;
}

.star-project-header h3 {
  margin: 0 0 16px;
  color: var(--text);
  font-size: 2rem;
  font-weight: 700;
}

.project-tagline {
  margin: 0;
  color: var(--muted);
  font-size: 1.1rem;
  font-style: italic;
}

.badge-secret {
  display: none;
  margin-top: 12px;
  background: var(--surface-2);
  border: 1px solid var(--hair);
  border-radius: 12px;
  padding: 10px 12px;
  display: none;
}

.badge-secret .secret-emoji {
  margin-right: 6px;
}

.badge-secret .secret-text {
  display: inline;
  color: var(--muted);
  font-size: 0.95rem;
}

@keyframes sparklePop {
  0% { transform: scale(0.6); opacity: 0; }
  50% { transform: scale(1.1); opacity: 1; }
  100% { transform: scale(1); opacity: 0; }
}

.sparkle {
  position: absolute;
  width: 8px;
  height: 8px;
  background: radial-gradient(circle, #fff 20%, #ffd700 60%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
  animation: sparklePop 700ms ease-out forwards;
}

.project-showcase {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  margin-bottom: 40px;
}

.project-story {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.story-section h4 {
  margin: 0 0 12px;
  color: var(--text);
  font-size: 1.2rem;
  font-weight: 600;
}

.story-section p {
  margin: 0;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.6;
}



.project-tech {
  margin-bottom: 40px;
}

.project-tech h4 {
  margin: 0 0 24px;
  color: var(--text);
  font-size: 1.4rem;
  font-weight: 600;
  text-align: center;
}

.story-hook {
  margin: 0 auto 16px;
  max-width: 760px;
  color: var(--muted);
  text-align: center;
  line-height: 1.7;
}

.micro-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin: 0 0 20px;
}

.micro-badge {
  background: var(--surface-2);
  border: 1px solid var(--hair);
  color: var(--text);
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 600;
}


.build-narrative {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.build-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}

.build-card {
  background: var(--surface-2);
  border: 1px solid var(--hair);
  border-radius: 16px;
  padding: 20px;
  transition: all 0.3s ease;
}

.build-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 25px rgba(0,0,0,0.1);
  border-color: var(--accent);
}

.build-card h5 {
  margin: 0 0 10px;
  color: var(--accent);
  font-size: 1.05rem;
  font-weight: 600;
}

.build-card p {
  margin: 0 0 12px;
  color: var(--muted);
  line-height: 1.6;
}

.build-note {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 0.9rem;
  font-style: italic;
}

.build-points {
  margin: 0;
  padding-left: 18px;
  color: var(--text);
}

.build-points li {
  margin: 6px 0;
  font-size: 0.95rem;
}

.project-cta {
  text-align: center;
}

.cta-button {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: linear-gradient(135deg, var(--accent), var(--accent-light));
  color: white;
  padding: 16px 32px;
  border-radius: 16px;
  text-decoration: none;
  font-size: 1.1rem;
  font-weight: 600;
  transition: all 0.3s ease;
  box-shadow: 0 8px 25px rgba(0,0,0,0.1);
}

.cta-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 35px rgba(0,0,0,0.15);
}

.button-icon {
  font-size: 1.2rem;
}

.button-arrow {
  font-size: 1.2rem;
  transition: transform 0.3s ease;
}

.cta-button:hover .button-arrow {
  transform: translateX(4px);
}

.cta-note {
  margin: 16px 0 0;
  color: var(--muted);
  font-size: 0.9rem;
  font-style: italic;
}


.learning-projects {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: 20px;
  padding: 40px;
}

.learning-projects h3 {
  margin: 0 0 16px;
  color: var(--text);
  font-size: 1.8rem;
  font-weight: 600;
  text-align: center;
}

.learning-intro {
  text-align: center;
  margin: 0 0 32px;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.6;
}

.learning-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 24px;
}

.learning-item {
  display: flex;
  gap: 16px;
  padding: 24px;
  background: var(--surface-2);
  border-radius: 16px;
  border: 1px solid var(--hair);
  transition: all 0.3s ease;
}

.learning-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 25px rgba(0,0,0,0.1);
  border-color: var(--accent);
}

.learning-icon {
  font-size: 2rem;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-light);
  border-radius: 12px;
  flex-shrink: 0;
}

.learning-content h4 {
  margin: 0 0 8px;
  color: var(--text);
  font-size: 1.1rem;
  font-weight: 600;
}

.learning-content p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.5;
}


.skills-showcase {
  background: var(--surface);
  border: 1px solid var(--hair);
  border-radius: 20px;
  padding: 40px;
}

.skills-showcase h3 {
  margin: 0 0 32px;
  color: var(--text);
  font-size: 1.6rem;
  font-weight: 600;
  text-align: center;
}

.skills-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 28px;
}

.skill-category {
  text-align: center;
}

.skill-category h4 {
  margin: 0 0 16px;
  color: var(--accent);
  font-size: 1.1rem;
  font-weight: 600;
}

.skill-category .pill-grid {
  justify-content: center;
}


.github-cta {
  background: linear-gradient(135deg, var(--accent), #a892ff);
  color: #000;
  border-radius: 24px;
  padding: 40px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.github-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.1), rgba(255,255,255,0.05));
  pointer-events: none;
}

.cta-content {
  position: relative;
  z-index: 1;
  margin-bottom: 32px;
}

.cta-content h3 {
  margin: 0 0 16px;
  color: #000;
  font-size: 1.8rem;
  font-weight: 700;
}

.cta-content p {
  margin: 0;
  color: rgba(0,0,0,0.8);
  font-size: 1.1rem;
  line-height: 1.6;
  max-width: 600px;
  margin: 0 auto;
}

.cta-buttons {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}

.cta-buttons .btn {
  min-width: 180px;
  padding: 16px 24px;
  font-size: 1.1rem;
  font-weight: 600;
}

.cta-buttons .btn--primary {
  background: #000;
  color: #fff;
  border: none;
}

.cta-buttons .btn--primary:hover {
  background: rgba(0,0,0,0.8);
  transform: translateY(-2px);
}

.cta-buttons .btn--ghost {
  background: rgba(255,255,255,0.2);
  color: #000;
  border: 2px solid rgba(0,0,0,0.3);
}

.cta-buttons .btn--ghost:hover {
  background: rgba(255,255,255,0.3);
  border-color: rgba(0,0,0,0.5);
}

.btn-icon {
  font-size: 1.2rem;
  margin-right: 8px;
}


.socials{display:flex;gap:10px;list-style:none;margin:0;padding:0}
.socials a{display:inline-flex;align-items:center;gap:6px;color:var(--muted)}
.socials a:hover{color:var(--accent)}


.back-to-top{position:fixed;right:16px;bottom:max(16px, env(safe-area-inset-bottom));border:1px solid var(--hair);background:var(--surface);color:var(--text);border-radius:999px;width:48px;height:48px;display:grid;place-items:center;box-shadow:var(--shadow-sm);opacity:0;transform:translateY(10px);pointer-events:none;transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease);touch-action:manipulation;font-size:1.2rem}


body.nav-open{overflow:hidden}
.back-to-top.show{opacity:1;transform:none;pointer-events:auto}


.level-nav{position:fixed;top:50%;right:8px;transform:translateY(-50%);display:flex;flex-direction:column;gap:8px;z-index:1200}
.level-nav a{position:relative;width:10px;height:10px;border-radius:999px;border:1px solid var(--hair);background:var(--surface-2);box-shadow:var(--shadow-sm);transition:transform 0.2s ease,background-color 0.2s ease,border-color 0.2s ease;opacity:0.6}
.level-nav a:hover,.level-nav a:focus-visible{transform:scale(1.3);border-color:var(--accent);background:var(--accent);opacity:1}
.level-nav a.active{transform:scale(1.3);border-color:var(--accent);background:var(--accent);opacity:1}
.level-nav a::after{content:attr(aria-label);position:absolute;right:120%;top:50%;transform:translateY(-50%);background:var(--header-bg);border:1px solid var(--hair);backdrop-filter:blur(8px);color:var(--text);padding:4px 6px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity 0.2s ease;font-size:0.8rem}
.level-nav a:hover::after,.level-nav a:focus-visible::after{opacity:1}
@media (min-width:1024px){.level-nav a::after{opacity:.7}}
@media (max-width:720px){.level-nav{display:none}}


.hud.hud--hidden{opacity:0;pointer-events:none;transform:translateY(-10px)}


@media (hover: none) and (pointer: coarse) {
  .btn:hover{transform:none;box-shadow:none}
  .btn:active{transform:scale(0.98);transition-duration:0.1s}
  .btn--primary:hover{filter:none;transform:none;box-shadow:0 4px 15px rgba(124,92,255,0.3)}
  .btn--primary:active{transform:scale(0.98);filter:brightness(0.9)}
  .card:hover{transform:none;box-shadow:none}
  .card:active{transform:scale(0.99);transition-duration:0.1s}
  .timeline-item:hover{transform:none;box-shadow:none}
  .timeline-item:active{transform:scale(0.99)}
  .personal-card:hover{transform:none;box-shadow:var(--shadow-md)}
  .personal-card:active{transform:scale(0.98)}
  .nav a:hover{background:transparent}
  .nav a:active{background:var(--surface-2);transform:scale(0.98)}
  .menu-toggle:active{transform:scale(0.95)}
  .back-to-top:active{transform:scale(0.9)}
}


@media (max-width: 768px) {
  a, button, [role="button"] {
    min-height: 44px;
    min-width: 44px;
  }
  
  .socials a {
    padding: 8px;
    min-height: 44px;
    min-width: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    transition: background-color 0.2s ease;
  }
  
  .socials a:active {
    background: var(--surface-2);
    transform: scale(0.95);
  }
  
  .site-footer {
    padding: 20px 0;
  }
  
  .project-link {
    display: inline-block;
    padding: 8px 12px;
    margin-top: 16px;
    border-radius: 8px;
    min-height: 44px;
    line-height: 1.2;
    transition: background-color 0.2s ease;
  }
  
  .project-link:active {
    background: var(--surface-2);
    transform: scale(0.98);
  }
  
  
  .nav {
    max-height: calc(100vh - var(--header-h, 56px));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  
  .nav a {
    font-weight: 500;
    border: 1px solid transparent;
    transition: all 0.2s ease;
  }
  
  .nav a:active {
    border-color: var(--hair);
    background: var(--surface-2);
  }
  
  
  .brand:active {
    transform: scale(0.98);
    transition-duration: 0.1s;
  }
  
  .menu-toggle:active {
    transform: scale(0.95);
    transition-duration: 0.1s;
  }
}

