@import url('https://fonts.googleapis.com/css2?family=Inter:wght@500;600;700;800;900&family=JetBrains+Mono:wght@500;700;800&display=swap');

:root{
  --bg:#050714;
  --bg-2:#0a0f24;
  --panel:#0e162b;
  --panel-2:#121d35;
  --panel-3:#182541;
  --text:#f4f7ff;
  --muted:#8b98b6;
  --muted-2:#65718d;
  --line:rgba(174,191,255,.16);
  --line-strong:rgba(210,220,255,.28);
  --blue:#6ca0ff;
  --cyan:#7de6ff;
  --violet:#a78bfa;
  --gold:#ffd166;
  --pink:#ff3da5;
  --green:#6cff9e;
  --danger:#ff435a;
  --shadow:0 28px 90px rgba(0,0,0,.38);
  --radius:32px;
  --radius-sm:18px;
  --font:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono','SFMono-Regular',Consolas,monospace;
  --transition:260ms cubic-bezier(.2,.8,.2,1);
}

html[data-theme='light']{
  --bg:#eef3ff;
  --bg-2:#dce8ff;
  --panel:rgba(255,255,255,.82);
  --panel-2:rgba(244,248,255,.94);
  --panel-3:#e8efff;
  --text:#091124;
  --muted:#5a6886;
  --muted-2:#76839f;
  --line:rgba(28,45,92,.16);
  --line-strong:rgba(27,42,90,.28);
  --shadow:0 28px 80px rgba(61,91,160,.18);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  color:var(--text);
  font-family:var(--font);
  background:
    radial-gradient(circle at 16% 12%, rgba(255,209,102,.18), transparent 28%),
    radial-gradient(circle at 78% 14%, rgba(255,61,165,.20), transparent 30%),
    radial-gradient(circle at 55% 72%, rgba(108,160,255,.14), transparent 34%),
    var(--bg);
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-3;
  background-image:
    linear-gradient(rgba(158,181,255,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(158,181,255,.055) 1px, transparent 1px);
  background-size:86px 86px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.95), rgba(0,0,0,.3));
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-2;
  background:
    linear-gradient(110deg, transparent 0 30%, rgba(255,255,255,.04) 45%, transparent 60%),
    radial-gradient(circle at 50% 50%, transparent 0, rgba(0,0,0,.42) 100%);
  mix-blend-mode:screen;
}

a{color:inherit;text-decoration:none}
button,input,textarea{font:inherit}
button{cursor:pointer;border:0;background:transparent;color:inherit}
img{max-width:100%;display:block}

.app-shell{
  min-height:100vh;
  padding:22px clamp(16px,3vw,46px) 48px;
}
.container{
  width:min(1180px,100%);
  margin-inline:auto;
}

.site-header{
  position:sticky;
  top:14px;
  z-index:80;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  width:min(1180px,100%);
  margin:0 auto 38px;
  padding:12px 14px 12px 18px;
  border:1px solid var(--line);
  border-radius:28px;
  background:rgba(10,15,36,.70);
  backdrop-filter:blur(24px) saturate(160%);
  box-shadow:0 20px 70px rgba(0,0,0,.26);
}
html[data-theme='light'] .site-header{background:rgba(255,255,255,.78)}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.brand-mark{
  width:44px;
  height:44px;
  border-radius:14px;
  display:grid;
  place-items:center;
  border:1px solid rgba(185,204,255,.24);
  background:
    radial-gradient(circle at 35% 20%, rgba(255,255,255,.44), transparent 30%),
    linear-gradient(145deg, rgba(108,160,255,.22), rgba(255,209,102,.12));
  box-shadow:0 0 24px rgba(108,160,255,.34), inset 0 0 18px rgba(255,255,255,.08);
}
.brand-mark img{width:34px;height:34px;object-fit:contain;filter:drop-shadow(0 0 12px rgba(123,166,255,.65))}
.brand-text{display:grid;line-height:1.05}
.brand-text strong{font-size:15px;letter-spacing:.06em;text-transform:uppercase}
.brand-text span{font-family:var(--mono);font-size:11px;color:var(--muted)}
.header-links{display:flex;align-items:center;gap:4px}
.header-links a{
  padding:12px 13px;
  border-radius:16px;
  color:var(--muted);
  font-weight:800;
  font-size:13px;
  letter-spacing:.03em;
  transition:var(--transition);
}
.header-links a:hover,.header-links a.active{color:var(--text);background:rgba(255,255,255,.07)}
.header-actions{display:flex;align-items:center;gap:10px}

.icon-btn{
  width:50px;height:50px;
  border-radius:18px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.055);
  border:1px solid var(--line);
  transition:var(--transition);
}
.icon-btn:hover{transform:translateY(-2px);border-color:var(--line-strong);box-shadow:0 0 30px rgba(108,160,255,.18)}
.menu-btn .bar{
  width:22px;height:2px;border-radius:20px;background:var(--text);position:relative;display:block;transition:var(--transition)
}
.menu-btn .bar::before,.menu-btn .bar::after{content:"";position:absolute;left:0;width:22px;height:2px;border-radius:20px;background:var(--text);transition:var(--transition)}
.menu-btn .bar::before{top:-7px}.menu-btn .bar::after{top:7px}
.menu-btn[aria-expanded='true'] .bar{background:transparent}
.menu-btn[aria-expanded='true'] .bar::before{top:0;transform:rotate(45deg)}
.menu-btn[aria-expanded='true'] .bar::after{top:0;transform:rotate(-45deg)}

.theme-toggle{
  position:relative;
  width:86px;height:48px;
  border-radius:999px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,#111827,#020617);
  overflow:hidden;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.035),0 12px 38px rgba(0,0,0,.22);
}
.theme-toggle .sky{
  position:absolute;inset:0;
  background:radial-gradient(circle at 28% 35%, rgba(255,255,255,.65), transparent 10%), linear-gradient(135deg,#10172f,#070a17);
  transition:var(--transition);
}
.theme-toggle .orb{
  position:absolute;top:5px;left:6px;width:36px;height:36px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #fff 0 18%, #eff4ff 19% 48%, #b9c8ff 49% 100%);
  box-shadow:0 0 22px rgba(185,205,255,.85);
  transition:420ms cubic-bezier(.34,1.56,.64,1);
}
.theme-toggle .stars{
  position:absolute;inset:0;background-image:radial-gradient(circle,#fff 1px,transparent 1.5px);background-size:18px 16px;opacity:.5;transition:var(--transition)
}
html[data-theme='light'] .theme-toggle .sky{background:linear-gradient(135deg,#8bd8ff,#f6d36f)}
html[data-theme='light'] .theme-toggle .orb{transform:translateX(38px);background:radial-gradient(circle at 35% 35%, #fff7c8 0 20%, #ffd166 21% 100%);box-shadow:0 0 25px rgba(255,209,102,.75)}
html[data-theme='light'] .theme-toggle .stars{opacity:0;transform:translateY(10px)}

.menu-overlay{
  position:fixed;
  inset:0;
  z-index:100;
  pointer-events:none;
  opacity:0;
  transition:opacity 260ms ease;
}
.menu-overlay.open{opacity:1;pointer-events:auto}
.menu-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.58);backdrop-filter:blur(18px)}
.menu-panel{
  position:absolute;
  inset:18px;
  border-radius:38px;
  border:1px solid var(--line-strong);
  background:
    radial-gradient(circle at 20% 10%, rgba(255,209,102,.16), transparent 30%),
    radial-gradient(circle at 80% 0%, rgba(108,160,255,.20), transparent 36%),
    rgba(7,11,25,.92);
  overflow:hidden;
  transform:translateY(28px) scale(.98);
  transition:460ms cubic-bezier(.34,1.56,.64,1);
  box-shadow:var(--shadow);
}
html[data-theme='light'] .menu-panel{background:rgba(248,251,255,.94)}
.menu-overlay.open .menu-panel{transform:none}
.menu-top{display:flex;align-items:center;justify-content:space-between;padding:26px clamp(22px,4vw,44px);border-bottom:1px solid var(--line)}
.menu-title{font-family:var(--mono);letter-spacing:.28em;text-transform:uppercase;color:var(--muted);font-size:12px}
.menu-close{width:52px;height:52px;border-radius:18px;background:rgba(255,255,255,.06);border:1px solid var(--line);display:grid;place-items:center}
.menu-content{display:grid;grid-template-columns:1.2fr .8fr;gap:34px;padding:clamp(26px,5vw,60px)}
.nav-editorial{display:grid;gap:12px}
.nav-editorial a{
  position:relative;
  width:max-content;
  font-size:clamp(44px,10vw,112px);
  line-height:.88;
  font-weight:900;
  letter-spacing:-.08em;
  color:rgba(244,247,255,.18);
  transition:color 250ms ease, transform 250ms ease;
}
html[data-theme='light'] .nav-editorial a{color:rgba(9,17,36,.18)}
.nav-editorial a::after{
  content:"";position:absolute;left:0;bottom:-8px;height:5px;width:100%;border-radius:999px;
  transform:scaleX(0);transform-origin:left;
  background:linear-gradient(90deg,var(--blue),var(--gold),var(--pink));
  box-shadow:0 0 28px rgba(108,160,255,.4);
  transition:transform 320ms cubic-bezier(.34,1.56,.64,1);
}
.nav-editorial a:hover,.nav-editorial a.active{color:var(--text);transform:translateX(12px)}
.nav-editorial a:hover::after,.nav-editorial a.active::after{transform:scaleX(1)}
.menu-side{display:grid;align-content:start;gap:18px}
.menu-card{padding:24px;border:1px solid var(--line);border-radius:28px;background:rgba(255,255,255,.055)}
.menu-card h3{margin:0 0 10px;font-size:18px}.menu-card p{margin:0;color:var(--muted);line-height:1.7}
.menu-socials{display:flex;gap:10px;flex-wrap:wrap}.menu-socials a{width:48px;height:48px;display:grid;place-items:center;border-radius:16px;background:rgba(255,255,255,.06);border:1px solid var(--line)}

.splash{
  position:fixed;inset:0;z-index:200;display:grid;place-items:center;background:#03050f;transition:opacity .55s ease,visibility .55s ease;
}
.splash.hide{opacity:0;visibility:hidden}
.splash-inner{display:grid;place-items:center;gap:22px;transform:translateY(-10px)}
.splash-logo{width:min(640px,84vw);filter:drop-shadow(0 0 34px rgba(123,166,255,.4));animation:splashFloat 3.2s ease-in-out infinite alternate}
.splash-loader{width:220px;height:3px;border-radius:20px;background:rgba(255,255,255,.12);overflow:hidden}
.splash-loader::after{content:"";display:block;height:100%;width:45%;background:linear-gradient(90deg,var(--gold),var(--blue),var(--pink));animation:loaderMove 1.2s ease-in-out infinite alternate;border-radius:inherit}
@keyframes splashFloat{to{transform:translateY(-12px) scale(1.02)}}
@keyframes loaderMove{from{transform:translateX(-10%)}to{transform:translateX(140%)}}

.hero{
  min-height:calc(100vh - 138px);
  display:grid;
  place-items:center;
  padding:40px 0 72px;
}
.identity-card{
  position:relative;
  width:min(920px,100%);
  display:grid;
  place-items:center;
  gap:20px;
  padding:clamp(38px,8vw,86px) clamp(22px,5vw,54px);
  text-align:center;
  border:1px solid var(--line-strong);
  border-radius:44px;
  background:
    linear-gradient(125deg, rgba(255,255,255,.09), rgba(255,255,255,.025)),
    rgba(14,22,43,.58);
  overflow:hidden;
  box-shadow:var(--shadow), inset 0 0 80px rgba(108,160,255,.05);
  animation:heroFloat 6.5s ease-in-out infinite alternate;
}
.identity-card::before{
  content:"";position:absolute;inset:-2px;border-radius:inherit;padding:2px;
  background:linear-gradient(105deg, rgba(255,209,102,.65), rgba(125,230,255,.45), rgba(255,61,165,.55), rgba(255,209,102,.65));
  background-size:260% 260%;
  mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);mask-composite:exclude;
  animation:borderFlow 7s linear infinite;
  pointer-events:none;
}
.identity-card::after{
  content:"";position:absolute;inset:0;background:linear-gradient(100deg, transparent 0 30%, rgba(255,255,255,.12) 47%, transparent 62%);transform:translateX(-120%);animation:sheen 5.8s ease-in-out infinite;
}
@keyframes heroFloat{from{transform:translateY(0)}to{transform:translateY(-12px)}}
@keyframes borderFlow{to{background-position:260% 0}}
@keyframes sheen{0%,30%{transform:translateX(-120%)}60%,100%{transform:translateX(120%)}}
.username{
  margin:0;
  font-size:clamp(58px,13vw,152px);
  line-height:.82;
  letter-spacing:-.075em;
  text-transform:lowercase;
  font-weight:900;
  text-shadow:0 0 28px rgba(108,160,255,.25);
}
.blocky{
  font-family:var(--mono);
  letter-spacing:-.12em;
  color:transparent;
  background:linear-gradient(180deg,#ffffff 0%,#dfe7ff 45%,#8299da 48%,#d8ae73 100%);
  -webkit-background-clip:text;background-clip:text;
  filter:drop-shadow(0 0 22px rgba(108,160,255,.42));
}
.cert-row{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;position:relative;z-index:2}
.cert-text{font-family:var(--mono);font-weight:900;font-size:clamp(18px,3vw,36px);letter-spacing:-.08em;color:#f3f6ff;text-shadow:0 0 20px rgba(255,255,255,.18)}
html[data-theme='light'] .cert-text{color:#14203e}
.verified-mark{
  width:46px;height:46px;border-radius:50%;display:grid;place-items:center;position:relative;
  background:linear-gradient(145deg,#eaf1ff,#93aaff 50%,#ffd3a1);
  box-shadow:0 0 28px rgba(108,160,255,.55), inset 0 1px 0 rgba(255,255,255,.6);
}
.verified-mark::before{
  content:"";position:absolute;inset:-8px;border-radius:inherit;background:inherit;filter:blur(18px);opacity:.5;z-index:-1;
}
.verified-mark i{font-size:20px;color:#243250}
.verified-mark.green{background:linear-gradient(145deg,#ecfff2,#6cff9e 55%,#1bd66a);box-shadow:0 0 28px rgba(108,255,158,.58)}
.home-links{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:8px;position:relative;z-index:2}
.pill-link{display:inline-flex;align-items:center;gap:10px;padding:13px 16px;border-radius:999px;background:rgba(255,255,255,.07);border:1px solid var(--line);font-weight:900;color:var(--text);transition:var(--transition)}
.pill-link:hover{transform:translateY(-3px);border-color:var(--line-strong);box-shadow:0 0 34px rgba(108,160,255,.16)}

.preview-grid{display:grid;grid-template-columns:1fr .78fr;gap:24px;margin-top:34px}
.panel{border:1px solid var(--line);border-radius:var(--radius);background:rgba(14,22,43,.62);box-shadow:var(--shadow);backdrop-filter:blur(18px);overflow:hidden}
html[data-theme='light'] .panel{background:rgba(255,255,255,.76)}
.panel-pad{padding:clamp(22px,4vw,38px)}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);margin:0 0 16px}
.big-title{font-size:clamp(44px,8vw,118px);line-height:.87;letter-spacing:-.08em;margin:0 0 22px;font-weight:900}
.section-title{font-size:clamp(34px,5vw,72px);line-height:.94;letter-spacing:-.07em;margin:0 0 18px;font-weight:900}
.lead{font-size:clamp(18px,2.2vw,25px);line-height:1.55;color:var(--text);margin:0}
.muted{color:var(--muted)}
.about-preview{position:relative;max-height:192px;overflow:hidden;color:var(--muted);font-size:17px;line-height:1.8}
.about-preview::after{content:"";position:absolute;left:0;right:0;bottom:0;height:86px;background:linear-gradient(to bottom, transparent, var(--panel));pointer-events:none}
html[data-theme='light'] .about-preview::after{background:linear-gradient(to bottom, transparent, rgba(255,255,255,.94))}
.learn-more{display:inline-flex;align-items:center;gap:10px;margin-top:20px;color:var(--text);font-weight:900}
.learn-more i{transition:var(--transition)}.learn-more:hover i{transform:translateX(6px)}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:18px}.stat{padding:20px;border-radius:22px;border:1px solid var(--line);background:rgba(255,255,255,.045)}.stat b{display:block;font-size:28px}.stat span{color:var(--muted);font-size:13px;font-family:var(--mono)}

.page-hero{padding:40px 0 34px}.page-hero .panel{position:relative;overflow:hidden}.page-hero .panel::after{content:"";position:absolute;right:-20%;top:-70%;width:70%;height:160%;background:radial-gradient(circle, rgba(108,160,255,.25), transparent 56%);pointer-events:none}.page-kicker{font-family:var(--mono);letter-spacing:.25em;text-transform:uppercase;color:var(--muted);font-size:12px;margin:0 0 14px}

.glow-card,.project-card,.skill-item,.link-card,.contact-card,.timeline-card,.mini-project{
  position:relative;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
  box-shadow:0 20px 60px rgba(0,0,0,.18);
  transform-style:preserve-3d;
  transition:transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
  overflow:hidden;
}
.glow-card::before,.project-card::before,.skill-item::before,.link-card::before,.contact-card::before,.mini-project::before{
  content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.16), transparent 28%);opacity:0;transition:opacity .2s ease;pointer-events:none;
}
.glow-card:hover::before,.project-card:hover::before,.skill-item:hover::before,.link-card:hover::before,.contact-card:hover::before,.mini-project:hover::before{opacity:1}
.glow-card:hover,.project-card:hover,.skill-item:hover,.link-card:hover,.contact-card:hover,.timeline-card:hover,.mini-project:hover{border-color:var(--line-strong);box-shadow:0 30px 90px rgba(0,0,0,.25),0 0 36px rgba(108,160,255,.12)}

.home-projects{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:22px}.mini-project{padding:22px}.mini-project i{font-size:26px;color:var(--cyan)}.mini-project h3{margin:16px 0 8px}.mini-project p{margin:0;color:var(--muted);line-height:1.6}.mini-project .tags{margin-top:16px}
.tags{display:flex;gap:8px;flex-wrap:wrap}.tag{font-family:var(--mono);font-size:11px;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:7px 9px;background:rgba(255,255,255,.035)}

.skills-shell{display:grid;grid-template-columns:300px 1fr;gap:24px;align-items:start}
.skills-sidebar{position:sticky;top:112px;max-height:calc(100vh - 132px);overflow:auto;padding:28px;border-radius:32px;background:rgba(14,22,43,.84);border:1px solid var(--line);box-shadow:var(--shadow)}
html[data-theme='light'] .skills-sidebar{background:rgba(255,255,255,.88)}
.sidebar-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.sidebar-top h2{margin:0;font-size:28px;letter-spacing:-.05em}.close-sidebar{display:none}
.skill-category{padding:14px 0 14px 24px;border-left:3px solid transparent}.skill-category.active{border-left-color:var(--danger)}.skill-category h3{margin:0 0 10px;color:var(--muted);font-size:18px;letter-spacing:-.04em}.skill-icons{display:flex;gap:10px;flex-wrap:wrap}.skill-icons span{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;border:1px solid var(--line);background:rgba(255,255,255,.055);font-family:var(--mono);font-size:11px;font-weight:900}.skill-icons i{font-size:17px}.open-sidebar{display:flex;align-items:center;gap:18px;width:100%;padding:24px;border-radius:24px;border:1px solid var(--line);background:rgba(14,22,43,.72);font-size:24px;font-weight:900;margin-bottom:22px;text-align:left}.open-sidebar i{font-size:28px}.skills-toolbar{display:flex;gap:12px;margin-bottom:18px}.search{flex:1;position:relative}.search i{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--muted)}.search input{width:100%;padding:17px 18px 17px 48px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.045);color:var(--text);outline:none}.skill-list{display:grid;gap:14px}.skill-item{padding:0}.skill-head{display:grid;grid-template-columns:58px 1fr 190px 42px;gap:18px;align-items:center;padding:22px 24px}.skill-logo{width:58px;height:58px;border-radius:14px;display:grid;place-items:center;background:rgba(255,255,255,.06);border:1px solid var(--line);font-family:var(--mono);font-weight:900;font-size:18px}.skill-logo i{font-size:28px}.skill-name h3{margin:0;font-size:24px;letter-spacing:-.04em}.skill-name span{color:var(--muted);font-family:var(--mono);font-size:12px}.skill-meter{height:18px;border-radius:999px;background:rgba(80,94,128,.25);overflow:hidden;position:relative}.skill-meter span{display:block;height:100%;width:var(--level);border-radius:inherit;background:linear-gradient(90deg,#ffe44d,#ff5f1f,#ff007f);box-shadow:0 0 24px rgba(255,61,165,.24)}.skill-arrow{display:grid;place-items:center;font-size:22px;color:var(--text);transition:var(--transition)}.skill-item.open .skill-arrow{transform:rotate(180deg)}.skill-body{display:none;padding:0 24px 26px}.skill-item.open .skill-body{display:block;animation:bodyIn .28s ease both}@keyframes bodyIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.skill-desc{font-size:18px;line-height:1.7;color:var(--text);margin:0 0 18px}.skill-bullets{margin:0 0 24px 0;padding-left:24px;color:var(--text);line-height:1.75}.skill-bullets li{padding-left:6px}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.detail-card{padding:18px;border-radius:20px;border:1px solid var(--line);background:rgba(255,255,255,.04)}.detail-card h4{margin:0 0 10px;font-size:16px}.detail-card p{margin:0;color:var(--muted);line-height:1.65}.projects-strip{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:16px 0 20px}.project-mini{padding:18px;border-radius:20px;border:1px solid var(--line);background:rgba(255,255,255,.045)}.project-mini strong{display:block;margin-bottom:6px}.project-mini span{color:var(--muted);line-height:1.5}

.project-filters{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 22px}.filter-btn{padding:12px 15px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.045);font-weight:900;color:var(--muted);transition:var(--transition)}.filter-btn.active,.filter-btn:hover{color:var(--text);border-color:var(--line-strong);background:rgba(255,255,255,.09)}.project-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.project-card{padding:26px}.project-top{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px}.project-icon{width:58px;height:58px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(108,160,255,.2),rgba(255,209,102,.16));border:1px solid var(--line)}.project-icon i{font-size:26px}.project-status{font-family:var(--mono);font-size:11px;color:var(--green);border:1px solid rgba(108,255,158,.28);background:rgba(108,255,158,.08);padding:7px 10px;border-radius:999px}.project-card h2{margin:0 0 10px;font-size:32px;letter-spacing:-.06em}.project-card p{color:var(--muted);line-height:1.72}.feature-list{display:grid;gap:10px;margin:18px 0}.feature-list div{display:flex;gap:10px;align-items:flex-start;color:var(--text)}.feature-list i{margin-top:3px;color:var(--cyan)}.project-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:18px}.meta-box{border:1px solid var(--line);border-radius:16px;padding:12px;background:rgba(255,255,255,.035)}.meta-box span{display:block;color:var(--muted);font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.14em}.meta-box b{font-size:13px}

.about-grid{display:grid;grid-template-columns:1fr .72fr;gap:22px}.text-block{font-size:18px;line-height:1.85;color:var(--muted)}.text-block strong{color:var(--text)}.timeline{display:grid;gap:14px}.timeline-card{padding:20px}.timeline-card span{font-family:var(--mono);font-size:12px;color:var(--gold)}.timeline-card h3{margin:8px 0}.timeline-card p{margin:0;color:var(--muted);line-height:1.65}.values{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}.value{padding:22px}.value i{font-size:24px;color:var(--cyan)}.value h3{margin:16px 0 8px}.value p{margin:0;color:var(--muted);line-height:1.6}

.coding-grid{display:grid;grid-template-columns:1fr .8fr;gap:22px}.code-window{border-radius:30px;overflow:hidden;border:1px solid var(--line);background:#050816;box-shadow:var(--shadow)}.window-top{height:54px;display:flex;align-items:center;gap:8px;padding:0 18px;border-bottom:1px solid rgba(255,255,255,.08)}.dot{width:12px;height:12px;border-radius:50%;background:var(--line-strong)}.dot.one{background:#ff5f57}.dot.two{background:#ffbd2e}.dot.three{background:#28c840}.code-window pre{margin:0;padding:24px;overflow:auto;font-family:var(--mono);line-height:1.65;color:#dfe7ff}.code-window .key{color:#ff7ab6}.code-window .str{color:#ffd166}.code-window .fn{color:#7de6ff}.lab-stack{display:grid;gap:14px}.stack-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px;border-radius:22px;border:1px solid var(--line);background:rgba(255,255,255,.045)}.stack-row strong{display:flex;align-items:center;gap:12px}.stack-row i{font-size:22px;color:var(--cyan)}.stack-row span{font-family:var(--mono);color:var(--muted);font-size:12px}

.links-grid,.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.link-card,.contact-card{padding:24px}.link-card i,.contact-card i{font-size:26px;color:var(--cyan)}.link-card h2,.contact-card h2{margin:18px 0 8px}.link-card p,.contact-card p{margin:0;color:var(--muted);line-height:1.6}.contact-form{display:grid;gap:14px}.contact-form input,.contact-form textarea{width:100%;border:1px solid var(--line);border-radius:18px;padding:16px;background:rgba(255,255,255,.045);color:var(--text);outline:none}.contact-form textarea{min-height:160px;resize:vertical}.primary-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:15px 18px;border-radius:18px;background:linear-gradient(90deg,var(--blue),var(--pink));color:white;font-weight:900;box-shadow:0 16px 40px rgba(108,160,255,.22)}

.footer{margin-top:60px;padding:26px 0;color:var(--muted);font-family:var(--mono);font-size:12px;text-align:center;border-top:1px solid var(--line)}

@media (max-width:980px){
  .header-links{display:none}.menu-content{grid-template-columns:1fr}.preview-grid,.about-grid,.coding-grid,.skills-shell{grid-template-columns:1fr}.home-projects,.project-grid,.values,.links-grid,.contact-grid{grid-template-columns:1fr}.skills-sidebar{position:fixed;inset:0 auto 0 0;width:min(78vw,420px);z-index:90;max-height:none;border-radius:0 34px 34px 0;transform:translateX(-110%);transition:var(--transition)}.skills-sidebar.open{transform:none}.close-sidebar{display:grid;width:44px;height:44px;place-items:center;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.06)}.skill-head{grid-template-columns:54px 1fr 110px 34px;padding:18px}.skill-meter{height:14px}.detail-grid,.projects-strip{grid-template-columns:1fr}.project-meta{grid-template-columns:1fr}.nav-editorial a{font-size:clamp(48px,18vw,88px)}
}
@media (max-width:620px){
  .app-shell{padding:14px 12px 34px}.site-header{top:10px;border-radius:22px;margin-bottom:24px}.brand-text span{display:none}.theme-toggle{width:72px;height:42px}.theme-toggle .orb{width:30px;height:30px}.theme-toggle .orb{top:5px;left:5px}html[data-theme='light'] .theme-toggle .orb{transform:translateX(31px)}.identity-card{border-radius:32px;min-height:54vh}.username{font-size:clamp(48px,18vw,86px)}.cert-text{font-size:20px}.verified-mark{width:38px;height:38px}.preview-grid{gap:14px}.big-title{font-size:56px}.section-title{font-size:42px}.skill-head{grid-template-columns:48px 1fr 90px 28px;gap:10px}.skill-logo{width:48px;height:48px}.skill-name h3{font-size:19px}.skill-name span{display:none}.skill-meter{height:12px}.menu-panel{inset:10px;border-radius:26px}.menu-content{padding:24px}.menu-top{padding:18px 20px}.panel-pad{padding:22px}.skills-toolbar{flex-direction:column}.open-sidebar{font-size:18px}.project-card h2{font-size:26px}.logo-wide{max-width:92vw}
}


/* V3 skills + menu fixes */
.menu-panel{overflow-y:auto;overscroll-behavior:contain;max-height:calc(100vh - 36px)}
.menu-content{grid-template-columns:1.05fr .95fr;gap:22px;padding:clamp(18px,3.2vw,38px)}
.nav-editorial{gap:4px}
.nav-editorial a{font-size:clamp(32px,6.8vw,78px);line-height:.92;letter-spacing:-.07em}
.menu-side{display:grid;gap:12px;align-content:start}
.menu-card{padding:16px 18px;border-radius:22px;background:rgba(255,255,255,.045);border:1px solid var(--line)}
.menu-card h3{font-size:14px;margin:0 0 8px;letter-spacing:.08em;text-transform:uppercase;color:var(--text)}
.menu-card p{font-size:13px;line-height:1.55;margin:0;color:var(--muted)}
.menu-socials a{width:40px;height:40px;border-radius:14px}
.skills-page .page-hero{margin-bottom:22px}
.compact-hero .panel-pad{padding:clamp(24px,4vw,42px)}
.skills-shell{grid-template-columns:330px minmax(0,1fr)}
.skills-sidebar{padding:24px;scrollbar-width:thin}
.skill-sidebar-note{margin:0 0 18px;color:var(--muted);font-family:var(--mono);font-size:12px;line-height:1.6}
.skill-category{padding:13px 0 15px 20px;border-left:3px solid rgba(255,255,255,.08);margin-bottom:2px}
.skill-category:hover{border-left-color:var(--blue)}
.skill-category h3{font-size:17px;margin-bottom:10px}
.skill-icons{gap:8px}
.skill-jump{width:34px;height:34px;border-radius:10px;border:1px solid var(--line);background:rgba(255,255,255,.055);display:grid;place-items:center;font-family:var(--mono);font-size:10px;font-weight:1000;color:var(--text);transition:var(--transition);box-shadow:inset 0 0 0 1px rgba(255,255,255,.02)}
.skill-jump i{font-size:16px}
.skill-jump:hover,.skill-jump:focus-visible{transform:translateY(-2px) scale(1.04);border-color:var(--line-strong);box-shadow:0 0 22px rgba(108,160,255,.24);outline:none}
.clear-skill{display:flex;align-items:center;gap:10px;padding:0 18px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.045);color:var(--text);font-weight:900;white-space:nowrap}
.skill-head{grid-template-columns:58px minmax(0,1fr) 210px 42px}
.skill-meter{display:flex;align-items:center;overflow:visible;background:rgba(80,94,128,.25);padding:0;position:relative}
.skill-meter span{position:absolute;left:0;top:0;bottom:0}
.skill-meter b{position:relative;z-index:2;margin-left:auto;margin-right:8px;font-size:10px;font-family:var(--mono);color:rgba(255,255,255,.86);text-shadow:0 1px 8px rgba(0,0,0,.55)}
html[data-theme='light'] .skill-meter b{color:#111827;text-shadow:none}
.skill-body{border-top:1px solid var(--line);margin:0 20px;padding:20px 4px 26px}
.skill-desc{font-size:17px}
.skill-bullets li{margin-bottom:5px}
.skill-list .skill-item{scroll-margin-top:130px}
.badge-js{background:#f7df1e!important;color:#111827!important}.badge-ts{background:#3178c6!important;color:#fff!important}.badge-html{background:#e34f26!important;color:#fff!important}.badge-css{background:#663399!important;color:#fff!important}.brand-react{color:#61dafb!important}.badge-python{background:linear-gradient(135deg,#3776ab 0 50%,#ffd43b 50% 100%)!important;color:#07111d!important}.badge-swift{background:linear-gradient(135deg,#ffac45,#ff2d20)!important;color:#fff!important}.badge-firebase{background:linear-gradient(135deg,#ffca28,#f57c00)!important;color:#1b1200!important}.badge-java{background:linear-gradient(135deg,#e76f00,#5382a1)!important;color:#fff!important}.badge-csharp{background:#68217a!important;color:#fff!important}.brand-node{color:#68a063!important}.badge-postgres{background:#336791!important;color:#fff!important}.badge-sql{background:#0f766e!important;color:#fff!important}.badge-prisma{background:#2d3748!important;color:#fff!important}.badge-bun{background:#f4e2d8!important;color:#161616!important}.badge-svelte{background:#ff3e00!important;color:#fff!important}.badge-vue{background:linear-gradient(135deg,#42b883,#35495e)!important;color:#fff!important}.badge-tanstack{background:linear-gradient(135deg,#7dd3fc,#f472b6)!important;color:#08111f!important}.badge-kotlin{background:linear-gradient(135deg,#7f52ff,#ff6b00)!important;color:#fff!important}.badge-android{background:#3ddc84!important;color:#052116!important}.badge-expo{background:#111827!important;color:#fff!important}.badge-express{background:#f8fafc!important;color:#111827!important}.badge-next{background:#050505!important;color:#fff!important}.badge-unreal{background:#111827!important;color:#fff!important}.badge-cpp{background:#00599c!important;color:#fff!important}.badge-unity{background:#222!important;color:#fff!important}.badge-godot{background:#478cbf!important;color:#fff!important}.badge-git{background:#f05032!important;color:#fff!important}.brand-npm{color:#cb3837!important}.badge-windows{background:linear-gradient(135deg,#00a4ef,#7fba00,#ffb900,#f25022)!important;color:#fff!important}.badge-cloudflare{background:#f38020!important;color:#111!important}.badge-vercel{background:#fff!important;color:#000!important}.badge-supabase{background:#3ecf8e!important;color:#06231b!important}.badge-azure{background:#0078d4!important;color:#fff!important}.badge-web{background:#334155!important;color:#fff!important}.badge-access{background:#005a9c!important;color:#fff!important}.badge-markdown{background:#111827!important;color:#fff!important}.badge-auto{background:linear-gradient(135deg,#facc15,#f472b6)!important;color:#111!important}.badge-yarn{background:#2c8ebb!important;color:#fff!important}.badge-cursor{background:#fff!important;color:#111!important}.badge-vscode{background:#007acc!important;color:#fff!important}.badge-visualstudio{background:#5c2d91!important;color:#fff!important}.badge-intellij{background:linear-gradient(135deg,#fe315d,#6b57ff,#00cfff)!important;color:#fff!important}.badge-xcode{background:#147efb!important;color:#fff!important}.badge-gcc{background:#d7a46a!important;color:#111!important}.badge-vite{background:linear-gradient(135deg,#646cff,#facc15)!important;color:#111!important}.badge-webpack{background:#8dd6f9!important;color:#1c3f54!important}.badge-rollup{background:#ec4a3f!important;color:#fff!important}.badge-eslint{background:#4b32c3!important;color:#fff!important}.badge-prettier{background:linear-gradient(135deg,#56b3b4,#f7ba3e,#ea5e5e)!important;color:#111!important}.badge-biome{background:#60a5fa!important;color:#06111f!important}.badge-stylelint{background:#263238!important;color:#fff!important}.badge-json{background:#f7df1e!important;color:#111!important}.badge-yaml{background:#cb171e!important;color:#fff!important}.badge-toml{background:#9c4221!important;color:#fff!important}.badge-xml{background:#f97316!important;color:#fff!important}.badge-plist{background:#7c3aed!important;color:#fff!important}.badge-blender{background:#f5792a!important;color:#fff!important}.badge-figma{background:linear-gradient(135deg,#f24e1e,#a259ff,#1abcfe,#0acf83)!important;color:#fff!important}.badge-audacity{background:#0b43a4!important;color:#fff!important}.badge-photoshop{background:#001e36!important;color:#31a8ff!important}
@media (max-width:980px){
  .menu-panel{max-height:calc(100vh - 20px)}
  .menu-content{grid-template-columns:1fr;padding:20px;gap:16px}
  .nav-editorial a{font-size:clamp(34px,12vw,64px)}
  .menu-side{grid-template-columns:1fr 1fr 1fr;gap:10px}
  .menu-card{padding:14px}
  .menu-card p{font-size:12px}
  .skills-shell{grid-template-columns:1fr}
  .skills-sidebar{width:min(86vw,430px);padding:22px}
  .skill-head{grid-template-columns:54px minmax(0,1fr) 120px 34px}
}
@media (max-width:620px){
  .menu-content{padding:16px;gap:12px}
  .nav-editorial a{font-size:clamp(30px,10.8vw,48px);line-height:.96}
  .menu-side{grid-template-columns:1fr}
  .menu-card{padding:12px 14px;border-radius:18px}
  .menu-card h3{font-size:12px;margin-bottom:5px}
  .menu-card p{font-size:11.5px;line-height:1.45}
  .menu-socials a{width:34px;height:34px;border-radius:12px}
  .skill-head{grid-template-columns:48px minmax(0,1fr) 84px 28px;gap:10px;padding:16px}
  .skill-meter b{display:none}
  .clear-skill{height:46px;justify-content:center}
  .skill-logo{font-size:13px}
  .skill-jump{width:32px;height:32px}
}

/* V4: real logo/image icons for every skill. No text-letter badges. */
.skill-jump.official-skill-icon,
.skill-logo.official-skill-icon{
  position:relative;
  overflow:hidden;
  color:var(--text)!important;
  background:
    radial-gradient(circle at 28% 18%, rgba(255,255,255,.28), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.11), rgba(255,255,255,.025));
  border:1px solid rgba(207,224,255,.22);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.035),
    0 12px 26px rgba(0,0,0,.22),
    0 0 20px rgba(95,145,255,.10);
  font-family:inherit;
  font-size:0;
}
.skill-jump.official-skill-icon::before,
.skill-logo.official-skill-icon::before{
  content:"";
  position:absolute;
  inset:-45%;
  background:linear-gradient(120deg, transparent 36%, rgba(255,255,255,.24), transparent 64%);
  transform:translateX(-62%) rotate(18deg);
  opacity:.42;
  pointer-events:none;
}
.skill-jump.official-skill-icon:hover::before,
.skill-logo.official-skill-icon:hover::before{
  animation:iconShine 1.1s ease both;
}
@keyframes iconShine{
  from{transform:translateX(-68%) rotate(18deg)}
  to{transform:translateX(68%) rotate(18deg)}
}
.skill-icon-img{
  width:72%;
  height:72%;
  object-fit:contain;
  display:block;
  z-index:1;
  filter:drop-shadow(0 0 10px rgba(190,210,255,.35));
  user-select:none;
  -webkit-user-drag:none;
}
.skill-logo .skill-icon-img{
  width:68%;
  height:68%;
  filter:drop-shadow(0 0 14px rgba(190,210,255,.42));
}
.skill-jump.official-skill-icon i,
.skill-logo.official-skill-icon i{
  z-index:1;
  font-size:18px;
  color:#f6f8ff!important;
  text-shadow:0 0 14px rgba(174,205,255,.48);
}
.skill-logo.official-skill-icon i{font-size:30px}
.skill-jump.official-skill-icon:hover,
.skill-jump.official-skill-icon:focus-visible{
  transform:translateY(-2px) scale(1.06);
  border-color:rgba(222,234,255,.44);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.07),
    0 14px 28px rgba(0,0,0,.28),
    0 0 26px rgba(101,161,255,.30);
}
.skill-head:hover .skill-logo.official-skill-icon,
.skill-item.open .skill-logo.official-skill-icon{
  border-color:rgba(222,234,255,.44);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.07),
    0 14px 28px rgba(0,0,0,.28),
    0 0 30px rgba(101,161,255,.26);
}
html[data-theme='light'] .skill-jump.official-skill-icon,
html[data-theme='light'] .skill-logo.official-skill-icon{
  background:
    radial-gradient(circle at 28% 18%, rgba(255,255,255,.86), transparent 38%),
    linear-gradient(145deg, rgba(255,255,255,.88), rgba(232,239,255,.72));
  border-color:rgba(30,48,82,.14);
}
html[data-theme='light'] .skill-jump.official-skill-icon i,
html[data-theme='light'] .skill-logo.official-skill-icon i{
  color:#101827!important;
  text-shadow:none;
}
@media (max-width:720px){
  .skill-icon-img{width:70%;height:70%}
  .skill-logo .skill-icon-img{width:66%;height:66%}
  .skill-jump.official-skill-icon i{font-size:16px}
  .skill-logo.official-skill-icon i{font-size:25px}
}
