@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--radius-md:.375rem;--radius-lg:.5rem;--ease-in:cubic-bezier(.4, 0, 1, 1);--ease-out:cubic-bezier(0, 0, .2, 1);--blur-xl:24px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.visible{visibility:visible}.col-span-2{grid-column:span 2/span 2}.row-span-1{grid-row:span 1/span 1}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.backdrop-blur-xl{--tw-backdrop-blur:blur(var(--blur-xl));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in{--tw-ease:var(--ease-in);transition-timing-function:var(--ease-in)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}}:root{--bg:#0a0a0f;--surface:#13131a;--primary:#8b5cf6;--accent:#06b6d4;--fg:#f1f5f9;--fg-muted:#94a3b8;--border:#ffffff14;--success:#22c55e;--error:#ef4444;--gradient-primary:linear-gradient(135deg, #8b5cf6, #06b6d4);--gradient-hero:linear-gradient(180deg, #0a0a0f 0%, #131125 48%, #0a0a0f 100%);--gradient-card-hover:linear-gradient(135deg, #8b5cf61f, #06b6d414);--ease-entry:cubic-bezier(.22, 1, .36, 1);--ease-exit:cubic-bezier(.64, 0, .78, 0);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--shadow-glow:0 20px 80px #8b5cf633;--radius-lg:28px;--radius-md:20px;--dim-2:#ffffff05;--dim-4:#ffffff0a;--dim-5:#ffffff0d;--dim-6:#ffffff0f;--dim-8:#ffffff14;--dim-10:#ffffff1a;--dim-12:#ffffff1f;--card-bg:linear-gradient(180deg, #ffffff0d, #ffffff05);--card-shine:inset 0 1px 0 #ffffff0f;--cover-bg:linear-gradient(180deg, #0a0a0f29, #0a0a0f99), radial-gradient(circle at top left, #8b5cf640, transparent 35%), radial-gradient(circle at bottom right, #06b6d426, transparent 32%), #0d0d18;--cover-overlay:linear-gradient(180deg, #0a0a0f0a, #0a0a0fd6);color:var(--fg);background:var(--bg);font-family:Inter,Microsoft YaHei,sans-serif}[data-theme=light]{--bg:#f4f6fb;--surface:#eef1f8;--fg:#1f2937;--fg-muted:#5f6b85;--border:#7c88a638;--shadow-glow:0 20px 80px #8b5cf61a;--gradient-hero:linear-gradient(180deg, #edf1fb 0%, #dfe6f7 48%, #e9edf8 100%);--gradient-card-hover:linear-gradient(135deg, #8b5cf61a, #06b6d41a);--dim-2:#00000005;--dim-4:#00000008;--dim-5:#0000000a;--dim-6:#0000000d;--dim-8:#0000000f;--dim-10:#00000014;--dim-12:#0000001a;--card-bg:linear-gradient(180deg, #ffffffb8, #e8ecf6d1);--card-shine:inset 0 1px 0 #ffffff52;--cover-bg:linear-gradient(180deg, #edf1fb29, #b8c4df7a), radial-gradient(circle at top left, #8b5cf661, transparent 35%), radial-gradient(circle at bottom right, #06b6d438, transparent 32%), #d7deef;--cover-overlay:linear-gradient(180deg, #ffffff0a, #dfe3f1d6)}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);min-width:320px;color:var(--fg);margin:0;transition:background-color .35s,color .35s}.glass-card,.bento-card,.site-header__inner,.site-footer__content,.skills-group,.github-repo-card,.achievement-card,.tag-badge,.button--secondary,.button--ghost,.project-filter__button,.theme-toggle,.menu-button{transition:background-color .35s,border-color .35s,color .35s,background .35s}body:before{content:"";z-index:0;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Cpath d='M1 3h1v1H1V3zm2-2h1v1H3V1z' fill='%23000000' fill-opacity='.03'/%3E%3C/svg%3E"),radial-gradient(at 50% 0,#8b5cf614 0%,#0000 60%),radial-gradient(at 80% 100%,#06b6d40d 0%,#0000 50%);position:fixed;inset:0}[data-theme=light] .hero-bg-full:after{background:linear-gradient(#f4f6fb80,#f4f6fbb8 50%,#f4f6fbeb)}[data-theme=light] .contact-page-bg:after{background:linear-gradient(#f4f6fb80,#f4f6fbc7)}[data-theme=light] body:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Cpath d='M1 3h1v1H1V3zm2-2h1v1H3V1z' fill='%23000000' fill-opacity='.02'/%3E%3C/svg%3E"),radial-gradient(at 50% 0,#8b5cf61f 0%,#0000 60%),radial-gradient(at 80% 100%,#06b6d414 0%,#0000 50%)}a{color:inherit;text-decoration:none}button,a{transition:border-color .2s,background-color .2s,color .2s,transform .2s}button{font:inherit;cursor:pointer}img{max-width:100%;display:block}::selection{color:#fff;background:#8b5cf666}:focus-visible{outline:2px solid var(--accent);outline-offset:3px}#root{min-height:100vh}.app-shell{min-height:100vh;position:relative}.app-main{padding:6rem clamp(1.25rem,2vw,2rem) 3rem}.site-header{z-index:40;-webkit-backdrop-filter:blur(24px);padding:1rem clamp(1.25rem,2vw,2rem);position:fixed;inset:0 0 auto}.site-header__inner{border:1px solid var(--border);background:var(--dim-4);border-radius:999px;justify-content:space-between;align-items:center;gap:1rem;max-width:1200px;margin:0 auto;padding:.85rem 1.25rem;display:flex}.site-logo{letter-spacing:.02em;flex-shrink:0;font-family:Space Grotesk,sans-serif;font-size:1.05rem;font-weight:700}.site-nav{align-items:center;gap:.35rem;display:flex}.site-nav__link{color:var(--fg-muted);white-space:nowrap;border-radius:999px;padding:.65rem .9rem;font-size:.9rem}.site-nav__link:hover,.site-nav__link--active{background:var(--dim-6);color:var(--fg)}.site-nav__right{align-items:center;gap:.5rem;display:flex}.site-nav__user{border:1px solid var(--border);color:var(--fg-muted);white-space:nowrap;border-radius:999px;align-items:center;gap:.4rem;padding:.35rem .75rem;font-size:.82rem;display:flex}.site-nav__avatar{object-fit:cover;border-radius:50%;flex-shrink:0}.theme-toggle{border:1px solid var(--border);background:var(--dim-4);width:2.5rem;height:2.5rem;color:var(--fg-muted);border-radius:999px;justify-content:center;align-items:center;transition:color .2s;display:flex}.theme-toggle:hover{color:var(--fg)}.menu-button{border:1px solid var(--border);background:var(--dim-4);width:2.5rem;height:2.5rem;color:var(--fg);border-radius:999px;justify-content:center;align-items:center;display:none}.hero-section{border:1px solid var(--border);background:var(--gradient-hero);border-radius:0;min-height:100vh;position:relative;overflow:hidden}.hero-bg-full{z-index:0;background:url(/hero-bg.png) 50%/cover no-repeat;position:absolute;inset:-6rem -2rem 0}.hero-bg-full:after{content:"";background:linear-gradient(#0a0a0f73,#0a0a0fa6 50%,#0a0a0fe6);position:absolute;inset:0}.hero-section__inner{z-index:1;align-items:center;min-height:100vh;padding:clamp(2rem,5vw,5rem);display:flex;position:relative}.hero{max-width:760px;position:relative}.hero__eyebrow,.card-eyebrow,.section-title__eyebrow,.site-footer__eyebrow{color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin:0 0 1rem;font-size:.82rem;font-weight:600}.hero__title{margin:0;font-family:Space Grotesk,sans-serif;font-size:clamp(3.25rem,7vw,5.2rem);line-height:1.05}.hero__subtitle{color:var(--fg-muted);margin:1rem 0 0;font-family:Space Grotesk,sans-serif;font-size:clamp(1.35rem,2.5vw,2rem)}.hero__description{max-width:40rem;color:var(--fg-muted);margin:1.5rem 0 0;font-size:1.0625rem;line-height:1.8}.hero__actions{flex-wrap:wrap;gap:1rem;margin-top:2rem;display:flex}.button{border:1px solid #0000;border-radius:999px;align-items:center;gap:.55rem;padding:.95rem 1.3rem;font-family:inherit;font-weight:600;display:inline-flex}.button--primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow)}.button--secondary{border-color:var(--border);background:var(--dim-4)}.button:hover{transform:translateY(-1px)}.button--ghost{border-color:var(--border);color:var(--fg);background:0 0}.shader-background{position:absolute;inset:0;overflow:hidden}.shader-background__orb{filter:blur(48px);border-radius:999px;animation:10s ease-in-out infinite float-orb;position:absolute}.shader-background__orb--primary{background:#8b5cf659;width:260px;height:260px;top:8%;left:10%}.shader-background__orb--accent{background:#06b6d43d;width:320px;height:320px;animation-delay:-4s;bottom:10%;right:12%}.shader-background__grid{background-image:linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px);background-size:36px 36px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle,#000,#0000 75%);mask-image:radial-gradient(circle,#000,#0000 75%)}.home-grid{grid-template-columns:repeat(12,minmax(0,1fr));gap:1.5rem;max-width:1200px;margin:1.5rem auto 0;display:grid}.home-grid>*{min-width:0}.home-grid__about,.home-grid__skills,.home-grid__experience,.home-grid__education,.home-grid__github,.home-grid__projects,.home-grid__achievements,.home-grid__contact,.home-grid__blog{grid-column:1/-1}.glass-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--card-bg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);box-shadow:var(--card-shine);position:relative;overflow:hidden}.bento-card{height:100%;padding:1.5rem}.section-title{max-width:42rem;margin-bottom:1.5rem}.section-title--center{text-align:center;margin-inline:auto}.section-title__heading{margin:0;font-family:Space Grotesk,sans-serif;font-size:clamp(2rem,4vw,2.8rem);line-height:1.15}.section-title__description,.about-card__content p,.featured-project__content p,.blog-card p,.project-card p,.site-footer__description,.post-detail__lead,.post-detail__body,.empty-state p,.timeline-item__desc,.achievement-card__org{color:var(--fg-muted);line-height:1.7}.about-card{grid-template-columns:160px 1fr;align-items:center;gap:1.5rem;display:grid}.about-card__avatar{aspect-ratio:1;background:radial-gradient(circle at 30% 30%, #8b5cf647, var(--surface));width:160px;color:var(--fg);border:1px solid #8b5cf661;border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 0 60px #8b5cf633}.about-card__content h3,.featured-project__content h3,.blog-card h3,.project-card h3,.skills-group h3,.timeline-item__title,.achievement-card__title{margin:0 0 .75rem;font-family:Space Grotesk,sans-serif}.about-card__meta,.featured-project__tags,.project-preview-card__tags,.project-card__tags,.blog-card__tags,.blog-list-card__tags,.post-detail__tags{flex-wrap:wrap;gap:.75rem;margin-top:1rem;display:flex}.tag-badge{border:1px solid var(--dim-8);background:var(--dim-4);color:var(--fg);border-radius:999px;align-items:center;gap:.45rem;padding:.6rem .8rem;font-family:JetBrains Mono,monospace;font-size:.78rem;display:inline-flex}.tag-badge--active{background:#8b5cf624;border-color:#8b5cf659}.skills-groups{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem;display:grid}.skills-group{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--dim-2);padding:1.1rem}.skills-group__items{flex-direction:column;gap:.6rem;display:flex}.skill-progress{align-items:center;gap:.75rem;display:flex}.skill-progress__bar{background:var(--dim-6);border-radius:3px;flex:1;height:6px;overflow:hidden}.skill-progress__fill{background:var(--gradient-primary);height:100%;transition:width 1s var(--ease-entry);border-radius:3px}.skill-progress__label{color:var(--fg-muted);text-align:right;min-width:3ch;font-family:JetBrains Mono,monospace;font-size:.85rem}.timeline{padding-left:2rem;position:relative}.timeline:before{content:"";background:linear-gradient(180deg, var(--primary), var(--accent), transparent);width:1px;position:absolute;top:0;bottom:0;left:0}.timeline-item{margin-bottom:2.5rem;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-item:before{content:"";background:var(--primary);border:2px solid var(--bg);border-radius:50%;width:12px;height:12px;position:absolute;top:.35rem;left:-2.3rem;box-shadow:0 0 12px #8b5cf680}.timeline-item__header{flex-wrap:wrap;align-items:baseline;gap:.5rem 1rem;margin-bottom:.35rem;display:flex}.timeline-item__title{margin-bottom:.1rem;font-size:1.1rem}.timeline-item__org{color:var(--accent);font-size:.95rem;font-weight:500}.timeline-item__date{color:var(--fg-muted);font-family:JetBrains Mono,monospace;font-size:.82rem}.timeline-item__desc{margin:.5rem 0 0;font-size:.95rem}.achievements-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1.25rem;display:grid}.achievement-card{text-align:center;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--dim-2);padding:1.75rem 1.25rem;transition:border-color .25s,transform .25s}.achievement-card:hover{border-color:#8b5cf64d;transform:translateY(-2px)}.achievement-card__icon{color:var(--accent);margin-bottom:.75rem}.achievement-card__title{font-size:1.05rem}.achievement-card__org{margin:.25rem 0 0;font-size:.85rem}.github-section__stats{flex-wrap:wrap;gap:1.25rem;margin-bottom:1.5rem;display:flex}.github-stat{border:1px solid var(--border);background:var(--dim-4);border-radius:999px;align-items:center;gap:.5rem;padding:.65rem 1rem;font-family:JetBrains Mono,monospace;font-size:.85rem;display:flex}.github-stat svg{color:var(--accent)}.github-repos{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.github-repo-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--dim-2);padding:1.25rem;transition:border-color .25s}.github-repo-card:hover{border-color:#8b5cf64d}.github-repo-card__header{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.github-repo-card__name{font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:600}.github-repo-card__desc{color:var(--fg-muted);margin:0 0 1rem;font-size:.9rem;line-height:1.6}.github-repo-card__meta{color:var(--fg-muted);align-items:center;gap:1rem;font-family:JetBrains Mono,monospace;font-size:.8rem;display:flex}.github-repo-card__lang{align-items:center;gap:.35rem;display:flex}.github-repo-card__dot{border-radius:50%;width:10px;height:10px}.contact-form{gap:1rem;display:grid}.contact-form__row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.contact-form__group{flex-direction:column;gap:.35rem;display:flex}.contact-form__label{color:var(--fg-muted);font-size:.85rem;font-weight:500}.contact-form__input,.contact-form__textarea{border:1px solid var(--border);background:var(--dim-4);color:var(--fg);border-radius:14px;outline:none;padding:.85rem 1rem;font-family:inherit;font-size:.95rem;transition:border-color .2s}.contact-form__input:focus,.contact-form__textarea:focus{border-color:#8b5cf680}.contact-form__textarea{resize:vertical;min-height:120px}.contact-form__success{text-align:center;color:var(--success);padding:2rem;font-family:Space Grotesk,sans-serif;font-size:1.1rem}.featured-project-layout{grid-template-columns:2fr 1fr;gap:1.5rem;display:grid}.featured-project{align-items:flex-end;min-height:430px;display:flex}.featured-project__image,.project-card__cover{background:var(--cover-bg);position:absolute;inset:0}.featured-project__overlay{background:var(--cover-overlay);position:absolute;inset:0}.featured-project__content,.project-card__content{z-index:1;position:relative}.featured-project__links,.project-card__links,.section-link,.site-footer__links{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.featured-project__links a,.project-card__links a,.section-link,.site-footer__links a{color:var(--fg);align-items:center;gap:.45rem;display:inline-flex}.section-link{color:var(--accent);margin-top:1.25rem}.project-preview-list,.blog-preview-grid,.blog-list,.projects-grid{gap:1.25rem;display:grid}.project-preview-card,.blog-card,.project-card,.blog-list-card{min-height:100%}.blog-preview-grid,.blog-list{grid-template-columns:repeat(3,minmax(0,1fr))}.blog-card__meta,.project-card__meta,.blog-list-card__meta{color:var(--fg-muted);justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;font-size:.85rem;display:flex}.page{max-width:1200px;margin:0 auto}.page--projects,.page--blog,.page--detail{padding-top:1rem}.projects-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:1.5rem}.project-card__content,.blog-list-card,.post-detail,.empty-state,.site-footer__content{padding:1.5rem}.project-filter{flex-wrap:wrap;gap:.75rem;display:flex}.project-filter__button{border:1px solid var(--border);background:var(--dim-4);color:var(--fg-muted);font:inherit;border-radius:999px;padding:.75rem 1rem}.project-filter__button--active,.project-filter__button:hover{color:var(--fg);background:#8b5cf624;border-color:#8b5cf652}.contact-page-wrapper{align-items:center;min-height:100vh;display:flex;position:relative}.contact-page-bg{z-index:0;background:url(/contact-bg.png) 50%/cover no-repeat;position:fixed;inset:0}.contact-page-bg:after{content:"";background:linear-gradient(#0a0a0f8c,#0a0a0fb8);position:absolute;inset:0}.page--contact{z-index:1;position:relative}.site-footer{max-width:1200px;margin:0 auto;padding:0 1.25rem 3rem}.site-footer__content{text-align:center}.site-footer__title,.post-detail h1,.empty-state h1{margin:0;font-family:Space Grotesk,sans-serif;font-size:clamp(2rem,4vw,3rem)}.site-footer__description{max-width:42rem;margin:1rem auto 1.75rem}.site-footer__links{justify-content:center;margin-top:1.5rem}.site-footer__copyright{color:var(--fg-muted);margin-top:1.75rem;font-size:.9rem}.post-detail__body{margin-top:1.5rem}.post-detail__body p{color:var(--fg-muted);margin:0 0 1.25rem;font-size:1.02rem;line-height:1.8}.post-detail__body h2{color:var(--fg);margin:2rem 0 .75rem;font-family:Space Grotesk,sans-serif;font-size:1.35rem;font-weight:600;line-height:1.35}.post-detail__body h2:first-child{margin-top:0}.post-detail__body ul,.post-detail__body ol{color:var(--fg-muted);margin:0 0 1.25rem;padding-left:1.5rem;line-height:1.8}.post-detail__body code{background:var(--dim-6);color:var(--accent);border-radius:6px;padding:.15rem .4rem;font-family:JetBrains Mono,monospace;font-size:.88em}.post-detail__body pre{border:1px solid var(--border);background:var(--dim-4);border-radius:14px;margin:0 0 1.25rem;padding:1rem 1.25rem;overflow-x:auto}.post-detail__body pre code{color:var(--fg);background:0 0;padding:0}.post-detail__body blockquote{border-left:3px solid var(--primary);background:var(--dim-2);color:var(--fg-muted);border-radius:0 10px 10px 0;margin:0 0 1.25rem;padding:.75rem 1.25rem;font-style:italic}.post-detail__body a{color:var(--accent);text-decoration:underline}.post-detail__body strong{color:var(--fg)}.typewriter{align-items:center;display:inline-flex}.typewriter__caret{color:var(--accent);margin-left:.2rem}.splash-screen{z-index:100;background:#050510;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.splash-screen__bg{position:absolute;inset:0;overflow:hidden}.lang-toggle{z-index:10;color:#ffffffb3;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0f;border:1px solid #ffffff26;border-radius:999px;align-items:center;gap:.35rem;padding:.45rem .75rem;font-family:JetBrains Mono,monospace;font-size:.78rem;transition:background .2s,color .2s,border-color .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.lang-toggle:hover{color:#fff;background:#ffffff1f;border-color:#ffffff4d}.splash-screen__content{z-index:1;text-align:center;padding:2rem;position:relative}.splash-screen__tag{color:var(--accent);letter-spacing:.15em;margin:0 0 1.5rem;font-family:JetBrains Mono,monospace;font-size:.85rem}.splash-screen__title{color:#f8fafc;letter-spacing:.02em;min-height:1.3em;margin:0;font-family:Space Grotesk,sans-serif;font-size:clamp(2.5rem,6vw,4.5rem);font-weight:700;line-height:1.2}.splash-screen__caret{color:var(--accent);animation:.8s step-end infinite blink}.splash-screen__subtitle{color:var(--fg-muted);margin:1.25rem 0 0;font-size:1.1rem}.splash-screen__actions{margin-top:2.5rem}.splash-screen__button{background:var(--gradient-primary);color:#fff;cursor:pointer;border:none;border-radius:999px;align-items:center;gap:.75rem;padding:1rem 2rem;font-family:Space Grotesk,sans-serif;font-size:1.1rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:inline-flex;box-shadow:0 0 40px #8b5cf659}.splash-screen__button:hover{transform:translateY(-2px);box-shadow:0 0 60px #8b5cf680}.splash-screen__button:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.splash-screen__decor{margin-bottom:1.5rem}.splash-screen__decor svg{margin:0 auto;display:block}.login-card{-webkit-backdrop-filter:blur(32px);backdrop-filter:blur(32px);background:#0a0a14a6;border:1px solid #ffffff1f;border-radius:28px;width:100%;max-width:420px;margin:0 auto;padding:2.5rem 2rem 2rem;position:relative;overflow:hidden;box-shadow:0 0 0 1px #8b5cf614,0 24px 80px #0000008c,inset 0 1px #ffffff0a}.login-card:before{content:"";background:linear-gradient(90deg,#0000,#8b5cf680,#06b6d466,#0000);height:1px;position:absolute;top:0;left:20%;right:20%}.avatar-particles{pointer-events:none;z-index:0;width:120px;height:120px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.avatar-particle{background:linear-gradient(135deg, var(--primary), var(--accent));box-shadow:0 0 8px var(--primary);border-radius:50%;position:absolute;transform:translate(-50%,-50%)}.login-card__avatar-area{z-index:1;flex-direction:column;align-items:center;margin-bottom:1.5rem;display:flex;position:relative}.login-card__avatar-ring{pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.login-card__avatar{z-index:1;cursor:pointer;background:#ffffff0d;border:2px solid #8b5cf64d;border-radius:50%;width:88px;height:88px;transition:border-color .2s,box-shadow .2s;position:relative;overflow:hidden;box-shadow:0 0 30px #8b5cf640}.login-card__avatar:hover{border-color:#8b5cf699;box-shadow:0 0 40px #8b5cf666}.login-card__avatar-img{object-fit:cover;width:100%;height:100%}.login-card__avatar-refresh{color:#ffffffb3;cursor:pointer;background:#0a0a14d9;border:1.5px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;transition:color .2s,border-color .2s;display:flex;position:absolute;bottom:3px;right:3px}.login-card__avatar-refresh:hover{color:#fff;border-color:#ffffff4d}.login-card__avatar-hint{color:#ffffff4d;margin:.5rem 0 0;font-size:.72rem}.login-card__header{text-align:center;z-index:1;margin-bottom:1.5rem;position:relative}.login-card__header h2{color:#f8fafc;margin:0 0 .4rem;font-family:Space Grotesk,sans-serif;font-size:1.35rem;font-weight:600}.login-card__header p{color:#64748b;margin:0;font-size:.87rem}.login-card__form{z-index:1;flex-direction:column;gap:.85rem;display:flex;position:relative}.login-card__input-wrapper{background:#ffffff0a;border:1px solid #ffffff1a;border-radius:14px;align-items:center;gap:.5rem;padding:1.15rem 1rem .65rem;transition:border-color .2s,box-shadow .2s;display:flex;position:relative}.login-card__input-wrapper:focus-within{border-color:#8b5cf673;box-shadow:0 0 0 3px #8b5cf614}.login-card__input-wrapper--shake{border-color:#ef444480}.login-card__label{color:#64748b;text-transform:uppercase;letter-spacing:.08em;align-items:center;font-size:.68rem;display:flex;position:absolute;top:.45rem;left:.9rem}.login-card__input{color:#f8fafc;background:0 0;border:none;outline:none;width:100%;font-family:inherit;font-size:.97rem}.login-card__input::placeholder{color:#475569}.login-card__eye{color:#64748b;cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;padding:.25rem;transition:color .2s;display:flex}.login-card__eye:hover{color:#94a3b8}.login-card__button{background:var(--gradient-primary);color:#fff;cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:.25rem;padding:.9rem;font-family:inherit;font-size:1rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:inline-flex}.login-card__button:disabled{opacity:.7;cursor:wait}.login-card__spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.login-card__back{color:#64748b;cursor:pointer;z-index:1;background:0 0;border:none;align-items:center;gap:.35rem;margin-top:.75rem;padding:.5rem;font-family:inherit;font-size:.85rem;transition:color .2s;display:inline-flex;position:relative}.login-card__back:hover{color:#94a3b8}@keyframes spin{to{transform:rotate(360deg)}}.scroll-to-top{z-index:50;border:1px solid var(--border);background:var(--surface);width:3rem;height:3rem;color:var(--fg);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:border-color .2s,box-shadow .2s;display:flex;position:fixed;bottom:2rem;right:2rem;box-shadow:0 4px 20px #0000004d}.scroll-to-top:hover{border-color:#8b5cf666;box-shadow:0 4px 24px #8b5cf640}@keyframes float-orb{0%,to{transform:translate(0)scale(1)}50%{transform:translate(18px,-12px)scale(1.06)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@media (width<=1023px){.featured-project-layout,.blog-preview-grid,.projects-grid,.blog-list,.achievements-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.github-repos,.skills-groups,.about-card{grid-template-columns:1fr}.about-card__avatar{width:120px}.contact-form__row{grid-template-columns:1fr}}.mobile-menu__backdrop{z-index:35;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;position:fixed;inset:0}.mobile-menu{z-index:39;border:1px solid var(--border);background:var(--surface);border-radius:24px;padding:.75rem;position:fixed;top:5rem;left:1rem;right:1rem;box-shadow:0 20px 60px #00000080}.mobile-menu__nav{flex-direction:column;gap:.25rem;display:flex}.mobile-menu__link{color:var(--fg-muted);border-radius:16px;align-items:center;padding:.9rem 1.1rem;font-size:1rem;transition:background .15s,color .15s;display:flex}.mobile-menu__link:hover,.mobile-menu__link--active{background:var(--dim-6);color:var(--fg)}@media (width<=767px){.app-main{padding-top:5.5rem}.site-nav{display:none}.menu-button{display:inline-flex}.glass-card{border-radius:28px}.featured-project-layout,.blog-preview-grid,.projects-grid,.blog-list,.achievements-grid,.github-repos{grid-template-columns:1fr}.hero__actions,.site-footer__links,.featured-project__links,.project-card__links{flex-direction:column;align-items:flex-start}.site-footer__links{align-items:center}.github-section__stats{flex-direction:column}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition-duration:.01ms!important;transition-delay:0s!important;animation:none!important}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
/*$vite$:1*/