*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#1e1e2e;--surface:#181825;--text:#cdd6f4;--accent:#cba6f7;--muted:#9399b2;--border:#ffffff1a;--border-subtle:#ffffff0f;--selection:#ffffff1f;--scrollbar:#9399b2;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--font-body:"Inter", "DM Sans", system-ui, sans-serif;--font-display:"Instrument Serif", "Lora", Georgia, serif;--glass-bg:color-mix(in srgb, var(--surface) 55%, transparent);--glass-bg-strong:color-mix(in srgb, var(--surface) 72%, transparent);--glass-bg-subtle:color-mix(in srgb, var(--surface) 38%, transparent);--glass-border:color-mix(in srgb, var(--accent) 16%, var(--border));--glass-border-subtle:color-mix(in srgb, var(--accent) 8%, var(--border));--glass-blur:blur(16px) saturate(160%);--glass-blur-sm:blur(8px) saturate(140%);--glass-shadow:0 8px 32px color-mix(in srgb, var(--bg) 60%, transparent), 0 1px 0 color-mix(in srgb, var(--accent) 8%, transparent);--glass-shadow-sm:0 4px 16px color-mix(in srgb, var(--bg) 55%, transparent);--z-base:0;--z-raised:10;--z-sticky:50;--z-nav:100;--z-dropdown:200;--z-modal:300;--z-toast:400;--z-cursor:9999}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100dvh;font-size:1rem;line-height:1.7;transition:background-color .3s,color .3s;overflow-x:hidden}body:before,body:after{content:"";pointer-events:none;z-index:0;border-radius:50%;position:fixed}body:before{background:radial-gradient(circle, color-mix(in srgb, var(--accent) 14%, transparent) 0%, transparent 68%);filter:blur(72px);width:700px;height:700px;top:-260px;left:-180px}body:after{background:radial-gradient(circle, color-mix(in srgb, var(--accent) 9%, transparent) 0%, transparent 70%);filter:blur(90px);width:560px;height:560px;bottom:-200px;right:-140px}.cursor-glow{pointer-events:none;background:radial-gradient(circle, var(--accent) 0%, transparent 70%);opacity:.05;z-index:0;border-radius:50%;width:500px;height:500px;transition:left .15s,top .15s;position:fixed;transform:translate(-50%,-50%)}.grain:before{content:"";pointer-events:none;z-index:var(--z-cursor);opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:128px;position:fixed;inset:0}#root{z-index:1;position:relative}body,nav,footer,main,section,.glass,.glass-sm,.glass-strong,.project-card,.repo-card,.btn,.btn-primary,.btn-ghost,.icon-btn,.nav-link,.mobile-nav-link,.ctrl-btn,.tab-btn,.tag-filter-btn,.footer-social,.music-pill,.card-link,.post-row,.stack-tag,.contact-card,.avatar-ring{transition:background-color .25s,border-color .25s,color .18s}.cursor-glow,.no-transition{transition:left .15s,top .15s!important}::selection{background:var(--accent);color:var(--bg)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}h1,h2,h3,h4{text-wrap:balance;line-height:1.2}p{text-wrap:pretty}p,li{max-width:72ch}img,video,svg{max-width:100%;height:auto;display:block}ul[role=list],ol[role=list]{padding:0;list-style:none}button,input,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.cursor-glow,body:before,body:after{display:none}}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:.6s forwards fadeUp}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.blink{animation:1s step-end infinite blink}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.bounce{animation:2s ease-in-out infinite bounce}@keyframes musicBounce{0%{transform:translateY(0)}to{transform:translateY(-2px)}}.glass,.glass-sm,.glass-strong{position:relative;overflow:hidden}.glass:after,.glass-sm:after,.glass-strong:after{content:"";border-radius:inherit;pointer-events:none;z-index:1;background:linear-gradient(#ffffff0e 0%,#0000 45%);position:absolute;inset:0}.glass{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow-sm)}.glass-sm{background:var(--glass-bg-subtle);-webkit-backdrop-filter:var(--glass-blur-sm);border:1px solid var(--glass-border-subtle)}.glass-strong{background:var(--glass-bg-strong);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.btn{font-size:.85rem;font-weight:600;font-family:var(--font-mono);cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;padding:9px 22px;text-decoration:none;transition:opacity .2s,border-color .2s,color .2s,background .2s;display:inline-flex}.btn-primary{background:var(--accent);color:var(--bg)}.btn-primary:hover{opacity:.82}.btn-ghost{color:var(--text);border-color:var(--border);background:0 0}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.icon-btn{background:var(--glass-bg);width:38px;height:38px;-webkit-backdrop-filter:var(--glass-blur-sm);border:1px solid var(--border);color:var(--muted);border-radius:9px;justify-content:center;align-items:center;text-decoration:none;display:flex;transition:border-color .2s,color .2s,background .2s!important}.icon-btn:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, var(--glass-bg))}.music-pill{background:var(--glass-bg-subtle);-webkit-backdrop-filter:var(--glass-blur-sm);border:1px solid var(--border);border-radius:999px;align-items:center;gap:6px;min-width:0;max-width:220px;padding:5px 10px;display:flex;position:relative;overflow:hidden;transition:background .2s,border-color .2s!important}.music-pill:after{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(#ffffff0a 0%,#0000 50%);position:absolute;inset:0}.music-pill:hover{background:color-mix(in srgb, var(--accent) 10%, var(--surface));border-color:color-mix(in srgb, var(--accent) 35%, transparent)}.music-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:2px;display:flex;transition:color .15s!important}.music-btn:hover{color:var(--text)}.music-btn--play{color:var(--accent)}.music-btn--play:hover{color:var(--accent);opacity:.8}.music-track{font-family:var(--font-mono);color:var(--muted);text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;max-width:80px;font-size:.7rem;overflow:hidden;transition:color .2s!important}.music-track--playing{color:var(--text)}.music-bar{background:color-mix(in srgb, var(--border) 80%, transparent);cursor:pointer;border-radius:999px;flex-shrink:0;width:40px;height:3px;position:relative;transition:height .15s!important}.music-bar:hover{height:6px}.music-bar__fill{background:var(--accent);border-radius:999px;position:absolute;top:0;bottom:0;left:0;transition:width .1s linear!important}.project-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur-sm);border:1px solid var(--glass-border-subtle);border-radius:14px;flex-direction:column;gap:12px;height:100%;padding:22px;display:flex;position:relative;overflow:hidden;transition:border-color .25s,transform .25s,box-shadow .25s,background .25s!important}.project-card:before{content:"";border-radius:inherit;background:linear-gradient(to bottom, color-mix(in srgb, var(--accent) 5%, transparent) 0%, transparent 40%);pointer-events:none;opacity:0;transition:opacity .3s;position:absolute;inset:0}.project-card:after{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(#ffffff0a 0%,#0000 40%);position:absolute;inset:0}.project-card:hover{border-color:var(--glass-border);box-shadow:var(--glass-shadow);background:var(--glass-bg-strong);transform:translateY(-3px)}.project-card:hover:before{opacity:1}.repo-card{background:var(--glass-bg-subtle);-webkit-backdrop-filter:var(--glass-blur-sm);border:1px solid var(--glass-border-subtle);border-radius:12px;flex-direction:column;gap:10px;padding:16px 18px;text-decoration:none;display:flex;position:relative;overflow:hidden;transition:border-color .22s,transform .22s,box-shadow .22s,background .22s!important}.repo-card:before{content:"";border-radius:inherit;background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 4%, transparent) 0%, transparent 60%);pointer-events:none;opacity:0;transition:opacity .25s;position:absolute;inset:0}.repo-card:after{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(#ffffff09 0%,#0000 40%);position:absolute;inset:0}.repo-card:hover{border-color:var(--glass-border);box-shadow:var(--glass-shadow-sm);background:var(--glass-bg);transform:translateY(-2px)}.repo-card:hover:before{opacity:1}.card-link{font-size:.75rem;font-family:var(--font-mono);border-radius:7px;align-items:center;gap:6px;padding:6px 14px;text-decoration:none;display:inline-flex;transition:border-color .18s,color .18s,background .18s,opacity .18s!important}.card-link--ghost{background:var(--glass-bg-subtle);-webkit-backdrop-filter:var(--glass-blur-sm);border:1px solid var(--border);color:var(--muted)}.card-link--ghost:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, var(--glass-bg-subtle))}.card-link--solid{background:var(--accent);color:var(--bg);border:1px solid #0000;font-weight:600}.card-link--solid:hover{opacity:.85}.tab-btn{cursor:pointer;font-family:var(--font-mono);color:var(--muted);background:0 0;border:none;border-radius:7px;align-items:center;gap:6px;padding:7px 18px;font-size:.8rem;display:flex;transition:color .2s,background .2s!important}.tab-btn:hover{color:var(--text);background:color-mix(in srgb, var(--text) 6%, transparent)}.tab-btn--active{background:var(--accent);color:var(--bg)}.tab-btn--active:hover{color:var(--bg)}.tag-filter-btn{border:1px solid var(--border);color:var(--muted);font-family:var(--font-mono);cursor:pointer;background:0 0;border-radius:20px;padding:4px 12px;font-size:.72rem;transition:background .2s,color .2s,border-color .2s!important}.tag-filter-btn:hover{color:var(--text);border-color:var(--accent)}.tag-filter-btn--active{background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent);border-color:color-mix(in srgb, var(--accent) 40%, transparent)}.nav-link{font-family:var(--font-mono);color:var(--muted);background:0 0;border:1px solid #0000;border-radius:7px;padding:6px 14px;font-size:.8rem;text-decoration:none;transition:color .2s,background .2s,border-color .2s!important}.nav-link:hover{color:var(--text);background:color-mix(in srgb, var(--text) 6%, transparent)}.nav-link.active{color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent);border-color:color-mix(in srgb, var(--accent) 30%, transparent)}.nav-link.active:hover{color:var(--accent)}.mobile-nav-link{font-family:var(--font-mono);color:var(--text);background:0 0;border:1px solid #0000;border-radius:8px;padding:10px 14px;font-size:.9rem;text-decoration:none;display:block;transition:color .15s,background .15s,border-color .15s!important}.mobile-nav-link:hover{background:color-mix(in srgb, var(--text) 6%, transparent)}.mobile-nav-link.active{color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent);border-color:color-mix(in srgb, var(--accent) 25%, transparent)}.ctrl-btn{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur-sm);border:1px solid var(--border);color:var(--muted);cursor:pointer;border-radius:8px;align-items:center;gap:5px;padding:7px 10px;display:flex;transition:border-color .2s,color .2s,background .2s!important}.ctrl-btn:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb, var(--accent) 6%, var(--glass-bg))}.footer-social{background:var(--glass-bg-subtle);width:34px;height:34px;-webkit-backdrop-filter:var(--glass-blur-sm);border:1px solid var(--border);color:var(--muted);border-radius:8px;justify-content:center;align-items:center;text-decoration:none;display:flex;transition:border-color .2s,color .2s,background .2s!important}.footer-social:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, var(--glass-bg-subtle))}.post-row{border-radius:8px;margin:0 -8px;padding-left:8px;padding-right:8px;transition:background .2s,padding-left .2s!important}.post-row:hover{background:color-mix(in srgb, var(--accent) 6%, transparent);padding-left:16px}.stack-tag{background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:.8rem;font-family:var(--font-mono);cursor:default;border-radius:6px;padding:5px 14px;transition:border-color .2s,color .2s,background .2s!important}.stack-tag:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb, var(--accent) 6%, var(--surface))}.contact-card{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:10px;align-items:center;gap:14px;padding:14px 18px;text-decoration:none;display:flex;transition:border-color .22s,transform .22s,background .22s!important}.contact-card:hover{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 4%, var(--surface));transform:translate(4px)}.avatar-ring{border:2px solid var(--border);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent);border-radius:50%;transition:box-shadow .3s,border-color .3s!important}.avatar-ring:hover{border-color:var(--accent);box-shadow:0 0 0 5px color-mix(in srgb, var(--accent) 20%, transparent), 0 0 20px color-mix(in srgb, var(--accent) 10%, transparent)}.footer-glass{background:var(--glass-bg-subtle);-webkit-backdrop-filter:var(--glass-blur-sm)}
