@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap";.navbar{position:fixed;top:0;left:calc(5vw + env(safe-area-inset-left));width:calc(90vw - env(safe-area-inset-left) - env(safe-area-inset-right));z-index:1000;padding-top:env(safe-area-inset-top);background:linear-gradient(to bottom,#ffffffa6,#f0f8ff73);border-bottom:1px solid var(--border);border-radius:0 0 10px 10px;box-shadow:0 8px 24px #00000014,inset 0 1px #ffffff80;transition:background .3s ease,backdrop-filter .3s ease}[data-theme=dark] .navbar{background:#000000bf;box-shadow:0 8px 24px #0006,inset 0 1px #ffffff14}@supports ((backdrop-filter: blur(10px)) or (-webkit-backdrop-filter: blur(10px))){.navbar{background:#f0f8ff85;backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%)}[data-theme=dark] .navbar{background:#0000004d}}body:has([data-low-contrast]) .navbar{background:#ffffffa6}[data-theme=dark] body:has([data-low-contrast]) .navbar{background:#0000007a}.navbar.scrolled{background:#0000008c;box-shadow:0 8px 24px #00000014}[data-theme=light] .navbar.scrolled{background:#ffffff73;box-shadow:0 10px 30px #00000014,0 1px #ffffffb3 inset}.navbar-inner{max-width:1200px;margin:0 auto;height:var(--nav-height);padding-block:1px;padding-inline:var(--section-x-padding);display:flex;align-items:center;justify-content:space-between}.navbar-inner>*{align-self:center}button:focus,a:focus{outline:none}#logo{color:var(--text)}.logo{height:100%;display:flex;align-items:center;opacity:.95}.logo:hover{opacity:1}.logo-svg{height:100%;width:auto;max-height:calc(var(--nav-height) - 8px);display:block;filter:drop-shadow(0 1px 0 rgba(0,0,0,.04))}[data-theme=dark] .logo-svg{filter:drop-shadow(0 1px 0 rgba(255,255,255,.05))}.nav-menu{display:flex;align-items:center;position:relative;overflow:hidden;gap:.45rem;list-style:none;padding-left:0;margin:0}[data-theme=dark] .nav-menu:before{opacity:.47}.nav-menu.active{transform:translateY(0) scale(1)}.nav-menu .nav-link{color:var(--text);text-decoration:none;font-size:.75rem;font-weight:300;padding:.1rem .22rem;opacity:.85;transition:opacity .2s ease}.nav-menu .nav-link:hover{opacity:1}.nav-menu .btn{padding:.2rem .6rem;margin-right:.4rem;margin-left:.1rem;border-radius:999px}[data-theme=light] .nav-menu .btn{box-shadow:0 2px 6px #0000000f}.nav-controls{display:flex;align-items:center;gap:10px}.toggle-pill{position:relative;width:46px;height:22px;padding:2px;border-radius:999px;border:1px solid var(--border);cursor:pointer}[data-theme=light] .toggle-pill{background:linear-gradient(to bottom,#00000008,#0000000f);box-shadow:inset 0 1px 2px #0000001f,inset 0 -1px 1px #ffffffb3,inset 0 0 #00000014}[data-theme=dark] .toggle-pill{background:var(--surface-2);box-shadow:none}.toggle-icon{display:block;color:var(--icon-color, currentColor)}.toggle-icon.moon{width:15px;height:15px}.toggle-icon.sun{width:12px;height:12px}.toggle-knob{position:absolute;top:2px;left:2px;width:16.5px;height:16.5px;border-radius:50%;background:var(--app-bg);border:1px solid var(--border);color:var(--text);display:flex;align-items:center;justify-content:center;transition:left .35s ease,transform .35s ease}[data-theme=light] .toggle-knob{left:2px;background:linear-gradient(to bottom,#ffffffe6,#f5f5f5e6);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);box-shadow:0 6px 14px #00000024,0 1px 2px #00000014}[data-theme=light] .toggle-pill:active .toggle-knob{transform:scale(.96);box-shadow:0 2px 6px #0000002e}[data-theme=dark] .toggle-knob{left:25px;top:1px;background:var(--surface-1);box-shadow:0 2px 6px #0009}.hamburger{display:none;flex-direction:column;gap:5px;align-items:center;justify-content:center;min-width:36px;min-height:36px;margin-right:6px;appearance:none;-webkit-appearance:none;background:transparent;border:none;padding:0;font:inherit;color:inherit;line-height:1;cursor:pointer;-webkit-tap-highlight-color:transparent}.hamburger.active{transform:translate(1px)}.hamburger.active .bar{opacity:1;height:2.5px;filter:brightness(1.05);clip-path:polygon(0% 50%,5% 0%,97% 0%,100% 50%,97% 100%,5% 100%)}.hamburger:hover .bar{opacity:1}.hamburger.active .bar:nth-child(1){transform:rotate(47deg) translate(6px,7.5px)}.hamburger.active .bar:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.active .bar:nth-child(3){transform:rotate(-47deg) translate(6px,-7.5px)}.nav-link:focus-visible,.hamburger:focus-visible,.toggle-pill:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:6px}.bar{width:20px;height:3px;background:var(--text);opacity:.8;clip-path:polygon(0% 50%,4% 0%,94% 0%,100% 50%,94% 100%,4% 100%);transition:transform .28s cubic-bezier(.4,0,.2,1),opacity .18s ease}@media(max-width:768px){.nav-controls{margin-left:auto;display:flex;flex-direction:row;align-items:center;gap:15px}.nav-menu{position:absolute;top:calc(100% + 6px);right:0;width:clamp(150px,60vw,165px);padding-bottom:calc(.05rem + env(safe-area-inset-bottom));padding-top:calc(.05rem + env(safe-area-inset-top));display:flex;flex-direction:column;align-items:stretch;gap:0;max-height:min(420px,calc(100dvh - var(--nav-height) - 20px));overflow-y:auto;overscroll-behavior:contain;border-radius:10px;border:1px solid var(--border);background:linear-gradient(to bottom,#ffffffbf,#f0f8ffa6);box-shadow:0 12px 30px #0000001a,inset 0 1px #fff9;transform-origin:top right;transform:scale(.96) translateY(-2px);opacity:0;pointer-events:none;transition:transform .22s cubic-bezier(.22,.61,.36,1),opacity .18s ease}@supports ((backdrop-filter: blur(10px)) or (-webkit-backdrop-filter: blur(10px))){.nav-menu{background:#f0f8ff8c;backdrop-filter:blur(14px) saturate(125%);-webkit-backdrop-filter:blur(14px) saturate(125%)}[data-theme=dark] .nav-menu{background:#00000059}}[data-theme=dark] .nav-menu:before{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.4'/%3E%3C/svg%3E");opacity:.45;mix-blend-mode:overlay}.nav-menu.active{transform:scale(1) translateY(0);opacity:1;pointer-events:auto}.nav-menu li{border-bottom:1px solid rgba(0,0,0,.05)}.nav-menu li:last-child{border-bottom:none}[data-theme=dark] .nav-menu li{border-bottom:1px solid rgba(255,255,255,.06)}.nav-menu .nav-link{display:block;width:100%;padding:.55rem 1rem;font-size:.7rem;font-weight:300;color:var(--text);line-height:1.4}.nav-menu .nav-link:hover{background:var(--surface-2);color:var(--primary)}[data-theme=dark] .nav-menu .nav-link:hover{background:#ffffff0f}.nav-menu .btn{border-radius:0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;border:none;font-weight:500;color:var(--accent)}[data-theme=light] .nav-menu .btn:hover{background:#0000000d}[data-theme=dark] .nav-menu .btn:hover{background:#ffffff0f}.nav-menu li:last-child .btn{border-radius:0 0 10px 10px}.hamburger{display:flex;margin-right:2px}}@media(max-width:360px){.nav-menu .nav-link{padding:.6rem .8rem;font-size:.65rem}}.hero{position:relative;min-height:calc(100vh - var(--nav-height));overflow:hidden;display:flex;align-items:center;padding-top:var(--nav-height);background:linear-gradient(to bottom,rgba(255,255,255,.6),transparent 45%),#fff}[data-theme=light] .hero:after,[data-theme=dark] .hero:after{content:"";position:absolute;bottom:0;left:0;right:0;pointer-events:none}[data-theme=light] .hero:after{height:120px;background:linear-gradient(to bottom,transparent 0%,rgba(246,234,255,.6) 60%,var(--content-bg) 100%)}[data-theme=dark] .hero:after{height:140px;background:linear-gradient(to bottom,transparent 0%,rgba(20,20,22,.55) 55%,var(--content-bg) 100%)}.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden;left:calc(-1 * var(--app-shell-gutter, 0px));right:calc(-1 * var(--app-shell-gutter, 0px))}.hero-canvas{position:absolute;inset:-35%;z-index:0;will-change:transform;transform:translateZ(0);transition:filter .6s cubic-bezier(.22,1,.36,1),transform .15s linear}.hero-noise{position:absolute;inset:0;opacity:.035;pointer-events:none;-webkit-mask-image:radial-gradient(ellipse at 50% 55%,black 65%,transparent 85%);mask-image:radial-gradient(ellipse at 50% 55%,black 65%,transparent 85%)}[data-theme=light] .hero-canvas{background:radial-gradient(135% 90% at 42% -12%,rgba(155,198,255,.72),rgba(198,215,255,.58) 36%,rgba(245,210,228,.42) 56%,rgba(252,220,235,.46) 68%,transparent 84%),radial-gradient(68% 52% at 86% 36%,rgba(205,175,255,.56),rgba(225,205,255,.38) 44%,rgba(255,255,255,.22) 62%,transparent 72%),radial-gradient(48% 42% at 72% 52%,rgba(190,155,255,.5),rgba(220,195,255,.34) 40%,rgba(255,255,255,.22) 60%,transparent 75%),radial-gradient(88% 68% at 78% 86%,rgba(255,150,205,.62),rgba(255,200,230,.44) 46%,rgba(255,255,255,.28) 64%,transparent 80%);filter:saturate(1.18) contrast(1.04) hue-rotate(-1deg)}[data-theme=light] .hero:before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,.25),transparent 40%,rgba(255,255,255,.18) 75%,transparent);pointer-events:none;z-index:0}[data-theme=dark] .hero{background:linear-gradient(to bottom,rgba(18,19,21,.85),rgba(18,19,21,.6) 40%,transparent 70%)}[data-theme=dark] .hero-canvas{background:radial-gradient(120% 90% at 50% -15%,rgba(255,255,255,.06),rgba(255,255,255,.03) 35%,transparent 65%),radial-gradient(80% 60% at 70% 35%,rgba(200,200,210,.05),transparent 70%),radial-gradient(90% 70% at 30% 70%,rgba(180,180,200,.04),transparent 75%);filter:saturate(.75) contrast(.98)}[data-theme=dark] .hero:before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 40% 35%,rgba(255,255,255,.04),transparent 70%);pointer-events:none;z-index:0}.hero.is-settled .hero-canvas{filter:saturate(.92) contrast(.98) hue-rotate(-1deg) blur(.6px);transform:translate3d(0,6px,0)}.hero-inner{position:relative;z-index:1;width:100%;max-width:1200px;margin:0 auto;padding:0 2rem}.hero-content{max-width:720px;display:flex;flex-direction:column;gap:.9rem}.hero-intro{font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;font-weight:500;color:var(--text-soft, var(--text-muted))}.hero-name{font-size:clamp(3.8rem,6vw,5.4rem);font-weight:700;letter-spacing:-.02em;line-height:1.05;color:var(--heading, var(--text))}.hero-role{font-size:1.55rem;font-weight:500;letter-spacing:-.01em;color:var(--text-muted)}.hero-description{margin-top:.5rem;font-size:1.05rem;line-height:1.75;max-width:640px;color:var(--text-muted)}[data-theme=dark] .hero-description{color:var(--text-muted)}[data-theme=dark] .hero-role{color:#cfcfd6}[data-theme=dark] .hero-name{text-shadow:0 2px 12px rgba(0,0,0,.6)}.hero-cta{margin-top:1.8rem;display:flex;gap:1.1rem;flex-wrap:wrap}.hero-socials{margin-top:1.5rem;display:flex;gap:1rem}.hero-socials a{color:var(--text-soft, var(--text-muted));transition:color .2s ease,transform .2s ease}.hero-socials a:hover{color:var(--primary);transform:translateY(-2px)}.scroll-indicator{position:absolute;bottom:clamp(32px,5vh,56px);left:50%;transform:translate(-55%);width:14px;height:56px;pointer-events:none;z-index:2}.scroll-indicator:before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,transparent,var(--scroll-track),transparent);border-radius:999px;opacity:.9}.scroll-dot{position:absolute;left:50%;top:2px;transform:translate(-50%);width:6px;height:6px;border-radius:50%;background:var(--scroll-dot);box-shadow:0 0 10px var(--scroll-glow);will-change:transform,opacity;animation:scrollFlow 3.2s cubic-bezier(.4,0,.9,.9) infinite}@keyframes scrollFlow{0%{transform:translate(-50%);opacity:0}15%{opacity:.9}45%{transform:translate(-50%,28px);opacity:1}70%{transform:translate(-50%,36px);opacity:.25}to{transform:translate(-50%,42px);opacity:0}}@media(max-width:768px){[data-theme=light] .hero-canvas{inset:-30%;filter:saturate(.9)}.scroll-indicator{height:40px;opacity:.55}}@media(dynamic-range:high){[data-theme=light] .hero-canvas{filter:saturate(1.08) contrast(1.02)}}@media(dynamic-range:standard){[data-theme=light] .hero-canvas{filter:saturate(1.16) contrast(1.04)}}.about-container{position:relative;isolation:isolate}.about-container:before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent 0%,transparent 10%,var(--section-tint) 18%,var(--section-tint-strong) 42%,var(--section-tint-strong) 60%,var(--section-tint) 85%,transparent 100%)}[data-theme=dark] .about-container:before{background:linear-gradient(180deg,transparent 0%,transparent 12%,rgba(255,255,255,.015) 25%,rgba(255,255,255,.025) 50%,rgba(255,255,255,.015) 75%,transparent 100%)}@media(min-width:1024px){.about-inner{padding:3.5rem 2rem}}.about-box{display:grid;grid-template-columns:30% 1fr;gap:0;background:var(--surface-1);border-radius:24px;width:100%;border:1px solid var(--border);box-shadow:none;overflow:hidden;transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease}.about-box:hover{box-shadow:0 4px 12px #0000000f,0 28px 60px #0000001f}[data-theme=dark] .about-box{background:#121212;border:1px solid rgba(255,255,255,.06);border-radius:28px;box-shadow:none}[data-theme=dark] .about-box:hover{transform:translateY(-2px);box-shadow:0 1px #ffffff0a,0 18px 36px #0000008c}.about-visual{position:relative;height:100%;background:var(--surface-2);border-right:1px solid var(--border)}[data-theme=dark] .about-visual{background:#171717;box-shadow:none}.about-content{padding:2.5rem 1.3rem 2rem 2.1rem;max-width:47rem}.about-title{font-size:clamp(1.9rem,1.5vw,2.2rem);font-weight:650;letter-spacing:-.02em;margin-bottom:.9rem}.about-content p{font-size:1rem;line-height:1.7;color:var(--text-muted);max-width:68ch;text-align:left;text-wrap:pretty}[data-theme=dark] .about-content p{color:var(--text-muted);font-weight:400}.about-content p+p{margin-top:.6rem}@media(max-width:1024px){.about-box{grid-template-columns:40% 1fr}.about-visual{min-height:360px}.about-content{padding:3rem}}@media(max-width:768px){.about-box{grid-template-columns:1fr}.about-content{grid-row:1;padding:2.5rem}.about-content p{text-align:left}.about-visual{border-right:none;border-top:1px solid var(--border)}}.project-card{display:grid;grid-template-columns:clamp(280px,35%,420px) 1fr;gap:2.5rem;position:relative;width:100%;padding:2rem;min-height:260px;border-radius:16px;background:var(--card-bg);border:1px solid var(--border);box-shadow:none;transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease}[data-theme=dark] .project-card{background:#121212;border:1px solid rgba(255,255,255,.06)}[data-theme=dark] .project-card:hover{transform:translateY(-2px);box-shadow:0 1px #ffffff0a,0 18px 36px #0000008c}.project-card:after{content:"";position:absolute;left:2rem;right:2rem;bottom:-1.375rem;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);opacity:.25}.project-card:last-child:after{display:none}.project-visual{position:relative;border-radius:12px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;min-height:100%}[data-theme=dark] .project-visual{background:#161616}.project-visual:after{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at top right,rgba(255,255,255,.08),transparent 60%);pointer-events:none}.visual-label{font-size:.85rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.project-content{display:flex;flex-direction:column;justify-content:space-between}.project-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.project-title{font-size:1.35rem;font-weight:600;letter-spacing:-.015em;line-height:1.3}.project-actions{display:flex;gap:.75rem}.project-actions a{color:var(--text-muted);position:relative;transition:color .2s ease,transform .15s ease}.project-actions a:after{content:"";position:absolute;inset:-6px}.project-actions a:hover{color:var(--primary);transform:translateY(-2px)}.project-description{font-size:.94rem;line-height:1.7;color:var(--text-muted);max-width:60ch}.project-tags{display:flex;flex-wrap:wrap;margin-top:auto;padding-top:.75rem;gap:.6rem;list-style:none;padding:0}.project-tags li{font-size:.7rem;font-weight:500;letter-spacing:.01em;padding:.35rem .6rem;border:1px solid var(--border);border-radius:999px;color:var(--text-muted);background:transparent}.project-tags li:hover{background:var(--surface-2);border-color:var(--primary);color:var(--text)}.project-card,.project-actions a,.btn-projects{transition-timing-function:cubic-bezier(.22,1,.36,1)}@media(max-width:1024px){.project-description{font-size:.94rem;line-height:1.7;max-width:60ch}}@media(max-width:768px){.project-card{grid-template-columns:1fr;padding:1.75rem}.project-visual{min-height:200px}}@media(max-width:640px){.project-description{font-size:.92rem;line-height:1.75;max-width:100%}}.project-container{position:relative;isolation:isolate}.project-container:before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent 0%,var(--section-tint) 18%,var(--section-tint-strong) 45%,var(--section-tint-strong) 65%,var(--section-tint) 88%,transparent 100%)}.project-container:after{content:"";display:block;height:1px;margin-top:2rem;background:linear-gradient(90deg,transparent,var(--border),transparent);opacity:.35}.projects-inner{padding:3rem 1.25rem}@media(min-width:1024px){.projects-inner{padding:4rem 2rem}}.content-text{text-align:center;margin-bottom:3rem}.division{width:60px;height:3px;background:var(--primary);margin:0 auto 1.75rem}.content-text h2{font-size:clamp(1.85rem,2vw,2.1rem);font-weight:600;letter-spacing:-.02em;color:var(--text)}.content-text p{font-size:.95rem;line-height:1.6;color:var(--text-muted);max-width:60ch;margin-inline:auto}.projects-list{display:flex;flex-direction:column;position:relative;gap:2rem}.projects-cta{display:flex;justify-content:center;margin-top:3rem}.btn-projects{display:inline-flex;align-items:center;gap:.6rem;padding:.85rem 1.6rem;border-radius:999px;font-size:.9rem;font-weight:500;letter-spacing:.01em;background:transparent;color:var(--primary);border:1px solid var(--border);transition:background .25s ease,border-color .25s ease,transform .2s ease}.btn-projects:hover{background:var(--section-tint);border-color:var(--primary);transform:translateY(-1px)}.btn-projects svg{transition:transform .2s ease}.btn-projects:hover svg{transform:translate(3px)}.footer{grid-column:2;margin-top:-10px;padding:clamp(1rem,2vw,1.5rem) .75rem;position:relative;z-index:2;background:var(--footer-bg);border-top:1px solid var(--border);border-radius:10px 10px 0 0}.footer-inner{max-width:1200px;margin:0 auto;padding-inline:var(--section-x-padding);display:flex;justify-content:space-between;align-items:center;gap:2rem}.footer-left{display:flex;flex-direction:column;gap:.4rem}.footer-line{display:flex;align-items:center;gap:.35rem;flex-wrap:nowrap;font-size:clamp(.8rem,.75rem + .3vw,.875rem);font-weight:500;color:var(--text);line-height:1.5;letter-spacing:-.01em}.footer-main,.footer-meta{display:inline-flex;align-items:center;gap:.35rem;white-space:nowrap}.footer-sep{margin:0 .5rem;color:var(--text-muted);font-weight:400}.footer-role{color:var(--text-muted);font-weight:500;white-space:nowrap}.role-short{display:none}.footer-heart{color:#e11d48;transition:transform .45s cubic-bezier(.19,1,.22,1),filter .45s ease;transform-origin:center;will-change:transform,filter}.footer-main:hover .footer-heart{animation:heartPulse .75s cubic-bezier(.19,1,.22,1) 80ms forwards}@keyframes heartPulse{0%{transform:scale(1) rotate(0) translateY(0);filter:drop-shadow(0 0 0 rgba(225,29,72,0))}40%{transform:scale(1.35) rotate(-8deg) translateY(-2px);filter:drop-shadow(0 10px 26px rgba(225,29,72,.55))}65%{transform:scale(1.18) rotate(4deg) translateY(-1px)}to{transform:scale(1) rotate(0) translateY(0);filter:drop-shadow(0 0 0 rgba(225,29,72,0))}}.footer-copy{font-size:.75rem;color:var(--text-muted);line-height:1.6}.footer-right{display:flex;justify-content:center;gap:1rem}.footer-right a{color:var(--text-muted);display:inline-flex;align-items:center;transition:color .2s ease,transform .2s ease;padding:8px;border:1px solid var(--border);border-radius:50%;background:var(--surface-1)}.footer-right a:hover{color:#000;transform:translateY(-2px);background:var(--surface-2);box-shadow:0 6px 16px #00000059}@media(max-width:900px){.role-full{display:none}.role-short{display:inline}.footer-line{letter-spacing:-.015em}}@media(max-width:640px){.footer-inner{flex-direction:column;text-align:center;gap:.9rem}.footer-left{align-items:center}.footer{padding:1.2rem 0}}@media(max-width:480px){.footer-meta{width:100%;justify-content:center}.footer-line{flex-direction:column;align-items:center;gap:.2rem}}.skills-container{position:relative;isolation:isolate;font-feature-settings:"liga" 1,"calt" 1;text-rendering:optimizeLegibility}.skills-container:before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent 0%,var(--section-tint) 25%,var(--section-tint-strong) 48%,var(--section-tint) 72%,transparent 100%)}.skills-container:after{content:"";display:block;height:1px;margin-top:1.5rem;background:linear-gradient(90deg,transparent,var(--border),transparent);opacity:.35}.skills-inner{display:flex;flex-direction:column;gap:2rem;padding:clamp(1.75rem,4vh,2.25rem) 1.25rem}@media(min-width:1024px){.skills-inner{padding:3rem 2rem}}.skills-header{max-width:640px;display:flex;flex-direction:column;gap:.6rem}.section-heading{font-size:clamp(1.8rem,3.2vw,2.2rem);font-weight:600;letter-spacing:-.015em;line-height:1.15;color:var(--text)}.section-subtitle{font-size:.95rem;font-weight:400;line-height:1.6;letter-spacing:.01em;color:var(--text-muted);max-width:55ch}.skills-sections{display:flex;flex-direction:column;gap:clamp(2.2rem,5vh,2.8rem)}.skills-section-block{display:flex;flex-direction:column;gap:1.1rem;width:100%;padding:1.6rem 1.4rem;border-radius:16px;background:var(--surface-bg);border:1px solid var(--border);transition:transform .2s ease,box-shadow .25s ease,border-color .25s ease}[data-theme=dark] .skills-section-block{background:#121212;border:1px solid rgba(255,255,255,.06);box-shadow:none;transition:transform .28s ease,box-shadow .28s ease}[data-theme=dark] .skills-section-block:hover{box-shadow:0 1px #ffffff0a,0 16px 32px #0000008c}.skills-title{font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text);opacity:.85}[data-theme=dark] .skills-title{color:var(--text-soft)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1.35rem}.skill-item{display:flex;position:relative;flex-direction:column;align-items:center;gap:.55rem;width:auto;padding:.9rem .4rem;border-radius:12px;background:transparent;transition:transform .2s ease,background .2s ease}.skill-item:after{content:"";position:absolute;inset:-1px;border-radius:12px;pointer-events:none;opacity:0;transition:opacity .2s ease}[data-theme=dark] .skill-item:after{background:linear-gradient(180deg,#ffffff08,#ffffff03)}.skill-item:hover:after{opacity:1}.skill-item:hover .skill-icon{opacity:1;transform:translateY(-.5px) scale(var(--optical-scale, 1))}.skill-item:hover .skill-name{color:var(--text);opacity:.95}.skill-item:focus-visible{outline:none;background:var(--surface-2);box-shadow:0 0 0 2px #ffffff1f,0 6px 16px #0000000f;transform:translateY(-1px)}.skill-item:focus-visible .skill-name{opacity:1}.skill-item:focus:not(:focus-visible){outline:none;box-shadow:none}.skill-icon{font-size:30px;opacity:.95;line-height:1;--optical-scale: 1;transform:scale(var(--optical-scale));transition:opacity .2s ease,transform .2s ease}.skill-icon[data-logo=mysql]{--optical-scale: 1.2;opacity:1}.skill-icon[data-logo=github-pages]{--optical-scale: 1.74}.skill-icon[data-optical=light]{transform:scale(1.1);opacity:.95}.skill-item:hover .skill-icon{opacity:1;transform:translateY(-.5px) scale(var(--optical-scale))}.skill-name{font-size:.72rem;font-weight:500;letter-spacing:.02em;line-height:1.3;text-align:center;color:var(--text-muted);opacity:.9}@media(max-width:480px){.skills-grid{grid-template-columns:repeat(3,1fr)}.skill-item{padding:.75rem .3rem}}@media(max-width:768px){.skills-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:clamp(1.1rem,3vw,1.3rem)}.skill-icon{font-size:26px}}@media(min-width:1024px){.skills-grid{grid-template-columns:repeat(auto-fit,110px);justify-content:start;gap:1.2rem}.skills-section-block{padding:1.6rem 1.4rem}}@media(prefers-color-scheme:light){.skill-item:hover{background:#ffffff73}}@media(prefers-reduced-motion:reduce){.skill-item,.skills-section-block{transition:none;transform:none}}.contact-section{position:relative;isolation:isolate}.contact-section *,.contact-section *:before,.contact-section *:after{box-sizing:border-box}.contact-grid>*{min-width:0}#contact{background:linear-gradient(180deg,transparent 0%,var(--footer-bg) 100%);padding-bottom:5rem}#contact:before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent 0%,var(--section-tint) 20%,var(--section-tint-strong) 45%,var(--section-tint-strong) 60%,var(--section-tint) 85%,transparent 100%)}.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:2rem}.contact-form{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:2.5rem;overflow:hidden;transition:box-shadow .2s ease,transform .2s ease}.contact-form:hover{box-shadow:var(--shadow);transform:translateY(-2px)}[data-theme=dark] .contact-form{background:#121212;border:1px solid rgba(255,255,255,.06);box-shadow:none}[data-theme=dark] .contact-form:hover{transform:translateY(-4px);box-shadow:0 1px #ffffff0a,0 16px 32px #0000008c}.contact-form h2{font-size:2rem;font-weight:600;letter-spacing:-.02em;margin-bottom:.6rem;line-height:1.25}.contact-subtext{font-size:.95rem;line-height:1.65;color:var(--text-muted);margin-bottom:1.8rem}.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem}.field label{font-size:.8rem;letter-spacing:.02em;text-transform:uppercase}.field input,.field textarea{width:100%;max-width:100%;padding:.7rem;background:var(--surface-bg);border:1px solid var(--border);border-radius:6px;color:var(--text)}[data-theme=dark] .field input,[data-theme=dark] .field textarea{background:#171717;border:1px solid rgba(255,255,255,.06);color:var(--text)}[data-theme=dark] .field input:focus,[data-theme=dark] .field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 1px #6366f12e}.field input:hover,.field textarea:hover{border-color:var(--text-muted)}.field input:focus,.field textarea:focus{background:var(--surface-bg);border-color:var(--primary);box-shadow:0 0 0 1px #6366f126}.contact-form .btn-primary{align-self:flex-start}.response-note{display:block;margin-top:1rem;font-size:.8rem;color:var(--text-muted)}.contact-form .field,.contact-form button,.contact-form .response-note{opacity:0;animation:fieldFadeUp .45s ease forwards}.contact-form .field:nth-child(1){animation-delay:.05s}.contact-form .field:nth-child(2){animation-delay:.1s}.contact-form .field:nth-child(3){animation-delay:.15s}.contact-form button{animation-delay:.22s}.contact-form .response-note{animation-delay:.28s}@media(prefers-reduced-motion:reduce){.contact-form .field,.contact-form button,.contact-form .response-note{animation:none;opacity:1}}.contact-cta{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:2rem;display:flex;flex-direction:column;justify-content:center;gap:1.2rem;box-shadow:none;transition:box-shadow .25s ease,transform .25s ease}.contact-cta:hover{box-shadow:var(--shadow);transform:translateY(-2px)}[data-theme=dark] .contact-cta{background:#121212;border:1px solid rgba(255,255,255,.06)}[data-theme=dark] .contact-cta:hover{transform:translateY(-4px);box-shadow:0 1px #ffffff0a,0 16px 32px #0000008c}.contact-cta h3{font-size:1.35rem;font-weight:600;letter-spacing:-.01em}.contact-cta p{color:var(--text-muted);line-height:1.65;max-width:38ch}[data-theme=dark] .contact-subtext,[data-theme=dark] .contact-cta p{color:var(--text-muted);opacity:.9}.direct-mail{display:inline-flex;align-items:center;gap:.6rem;margin:1.5rem 0;font-weight:500;color:var(--primary);padding-bottom:2px;border-bottom:1px dashed var(--border);max-width:100%;white-space:normal;overflow-wrap:anywhere;word-break:break-word}.direct-mail:hover{border-bottom-color:var(--primary)}.cta-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1.2rem}.cta-actions .btn{flex-shrink:0}.social-links{display:flex;flex-wrap:wrap;gap:1rem}.social-links a{max-width:100%;white-space:nowrap;margin-top:.8rem;transition:color .2s ease,transform .15s ease}.social-links a:hover{color:var(--primary);background:#171717;transform:translateY(-2px)}.btn-primary,.btn-secondary{transition:background .2s ease,transform .15s ease}.btn-primary:hover,.btn-secondary:hover{transform:translateY(-1px)}.contact-form,.contact-cta,.social-links a,.btn-primary,.btn-secondary{transition-timing-function:cubic-bezier(.22,1,.36,1)}@keyframes fieldFadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.contact-grid{grid-template-columns:1fr}.contact-form,.contact-cta{padding:2rem}.field{margin-bottom:1.4rem}.field input,.field textarea{padding:.9rem;font-size:.95rem}.contact-form .btn-primary{width:100%;padding:.85rem 1rem;font-size:.95rem;min-height:44px}.social-links a{padding:.4rem .6rem;border-radius:6px}}@media(max-width:480px){.cta-actions{flex-direction:column;align-items:flex-start;gap:1rem}.social-links{gap:.6rem}}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;scrollbar-width:thin}:root{--app-bg: #ffffff;--content-bg: #f6eaff;--surface-bg: #ffffff;--footer-bg: #eef0f3;--dot-color: rgba(0, 0, 0, .28);--text: #0f0d0f;--text-muted: #6f6892;--primary: #4f46e5;--border: rgba(120, 96, 200, .1);--card-bg: #ffffff;--surface-1: #fbfaff;--surface-2: #f3f0ff;--section-tint: rgba(255, 220, 210, .24);--section-tint-strong: rgba(255, 210, 235, .28);--nav-height: 57px;--shadow: 0 1px 0 rgba(0, 0, 0, .03), 0 10px 30px rgba(0, 0, 0, .08);--atmo-lavender-1: rgba(230, 220, 255, .65);--atmo-lavender-2: rgba(210, 200, 255, .45);--atmo-pink: rgba(255, 220, 235, .55);--atmo-lavender: rgba(210, 190, 255, .48);--scroll-accent: rgba(190, 170, 255, .45);--scroll-track: rgba(160, 130, 255, .45);--scroll-dot: rgba(130, 100, 255, .95);--scroll-glow: rgba(160, 130, 255, .5);--font-ui: "Inter", system-ui, sans-serif;--accent-soft: rgba(79, 70, 229, .15)}[data-theme=dark]{--app-bg: #121315;--content-bg: #17181b;--surface-bg: #1c1d21;--card-bg: #1f2024;--footer-bg: #0f0f10;--dot-color: rgba(255, 255, 255, .18);--text: #f1f1f2;--text-muted: #b2b2ba;--text-soft: #8e8e96;--heading: #ffffff;--surface-1: #202126;--surface-2: #26272d;--primary: #9a9ff8;--accent-soft: rgba(154, 159, 248, .16);--border: rgba(255, 255, 255, .06);--section-tint: rgba(255, 255, 255, .015);--section-tint-strong: rgba(255, 255, 255, .025);--shadow: 0 1px 0 rgba(255, 255, 255, .03), 0 10px 24px rgba(0, 0, 0, .6);--scroll-track: rgba(180, 180, 200, .25);--scroll-dot: rgba(210, 210, 230, .75);--scroll-glow: rgba(180, 180, 220, .25);--scroll-accent: rgba(180, 180, 220, .25)}:root{--section-x-padding: clamp(1rem, 4vw, 2rem);--section-y-padding: clamp(3rem, 8vh, 4.5rem);--section-inner-gap: clamp(2rem, 5vh, 3rem)}body{background:var(--app-bg);color:var(--text);font-family:var(--font-ui);line-height:1.65;letter-spacing:.01em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4{color:var(--heading, var(--text));font-weight:600;letter-spacing:-.015em}p{font-size:1.02rem}::selection{background:var(--primary);color:#fff}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:#00000040;border-radius:999px}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#ffffff40}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.1rem;border-radius:6px;font-weight:500;text-decoration:none;transition:transform .15s ease,filter .15s ease}.btn:hover{transform:translateY(-1px);filter:brightness(1.05)}.btn-primary{background:var(--primary);color:#fff}.btn-secondary{padding:.7rem 1.2rem;border:1px solid var(--primary);color:var(--primary);background:var(--bg)}a{text-decoration:none;color:inherit}svg{color:inherit}.app-shell{min-height:100vh;display:grid;grid-template-columns:5vw 90vw 5vw;background:var(--app-bg);background-image:radial-gradient(var(--dot-color) 1.5px,transparent 1.2px);background-size:18px 18px;opacity:.95}:root .app-shell{background-image:radial-gradient(1100px 600px at 20% -10%,rgba(160,130,255,.22),transparent 60%),radial-gradient(900px 500px at 80% 0%,rgba(200,160,255,.18),transparent 65%),radial-gradient(var(--dot-color) 1.5px,transparent 1.2px);background-size:auto,auto,18px 18px}[data-theme=dark] .app-shell{background-image:radial-gradient(900px 500px at 20% -10%,rgba(255,255,255,.04),transparent 70%),radial-gradient(700px 400px at 80% 0%,rgba(255,255,255,.03),transparent 75%),radial-gradient(var(--dot-color) 1.5px,transparent 1.2px),repeating-linear-gradient(0deg,rgba(255,255,255,.025) 0px,rgba(255,255,255,.025) 1px,transparent 1px,transparent 2px),linear-gradient(to right,rgba(0,0,0,.35) 0%,transparent 8%,transparent 92%,rgba(0,0,0,.35) 100%);background-size:auto,auto,20px 20px,auto,auto}.content-container{grid-column:2;background:var(--content-bg);padding:0 1rem;border-left:1px solid var(--border);border-right:1px solid var(--border);min-height:100vh;display:flex;flex-direction:column}:root .content-container{box-shadow:var(--shadow)}[data-theme=dark] .content-container{box-shadow:var(--shadow)}.main-content{flex:1}.section{padding:var(--section-y-padding) 0;position:relative}[data-theme=dark] .section{background:linear-gradient(to bottom,transparent 0%,var(--section-tint) 50%,transparent 100%)}.section-inner{max-width:1200px;margin:0 auto;padding-inline:var(--section-x-padding);display:flex;flex-direction:column;gap:var(--section-inner-gap);scroll-margin-top:70px}@media(min-width:1024px){.content-container{padding:0 2rem}:root:not([data-theme=dark]){--section-tint: rgba(245, 210, 235, .3);--section-tint-strong: rgba(235, 195, 255, .32)}}@media(max-width:768px)and (prefers-contrast:more){:root{--section-tint: rgba(245, 210, 235, .2)}}@media(prefers-contrast:more){:root{--section-tint: rgba(245, 210, 235, .22);--section-tint-strong: rgba(225, 190, 255, .26)}}@media(prefers-reduced-transparency:reduce){:root{--section-tint: rgb(246, 240, 244);--section-tint-strong: rgb(236, 228, 234)}}@media(forced-colors:active){:root{--section-tint: rgb(248, 245, 247);--section-tint-strong: rgb(242, 238, 242)}}@media print{:root{--section-tint: rgb(250, 248, 249);--section-tint-strong: rgb(240, 236, 238)}.section{background:var(--section-tint)!important}*{box-shadow:none!important;text-shadow:none!important}}
