.warp-overlay{z-index:9999;background-color:#000;justify-content:center;align-items:flex-end;width:100vw;height:100vh;padding-bottom:80px;font-family:Courier New,Courier,monospace;display:flex;position:fixed;top:0;left:0;overflow:hidden}.warp-canvas{width:100%;height:100%;display:block;position:absolute;top:0;left:0}.warp-content{z-index:10;text-align:center;color:#fff;text-shadow:0 0 15px #8a2be2cc;animation:1.5s ease-out fadeIn;position:relative}.warp-btn{color:#e0c3fc;cursor:pointer;text-transform:uppercase;letter-spacing:3px;background:0 0;border:2px solid #e0c3fc;border-radius:50px;padding:15px 50px;font-size:1.1rem;font-weight:700;transition:all .3s;box-shadow:0 0 20px #8a2be266}.warp-btn:hover{color:#050505;background:#e0c3fc;transform:scale(1.05);box-shadow:0 0 40px #8a2be2e6}@keyframes fadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid oklch(88% 0 0)}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:Inter,system-ui,sans-serif;line-height:1.5}body{line-height:inherit;margin:0}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;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}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:oklch(65% 0 0)}textarea::-moz-placeholder{opacity:1;color:oklch(65% 0 0)}input::placeholder,textarea::placeholder{opacity:1;color:oklch(65% 0 0)}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (width>=640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (width>=768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (width>=1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (width>=1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (width>=1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.-ml-1{margin-left:-4px}.mb-1{margin-bottom:4px}.mb-3{margin-bottom:12px}.mb-6{margin-bottom:24px}.mr-2{margin-right:8px}.mt-1{margin-top:4px}.mt-\[50px\]{margin-top:50px}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.hidden{display:none}.h-12{height:48px}.h-4{height:16px}.h-8{height:32px}.min-h-\[50vh\]{min-height:50vh}.w-12{width:48px}.w-4{width:16px}.w-8{width:32px}.w-full{width:100%}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize{resize:both}.items-center{align-items:center}.justify-center{justify-content:center}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.rounded-lg{border-radius:12px}.rounded-xl{border-radius:16px}.border{border-width:1px}.border-gray-200{border-color:oklch(88% 0 0)}.border-gray-300{border-color:oklch(78% 0 0)}.border-green-500{--tw-border-opacity:1;border-color:rgb(34 197 94/var(--tw-border-opacity,1))}.border-red-500{--tw-border-opacity:1;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.bg-gray-100{background-color:oklch(94% 0 0)}.bg-primary-600{background-color:oklch(45% .18 248)}.bg-red-600{--tw-bg-opacity:1;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.px-3{padding-left:12px;padding-right:12px}.px-4{padding-left:16px;padding-right:16px}.px-6{padding-left:24px;padding-right:24px}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:8px;padding-bottom:8px}.py-3{padding-top:12px;padding-bottom:12px}.text-center{text-align:center}.text-2xl{font-size:32px;line-height:1.2}.text-base{font-size:16px;line-height:1.5}.text-lg{font-size:20px;line-height:1.4}.text-sm{font-size:14px;line-height:1.5}.font-medium{font-weight:500}.font-semibold{font-weight:600}.capitalize{text-transform:capitalize}.text-gray-500{color:oklch(50% 0 0)}.text-gray-600{color:oklch(35% 0 0)}.text-gray-700{color:oklch(25% 0 0)}.text-red-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-slate-500{--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.text-slate-900{--tw-text-opacity:1;color:rgb(15 23 42/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-property:all;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}:root{--bg-base:oklch(20% .005 265);--bg-surface:oklch(22% .005 265);--bg-surface-dark:oklch(20% .005 265);--text-primary:oklch(95% 0 0);--text-secondary:oklch(80% .06 250);--text-tertiary:oklch(65% .08 145);--accent-start:oklch(55% .2 248);--accent-end:oklch(70% .16 248);--accent-secondary:oklch(70% .12 175);--border:oklch(100% 0 0/.06);--border-solid:oklch(35% .005 265);--shadow:oklch(0% 0 0/.4);--shadow-hover:oklch(0% 0 0/.5);--input-bg:oklch(26% .005 265);--focus-glow:oklch(55% .2 248/.2);--header-bg:oklch(20% .005 265/.95);--card-border:oklch(100% 0 0/.08);--badge-bg:oklch(55% .2 248/.12);--badge-text:oklch(80% .06 250);--toast-bg:oklch(22% .005 265);--toast-border:oklch(35% .005 265);--string:oklch(80% .14 50);--keyword:oklch(75% .14 330);--function:oklch(88% .1 85);--type:oklch(75% .12 175);--variable:oklch(88% .06 250);--comment:oklch(65% .08 145);--z-base:0;--z-dropdown:100;--z-sticky:200;--z-modal-backdrop:300;--z-modal:400;--z-tooltip:500;--z-toast:600;--duration-instant:0s;--duration-fast:.15s;--duration-base:.3s;--duration-slow:.5s}[data-theme=light]{--bg-base:oklch(98% 0 0);--bg-surface:oklch(100% 0 0);--bg-surface-dark:oklch(98% 0 0);--text-primary:oklch(15% 0 0);--text-secondary:oklch(40% .14 248);--text-tertiary:oklch(45% .1 145);--accent-start:oklch(50% .2 248);--accent-end:oklch(42% .2 248);--accent-secondary:oklch(50% .12 175);--border:oklch(0% 0 0/.06);--border-solid:oklch(85% 0 0);--shadow:oklch(0% 0 0/.08);--shadow-hover:oklch(0% 0 0/.1);--input-bg:oklch(98% 0 0);--focus-glow:oklch(48% .18 248/.12);--header-bg:oklch(98% 0 0/.88);--card-border:oklch(0% 0 0/.06);--badge-bg:oklch(48% .18 248/.08);--badge-text:oklch(48% .18 248);--toast-bg:oklch(100% 0 0);--toast-border:oklch(88% 0 0);--string:oklch(42% .18 25);--keyword:oklch(48% .22 310);--function:oklch(52% .14 85);--type:oklch(52% .1 195);--variable:oklch(42% .08 260);--comment:oklch(48% .08 145)}:root{--primary-50:oklch(97% 0 0);--primary-100:oklch(94% 0 0);--primary-200:oklch(88% 0 0);--primary-300:oklch(80% 0 0);--primary-400:oklch(70% 0 0);--primary-500:oklch(50% .18 248);--primary-600:oklch(45% .18 248);--primary-700:oklch(40% .18 248);--primary-800:oklch(35% .18 248);--primary-900:oklch(25% .18 248);--gray-100:oklch(94% 0 0);--gray-200:oklch(88% 0 0);--gray-300:oklch(78% 0 0);--gray-400:oklch(65% 0 0);--gray-500:oklch(50% 0 0);--gray-600:oklch(35% 0 0);--gray-700:oklch(25% 0 0);--gray-800:oklch(18% 0 0);--gray-900:oklch(12% 0 0);--success-500:oklch(65% .15 145);--success-bg:oklch(65% .15 145/.12);--danger-500:oklch(55% .2 25);--danger-bg:oklch(55% .2 25/.12);--warning-500:oklch(75% .15 85);--warning-bg:oklch(75% .15 85/.12);--spacing-1:4px;--spacing-2:8px;--spacing-3:12px;--spacing-4:16px;--spacing-5:20px;--spacing-6:24px;--spacing-8:32px;--spacing-10:40px;--spacing-12:48px;--spacing-16:64px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:24px;--radius-full:9999px;--text-xs:12px;--text-sm:14px;--text-base:16px;--text-lg:18px;--text-xl:20px;--text-2xl:24px;--text-3xl:32px;--text-4xl:40px;--text-5xl:48px;--text-6xl:64px}[data-theme=light]{--gray-100:oklch(98% 0 0);--gray-200:oklch(94% 0 0);--gray-300:oklch(88% 0 0);--gray-400:oklch(70% 0 0);--gray-500:oklch(50% 0 0);--gray-600:oklch(35% 0 0);--gray-700:oklch(25% 0 0);--gray-800:oklch(18% 0 0);--gray-900:oklch(12% 0 0)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:oklch(50% 0 0/.2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:oklch(50% 0 0/.35)}::-webkit-scrollbar-corner{background:0 0}*{scrollbar-width:thin;scrollbar-color:oklch(50% 0 0/.2) transparent}body{color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;flex-direction:column;height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:16px;font-weight:400;line-height:1.5;transition:background-color .2s ease-in-out,color .2s ease-in-out;display:flex;overflow:hidden;background-color:#0000!important}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}ul,ol{list-style:none}.skip-link{z-index:9999;background:var(--accent-start);color:#fff;border-radius:0 0 8px 8px;padding:12px 24px;font-size:14px;font-weight:600;transition:top .2s;position:absolute;top:-100%;left:16px}.skip-link:focus{outline:2px solid var(--accent-start);outline-offset:2px;top:0}:focus-visible{outline:2px solid var(--accent-start);outline-offset:2px}h1,h2,h3{font-family:Space Grotesk,Inter,sans-serif;line-height:1.2;font-size:var(--text-2xl);letter-spacing:-.02em;font-weight:800}h2{font-size:var(--text-xl);letter-spacing:-.01em;font-weight:600}h3{font-size:var(--text-lg);font-weight:600}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.gradient-text{background:linear-gradient(90deg, var(--function), var(--type));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.container{max-width:1200px;margin:0 auto;padding:0 24px}.section{height:100%;padding:24px 0}.section-compact{padding:32px 0 48px}.page-loader{justify-content:center;align-items:center;min-height:60vh;display:flex}.app-layout{z-index:1;background-color:#0000;flex-direction:column;height:100vh;display:flex;position:relative}.main-content{background-color:#0000;flex:1;min-height:0;overflow-y:auto}.about-social-wrap{justify-content:center;width:100%;margin-top:32px;display:flex}.code-pre{color:#a5b4fc;margin-bottom:20px;font-size:.9rem}.section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--comment);margin-bottom:12px;font-size:13px;font-weight:600;display:inline-block}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:40px;justify-content:center;align-items:center;gap:8px;min-height:44px;padding:12px 24px;font-family:Inter,sans-serif;font-size:14px;font-weight:600;transition:all .2s ease-in-out;display:inline-flex}.btn:focus-visible{outline:2px solid var(--accent-start);outline-offset:2px}.btn-primary{background:linear-gradient(135deg, var(--accent-start), var(--accent-end));color:#fff;box-shadow:0 4px 16px #007acc40}.btn-primary:hover{transform:scale(1.02);box-shadow:0 6px 24px #007acc59}.btn-secondary{color:var(--accent-start);border:1.5px solid var(--accent-start);background:0 0}.btn-secondary:hover{background:var(--badge-bg);transform:scale(1.02)}.btn-ghost{color:var(--text-secondary);border:1.5px solid var(--border-solid);background:0 0}.btn-ghost:hover{color:var(--text-primary);border-color:var(--text-tertiary);background:var(--border);transform:scale(1.02)}.tech-badges{flex-wrap:wrap;gap:6px;display:flex}.tech-badge{color:var(--badge-text);background:var(--badge-bg);border-radius:6px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-block}.social-links{gap:8px;display:flex}.social-link{border:1px solid var(--border-solid);width:40px;height:40px;color:var(--text-secondary);border-radius:10px;justify-content:center;align-items:center;font-size:16px;transition:all .2s ease-in-out;display:flex}.social-link:hover{color:var(--accent-start);border-color:var(--accent-start);background:var(--badge-bg);transform:translateY(-2px)}.page-enter{animation:.3s ease-out pageIn}@keyframes pageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}#site-header{z-index:100;-webkit-backdrop-filter:none;backdrop-filter:none;border-bottom:1px solid #0000;transition:background .2s ease-in-out,border-color .2s ease-in-out;position:sticky;top:0;background:0 0!important}.header-inner{justify-content:space-between;align-items:center;max-width:1200px;height:64px;margin:0 auto;padding:0 24px;display:flex}.logo{color:var(--text-primary);letter-spacing:-.02em;flex-shrink:0;font-family:Space Grotesk,sans-serif;font-size:20px;font-weight:700}.logo span{color:var(--text-tertiary);font-weight:400}.nav-links{align-items:center;gap:4px;display:flex}.nav-links a{color:var(--text-secondary);white-space:nowrap;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500;transition:color .2s ease-in-out,background-color .2s ease-in-out}.nav-links a:hover{color:var(--text-primary);background:var(--border)}.nav-links a.active{color:var(--text-primary);background:var(--badge-bg)}.header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.icon-btn{border:1px solid var(--border-solid);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;font-size:16px;transition:all .2s ease-in-out;display:flex}.icon-btn:hover{color:var(--text-primary);border-color:var(--text-tertiary);background:var(--border)}.warp-trigger-btn{border:1px solid var(--border-solid);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;font-size:16px;transition:all .2s ease-in-out;display:flex}.warp-trigger-btn:hover{color:var(--text-primary);border-color:var(--text-tertiary)}.hamburger{border:1px solid var(--border-solid);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;font-size:18px;transition:all .2s ease-in-out;display:none}.hamburger:hover{color:var(--text-primary);border-color:var(--text-tertiary)}.mobile-nav{background:var(--bg-surface);border-bottom:1px solid var(--border-solid);box-shadow:var(--shadow);flex-direction:column;gap:4px;padding:16px 24px;transition:background-color .2s ease-in-out,border-color .2s ease-in-out;display:none;position:absolute;top:64px;left:0;right:0}.mobile-nav.open{display:flex}.mobile-nav a{color:var(--text-secondary);border-radius:10px;padding:14px 16px;font-size:15px;font-weight:500;transition:all .2s ease-in-out;display:block}.mobile-nav a:hover,.mobile-nav a.active{color:var(--text-primary);background:var(--badge-bg)}#toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--toast-bg);border:1px solid var(--toast-border);box-shadow:var(--shadow);color:var(--text-primary);border-radius:12px;align-items:center;gap:10px;padding:14px 20px;transition:background .2s ease-in-out,border-color .2s ease-in-out;animation:.3s ease-out toastIn;display:flex}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.hero{align-items:center;height:100%;display:flex;position:relative;overflow:hidden}.hero:before{content:"";background-image:linear-gradient(var(--border-solid) 1px, transparent 1px), linear-gradient(90deg, var(--border-solid) 1px, transparent 1px);opacity:.3;pointer-events:none;background-size:64px 64px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 70%,#000 15%,#0000 70%);mask-image:radial-gradient(80% 70%,#000 15%,#0000 70%)}.hero:after{content:"";background:radial-gradient(circle, var(--focus-glow), transparent 65%);pointer-events:none;width:600px;height:600px;position:absolute;top:10%;left:30%}.hero-grid{z-index:1;justify-content:center;align-items:center;display:flex;position:relative}.hero-content{text-align:center;max-width:700px}.hero h1{margin-bottom:20px}.hero-desc{color:var(--text-secondary);margin-bottom:36px;font-size:18px;line-height:1.7}.hero-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.hero-stats{border-top:1px solid var(--border-solid);justify-content:center;align-items:center;gap:24px;margin-top:48px;padding-top:32px;display:flex}.hero-stat-num{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:24px;font-weight:700;display:block}.hero-stat-label{color:var(--text-tertiary);font-size:13px}.hero-stat-divider{background:var(--border-solid);width:1px;height:36px}.hero-visual{justify-content:center;display:flex}.code-window{background:var(--bg-surface);border:1px solid var(--card-border);width:100%;max-width:420px;box-shadow:var(--shadow);border-radius:16px;transition:all .3s ease-in-out;overflow:hidden}.code-window:hover{box-shadow:var(--shadow-hover);border-color:#8b5cf633;transform:translateY(-4px)}.code-window-bar{background:var(--bg-surface-dark);border-bottom:1px solid var(--border-solid);align-items:center;gap:8px;padding:14px 18px;display:flex}.code-dot{border-radius:50%;width:12px;height:12px}.code-window-title{color:var(--text-tertiary);margin-left:8px;font-family:Inter,monospace;font-size:12px}.code-window-body{padding:20px}.code-window-body pre{margin:0}.code-window-body code{color:var(--text-primary);font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:13px;line-height:1.8}.projects-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.project-card{background:var(--bg-surface);border:1px solid var(--card-border);height:100%;box-shadow:var(--shadow);cursor:default;border-radius:16px;flex-direction:column;transition:all .2s ease-in-out;display:flex;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-hover);border-color:var(--accent-start);z-index:10}.project-card-img-wrap{position:relative}.project-card-img{aspect-ratio:16/9;-o-object-fit:cover;object-fit:cover;border-bottom:1px solid var(--border);width:100%}.project-status-badge{color:#fff;letter-spacing:.3px;text-transform:uppercase;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600;position:absolute;top:10px;right:10px}.project-card-body{flex:1;padding:20px}.project-card-body h3{margin-bottom:8px;font-size:17px}.project-card-body p{color:var(--text-secondary);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin-bottom:16px;font-size:14px;line-height:1.5;display:-webkit-box;overflow:hidden}.project-card-footer{padding:0 20px 20px}.detail-screenshots{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:16px;display:grid}.detail-screenshots img{border:1px solid var(--border-solid);aspect-ratio:16/9;-o-object-fit:cover;object-fit:cover;border-radius:12px;width:100%;transition:border-color .2s ease-in-out}.back-link{color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:32px;font-size:14px;font-weight:500;transition:color .2s;display:inline-flex}.back-link:hover{color:var(--accent-start)}.about-layout{max-width:800px}.about-profile-card{background:var(--bg-surface);border:1px solid var(--card-border);box-shadow:var(--shadow);border-radius:20px;align-items:center;gap:28px;margin-bottom:40px;padding:32px;transition:all .2s ease-in-out;display:flex}.about-avatar img{-o-object-fit:cover;object-fit:cover;border:2px solid var(--border-solid);border-radius:16px;flex-shrink:0;width:120px;height:120px}.about-profile-info h2{margin-bottom:4px;font-size:24px}.about-role{color:var(--accent-secondary);margin-bottom:10px;font-size:14px;font-weight:500}.about-bio-inline{color:var(--text-secondary);margin-bottom:16px;font-size:15px;line-height:1.5}.about-profile-links{gap:8px;display:flex}.about-bio-block{margin-bottom:48px}.about-bio-block p{color:var(--text-secondary);margin-bottom:16px;font-size:16px;line-height:1.8}.about-bio-block p:last-child{margin-bottom:0}.about-section-title{margin-bottom:20px;font-size:20px}.about-interests{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.interest-item{background:var(--bg-surface);border:1px solid var(--card-border);border-radius:14px;align-items:flex-start;gap:14px;padding:18px;transition:all .2s ease-in-out;display:flex}.interest-item:hover{border-color:var(--accent-start);box-shadow:var(--shadow);transform:translateY(-2px)}.interest-icon-wrap{background:var(--badge-bg);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.interest-icon-wrap i{color:var(--accent-start);font-size:16px}.interest-label{color:var(--text-primary);margin-bottom:2px;font-size:14px;font-weight:600;display:block}.interest-desc{color:var(--text-tertiary);font-size:13px;display:block}.blog-card-inner{flex-direction:column;height:100%;display:flex}.blog-card-image-wrap{border-radius:8px;width:100%;height:140px;margin-bottom:12px;overflow:hidden}.blog-card-image{-o-object-fit:cover;object-fit:cover;width:100%;height:100%;transition:transform .3s}.blog-card-image:hover{transform:scale(1.05)}.blog-card-body{flex-direction:column;flex:1;padding:0 15px 15px;display:flex}.blog-card-date{color:var(--text-tertiary);margin-bottom:8px;font-size:.75rem}.blog-card-title{color:var(--text-primary);margin-bottom:10px;font-size:1.15rem}.blog-card-excerpt{color:var(--text-secondary);flex:1;margin-bottom:15px;font-size:.9rem;line-height:1.5}.blog-card-cta{text-align:center;margin-top:auto;padding:8px 16px;font-size:.85rem}.search-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);background:oklch(0% 0 0/.6);justify-content:center;padding-top:100px;display:flex;position:fixed;inset:0}.search-modal-content{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-solid);width:100%;max-width:600px;max-height:70vh;box-shadow:var(--shadow-hover);flex-direction:column;display:flex;overflow:hidden}.search-modal-input-wrap{padding:var(--spacing-4);border-bottom:1px solid var(--border);align-items:center;gap:var(--spacing-3);display:flex}.search-modal-icon{color:var(--text-tertiary);font-size:18px}.search-modal-input{font-size:var(--text-base);color:var(--text-primary);background:0 0;border:none;outline:none;flex:1}.search-modal-close{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;padding:4px}.search-modal-results{flex:1;overflow-y:auto}.search-modal-empty{padding:var(--spacing-6);text-align:center;color:var(--text-tertiary)}.search-result-item{padding:var(--spacing-3) var(--spacing-4);cursor:pointer;align-items:center;gap:var(--spacing-3);transition:background .15s;display:flex}.search-result-item:hover,.search-result-active{background:var(--bg-surface-dark);outline:none}.search-result-badge{border-radius:var(--radius-sm);font-size:var(--text-xs);white-space:nowrap;padding:2px 8px;font-weight:600}.badge-project{color:var(--accent-start);background:oklch(55% .2 248/.15)}.badge-blog{color:var(--success-500);background:oklch(65% .15 145/.15)}.search-result-title{color:var(--text-primary);font-weight:500}.search-result-desc{font-size:var(--text-sm);color:var(--text-tertiary);white-space:nowrap;text-overflow:ellipsis;max-width:400px;overflow:hidden}.search-modal-footer{padding:var(--spacing-2) var(--spacing-4);border-top:1px solid var(--border);font-size:var(--text-xs);color:var(--text-tertiary);gap:var(--spacing-4);display:flex}.search-kbd{background:var(--bg-surface-dark);border-radius:4px;padding:2px 6px;font-family:inherit}.blog-detail-container{max-width:900px;margin:0 auto}.blog-detail-back{color:var(--text-secondary);margin-bottom:30px;font-size:.9rem;text-decoration:none;display:inline-block}.blog-detail-back:hover{color:var(--accent-start)}.blog-title{color:var(--text-primary);margin:0;font-size:3.5rem;line-height:1.2}.status-badge{background:var(--accent-start);color:#fff;text-transform:uppercase;letter-spacing:1px;border-radius:20px;padding:5px 12px;font-size:.85rem;font-weight:700;display:inline-block}.project-title-row{flex-wrap:wrap;align-items:center;gap:16px;margin-top:15px;display:flex}.project-links{flex-wrap:wrap;gap:10px;display:flex}.project-detail-header{margin-bottom:40px}.btn-sm{padding:8px 18px;font-size:.85rem}.blog-content{color:var(--text-secondary);line-height:1.9}.detail-section{flex:1;overflow-y:auto}.contact-layout{justify-content:center;width:100%;display:flex}.contact-desc{color:var(--text-secondary);max-width:520px;margin-bottom:48px;font-size:17px;line-height:1.6}.contact-grid{grid-template-columns:1fr 1.4fr;align-items:start;gap:32px;display:grid}.contact-info{flex-direction:column;gap:12px;display:flex}.contact-info-card{background:var(--bg-surface);border:1px solid var(--card-border);border-radius:14px;align-items:center;gap:16px;padding:20px;transition:all .2s ease-in-out;display:flex}.contact-info-card:hover{border-color:var(--accent-start);box-shadow:var(--shadow);transform:translateY(-2px)}.contact-info-icon{background:var(--badge-bg);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.contact-info-icon i{color:var(--accent-start);font-size:16px}.contact-info-label{color:var(--text-tertiary);margin-bottom:2px;font-size:12px;font-weight:500;display:block}.contact-info-value{color:var(--text-primary);font-size:14px;font-weight:600;display:block}.contact-form-card{background:var(--bg-surface);border:1px solid var(--card-border);box-shadow:var(--shadow);border-radius:20px;padding:32px}.form-group label{color:var(--text-primary);margin-bottom:8px;font-size:14px;font-weight:500;display:block}.form-group input,.form-group textarea{width:100%;color:var(--text-primary);background:var(--input-bg);border:1.5px solid var(--border-solid);border-radius:12px;padding:12px;font-family:Inter,sans-serif;font-size:15px;line-height:1.5;transition:all .2s ease-in-out}.form-group input::-moz-placeholder{color:var(--text-tertiary)}.form-group textarea::-moz-placeholder{color:var(--text-tertiary)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-tertiary)}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent-start);box-shadow:0 0 0 3px var(--focus-glow);outline:none}:is(.form-group input:invalid:not(:placeholder-shown),.form-group textarea:invalid:not(:placeholder-shown)),.form-group input:invalid:not(:placeholder-shown),.form-group textarea:invalid:not(:placeholder-shown){border-color:#ef4444}.form-group textarea{resize:vertical;min-height:80px}.form-error-msg{color:#ef4444;margin-top:6px;font-size:13px;display:none}.form-error-msg.visible{display:block}.coming-soon{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:50vh;padding:120px 24px;display:flex}.coming-soon-icon{background:var(--badge-bg);width:80px;height:80px;color:var(--accent-start);border-radius:20px;justify-content:center;align-items:center;margin-bottom:24px;font-size:32px;display:flex}.coming-soon h2{margin-bottom:12px;font-size:28px}.coming-soon p{color:var(--text-secondary);max-width:400px;margin-bottom:32px;font-size:16px}.contact-section{justify-content:center;align-items:center;height:calc(100vh - 120px);padding:16px 24px;display:flex;overflow:hidden}.contact-card{border:1px solid var(--border-solid);background-color:var(--bg-surface);border-radius:16px;width:100%;max-width:420px;padding:20px 24px;transition:all .2s ease-in-out;box-shadow:0 8px 32px #0000001f}.contact-card:hover{border-color:var(--accent-start);box-shadow:0 8px 32px #0000001f, var(--shadow-hover);transform:translateY(-2px)}.contact-card-title{text-align:center;color:var(--text-primary);margin-bottom:12px}.contact-card-desc{color:var(--text-secondary);text-align:center;margin-bottom:16px;font-size:14px}.contact-success{text-align:center}.contact-success-icon{color:var(--accent-start);margin-bottom:8px;font-size:32px}.form-group{margin-bottom:10px}.form-label{color:var(--text-primary);margin-bottom:4px;font-size:14px;font-weight:500;display:block}.form-input{border:1px solid var(--border-solid);background-color:var(--input-bg);width:100%;color:var(--text-primary);border-radius:8px;margin-top:4px;padding:8px 16px}.form-textarea{resize:vertical;min-height:70px}.login-card{border:1px solid var(--border-solid);background-color:var(--bg-surface);border-radius:16px;width:100%;max-width:420px;padding:24px;transition:all .2s ease-in-out;box-shadow:0 8px 32px #0000001f}.login-card:hover{border-color:var(--accent-start);box-shadow:0 8px 32px #0000001f, var(--shadow-hover);transform:translateY(-2px)}.pagination{justify-content:center;gap:var(--spacing-2);margin-top:var(--spacing-10);display:flex}.pagination-btn{border-radius:var(--radius-md);border:1px solid var(--border-solid);width:40px;height:40px;color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;background:0 0;font-weight:600;transition:all .2s ease-in-out}.pagination-btn:hover{border-color:var(--accent-start);color:var(--text-primary)}.pagination-active{background:var(--accent-start);color:#fff;border:none}.site-footer{border-top:1px solid var(--border-solid);padding:0 var(--spacing-4);text-align:center;flex-shrink:0;transition:border-color .2s ease-in-out}.footer-inner{justify-content:space-between;align-items:center;gap:16px;max-width:1200px;height:56px;margin:0 auto;display:flex}.footer-nav{flex-wrap:wrap;gap:20px;display:flex}.footer-nav a{font-size:var(--text-sm);color:var(--text-secondary);transition:color .2s ease-in-out}.footer-nav a:hover{color:var(--accent-start)}.site-footer p{font-size:var(--text-sm);color:var(--text-tertiary);flex-shrink:0}.not-found{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:50vh;padding:120px 24px;display:flex}.not-found h2{color:var(--text-tertiary);margin-bottom:12px;font-size:48px}.not-found p{color:var(--text-secondary);margin-bottom:32px}@media (width>=768px){h1{font-size:48px}h2{font-size:32px}}@media (width<=767px){body{font-size:14px}.nav-links{display:none}.hamburger{display:flex}.hero{height:auto;padding:48px 0 64px}.hero:before,.hero:after{display:none}.hero-grid{flex-direction:column;gap:48px}.hero-content,.hero-desc,.hero-actions,.hero-stats{opacity:1!important;transform:none!important}.hero-desc{font-size:15px}.hero-stats{gap:16px;margin-top:32px;padding-top:24px}.hero-stat-num{font-size:20px}.hero-visual{order:-1}.code-window{max-width:100%}.projects-grid{grid-template-columns:1fr}.blog-title{font-size:2rem!important}.blog-detail-image{height:200px!important}.blog-content{font-size:1rem!important}.search-modal-content{max-width:90vw!important}.search-modal-overlay{padding-top:40px!important}.search-result-desc{max-width:100%!important}.about-profile-card{text-align:center;flex-direction:column;padding:28px}.about-profile-links{justify-content:center}.about-interests{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr;gap:24px}}@media (width<=1023px) and (width>=640px){.projects-grid{grid-template-columns:repeat(2,1fr)}}.social-icons-wrapper{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:10px;display:flex}.social-link-item{color:var(--text-primary);border:1px solid var(--border-solid);background-color:#ffffff08;border-radius:8px;align-items:center;gap:8px;padding:6px 14px;font-family:Courier New,Courier,monospace;font-size:.9rem;text-decoration:none;transition:all .2s;display:flex}.social-link-item svg{color:var(--text-primary)}.social-link-item:hover{background-color:var(--bg-surface-dark);border-color:var(--text-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.hover\:bg-gray-100:hover{background-color:oklch(94% 0 0)}.hover\:bg-gray-200:hover{background-color:oklch(88% 0 0)}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.hover\:bg-primary-700:hover{background-color:oklch(40% .18 248)}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity,1))}.focus\:outline-none:focus{outline-offset:2px;outline:2px solid #0000}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.focus\:ring-blue-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.focus\:ring-gray-500:focus{--tw-ring-color:oklch(50% 0 0)}.focus\:ring-green-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(34 197 94/var(--tw-ring-opacity,1))}.focus\:ring-red-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(239 68 68/var(--tw-ring-opacity,1))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}
