:root{--bg: #0d0c0a;--bg-elev: #14120f;--surface: #1a1814;--surface-2: #211e19;--border: oklch(.28 .006 70);--border-strong: oklch(.38 .008 70);--text: oklch(.94 .008 75);--text-dim: oklch(.7 .01 70);--text-mute: oklch(.52 .012 70);--accent-h: 60;--accent: oklch(.74 .15 var(--accent-h));--accent-soft: oklch(.74 .15 var(--accent-h) / .14);--accent-line: oklch(.74 .15 var(--accent-h) / .35);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", ui-monospace, "SF Mono", Menlo, monospace;--font-display: "Inter", sans-serif;--density: 1;--max-w: 1180px;--radius: 14px;--radius-sm: 8px}[data-theme=light]{--bg: #f5f2ec;--bg-elev: #fbf9f4;--surface: #ffffff;--surface-2: #f0ece3;--border: oklch(.85 .008 75);--border-strong: oklch(.72 .01 75);--text: oklch(.22 .008 75);--text-dim: oklch(.42 .01 70);--text-mute: oklch(.55 .012 70);--accent: oklch(.58 .13 var(--accent-h));--accent-soft: oklch(.58 .13 var(--accent-h) / .12);--accent-line: oklch(.58 .13 var(--accent-h) / .4)}*{box-sizing:border-box}html,body{margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.5;transition:background-color .4s ease,color .4s ease;overflow-x:hidden;min-width:320px}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.035;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}img{display:block;max-width:100%}.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}section{position:relative;padding:calc(120px * var(--density)) 0;scroll-margin-top:80px}.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:color-mix(in oklch,var(--bg) 78%,transparent);border-bottom:1px solid transparent;transition:border-color .3s ease,padding .3s ease}.nav.scrolled{padding:12px 0;border-bottom-color:var(--border)}.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-mono);font-size:14px;font-weight:600;letter-spacing:-.01em}.brand-mark{width:32px;height:32px;border-radius:9px;background:var(--accent);color:var(--bg);display:grid;place-items:center;font-family:var(--font-mono);font-weight:700;font-size:14px;position:relative;overflow:hidden}.brand-mark:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,.18) 50%,transparent 70%)}.brand-name{color:var(--text)}.brand-dot{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:2px}.nav-link{padding:7px 10px;font-size:12.5px;font-family:var(--font-mono);color:var(--text-dim);border-radius:8px;transition:color .2s ease,background .2s ease;position:relative;white-space:nowrap}.nav-link:hover,.nav-link.active{color:var(--text)}.nav-link.active:before{content:"▸";color:var(--accent);margin-right:4px}.nav-num{color:var(--text-mute);font-size:10.5px;margin-right:6px;letter-spacing:.02em}.nav-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;color:var(--text-dim);border:1px solid var(--border);background:var(--surface);transition:all .2s ease}.icon-btn:hover{color:var(--text);border-color:var(--border-strong)}.lang-btn{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.04em;padding:0 12px;width:auto;height:36px;gap:4px;display:inline-flex;align-items:center}.lang-btn .lang-active{color:var(--accent)}.lang-sep{opacity:.4}.hero{min-height:100vh;display:flex;align-items:center;position:relative;padding-top:120px}.hero-grid{display:grid;grid-template-columns:1fr 320px;gap:80px;align-items:center}.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:12px;color:var(--text-dim);padding:6px 12px;border:1px solid var(--border);border-radius:99px;background:var(--surface);margin-bottom:28px}.status-dot{width:7px;height:7px;border-radius:50%;background:#5bbe62;box-shadow:0 0 #5bbe6299;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #5bbe6299}50%{box-shadow:0 0 0 7px #5bbe6200}}.hero h1{font-family:var(--font-display);font-size:clamp(40px,6.2vw,84px);font-weight:600;letter-spacing:-.035em;line-height:1.02;margin:0 0 24px}.hero h1 .accent{color:var(--accent);font-style:italic;font-weight:500}.typewriter-line{font-family:var(--font-mono);font-size:clamp(16px,1.8vw,22px);color:var(--text-dim);margin-bottom:36px;min-height:1.5em;display:flex;align-items:center;gap:12px}.typewriter-prompt{color:var(--accent)}.typewriter-text{color:var(--text)}.cursor{display:inline-block;width:2px;background:var(--accent);height:1em;margin-left:-12px;animation:blink 1s steps(2) infinite;vertical-align:text-bottom}@keyframes blink{0%,50%{opacity:1}50.01%,to{opacity:0}}.hero-desc{font-size:17px;color:var(--text-dim);max-width:580px;margin-bottom:40px;line-height:1.6}.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:56px}.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;border-radius:10px;font-family:var(--font-mono);font-size:13px;font-weight:600;letter-spacing:.01em;transition:all .2s ease;border:1px solid transparent}.btn-primary{background:var(--accent);color:var(--bg)}.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.08)}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.btn-secondary:hover{border-color:var(--border-strong);background:var(--surface-2)}.btn-ghost{color:var(--text-dim);padding:13px 14px}.btn-ghost:hover{color:var(--text)}.hero-meta{display:flex;gap:32px;flex-wrap:wrap;font-family:var(--font-mono);font-size:12px;color:var(--text-mute)}.hero-meta-item{display:flex;align-items:center;gap:8px}.hero-meta-item svg{color:var(--accent)}.hero-card{position:relative;border:1px solid var(--border);border-radius:18px;background:var(--surface);padding:0;overflow:hidden;aspect-ratio:.85}.hero-card-window{height:38px;background:var(--surface-2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 14px;gap:8px}.window-dot{width:10px;height:10px;border-radius:50%;background:var(--border-strong)}.window-title{font-family:var(--font-mono);font-size:11px;color:var(--text-mute);margin-left:12px}.hero-card-body{padding:24px;font-family:var(--font-mono);font-size:12.5px;line-height:1.8;color:var(--text-dim)}.code-line{display:block}.code-comment{color:var(--text-mute)}.code-kw{color:#f07f77}.code-fn{color:var(--accent)}.code-str{color:#7acf7e}.code-prop{color:#55aee8}.code-indent{padding-left:16px}.section-head{display:flex;align-items:baseline;gap:20px;margin-bottom:60px}.section-num{font-family:var(--font-mono);font-size:13px;color:var(--accent);letter-spacing:.04em}.section-head h2{font-family:var(--font-display);font-size:clamp(32px,4vw,48px);font-weight:600;letter-spacing:-.03em;margin:0;line-height:1}.section-rule{flex:1;height:1px;background:var(--border);transform:translateY(-8px)}.about-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:80px;align-items:start}.about-text p{font-size:17px;color:var(--text-dim);line-height:1.7;margin:0 0 20px}.about-text strong{color:var(--text);font-weight:600}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.stat{padding:28px 24px;background:var(--surface)}.stat-value{font-family:var(--font-display);font-size:44px;font-weight:600;letter-spacing:-.03em;color:var(--text);display:flex;align-items:baseline;gap:4px}.stat-value .plus{color:var(--accent);font-weight:500}.stat-label{font-family:var(--font-mono);font-size:11px;color:var(--text-mute);margin-top:6px;letter-spacing:.04em;text-transform:uppercase}.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.skill-cat{border:1px solid var(--border);border-radius:var(--radius);padding:24px 24px 20px;background:var(--surface);transition:border-color .25s ease}.skill-cat:hover{border-color:var(--border-strong)}.skill-cat-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.skill-cat-name{font-family:var(--font-mono);font-size:12px;color:var(--accent);letter-spacing:.06em;text-transform:uppercase}.skill-cat-count{font-family:var(--font-mono);font-size:11px;color:var(--text-mute)}.skill-list{display:flex;flex-direction:column;gap:12px}.skill-row{display:flex;flex-direction:column;gap:6px}.skill-row-top{display:flex;justify-content:space-between;align-items:baseline;font-size:13.5px}.skill-name{color:var(--text)}.skill-level{font-family:var(--font-mono);font-size:11px;color:var(--text-mute)}.skill-bar{height:3px;background:var(--surface-2);border-radius:2px;overflow:hidden;position:relative}.skill-bar-fill{height:100%;width:0;background:var(--accent);border-radius:2px;transition:width 1s cubic-bezier(.22,1,.36,1)}.timeline{position:relative;padding-left:32px}.timeline:before{content:"";position:absolute;left:8px;top:8px;bottom:8px;width:1px;background:var(--border)}.timeline-item{position:relative;padding-bottom:48px}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:-32px;top:6px;width:17px;height:17px;border-radius:50%;background:var(--bg);border:2px solid var(--accent);display:grid;place-items:center}.timeline-dot:after{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent)}.timeline-dot.current:before{content:"";position:absolute;inset:-6px;border-radius:50%;border:1px solid var(--accent-line);animation:ringPulse 2.4s ease-out infinite}@keyframes ringPulse{0%{transform:scale(.8);opacity:1}to{transform:scale(1.8);opacity:0}}.exp-card{border:1px solid var(--border);border-radius:var(--radius);padding:28px;background:var(--surface)}.exp-logo,.edu-logo{width:44px;height:44px;border-radius:10px;object-fit:cover;border:1px solid var(--border);background:var(--surface-2);flex-shrink:0}.edu-logo{width:40px;height:40px;border-radius:8px;margin-bottom:14px;display:block}.exp-head-left{display:flex;align-items:center;gap:14px}.projects-state{text-align:center;padding:64px 0;color:var(--text-mute);font-family:var(--font-mono);font-size:13px}.exp-head{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:14px;flex-wrap:wrap}.exp-company{font-family:var(--font-display);font-size:22px;font-weight:600;letter-spacing:-.02em}.exp-position{color:var(--text-dim);font-size:15px;margin-top:2px}.exp-meta{font-family:var(--font-mono);font-size:12px;color:var(--text-mute);text-align:right;white-space:nowrap}.exp-meta .duration{display:inline-block;padding:3px 8px;background:var(--accent-soft);color:var(--accent);border-radius:6px;margin-top:6px}.exp-desc{font-size:15px;color:var(--text-dim);line-height:1.65;white-space:pre-line;margin:12px 0 18px}.tech-tags{display:flex;flex-wrap:wrap;gap:6px}.tech-tag{font-family:var(--font-mono);font-size:11px;padding:5px 10px;border-radius:6px;background:var(--surface-2);color:var(--text-dim);border:1px solid var(--border)}.edu-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.edu-card{border:1px solid var(--border);border-radius:var(--radius);padding:24px;background:var(--surface);position:relative;display:flex;flex-direction:column;transition:border-color .25s ease}.edu-card:hover{border-color:var(--border-strong)}.edu-card.in-progress{border-color:var(--accent-line)}.edu-status{position:absolute;top:20px;right:20px;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:4px 8px;border-radius:5px;background:var(--accent-soft);color:var(--accent)}.edu-status.done{background:var(--surface-2);color:var(--text-mute)}.edu-degree{font-family:var(--font-mono);font-size:11px;color:var(--text-mute);letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px}.edu-institution{font-size:18px;font-weight:600;letter-spacing:-.01em;line-height:1.3;margin-bottom:6px}.edu-field{color:var(--accent);font-size:14px;margin-bottom:14px}.edu-desc{font-size:13.5px;color:var(--text-dim);line-height:1.55;margin-bottom:16px}.edu-meta{font-family:var(--font-mono);font-size:11px;color:var(--text-mute);margin-top:auto;display:flex;justify-content:space-between;padding-top:14px;border-top:1px solid var(--border)}.projects-lead{color:var(--text-dim);max-width:620px;margin-top:-36px;margin-bottom:32px}.projects-controls{display:flex;align-items:center;gap:8px;margin-bottom:32px;flex-wrap:wrap}.filter-chip{font-family:var(--font-mono);font-size:12px;padding:7px 14px;border-radius:99px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);transition:all .2s ease}.filter-chip:hover{color:var(--text);border-color:var(--border-strong)}.filter-chip.active{background:var(--text);color:var(--bg);border-color:var(--text)}.filter-chip-count{margin-left:6px;opacity:.6}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.project-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden;display:flex;flex-direction:column;transition:all .3s cubic-bezier(.22,1,.36,1)}.project-card:hover{border-color:var(--border-strong);transform:translateY(-3px)}.project-cover{height:160px;position:relative;background:repeating-linear-gradient(45deg,var(--surface-2) 0,var(--surface-2) 8px,var(--surface) 8px,var(--surface) 16px);border-bottom:1px solid var(--border);display:grid;place-items:center;overflow:hidden}.project-cover-label{font-family:var(--font-mono);font-size:11px;color:var(--text-mute);letter-spacing:.06em;text-transform:uppercase;padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:6px}.project-cover .lang-badge{position:absolute;top:12px;left:12px;font-family:var(--font-mono);font-size:10px;padding:4px 8px;border-radius:5px;background:var(--accent);color:var(--bg);font-weight:600;letter-spacing:.04em}.project-body{padding:22px;flex:1;display:flex;flex-direction:column}.project-name{font-size:18px;font-weight:600;letter-spacing:-.01em;margin-bottom:8px}.project-name-prefix{color:var(--text-mute);font-family:var(--font-mono);font-weight:400}.project-desc{font-size:14px;color:var(--text-dim);line-height:1.55;flex:1;margin-bottom:16px}.project-stats{display:flex;gap:14px;font-family:var(--font-mono);font-size:11px;color:var(--text-mute);margin-bottom:14px;padding-top:14px;border-top:1px solid var(--border)}.project-stat{display:inline-flex;align-items:center;gap:5px}.project-stat.explore{margin-left:auto;color:var(--accent)}.project-tags{display:flex;flex-wrap:wrap;gap:6px}.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:start}.contact-intro h2{font-family:var(--font-display);font-size:clamp(36px,4.5vw,56px);font-weight:600;letter-spacing:-.035em;line-height:1.05;margin:0 0 20px}.contact-intro h2 .accent{color:var(--accent);font-style:italic;font-weight:500}.contact-intro p{font-size:16px;color:var(--text-dim);line-height:1.65;margin:0 0 32px}.contact-channels{display:flex;flex-direction:column;gap:12px}.contact-channel{display:flex;align-items:center;gap:14px;padding:16px 18px;border:1px solid var(--border);border-radius:10px;background:var(--surface);transition:all .2s ease}.contact-channel:hover{border-color:var(--accent-line);background:var(--surface-2)}.contact-channel-icon{width:38px;height:38px;display:grid;place-items:center;border-radius:8px;background:var(--accent-soft);color:var(--accent);flex-shrink:0}.contact-channel-arrow{margin-left:auto;color:var(--text-mute)}.contact-channel-meta{font-family:var(--font-mono);font-size:11px;color:var(--text-mute);letter-spacing:.04em;text-transform:uppercase;margin-bottom:2px}.contact-channel-value{font-size:14.5px;color:var(--text)}.contact-form{border:1px solid var(--border);border-radius:var(--radius);padding:28px;background:var(--surface)}.form-row{margin-bottom:18px}.form-row.split{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-label{display:block;font-family:var(--font-mono);font-size:11px;color:var(--text-mute);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}.form-label .req{color:var(--accent)}.form-input,.form-textarea{width:100%;padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font:inherit;font-size:14px;transition:border-color .2s ease;font-family:var(--font-sans)}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--accent)}.form-textarea{min-height:130px;resize:vertical;font-family:var(--font-sans)}.form-error{display:block;font-family:var(--font-mono);font-size:11px;color:#e85854;margin-top:6px}.form-input.error,.form-textarea.error{border-color:#e85854}.form-actions{display:flex;justify-content:space-between;align-items:center;margin-top:24px}.form-status{font-family:var(--font-mono);font-size:12px;color:var(--accent)}.footer{padding:60px 0 40px;border-top:1px solid var(--border);position:relative}.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}.footer-meta{font-family:var(--font-mono);font-size:12px;color:var(--text-mute)}.footer-links{display:flex;gap:18px;font-family:var(--font-mono);font-size:12px}.footer-links a{color:var(--text-dim);transition:color .2s ease}.footer-links a:hover{color:var(--accent)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}::selection{background:var(--accent);color:var(--bg)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}@media(max-width:980px){.hero-grid,.about-grid,.contact-grid{grid-template-columns:1fr;gap:48px}.skills-grid,.edu-grid,.projects-grid{grid-template-columns:1fr}.nav-links{display:none}section{padding:80px 0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
