:root{--bg: #0b0b0f;--text: #e9e9ee;--subtext: #b8b8c3;--card: #111118;--accent: #ff2d87;--accent-2: #b40062;--btn-txt: #0b0b0f;--glow: 0 0 40px rgba(255, 45, 135, .25);--shadow: 0 10px 30px rgba(0, 0, 0, .45)}html[data-theme=light]{--bg: #ffffff;--text: #141414;--subtext: #52525b;--card: #ffffff;--border: rgba(0, 0, 0, .06);--accent: #ff2d87;--accent-2: #b40062;--btn-txt: #ffffff;--glow: 0 0 28px rgba(255, 45, 135, .18);--shadow: 0 12px 24px rgba(20, 7, 13, .08)}.hero-wrapper{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;padding:clamp(48px,6vw,96px) clamp(20px,6vw,96px) 0 clamp(20px,6vw,96px);background:var(--bg);color:var(--text);overflow:hidden}@media (max-width: 980px){.hero-wrapper{grid-template-columns:1fr;gap:32px}}.hero-blob{position:absolute;inset:-20% -10% auto auto;width:60vmax;height:60vmax;background:radial-gradient(40% 40% at 50% 50%,rgba(255,45,135,.35),transparent 60%);filter:blur(60px);z-index:0;pointer-events:none}.theme-toggle{position:absolute;top:18px;right:18px;width:40px;height:40px;border-radius:999px;border:1px solid var(--border);background:var(--card);display:grid;place-items:center;color:var(--text);box-shadow:var(--shadow);z-index:3;transition:transform .2s ease}.theme-toggle:hover{transform:translateY(-2px)}.hero-content{position:relative;z-index:1}.hero-badge{display:inline-block;padding:6px 12px;border:1px solid var(--border);border-radius:999px;font-size:14px;letter-spacing:.2px;background:linear-gradient(180deg,#ffffff05,#00000014);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.hero-title{margin:14px 0 10px;font-size:clamp(34px,4vw,56px);line-height:1.05;font-weight:800}.highlight-orange{background:linear-gradient(90deg,var(--accent),#ff6aa9);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:var(--glow)}.hero-desc{margin:10px 0 22px;color:var(--subtext);font-size:clamp(15px,1.15vw,18px)}.hero-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);text-decoration:none;font-weight:600;transition:transform .15s ease,box-shadow .2s ease,border-color .2s ease}.btn:hover{transform:translateY(-2px);border-color:#ffffff38}.btn.primary{background:linear-gradient(135deg,var(--accent),#ff6aa9);color:var(--btn-txt);border:none;box-shadow:var(--glow)}.btn.linkedin:hover,.btn.github:hover{box-shadow:var(--shadow)}.hero-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:16px 0 8px;padding:0;list-style:none}@media (max-width: 680px){.hero-stats{grid-template-columns:1fr}}.stat{border:1px solid var(--border);border-radius:14px;padding:12px 14px;background:linear-gradient(180deg,#ffffff05,#0000000a)}.stat strong{font-size:18px;display:block}.stat span{color:var(--subtext);font-size:14px}.hero-stack{margin-top:10px;font-size:14px;color:var(--subtext)}.hero-stack span{color:var(--text);font-weight:600}.hero-image{position:relative;justify-self:center;z-index:1}.hero-image img{width:min(420px,86vw);height:auto;border-radius:22px;border:1px solid var(--border);box-shadow:var(--shadow);background:var(--card)}.hero-badge-exp{position:absolute;bottom:-14px;right:-14px;background:var(--card);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow);padding:10px 12px;border-radius:14px;font-size:14px}.hero-badge-exp strong{color:var(--accent);font-size:18px}.ae-section{position:relative;background:var(--bg);color:var(--text);padding:0 clamp(16px,6vw,28px) clamp(32px,6vw,96px) clamp(16px,6vw,28px)}.ae-container{max-width:1100px;margin:0 auto}.ae-title-wrap{margin-bottom:10px}.ae-h2{font-size:clamp(22px,3.6vw,34px);font-weight:800;line-height:1.1;display:inline-block;position:relative;margin-bottom:30px}.ae-underline{position:absolute;left:0;right:0;bottom:-6px;height:3px;background:linear-gradient(90deg,var(--accent),#ff6aa9);border-radius:999px;transform-origin:left center;animation:ae-scan 2.8s ease-in-out infinite}@keyframes ae-scan{0%{transform:scaleX(.2);opacity:.4}50%{transform:scaleX(1);opacity:1}to{transform:scaleX(.2);opacity:.4}}.ae-sub{margin-top:8px;color:var(--subtext);font-size:14px;letter-spacing:.2px}.ae-desc{margin-top:10px;color:var(--text);opacity:.92;line-height:1.65}.ae-stats{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.ae-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid rgba(255,45,135,.35);background:linear-gradient(135deg,#ff2d872e,#ff6aa91f);box-shadow:0 0 20px #ff2d872e;font-weight:700}.ae-pill em{font-style:normal;font-weight:600;color:var(--subtext)}.ae-xp-wrap{margin-top:clamp(26px,4vw,40px)}.ae-xp-header{position:relative;margin-bottom:18px}.ae-h3{font-size:clamp(18px,2.6vw,24px);font-weight:800;display:inline-block}.ae-flow{position:absolute;right:-10px;top:-6px;width:54px;height:54px;border-radius:50%;background:radial-gradient(35px 35px at 30% 30%,rgba(255,144,192,.9),var(--accent));filter:blur(14px);animation:ae-orb 5s ease-in-out infinite alternate}@keyframes ae-orb{0%{transform:translate(0)}to{transform:translate(8px,-8px)}}.ae-xp-list{position:relative;margin:0;padding:0;list-style:none}.ae-xp-list:before{content:"";position:absolute;left:20px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,#ff2d8761,#ff6aa933);border-radius:2px}.ae-xp-card{position:relative;padding-left:52px;margin-bottom:16px;transform:perspective(900px) rotateX(var(--rx,0)) rotateY(var(--ry,0));transition:transform .12s ease-out}.ae-dot{position:absolute;left:12px;top:20px;width:12px;height:12px;border-radius:50%;background:var(--card);border:2px solid var(--accent);box-shadow:0 0 18px #ff2d8773}.ae-line{position:absolute;left:18px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,#ff2d8759,#ff6aa926);border-radius:2px}.ae-card-inner{border:1px solid var(--border);border-radius:16px;background:radial-gradient(120% 80% at 0% 0%,rgba(255,45,135,.06),transparent 60%),linear-gradient(180deg,#ffffff05,#0000000f);overflow:hidden;transition:border-color .25s ease,box-shadow .25s ease,background .25s ease}.ae-xp-card:hover .ae-card-inner{border-color:#fff3;box-shadow:0 12px 28px #00000040,0 0 40px #ff2d872e}.ae-head{padding:14px 16px 12px}.ae-period{font-size:12px;color:var(--subtext);letter-spacing:.3px;display:block}.ae-title{font-size:clamp(16px,2.1vw,20px);font-weight:800;line-height:1.2}.ae-company{font-weight:800;background:linear-gradient(90deg,var(--accent),#ff6aa9);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 22px rgba(255,45,135,.18)}.ae-meta{font-size:12px;color:var(--subtext);display:block;margin-top:4px}.ae-details{height:0;opacity:0;overflow:clip;padding:0 16px}.ae-xp-card.is-open .ae-details{padding:8px 16px 6px;border-top:1px solid var(--border)}.ae-bullets{margin:6px 0;padding-left:18px}.ae-bullets li{list-style:disc;margin:6px 0;color:var(--subtext)}.ae-tags{display:flex;flex-wrap:wrap;gap:8px;padding-bottom:8px}.ae-tag{font-size:12px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,45,135,.35);background:linear-gradient(135deg,#ff2d872e,#ff6aa91f);box-shadow:0 0 16px #ff2d872e}.ae-expand{width:100%;display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:10px 14px 12px;background:transparent;border:0;color:var(--text)}.ae-expand-label{font-weight:700;opacity:.9}.ae-chevron{width:16px;height:16px;border-right:2px solid var(--text);border-bottom:2px solid var(--text);transform:rotate(-45deg);opacity:.75;transition:transform .25s,opacity .25s}.ae-chevron.open{transform:rotate(135deg);opacity:1}@media (max-width: 680px){.ae-xp-list:before{left:16px}.ae-xp-card{padding-left:46px}.ae-dot{left:8px}.ae-line{left:16px}}.ae-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:clamp(18px,3vw,32px);align-items:start;margin-top:clamp(18px,3vw,28px)}@media (max-width: 980px){.ae-grid{grid-template-columns:1fr}}.ae-edu{position:sticky;top:clamp(72px,9vh,120px);align-self:start}.ae-xp-wrap{margin-top:0}.ae-progress{position:absolute;left:20px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,#ff2d8773,#ff6aa933);transform-origin:top center;border-radius:2px;pointer-events:none;z-index:0}.ae-xp-list{position:relative;z-index:1}.ae-intro-grid{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);gap:clamp(16px,3vw,28px);align-items:center;margin-bottom:clamp(16px,3vw,28px)}.ae-intro-left,.ae-intro-right{min-width:0}.ae-intro-right .sp-section{padding:0;background:transparent}.ae-intro-right .sp-container{max-width:none;margin:0}.ae-intro-right .sp-viewport{height:clamp(360px,42vw,520px);border-radius:18px}@media (max-width: 980px){.ae-intro-grid{grid-template-columns:1fr;align-items:start}.ae-intro-right .sp-viewport{height:clamp(360px,58vw,520px)}}.kw{display:inline-block;padding:2px 8px;margin:0 2px;border-radius:999px;font-weight:800;line-height:1.2;white-space:nowrap;vertical-align:baseline;border:1px solid var(--border);background:#10101859;box-shadow:0 6px 16px #00000038}.kw-hard{border-color:#ff2d8773;background:linear-gradient(135deg,#ff2d8733,#ff6aa91a)}.kw-soft{border-color:#7878dc59;background:linear-gradient(135deg,#7878dc2e,#5050a01a)}.kw-trait{border-color:#ffb45059;background:linear-gradient(135deg,#ffb4502e,#b478281a)}html[data-theme=light] .kw{background:#ffffffbf;color:#141414}.ae-section,.ae-container,.ae-grid,.ae-intro-grid,.ae-xp-wrap,.ae-edu{overflow-x:clip}.ae-flow{right:0;transform:translate(10px)}.ae-intro-right .sp-viewport{width:100%;max-width:100%;overflow:hidden}@media (max-width: 680px){.ae-xp-list,.edu-stack{max-width:100%;overflow-x:clip}}html,body{max-width:100%;overflow-x:hidden}.edu-section{position:relative;background:var(--bg);color:var(--text);padding:clamp(28px,6vw,90px) clamp(16px,6vw,28px)}.edu-container{max-width:1100px;margin:0 auto}.edu-headline{position:relative;display:flex;align-items:center;gap:12px;margin-bottom:24px}.edu-h2{font-size:clamp(22px,3.6vw,34px);font-weight:800;line-height:1.1;display:inline-block;position:relative}.edu-underline{position:absolute;left:0;right:0;bottom:-6px;height:3px;background:linear-gradient(90deg,var(--accent),#ff6aa9);border-radius:999px;transform-origin:left;animation:edu-scan 2.6s ease-in-out infinite}@keyframes edu-scan{0%{transform:scaleX(.2);opacity:.4}50%{transform:scaleX(1);opacity:1}to{transform:scaleX(.2);opacity:.4}}.edu-orb{width:26px;height:26px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ff90c0,var(--accent));filter:blur(.2px);box-shadow:0 0 34px #ff2d8780,0 0 80px #ff2d8738;animation:edu-orb 5s ease-in-out infinite alternate}.edu-shuffle{margin-left:auto;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--card);color:var(--text);font-weight:700}.edu-shuffle:hover{border-color:#ffffff38}.edu-stack{list-style:none;margin:0;padding:0;display:grid;gap:26px;overflow:visible}.edu-card{transform:perspective(900px) rotateX(var(--rx,0)) rotateY(var(--ry,0));transition:transform .12s ease-out}.edu-card-inner{width:min(880px,100%);display:grid;grid-template-columns:64px 1fr;gap:14px;border:1px solid var(--border);border-radius:16px;background:radial-gradient(120% 80% at 0% 0%,rgba(255,45,135,.06),transparent 60%),linear-gradient(180deg,#ffffff05,#0000000f);padding:12px 14px;box-shadow:0 12px 26px #00000040}.edu-card:hover .edu-card-inner{border-color:#fff3;box-shadow:0 16px 36px #00000047,0 0 40px #ff2d8729}.edu-logo-wrap{width:64px;height:64px;border-radius:14px;overflow:hidden;background:linear-gradient(135deg,#ff2d872e,#ff6aa91f);border:1px solid rgba(255,45,135,.35);display:grid;place-items:center}.edu-logo{width:100%;height:100%;object-fit:cover;display:block}.edu-info{display:grid;align-content:center}.edu-period{font-size:12px;color:var(--subtext);letter-spacing:.3px}.edu-degree{font-size:clamp(16px,2.1vw,19px);font-weight:800;line-height:1.15;margin-top:2px}.edu-school{color:var(--text);opacity:.9;margin-top:2px;line-height:1.3}.edu-loc{color:var(--subtext)}.edu-card:hover{--rx: 2deg;--ry: 0deg}@media (max-width: 880px){.edu-stack{gap:18px}.edu-card-inner{grid-template-columns:56px 1fr;gap:12px}.edu-logo-wrap{width:56px;height:56px;border-radius:12px}}.sp-section{background:var(--bg);color:var(--text);padding:clamp(20px,6vw,96px) clamp(14px,6vw,28px);position:relative;overflow:hidden}.sp-container{max-width:1100px;margin:0 auto}.sp-head{margin-bottom:12px}.sp-title{font-size:clamp(20px,4.8vw,34px);font-weight:800;line-height:1.1;position:relative;display:inline-block}.sp-underline{position:absolute;left:0;right:0;bottom:-6px;height:3px;background:linear-gradient(90deg,var(--accent),#ff6aa9);border-radius:999px;transform-origin:left;animation:sp-scan 2.8s ease-in-out infinite}@keyframes sp-scan{0%{transform:scaleX(.2);opacity:.4}50%{transform:scaleX(1);opacity:1}to{transform:scaleX(.2);opacity:.4}}.sp-sub{color:var(--subtext);margin-top:8px}.sp-viewport{--sp-scale: 1;position:relative;width:100%;height:clamp(360px,60vw,560px);margin-top:12px;overflow:hidden;perspective:1000px;transform:scale(var(--sp-scale));transform-origin:center}.sp-tag{position:absolute;left:50%;top:50%;transform-style:flat;white-space:nowrap;font-weight:800;font-size:clamp(11px,2.6vw,14px);letter-spacing:.2px;padding:clamp(5px,1.2vw,7px) clamp(8px,2vw,12px);border-radius:999px;-webkit-user-select:none;user-select:none;backface-visibility:hidden;will-change:transform,opacity,filter;color:var(--text);border:1px solid var(--border);background:#10101859;box-shadow:0 6px 20px #00000040;max-width:46vw;text-overflow:ellipsis;overflow:hidden}.sp-hard{border-color:#ff2d8773;background:linear-gradient(135deg,#ff2d8733,#ff6aa91a)}.sp-soft{border-color:#7878dc59;background:linear-gradient(135deg,#7878dc2e,#5050a01a)}.sp-sport{border-color:#50c8a059;background:linear-gradient(135deg,#50c8a02e,#28a0781a)}.sp-trait{border-color:#ffb45059;background:linear-gradient(135deg,#ffb4502e,#b478281a)}.sp-stars{position:absolute;inset:0;background-image:radial-gradient(2px 2px at 20% 30%,rgba(255,255,255,.35),transparent 40%),radial-gradient(1.5px 1.5px at 70% 60%,rgba(255,255,255,.25),transparent 40%),radial-gradient(1.2px 1.2px at 40% 80%,rgba(255,255,255,.22),transparent 40%),radial-gradient(1.8px 1.8px at 85% 20%,rgba(255,255,255,.28),transparent 40%);filter:blur(.2px);opacity:.55;pointer-events:none}.sp-legend{display:flex;flex-wrap:wrap;gap:8px 10px;margin-top:10px;color:var(--subtext);font-size:13px}.sp-legend .dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:6px;box-shadow:0 0 12px #ff2d8738}.sp-legend .hard{background:#ff2d87d9}.sp-legend .soft{background:#7878dcd9;box-shadow:0 0 12px #7878dc40}.sp-legend .sport{background:#50c8a0d9;box-shadow:0 0 12px #50c8a040}.sp-legend .trait{background:#ffb450e6;box-shadow:0 0 12px #ffb45040}html[data-theme=light] .sp-tag{background:#ffffffbf;color:#141414}html[data-theme=light] .sp-viewport{background:linear-gradient(180deg,#14070d0a,#14070d0f)}@media (max-width: 820px){.sp-viewport{height:clamp(360px,72vw,520px);--sp-scale: .95}.sp-legend{font-size:12.5px}}@media (max-width: 560px){.sp-viewport{height:clamp(340px,90vw,500px);--sp-scale: .92}.sp-tag{max-width:60vw}.sp-legend{gap:6px 8px}}@media (max-width: 400px){.sp-viewport{height:max(320px,95vw);--sp-scale: .88}.sp-tag{font-size:clamp(10.5px,3.2vw,12px);padding:5px 8px;max-width:68vw}.sp-legend{font-size:12px}}@media (prefers-reduced-motion: reduce){.sp-viewport{animation:none!important}}.pj-section{background:var(--bg);color:var(--text);padding:clamp(28px,6vw,96px) clamp(16px,6vw,28px)}.pj-container{max-width:1100px;margin:0 auto}.pj-head{margin-bottom:14px}.pj-h2{font-size:clamp(22px,3.6vw,34px);font-weight:800;line-height:1.1;position:relative;display:inline-block}.pj-underline{position:absolute;left:0;right:0;bottom:-6px;height:3px;background:linear-gradient(90deg,var(--accent),#ff6aa9);border-radius:999px;transform-origin:left;animation:pj-scan 2.6s ease-in-out infinite}@keyframes pj-scan{0%{transform:scaleX(.2);opacity:.4}50%{transform:scaleX(1);opacity:1}to{transform:scaleX(.2);opacity:.4}}.pj-sub{color:var(--subtext);margin-top:8px}.pj-filters{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.chip{padding:7px 12px;border-radius:999px;border:1px solid var(--border);background:var(--card);font-weight:700;color:var(--text)}.chip.active{border-color:#ff2d8766;box-shadow:0 0 18px #ff2d8733;background:linear-gradient(135deg,#ff2d8726,#ff6aa91a)}.pj-grid{list-style:none;margin:16px 0 0;padding:0;display:grid;grid-template-columns:repeat(12,1fr);gap:16px}.pj-card{grid-column:span 6;border:1px solid var(--border);border-radius:16px;overflow:hidden;background:radial-gradient(120% 80% at 0% 0%,rgba(255,45,135,.06),transparent 60%),linear-gradient(180deg,#ffffff05,#0000000f);box-shadow:0 12px 26px #00000038;transition:box-shadow .25s,border-color .25s}.pj-card:hover{border-color:#ffffff2e;box-shadow:0 16px 36px #00000047,0 0 44px #ff2d872e}@media (max-width: 920px){.pj-card{grid-column:span 12}}.pj-cover{position:relative;height:180px;background:#0f0f14}.pj-cover img{width:100%;height:100%;object-fit:cover;display:block}.pj-fallback{position:absolute;inset:0;background:radial-gradient(120px 90px at 20% 30%,rgba(255,45,135,.25),transparent 60%),linear-gradient(180deg,#ffffff05,#00000014)}.pj-period{position:absolute;left:10px;top:10px;font-size:12px;color:var(--subtext);background:#00000059;border:1px solid var(--border);border-radius:999px;padding:4px 8px}.pj-cat{position:absolute;right:10px;bottom:10px;font-size:12px;font-weight:800;padding:6px 10px;border-radius:999px;border:1px solid var(--border);color:var(--text);background:#10101859;box-shadow:0 0 18px #0003}.cat-web,.cat-platform{border-color:#ff2d8759}.cat-pwa{border-color:#50c8a059}.cat-ecommerce{border-color:#ffb45059}.cat-mobile{border-color:#7878dc59}.cat-game{border-color:#dc787859}.cat-contrib{border-color:#a0a0a059}.pj-body{padding:12px 14px}.pj-title{font-size:clamp(16px,2vw,20px);font-weight:800}.pj-brief{color:var(--subtext);margin-top:6px}.pj-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.pj-tag{font-size:12px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,45,135,.35);background:linear-gradient(135deg,#ff2d872e,#ff6aa91f);box-shadow:0 0 16px #ff2d872e}.pj-actions{display:flex;gap:10px;padding:12px 14px;border-top:1px solid var(--border)}.btn.small{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);font-weight:700}.btn.small.primary{background:linear-gradient(135deg,var(--accent),#ff6aa9);color:var(--btn-txt);border:none;box-shadow:0 0 22px #ff2d8738}.pj-card.pj-more{display:flex;align-items:center;justify-content:center;min-height:180px;text-align:center;border:1px solid var(--border);border-radius:16px;background:radial-gradient(120% 80% at 0% 0%,rgba(255,45,135,.06),transparent 60%),linear-gradient(180deg,#ffffff05,#0000000f)}:root{--bg: #0b0b0f;--text: #e9e9ee;--subtext: #b8b8c3;--card: #111118;--border: rgba(255, 255, 255, .08);--accent: #ff2d87;--accent-2: #b40062;--btn-txt: #0b0b0f;--glow: 0 0 40px rgba(255, 45, 135, .25);--shadow: 0 10px 30px rgba(0, 0, 0, .45)}html[data-theme=light]{--bg: #ffffff;--text: #141414;--subtext: #52525b;--card: #ffffff;--border: rgba(0, 0, 0, .06);--accent: #ff2d87;--accent-2: #b40062;--glow: 0 0 28px rgba(255, 45, 135, .18);--shadow: 0 12px 24px rgba(20, 7, 13, .08)}.header-jc{position:sticky;top:0;z-index:50;-webkit-backdrop-filter:saturate(140%) blur(10px);backdrop-filter:saturate(140%) blur(10px);background:linear-gradient(180deg,#0a0a0ea6,#0a0a0e33);border-bottom:1px solid var(--border)}html[data-theme=light] .header-jc{background:linear-gradient(180deg,#ffffffbf,#fff6)}.header-jc .inner{max-width:1200px;margin:0 auto;padding:12px clamp(16px,4vw,28px);display:flex;align-items:center;justify-content:space-between}.logo{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--text)}.logo-badge{width:36px;height:36px;border-radius:12px;display:grid;place-items:center;font-weight:800;letter-spacing:.5px;background:linear-gradient(135deg,var(--accent),#ff6aa9);color:#0b0b0f;box-shadow:var(--glow);border:1px solid rgba(255,255,255,.12)}.logo-text{font-weight:800;font-size:16px;letter-spacing:.5px}.nav-jc{display:flex;align-items:center;gap:10px}.nav-btn{position:relative;padding:8px 12px;border-radius:10px;text-decoration:none;color:var(--text);border:1px solid transparent;transition:transform .15s ease,border-color .2s ease,background .2s ease}.nav-btn:hover{transform:translateY(-1px);border-color:var(--border);background:linear-gradient(180deg,#ffffff05,#0000000d)}.nav-btn.active{color:var(--text);background:linear-gradient(135deg,#ff2d8740,#ff6aa92e);border:1px solid rgba(255,45,135,.35);box-shadow:var(--glow)}.theme-toggle{margin-left:8px;width:40px;height:40px;border-radius:999px;border:1px solid var(--border);background:var(--card);display:grid;place-items:center;color:var(--text);box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.theme-toggle:hover{transform:translateY(-1px);border-color:#ffffff38}.burger{display:none;width:44px;height:40px;border-radius:10px;border:1px solid var(--border);background:var(--card);color:var(--text);align-items:center;justify-content:center;gap:4px}.burger span{display:block;width:20px;height:2px;background:currentColor;transition:transform .25s ease,opacity .25s ease}.burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}.burger.open span:nth-child(2){opacity:0}.burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}@media (max-width: 920px){.burger{display:inline-flex}.nav-jc{position:absolute;top:64px;right:16px;left:16px;padding:10px;border-radius:14px;border:1px solid var(--border);background:var(--card);box-shadow:var(--shadow);display:grid;grid-template-columns:1fr;gap:6px;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .2s ease,transform .2s ease}.nav-jc.open{opacity:1;pointer-events:auto;transform:translateY(0)}}[id]{scroll-margin-top:80px}.site-footer{position:relative;background:var(--bg);color:var(--text);padding:clamp(28px,6vw,80px) clamp(16px,6vw,28px);border-top:1px solid var(--border);overflow:hidden;isolation:isolate}.foot-glow{position:absolute;right:-120px;bottom:-120px;width:420px;height:420px;border-radius:50%;background:radial-gradient(180px 180px at 40% 40%,rgba(255,144,192,.9),var(--accent));filter:blur(40px);opacity:.35;animation:foot-float 8s ease-in-out infinite alternate;z-index:-1}@keyframes foot-float{0%{transform:translate(0) scale(1)}to{transform:translate(-16px,-14px) scale(1.02)}}.foot-inner{max-width:1100px;margin:0 auto}.foot-cta{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:clamp(18px,3vw,32px);align-items:stretch}.foot-title{font-size:clamp(22px,3.6vw,34px);font-weight:800;line-height:1.1;position:relative;display:inline-block}.foot-underline{position:absolute;left:0;right:0;bottom:-6px;height:3px;background:linear-gradient(90deg,var(--accent),#ff6aa9);border-radius:999px;transform-origin:left;animation:foot-scan 2.6s ease-in-out infinite}@keyframes foot-scan{0%{transform:scaleX(.2);opacity:.4}50%{transform:scaleX(1);opacity:1}to{transform:scaleX(.2);opacity:.4}}.foot-tagline{margin-top:10px;color:var(--subtext);line-height:1.6}.foot-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.btn.ghost{border:1px solid var(--border);background:linear-gradient(180deg,#ffffff05,#0000000f)}.btn.tiny{padding:6px 10px;font-size:13px;border-radius:999px}.btn.linkedin,.btn.github{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;padding:0;border-radius:12px}.foot-card{border:1px solid var(--border);border-radius:16px;background:radial-gradient(120% 80% at 0% 0%,rgba(255,45,135,.06),transparent 60%),linear-gradient(180deg,#ffffff05,#0000000f);padding:14px;box-shadow:0 12px 26px #00000040}.foot-card-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}.foot-card-head .chip{padding:6px 10px;border-radius:999px;font-weight:700;font-size:12px;border:1px solid rgba(255,45,135,.35);background:linear-gradient(135deg,#ff2d872e,#ff6aa91f)}.ping{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px #ff2d87a6;position:relative}.ping:after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--accent);opacity:.4;animation:ping 1.8s ease-out infinite}@keyframes ping{0%{transform:scale(.8);opacity:.6}to{transform:scale(2.2);opacity:0}}.foot-card-text{color:var(--text);opacity:.92;line-height:1.55}.foot-card-actions{display:flex;gap:8px;margin-top:10px}.foot-links{display:flex;flex-wrap:wrap;gap:12px 18px;margin:clamp(18px,3vw,28px) 0 8px}.foot-links a{color:var(--text);opacity:.82;text-decoration:none;border-bottom:1px dashed transparent;transition:opacity .2s,border-color .2s}.foot-links a:hover{opacity:1;border-color:var(--accent)}.foot-meta{display:flex;flex-wrap:wrap;gap:8px 16px;color:var(--subtext);border-top:1px solid var(--border);padding-top:12px;font-size:13px;justify-content:space-between}@media (max-width: 840px){.foot-cta{grid-template-columns:1fr}}:root{--glow-size: 320px;--glow-color: 255,45,135;--glow-core: .4;--glow-ring: .18}html[data-theme=light]{--glow-core: .22;--glow-ring: .12}.cursor-glow{position:fixed;left:0;top:0;width:var(--glow-size);height:var(--glow-size);pointer-events:none;z-index:9;will-change:transform;mix-blend-mode:plus-lighter}@supports not (mix-blend-mode: plus-lighter){.cursor-glow{mix-blend-mode:screen}}.cursor-glow:before{content:"";position:absolute;inset:0;border-radius:50%;background:radial-gradient(closest-side,rgba(var(--glow-color),var(--glow-core)),rgba(var(--glow-color),var(--glow-ring)) 55%,rgba(var(--glow-color),0) 70%);filter:blur(40px)}@media (pointer: coarse),(max-width: 820px){.cursor-glow{display:none}}@media (prefers-reduced-motion: reduce){.cursor-glow{display:none}}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica Neue,Arial,Noto Sans,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;max-width:100%;overflow-x:hidden}h1,h2,h3,h4,h5,h6,p,ul,ol,figure{margin:0}ul,ol{padding-left:0;list-style:none}img,svg,video{display:block;max-width:100%;height:auto}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.container{width:100%;max-width:1200px;margin:0 auto;padding-inline:clamp(16px,4vw,28px)}.section{padding-block:clamp(40px,7vw,96px)}.app-main{padding-top:72px}@media (max-width:920px){.app-main{padding-top:64px}}.pj-section.wow-hit,.hero-wrapper{overflow-x:clip}.pj-section.wow-hit{position:relative}.pj-section.wow-hit:before{content:"";position:absolute;left:-10%;right:-10%;top:-40px;height:140px;pointer-events:none;background:radial-gradient(240px 120px at 50% 0%,rgba(255,45,135,.18),transparent 60%);animation:pj-glowfade 1s ease-out;z-index:0}@keyframes pj-glowfade{0%{opacity:.85}to{opacity:0}}.pj-section.wow-hit .pj-h2{position:relative;z-index:1}.pj-section.wow-hit .pj-h2:after{content:"";position:absolute;left:-10%;right:-10%;height:3px;bottom:-8px;background:linear-gradient(90deg,var(--accent),#ff6aa9);filter:drop-shadow(0 0 8px rgba(255,45,135,.35));animation:pj-sweep .9s ease-out}@keyframes pj-sweep{0%{transform:translate(-110%);opacity:.3}to{transform:translate(110%);opacity:1}}.pj-section.wow-hit .pj-card{animation:pj-pop .6s cubic-bezier(.2,.8,.2,1) both}.pj-section.wow-hit .pj-card:nth-child(odd){animation-delay:.05s}.pj-section.wow-hit .pj-card:nth-child(2n){animation-delay:.12s}@keyframes pj-pop{0%{transform:translateY(12px) scale(.98);filter:blur(3px);opacity:0}60%{transform:translateY(-4px) scale(1.02);opacity:1}to{transform:translateY(0) scale(1);filter:blur(0)}}
