*,:before,:after{--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: rgb(59 130 246 / .5);--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: }::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: rgb(59 130 246 / .5);--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-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:DM Mono,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings: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:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-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{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.relative{position:relative}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.ring{--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(3px + 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)}.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)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #070710;--bg2: #0d0d1a;--bg3: #111128;--surface: rgba(255,255,255,.03);--surface2: rgba(255,255,255,.06);--border: rgba(255,255,255,.07);--teal: #00e5cc;--teal2: #00b8a9;--amber: #ff6b35;--amber2: #ff9500;--purple: #7b5ea7;--text: #e8e8f0;--text2: #8888aa;--text3: #555570;--danger: #ff5470;--success: #2ee6a6;--font-display: "Syne", sans-serif;--font-mono: "DM Mono", monospace;--font-body: "Outfit", sans-serif;--radius: 12px;--radius-lg: 20px;--glow-teal: 0 0 40px rgba(0,229,204,.15);--glow-amber: 0 0 40px rgba(255,107,53,.15)}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}@media(min-width:769px){body.has-cursor{cursor:none}}a{color:inherit}::-moz-selection{background:#00e5cc33;color:var(--teal)}::selection{background:#00e5cc33;color:var(--teal)}.cursor{width:8px;height:8px;background:var(--teal);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transition:transform .1s;mix-blend-mode:screen}.cursor-ring{width:36px;height:36px;border:1px solid rgba(0,229,204,.4);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transition:all .18s ease;transform:translate(-50%,-50%)}.cursor.active{transform:scale(3);background:var(--amber)}.cursor-ring.active{width:60px;height:60px;border-color:#ff6b354d}@media(max-width:768px){.cursor,.cursor-ring{display:none}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--teal2);border-radius:2px}nav.site-nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.2rem 4rem;display:flex;align-items:center;justify-content:space-between;transition:all .4s ease}nav.site-nav.scrolled{background:#070710d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:.9rem 4rem}.nav-logo{font-family:var(--font-display);font-weight:800;font-size:1.3rem;color:var(--text);text-decoration:none;letter-spacing:-.02em}.nav-logo span{color:var(--teal)}.nav-links{display:flex;gap:2.5rem;list-style:none;align-items:center}.nav-links a{font-family:var(--font-mono);font-size:.75rem;color:var(--text2);text-decoration:none;letter-spacing:.1em;text-transform:uppercase;transition:color .3s;position:relative;background:none;border:none;cursor:pointer}.nav-links a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--teal);transition:width .3s}.nav-links a:hover,.nav-links a.active{color:var(--teal)}.nav-links a:hover:after,.nav-links a.active:after{width:100%}.nav-cta{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding:.55rem 1.4rem;border:1px solid var(--teal);color:var(--teal);text-decoration:none;border-radius:4px;transition:all .3s}.nav-cta:hover{background:var(--teal);color:var(--bg)}.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer}.hamburger span{width:24px;height:1.5px;background:var(--text);transition:all .3s}#hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding:0 4rem}canvas#constellation{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0;opacity:.85}.hero-grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(0,229,204,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,229,204,.03) 1px,transparent 1px);background-size:60px 60px;z-index:1;-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black,transparent);mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black,transparent)}.hero-content{position:relative;z-index:2;max-width:900px}.hero-tag{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-mono);font-size:.72rem;color:var(--teal);letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.5rem;opacity:0;animation:fadeUp .8s .3s forwards}.hero-tag:before{content:"";width:30px;height:1px;background:var(--teal)}.hero-name{font-family:var(--font-display);font-size:clamp(3rem,8vw,6.5rem);font-weight:800;line-height:.95;letter-spacing:-.04em;margin-bottom:1rem;opacity:0;animation:fadeUp .9s .5s forwards}.hero-name .line1{display:block;color:var(--text)}.hero-name .line2{display:block;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.15)}.hero-name .accent{color:var(--teal);-webkit-text-stroke:0}.hero-role{font-family:var(--font-display);font-size:clamp(1.1rem,2.5vw,1.6rem);font-weight:500;color:var(--text2);margin-bottom:1.8rem;min-height:2.2rem;opacity:0;animation:fadeUp .9s .7s forwards}.typed-text{color:var(--amber)}.cursor-blink{display:inline-block;width:2px;height:1.2em;background:var(--amber);margin-left:3px;vertical-align:text-bottom;animation:blink .8s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-desc{max-width:520px;font-size:1rem;color:var(--text2);line-height:1.8;margin-bottom:2.5rem;opacity:0;animation:fadeUp .9s .9s forwards}.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:fadeUp .9s 1.1s forwards}.btn-primary{display:inline-flex;align-items:center;gap:.6rem;padding:.9rem 2rem;background:var(--teal);color:var(--bg);font-family:var(--font-mono);font-size:.78rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border-radius:6px;transition:all .3s;border:1px solid var(--teal);cursor:pointer}.btn-primary:hover{background:transparent;color:var(--teal);box-shadow:var(--glow-teal);transform:translateY(-2px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-outline{display:inline-flex;align-items:center;gap:.6rem;padding:.9rem 2rem;border:1px solid var(--border);color:var(--text);font-family:var(--font-mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border-radius:6px;transition:all .3s;cursor:pointer;background:none}.btn-outline:hover{border-color:var(--amber);color:var(--amber);box-shadow:var(--glow-amber);transform:translateY(-2px)}.hero-socials{position:absolute;right:4rem;top:50%;transform:translateY(-50%);z-index:2;display:flex;flex-direction:column;gap:1.2rem;align-items:center;opacity:0;animation:fadeIn 1s 1.5s forwards}.hero-socials:before,.hero-socials:after{content:"";width:1px;height:60px;background:linear-gradient(to bottom,transparent,var(--teal));opacity:.4}.hero-socials:after{background:linear-gradient(to top,transparent,var(--teal))}.hero-socials a{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid rgba(0,229,204,.25);background:#00e5cc0f;color:var(--teal);font-size:.95rem;text-decoration:none;transition:all .3s;box-shadow:0 0 12px #00e5cc1a}.hero-socials a:hover{background:var(--teal);color:var(--bg);border-color:var(--teal);transform:scale(1.15);box-shadow:0 0 24px #00e5cc73}.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.68rem;color:var(--teal);letter-spacing:.2em;text-transform:uppercase;animation:fadeIn 1s 1.8s both;text-shadow:0 0 12px rgba(0,229,204,.6)}.scroll-line{width:2px;height:50px;background:linear-gradient(to bottom,var(--teal),transparent);border-radius:2px;animation:scrollPulse 2s infinite;box-shadow:0 0 8px #00e5cc80}@keyframes scrollPulse{0%,to{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.15)}}.stats-band{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:2.5rem 4rem;display:grid;grid-template-columns:repeat(var(--stat-count, 4),1fr);gap:1rem}.stat-item{text-align:center;padding:1rem;border-right:1px solid var(--border)}.stat-item:last-child{border-right:none}.stat-num{font-family:var(--font-display);font-size:2.5rem;font-weight:800;color:var(--teal);line-height:1;margin-bottom:.3rem}.stat-label{font-family:var(--font-mono);font-size:.65rem;color:var(--text3);letter-spacing:.15em;text-transform:uppercase}section{padding:7rem 4rem}.section-header{margin-bottom:4rem}.section-tag{font-family:var(--font-mono);font-size:.68rem;color:var(--teal);letter-spacing:.2em;text-transform:uppercase;margin-bottom:.8rem;display:flex;align-items:center;gap:.8rem}.section-tag:after{content:"";flex:1;max-width:50px;height:1px;background:var(--teal)}.section-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;color:var(--text)}.section-title .highlight{color:var(--teal)}.page-section{padding-top:9rem;min-height:70vh}#about{background:var(--bg2);position:relative;overflow:hidden}#about:before{content:"";position:absolute;bottom:-60px;left:-60px;width:520px;height:520px;background-image:linear-gradient(rgba(0,229,204,.13) 1px,transparent 1px),linear-gradient(90deg,rgba(0,229,204,.13) 1px,transparent 1px);background-size:36px 36px;mask-image:radial-gradient(ellipse 75% 75% at 20% 80%,black 0%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse 75% 75% at 20% 80%,black 0%,transparent 75%);pointer-events:none;z-index:0;animation:meshPulse 6s ease-in-out infinite}#about:after{content:"";position:absolute;bottom:-40px;left:-40px;width:380px;height:380px;background:radial-gradient(ellipse at 15% 85%,rgba(0,229,204,.06) 0%,transparent 65%);pointer-events:none;z-index:0;animation:meshPulse 6s ease-in-out infinite reverse}@keyframes meshPulse{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}#about>*{position:relative;z-index:1}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}.about-text p{color:var(--text2);line-height:1.9;margin-bottom:1.5rem;font-size:1.05rem}.about-highlights{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2rem}.highlight-chip{display:flex;align-items:center;gap:.7rem;padding:.8rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:.85rem;color:var(--text2);transition:all .3s}.highlight-chip:hover{border-color:var(--teal);color:var(--teal);background:#00e5cc0d}.highlight-chip i{color:var(--teal);font-size:.9rem}.about-visual{position:relative}.about-card-main{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.about-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--purple));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.8rem;font-weight:800;color:var(--bg);margin-bottom:1.5rem;position:relative;overflow:hidden}.about-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%}.about-name-big{font-family:var(--font-display);font-size:1.3rem;font-weight:700;margin-bottom:.2rem}.about-role-tag{font-family:var(--font-mono);font-size:.72rem;color:var(--amber);letter-spacing:.1em;margin-bottom:1.5rem}.about-info-list{list-style:none;display:flex;flex-direction:column;gap:.9rem}.about-info-list li{display:flex;align-items:center;gap:.8rem;font-size:.88rem;color:var(--text2)}.about-info-list i{color:var(--teal);width:16px}.about-info-list a{color:var(--text2);text-decoration:none;transition:color .2s}.about-info-list a:hover{color:var(--teal)}.timeline{position:relative;padding-left:2rem}.timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,var(--teal),transparent)}.timeline-item{position:relative;padding-left:3rem;padding-bottom:3.5rem}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:-2.45rem;top:.3rem;width:16px;height:16px;border-radius:50%;background:var(--bg);border:2px solid var(--teal);box-shadow:0 0 15px #00e5cc66;transition:all .3s}.timeline-item:hover .timeline-dot{background:var(--teal);transform:scale(1.3)}.timeline-period{font-family:var(--font-mono);font-size:.68rem;color:var(--teal);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.5rem}.timeline-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;transition:all .4s}.timeline-card:hover{border-color:#00e5cc33;background:var(--surface2);transform:translate(6px);box-shadow:var(--glow-teal)}.timeline-role{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:.3rem}.timeline-company{font-family:var(--font-mono);font-size:.78rem;color:var(--amber);margin-bottom:.3rem}.timeline-loc{font-size:.8rem;color:var(--text3);margin-bottom:1.2rem}.timeline-bullets{list-style:none;display:flex;flex-direction:column;gap:.6rem}.timeline-bullets li{display:flex;align-items:flex-start;gap:.7rem;font-size:.9rem;color:var(--text2);line-height:1.6}.timeline-bullets li:before{content:"▹";color:var(--teal);flex-shrink:0;margin-top:.1rem}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;display:flex;flex-direction:column;transition:all .4s cubic-bezier(.23,1,.32,1);position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--teal),var(--purple));transform:scaleX(0);transform-origin:left;transition:transform .4s}.project-card:hover:before{transform:scaleX(1)}.project-card:hover{border-color:#00e5cc26;background:var(--surface2);transform:translateY(-8px);box-shadow:0 20px 60px #0006,var(--glow-teal)}.project-card.featured{grid-column:span 2;background:linear-gradient(135deg,var(--surface),rgba(0,229,204,.03))}.project-num{font-family:var(--font-mono);font-size:.65rem;color:var(--text3);letter-spacing:.15em;margin-bottom:.5rem}.project-thumb{width:100%;height:180px;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius);margin-bottom:1.2rem;border:1px solid var(--border)}.project-icon{width:44px;height:44px;background:#00e5cc14;border:1px solid rgba(0,229,204,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--teal);margin-bottom:1.2rem;transition:all .3s}.project-card:hover .project-icon{background:#00e5cc26;box-shadow:0 0 20px #00e5cc33}.project-name{font-family:var(--font-display);font-size:1.05rem;font-weight:700;margin-bottom:.4rem;line-height:1.3}.project-period{font-family:var(--font-mono);font-size:.65rem;color:var(--amber);letter-spacing:.1em;margin-bottom:.8rem}.project-desc{font-size:.88rem;color:var(--text2);line-height:1.7;flex:1;margin-bottom:1.2rem}.project-tags{display:flex;flex-wrap:wrap;gap:.4rem}.tag{font-family:var(--font-mono);font-size:.62rem;padding:.25rem .7rem;border:1px solid var(--border);border-radius:3px;color:var(--text3);letter-spacing:.05em;transition:all .2s}.project-card:hover .tag{border-color:#00e5cc33;color:var(--text2)}.project-links{display:flex;gap:.6rem;margin-top:1rem;flex-wrap:wrap;align-self:flex-end}.project-link{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.72rem;color:var(--text2);text-decoration:none;letter-spacing:.08em;text-transform:uppercase;padding:.5rem .9rem;border:1px solid var(--border);border-radius:4px;transition:all .25s}.project-link i{font-size:.95rem}.project-link:hover{color:var(--teal);border-color:#00e5cc59;background:#00e5cc0d;transform:translate(2px)}.skills-layout{display:grid;grid-template-columns:1fr 1fr;gap:4rem}.skills-col-title{font-family:var(--font-display);font-size:.9rem;font-weight:600;color:var(--text2);margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:.1em}.skill-bar-item{margin-bottom:1.4rem}.skill-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.skill-name{font-family:var(--font-mono);font-size:.8rem;color:var(--text)}.skill-pct{font-family:var(--font-mono);font-size:.68rem;color:var(--teal)}.skill-track{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.skill-fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--purple));border-radius:2px;width:0;transition:width 1.2s cubic-bezier(.23,1,.32,1)}.tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}.tech-chip{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem .8rem;text-align:center;font-family:var(--font-mono);font-size:.75rem;color:var(--text2);transition:all .3s;display:flex;flex-direction:column;align-items:center;gap:.5rem}.tech-chip i{font-size:1.3rem;color:var(--teal)}.tech-chip:hover{border-color:var(--teal);color:var(--teal);background:#00e5cc0d;transform:translateY(-3px);box-shadow:var(--glow-teal)}.edu-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.edu-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;transition:all .3s;position:relative}.edu-card:after{content:attr(data-year);position:absolute;top:1.5rem;right:1.5rem;font-family:var(--font-mono);font-size:.65rem;color:var(--text3);letter-spacing:.1em}.edu-card:hover{border-color:#00e5cc33;transform:translateY(-4px);box-shadow:var(--glow-teal)}.edu-card.primary{grid-column:span 2;background:linear-gradient(135deg,var(--surface),rgba(123,94,167,.05))}.edu-icon{width:40px;height:40px;background:#00e5cc14;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--teal);font-size:1rem;margin-bottom:1rem}.edu-degree{font-family:var(--font-display);font-size:1rem;font-weight:700;margin-bottom:.3rem;line-height:1.3}.edu-inst{font-size:.85rem;color:var(--amber);font-family:var(--font-mono);margin-bottom:.2rem}.edu-loc{font-size:.8rem;color:var(--text3)}.cert-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.cert-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;display:flex;gap:1rem;align-items:flex-start;transition:all .3s}.cert-card:hover{border-color:#00e5cc33;background:var(--surface2);transform:translate(4px)}.cert-icon{width:36px;height:36px;flex-shrink:0;background:#00e5cc14;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--teal);font-size:.9rem;overflow:hidden}.cert-icon img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.cert-name{font-size:.85rem;font-weight:500;line-height:1.4;margin-bottom:.2rem}.cert-issuer{font-family:var(--font-mono);font-size:.65rem;color:var(--amber);letter-spacing:.08em}.cert-body{display:flex;flex-direction:column;flex:1}.cert-verify{display:inline-flex;align-items:center;gap:.35rem;margin-left:auto;align-self:center;flex-shrink:0;font-family:var(--font-mono);font-size:.6rem;color:var(--text2);text-decoration:none;letter-spacing:.1em;text-transform:uppercase;padding:.7rem 1.2rem;border:1px solid var(--border);border-radius:4px;transition:all .25s}.cert-verify i{font-size:.7rem}.cert-verify:hover{color:var(--teal);border-color:#00e5cc59;background:#00e5cc0d}.award-banner{background:linear-gradient(135deg,#00e5cc0d,#7b5ea70d);border:1px solid rgba(0,229,204,.15);border-radius:var(--radius-lg);padding:2.5rem 3rem;display:flex;align-items:center;gap:2rem;margin-top:3rem;text-decoration:none;color:inherit;transition:transform .2s ease,border-color .2s ease}.award-banner:hover{transform:translateY(-2px);border-color:#00e5cc59}.award-icon{width:60px;height:60px;flex-shrink:0;background:linear-gradient(135deg,#ff6b3526,#ff950026);border:1px solid rgba(255,107,53,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--amber)}.award-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;margin-bottom:.3rem}.award-desc{color:var(--text2);font-size:.92rem}.award-rank{margin-left:auto;flex-shrink:0;text-align:center}.rank-num{font-family:var(--font-display);font-size:3.5rem;font-weight:800;color:var(--amber);line-height:1}.rank-label{font-family:var(--font-mono);font-size:.65rem;color:var(--text3);letter-spacing:.15em;text-transform:uppercase}#contact{background:var(--bg2);text-align:center}.contact-inner{max-width:700px;margin:0 auto}.contact-pre{font-family:var(--font-mono);font-size:.72rem;color:var(--teal);letter-spacing:.15em;text-transform:uppercase;margin-bottom:1rem}.contact-headline{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:800;letter-spacing:-.03em;margin-bottom:1.5rem;line-height:1.1}.contact-desc{color:var(--text2);font-size:1rem;line-height:1.8;margin-bottom:3rem}.contact-links{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}.contact-link{display:inline-flex;align-items:center;gap:.7rem;padding:.9rem 1.8rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text2);text-decoration:none;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.05em;transition:all .3s}.contact-link i{color:var(--teal)}.contact-link:hover{border-color:var(--teal);color:var(--teal);background:#00e5cc0d;transform:translateY(-2px);box-shadow:var(--glow-teal)}footer.site-footer{background:var(--bg);border-top:1px solid var(--border);padding:2rem 4rem;display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:.68rem;color:var(--text3);letter-spacing:.08em}footer.site-footer span{color:var(--teal)}.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-left{opacity:0;transform:translate(-30px);transition:opacity .7s ease,transform .7s ease}.reveal-left.visible{opacity:1;transform:translate(0)}.reveal-right{opacity:0;transform:translate(30px);transition:opacity .7s ease,transform .7s ease}.reveal-right.visible{opacity:1;transform:translate(0)}.delay-1{transition-delay:.1s!important}.delay-2{transition-delay:.2s!important}.delay-3{transition-delay:.3s!important}.delay-4{transition-delay:.4s!important}.delay-5{transition-delay:.5s!important}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.mobile-menu{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#070710fa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:2rem}.mobile-menu.open{display:flex}.mobile-menu a{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--text);text-decoration:none;transition:color .2s;background:none;border:none;cursor:pointer}.mobile-menu a:hover{color:var(--teal)}.close-menu{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:var(--text);font-size:1.5rem;cursor:pointer}.loader-wrap{display:flex;align-items:center;justify-content:center;min-height:60vh}.loader-wrap.full{min-height:100vh}.loader-ring{width:46px;height:46px;border:3px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:spin .8s linear infinite}.admin-shell{display:flex;min-height:100vh;background:var(--bg)}.admin-sidebar{width:250px;flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);padding:2rem 1.2rem;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.admin-brand{font-family:var(--font-display);font-weight:800;font-size:1.2rem;margin-bottom:.2rem}.admin-brand span{color:var(--teal)}.admin-brand-sub{font-family:var(--font-mono);font-size:.6rem;color:var(--text3);letter-spacing:.15em;text-transform:uppercase;margin-bottom:2rem}.admin-nav{display:flex;flex-direction:column;gap:.3rem;flex:1}.admin-nav a{display:flex;align-items:center;gap:.8rem;padding:.7rem 1rem;border-radius:8px;font-family:var(--font-mono);font-size:.78rem;color:var(--text2);text-decoration:none;transition:all .2s}.admin-nav a i{width:18px;text-align:center;color:var(--text3);transition:color .2s}.admin-nav a:hover{background:var(--surface);color:var(--text)}.admin-nav a.active{background:#00e5cc14;color:var(--teal)}.admin-nav a.active i{color:var(--teal)}.admin-logout{margin-top:1rem;display:flex;align-items:center;gap:.6rem;justify-content:center;padding:.7rem;border:1px solid var(--border);border-radius:8px;background:none;color:var(--text2);font-family:var(--font-mono);font-size:.72rem;cursor:pointer;transition:all .2s}.admin-logout:hover{border-color:var(--danger);color:var(--danger)}.admin-main{flex:1;padding:2.5rem 3rem;max-width:100%;overflow-x:hidden}.admin-header{margin-bottom:2rem}.admin-title{font-family:var(--font-display);font-size:1.8rem;font-weight:800}.admin-subtitle{color:var(--text2);font-size:.9rem;margin-top:.3rem}.admin-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-mobile-bar{display:none}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;margin-bottom:1.5rem}.card-title{font-family:var(--font-display);font-size:1.05rem;font-weight:700;margin-bottom:1.2rem;display:flex;align-items:center;gap:.6rem}.card-title i{color:var(--teal)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.2rem}.form-group.full{grid-column:1 / -1}label{font-family:var(--font-mono);font-size:.7rem;color:var(--text2);letter-spacing:.08em;text-transform:uppercase}input,textarea,select{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.7rem .9rem;color:var(--text);font-family:var(--font-body);font-size:.9rem;transition:border-color .2s;width:100%}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--teal)}textarea{resize:vertical;min-height:90px}input[type=range]{padding:0;accent-color:var(--teal)}input[type=file]{padding:.5rem;font-size:.8rem}.form-actions{display:flex;gap:.8rem;margin-top:.5rem;flex-wrap:wrap}.btn-sm{padding:.6rem 1.2rem;font-size:.72rem}.btn-ghost{background:none;border:1px solid var(--border);color:var(--text2);border-radius:6px;padding:.6rem 1.2rem;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:all .2s}.btn-ghost:hover{border-color:var(--text2);color:var(--text)}.btn-danger{background:none;border:1px solid rgba(255,84,112,.4);color:var(--danger);border-radius:6px;padding:.5rem .9rem;font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;cursor:pointer;transition:all .2s}.btn-danger:hover{background:#ff54701a}.admin-list{display:flex;flex-direction:column;gap:.8rem}.admin-row{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;background:var(--bg);border:1px solid var(--border);border-radius:10px;transition:border-color .2s}.admin-row:hover{border-color:#00e5cc33}.admin-row-main{flex:1;min-width:0}.admin-row-title{font-weight:600;font-size:.92rem;margin-bottom:.2rem}.admin-row-sub{font-family:var(--font-mono);font-size:.7rem;color:var(--text3)}.admin-row-actions{display:flex;gap:.5rem;flex-shrink:0}.icon-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:7px;border:1px solid var(--border);background:none;color:var(--text2);cursor:pointer;transition:all .2s}.icon-btn:hover{border-color:var(--teal);color:var(--teal)}.icon-btn.danger:hover{border-color:var(--danger);color:var(--danger)}.status-pill{display:inline-block;margin-left:.5rem;padding:.1rem .5rem;border-radius:999px;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;vertical-align:middle}.status-pill.active{background:#00e5cc1f;border:1px solid rgba(0,229,204,.35);color:var(--teal)}.status-pill.inactive{background:#ff54701a;border:1px solid rgba(255,84,112,.3);color:var(--danger)}.data-table-wrap{overflow-x:auto;margin-top:.4rem}.data-table{width:100%;border-collapse:collapse;font-size:.84rem}.data-table th{text-align:left;padding:.6rem .9rem;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:.75rem .9rem;border-bottom:1px solid var(--border);color:var(--text2);white-space:nowrap}.data-table tbody tr:hover{background:var(--bg)}.data-table tbody tr:last-child td{border-bottom:none}.data-table .mono{font-family:var(--font-mono);color:var(--text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:#05080cb3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:modal-fade .18s ease-out}.modal-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;text-align:center;box-shadow:0 24px 60px #00000080;animation:modal-pop .2s ease-out}.modal-icon{width:54px;height:54px;margin:0 auto 1.1rem;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:1.4rem}.modal-icon.danger{background:#ff54701f;color:var(--danger)}.modal-icon.primary{background:#00e5cc1f;color:var(--teal)}.modal-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin-bottom:.5rem}.modal-message{font-size:.88rem;color:var(--text2);line-height:1.5;margin-bottom:1.6rem}.modal-actions{display:flex;gap:.8rem;justify-content:center}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}@keyframes modal-pop{0%{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:none}}.toggle-row{flex-direction:row!important;align-items:center;justify-content:space-between;gap:.8rem;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:.85rem 1rem}.switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0;cursor:pointer}.switch input{position:absolute;opacity:0;width:0;height:0;margin:0;padding:0;border:0}.switch .slider{position:absolute;top:0;right:0;bottom:0;left:0;cursor:pointer;background:var(--border);border-radius:999px;transition:background .25s}.switch .slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:var(--text2);border-radius:50%;transition:transform .25s,background .25s}.switch input:checked+.slider{background:var(--teal)}.switch input:checked+.slider:before{transform:translate(20px);background:var(--bg)}.switch input:focus-visible+.slider{box-shadow:0 0 0 2px #00e5cc66}.manage-split{display:grid;grid-template-columns:minmax(300px,380px) 1fr;gap:1.5rem;align-items:start}.manage-split .card{margin-bottom:0}.manage-list-pane{position:sticky;top:2rem;max-height:calc(100vh - 4rem);overflow-y:auto}.manage-list-head{justify-content:space-between}.manage-list-head span{display:flex;align-items:center;gap:.6rem}.admin-row.selectable .admin-row-main{cursor:pointer}.admin-row.selected{border-color:var(--teal);box-shadow:0 0 0 1px var(--teal) inset}@media(max-width:900px){.manage-split{grid-template-columns:1fr}.manage-list-pane{position:static;max-height:none}}.alert{padding:.8rem 1rem;border-radius:8px;font-size:.82rem;margin-bottom:1.2rem;font-family:var(--font-mono)}.alert-success{background:#2ee6a61a;border:1px solid rgba(46,230,166,.3);color:var(--success)}.alert-error{background:#ff54701a;border:1px solid rgba(255,84,112,.3);color:var(--danger)}.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1.2rem}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.6rem;text-decoration:none;color:inherit;transition:all .3s;display:flex;flex-direction:column;gap:.8rem}.dash-card:hover{border-color:#00e5cc40;transform:translateY(-4px);box-shadow:var(--glow-teal)}.dash-card i{font-size:1.4rem;color:var(--teal)}.dash-card-title{font-family:var(--font-display);font-weight:700}.dash-card-desc{font-size:.8rem;color:var(--text2)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;z-index:2}.login-logo{font-family:var(--font-display);font-weight:800;font-size:1.6rem;text-align:center;margin-bottom:.3rem}.login-logo span{color:var(--teal)}.login-sub{text-align:center;font-family:var(--font-mono);font-size:.7rem;color:var(--text3);letter-spacing:.15em;text-transform:uppercase;margin-bottom:2rem}.login-back{display:block;text-align:center;margin-top:1.5rem;font-family:var(--font-mono);font-size:.72rem;color:var(--text2);text-decoration:none}.login-back:hover{color:var(--teal)}@media(max-width:1024px){.projects-grid{grid-template-columns:repeat(2,1fr)}.project-card.featured{grid-column:span 2}.about-grid{gap:3rem}.form-grid{grid-template-columns:1fr}}@media(max-width:768px){nav.site-nav{padding:1rem 1.5rem}nav.site-nav.scrolled{padding:.8rem 1.5rem}.nav-links,.nav-cta{display:none}.hamburger{display:flex}#hero{padding:0 1.5rem;min-height:100dvh}.hero-socials{display:none}section{padding:4rem 1.5rem}.page-section{padding-top:7rem}.stats-band{grid-template-columns:repeat(2,1fr);padding:2rem 1.5rem}.stat-item:nth-child(2){border-right:none}.about-grid{grid-template-columns:1fr;gap:2.5rem}.projects-grid{grid-template-columns:1fr}.project-card.featured{grid-column:span 1}.skills-layout{grid-template-columns:1fr;gap:2.5rem}.tech-grid{grid-template-columns:repeat(2,1fr)}.edu-grid{grid-template-columns:1fr}.edu-card.primary{grid-column:span 1}.cert-grid{grid-template-columns:1fr}.award-banner{flex-direction:column;text-align:center;padding:2rem}.award-rank{margin-left:0}footer.site-footer{flex-direction:column;gap:.5rem;text-align:center;padding:1.5rem}.admin-sidebar{display:none}.admin-sidebar.open{display:flex;position:fixed;z-index:1100;width:260px}.admin-main{padding:1.5rem}.admin-mobile-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.admin-mobile-bar button{background:none;border:1px solid var(--border);color:var(--text);border-radius:8px;padding:.5rem .8rem;cursor:pointer}}
