@font-face{font-family:Syne;font-style:normal;font-weight:400;font-display:swap;src:url(../media/ab624315db63c58d-s.028be875.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Syne;font-style:normal;font-weight:400;font-display:swap;src:url(../media/e94b8ab81811a983-s.399ca42d.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Syne;font-style:normal;font-weight:400;font-display:swap;src:url(../media/0c795a286deabae8-s.p.b6c48e4e.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Syne;font-style:normal;font-weight:500;font-display:swap;src:url(../media/ab624315db63c58d-s.028be875.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Syne;font-style:normal;font-weight:500;font-display:swap;src:url(../media/e94b8ab81811a983-s.399ca42d.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Syne;font-style:normal;font-weight:500;font-display:swap;src:url(../media/0c795a286deabae8-s.p.b6c48e4e.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Syne;font-style:normal;font-weight:600;font-display:swap;src:url(../media/ab624315db63c58d-s.028be875.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Syne;font-style:normal;font-weight:600;font-display:swap;src:url(../media/e94b8ab81811a983-s.399ca42d.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Syne;font-style:normal;font-weight:600;font-display:swap;src:url(../media/0c795a286deabae8-s.p.b6c48e4e.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Syne;font-style:normal;font-weight:700;font-display:swap;src:url(../media/ab624315db63c58d-s.028be875.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Syne;font-style:normal;font-weight:700;font-display:swap;src:url(../media/e94b8ab81811a983-s.399ca42d.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Syne;font-style:normal;font-weight:700;font-display:swap;src:url(../media/0c795a286deabae8-s.p.b6c48e4e.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Syne;font-style:normal;font-weight:800;font-display:swap;src:url(../media/ab624315db63c58d-s.028be875.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Syne;font-style:normal;font-weight:800;font-display:swap;src:url(../media/e94b8ab81811a983-s.399ca42d.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Syne;font-style:normal;font-weight:800;font-display:swap;src:url(../media/0c795a286deabae8-s.p.b6c48e4e.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Syne Fallback;src:local(Arial);ascent-override:93.93%;descent-override:27.93%;line-gap-override:0.0%;size-adjust:98.47%}.syne_8147846f-module__Hjpmoq__className{font-family:Syne,Syne Fallback;font-style:normal}.syne_8147846f-module__Hjpmoq__variable{--font-syne:"Syne","Syne Fallback"}
@font-face{font-family:Figtree;font-style:normal;font-weight:300;font-display:swap;src:url(../media/400bf8aa837fcb7e-s.b68677ba.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Figtree;font-style:normal;font-weight:300;font-display:swap;src:url(../media/f7aa21714c1c53f8-s.p.e3544bb0.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Figtree;font-style:normal;font-weight:400;font-display:swap;src:url(../media/400bf8aa837fcb7e-s.b68677ba.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Figtree;font-style:normal;font-weight:400;font-display:swap;src:url(../media/f7aa21714c1c53f8-s.p.e3544bb0.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Figtree;font-style:normal;font-weight:500;font-display:swap;src:url(../media/400bf8aa837fcb7e-s.b68677ba.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Figtree;font-style:normal;font-weight:500;font-display:swap;src:url(../media/f7aa21714c1c53f8-s.p.e3544bb0.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Figtree;font-style:normal;font-weight:600;font-display:swap;src:url(../media/400bf8aa837fcb7e-s.b68677ba.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Figtree;font-style:normal;font-weight:600;font-display:swap;src:url(../media/f7aa21714c1c53f8-s.p.e3544bb0.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Figtree;font-style:normal;font-weight:700;font-display:swap;src:url(../media/400bf8aa837fcb7e-s.b68677ba.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Figtree;font-style:normal;font-weight:700;font-display:swap;src:url(../media/f7aa21714c1c53f8-s.p.e3544bb0.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Figtree Fallback;src:local(Arial);ascent-override:94.32%;descent-override:24.82%;line-gap-override:0.0%;size-adjust:100.72%}.figtree_7570654-module__oJj9bq__className{font-family:Figtree,Figtree Fallback;font-style:normal}.figtree_7570654-module__oJj9bq__variable{--font-figtree:"Figtree","Figtree Fallback"}
:root{--bg:#0c0c0f;--bg-2:#131318;--bg-3:#1c1c24;--surface:#1e1e28;--surface-2:#26262f;--border:#ffffff12;--text:#e8e8f0;--text-muted:#8888a0;--text-dim:#55556a;--accent:#f5a623;--accent-dim:#f5a62320;--accent-2:#e07b00;--white:#fff;--section-pad:clamp(5rem,10vw,8rem);--container:1200px;--gap:1.5rem;--font-display:var(--font-syne),sans-serif;--font-body:var(--font-figtree),sans-serif;--r-sm:6px;--r-md:12px;--r-lg:20px;--shadow-sm:0 2px 12px #00000059;--shadow-md:0 8px 32px #00000080;--shadow-lg:0 20px 60px #0009;--glow:0 0 40px #f5a6232e;--t:.3s ease;--t-fast:.15s ease;--nav-h:70px}[data-theme=light]{--bg:#f4f3f0;--bg-2:#eeede9;--bg-3:#e5e4df;--surface:#fff;--surface-2:#f0efe9;--border:#00000014;--text:#1a1a26;--text-muted:#5a5a72;--text-dim:#99a;--accent:#d4820a;--accent-dim:#d4820a20;--accent-2:#b86e08;--shadow-sm:0 2px 12px #00000014;--shadow-md:0 8px 32px #0000001f;--shadow-lg:0 20px 60px #00000026;--glow:0 0 40px #d4820a1f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h);font-size:16px}body{font-family:var(--font-body);background-color:var(--bg);color:var(--text);line-height:1.7;transition:background-color .4s,color .4s;overflow-x:hidden}img,svg{max-width:100%;display:block}a{color:inherit;transition:color var(--t);text-decoration:none}ul{list-style:none}button{cursor:pointer;font:inherit;background:0 0;border:none}input,textarea{font-family:var(--font-body);font-size:1rem}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent-2)}::selection{background:var(--accent);color:#000}.container{max-width:var(--container);margin:0 auto;padding:0 clamp(1.25rem,4vw,2.5rem)}.section{padding:var(--section-pad)0}.section-header{margin-bottom:3.5rem}.section-tag{font-family:var(--font-display);letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;font-size:.75rem;font-weight:600;display:inline-block}.section-title{font-family:var(--font-display);color:var(--text);font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.1}.btn{border-radius:var(--r-sm);font-family:var(--font-display);letter-spacing:.03em;cursor:pointer;transition:transform var(--t-fast),box-shadow var(--t),background var(--t),color var(--t),border-color var(--t);align-items:center;gap:.5rem;padding:.75rem 1.75rem;font-size:.875rem;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";opacity:0;transition:opacity var(--t-fast);background:#ffffff14;position:absolute;inset:0}.btn:hover:after{opacity:1}.btn:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn-primary{background:var(--accent);color:#000;box-shadow:0 4px 20px #f5a6234d}.btn-primary:hover{box-shadow:0 8px 32px #f5a62380}.btn-ghost{color:var(--text);border:1.5px solid var(--border);background:0 0}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.btn-sm{padding:.55rem 1.25rem;font-size:.8rem}.btn-full{justify-content:center;width:100%}.navbar{z-index:1000;height:var(--nav-h);transition:background var(--t),box-shadow var(--t),backdrop-filter var(--t);background:0 0;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.navbar.scrolled{-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--border);background:#0c0c0fd9}[data-theme=light] .navbar.scrolled{background:#f4f3f0e0}.nav-container{max-width:var(--container);justify-content:space-between;align-items:center;gap:2rem;width:100%;margin:0 auto;padding:0 clamp(1.25rem,4vw,2.5rem);display:flex}.nav-logo{font-family:var(--font-display);color:var(--text);letter-spacing:-.03em;font-size:1.5rem;font-weight:800}.nav-logo .dot{color:var(--accent)}.nav-links{align-items:center;gap:.25rem;display:flex}.nav-link{font-family:var(--font-display);color:var(--text-muted);border-radius:var(--r-sm);transition:color var(--t),background var(--t);padding:.5rem .875rem;font-size:.875rem;font-weight:600;position:relative}.nav-link:hover,.nav-link.active{color:var(--text);background:var(--accent-dim)}.nav-link.active{color:var(--accent)}.nav-actions{align-items:center;gap:.75rem;display:flex}.theme-toggle{border-radius:var(--r-sm);background:var(--surface);width:38px;height:38px;color:var(--text-muted);border:1px solid var(--border);transition:color var(--t),background var(--t),border-color var(--t);justify-content:center;align-items:center;display:flex}.theme-toggle:hover{color:var(--accent);border-color:var(--accent)}.theme-icon{align-items:center;display:flex}[data-theme=dark] .icon-sun{display:block}[data-theme=dark] .icon-moon,[data-theme=light] .icon-sun{display:none}[data-theme=light] .icon-moon{display:block}.hamburger{border-radius:var(--r-sm);background:var(--surface);border:1px solid var(--border);flex-direction:column;justify-content:center;gap:5px;width:38px;height:38px;padding:8px;display:none}.bar{background:var(--text);border-radius:2px;width:100%;height:2px;transition:transform .3s,opacity .3s;display:block}.hamburger.open .bar:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.open .bar:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.open .bar:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.hero{min-height:100vh;padding:calc(var(--nav-h) + 2rem)0 4rem;align-items:center;display:flex;position:relative;overflow:hidden}.hero-bg-grid{background-image:linear-gradient(var(--border)1px,transparent 1px),linear-gradient(90deg,var(--border)1px,transparent 1px);pointer-events:none;background-size:60px 60px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 80%,#000 30%,#0000 100%);mask-image:radial-gradient(80% 80%,#000 30%,#0000 100%)}.hero>.container,.hero{align-items:center;display:flex}.hero{grid-template-columns:1fr;gap:2rem;padding-left:clamp(1.25rem,8vw,10rem);padding-right:clamp(1.25rem,4vw,2.5rem);display:grid}.hero-content{z-index:1;max-width:640px;position:relative}.hero-eyebrow{font-family:var(--font-display);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;font-size:.875rem;font-weight:600}.hero-name{font-family:var(--font-display);letter-spacing:-.04em;color:var(--text);margin-bottom:1.25rem;font-size:clamp(56px,9vw,92px);font-weight:800;line-height:.95}.hero-name .accent{color:var(--accent)}.hero-role{font-family:var(--font-display);color:var(--text-muted);align-items:center;gap:2px;min-height:2em;margin-bottom:1.5rem;font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:600;display:flex}.cursor-blink{color:var(--accent);font-weight:300;animation:1s step-end infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-intro{color:var(--text-muted);max-width:480px;margin-bottom:2rem;font-size:1.125rem;font-weight:300}.hero-cta{flex-wrap:wrap;gap:1rem;margin-bottom:3rem;display:flex}.hero-scroll-hint{color:var(--text-dim);font-size:.75rem;font-family:var(--font-display);letter-spacing:.12em;text-transform:uppercase;align-items:center;gap:.75rem;display:flex}.scroll-line{background:var(--text-dim);width:40px;height:1px}.hero-visual{z-index:1;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;right:clamp(1.25rem,6vw,5rem);transform:translateY(-50%)}.hero-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg),var(--glow);min-width:300px;padding:1.75rem;animation:6s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.code-block{color:var(--text-muted);font-family:Courier New,monospace;font-size:.85rem;line-height:1.8}.code-block .indent{padding-left:1.25rem}.code-block .kw{color:#c792ea}.code-block .key{color:#82aaff}.code-block .str{color:#c3e88d}.code-block .bool{color:var(--accent)}.about{background:var(--bg-2)}.about-grid{grid-template-columns:340px 1fr;align-items:center;gap:4rem;display:grid}.about-image-wrap{justify-content:center;display:flex}.about-image-frame{display:inline-block;position:relative}.about-image-placeholder{border-radius:var(--r-lg);background:linear-gradient(135deg,var(--surface)0%,var(--surface-2)100%);border:1px solid var(--border);width:300px;height:420px;box-shadow:var(--shadow-lg);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.about-image{object-fit:cover;border-radius:var(--r-lg);width:100%;height:100%;display:block}.about-image-placeholder:before{content:"";background:radial-gradient(circle at 60% 30%,var(--accent-dim),transparent 70%);position:absolute;inset:0}.initials{font-family:var(--font-display);color:var(--accent);opacity:.6;z-index:1;font-size:4rem;font-weight:800;position:relative}.about-badge{background:var(--accent);color:#000;font-family:var(--font-display);border-radius:var(--r-sm);box-shadow:var(--shadow-sm);white-space:nowrap;z-index:5;padding:.5rem 1rem;font-size:.75rem;font-weight:700;position:absolute;bottom:-1rem;right:-1rem}.about-image-placeholder{position:relative}.anime-img,.real-img{transition:opacity .4s;position:absolute;top:0;left:0}.anime-img{opacity:1;z-index:1}.real-img{opacity:0;z-index:2}.about-image-placeholder:hover .anime-img{opacity:0}.about-image-placeholder:hover .real-img{opacity:1}.about-text{flex-direction:column;gap:1.25rem;display:flex}.about-intro{color:var(--text);font-size:1.125rem}.about-text p{color:var(--text-muted)}.about-stats{border-top:1px solid var(--border);border-bottom:1px solid var(--border);gap:2.5rem;padding:1.5rem 0;display:flex}.stat{flex-direction:column;display:flex}.stat-num{font-family:var(--font-display);color:var(--accent);font-size:2rem;font-weight:800;line-height:1}.stat-label{color:var(--text-muted);margin-top:.25rem;font-size:.8rem;font-weight:500}.skills{background:var(--bg)}.skills-grid{grid-template-columns:1.2fr 1fr;align-items:start;gap:3rem;display:grid}.skills-subtitle{font-family:var(--font-display);color:var(--text);align-items:center;gap:.5rem;margin-bottom:1.75rem;font-size:1rem;font-weight:700;display:flex}.skills-subtitle:after{content:"";background:var(--border);flex:1;height:1px;margin-left:.5rem}.skills-bars{flex-direction:column;gap:1.5rem;display:flex}.skill-item{flex-direction:column;gap:.5rem;display:flex}.skill-meta{justify-content:space-between;align-items:center;display:flex}.skill-name{font-family:var(--font-display);color:var(--text);font-size:.875rem;font-weight:600}.skill-percent{color:var(--accent);font-size:.8rem;font-weight:600}.progress-track{background:var(--surface-2);border-radius:3px;height:6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,var(--accent-2),var(--accent));border-radius:3px;width:0%;height:100%;transition:width 1.2s cubic-bezier(.16,1,.3,1)}.tech-grid{grid-template-columns:repeat(4,1fr);gap:.75rem;display:grid}.tech-stack-wrap{flex-direction:column;display:flex}.tech-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-muted);font-size:.75rem;font-weight:600;font-family:var(--font-display);transition:border-color var(--t),color var(--t),transform var(--t-fast),box-shadow var(--t);cursor:default;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .75rem;display:flex}.tech-card:hover{border-color:var(--accent);color:var(--text);box-shadow:var(--shadow-sm),var(--glow);transform:translateY(-3px)}.tech-icon{font-size:1.5rem}.projects{background:var(--bg-2)}.projects-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);transition:transform var(--t),box-shadow var(--t),border-color var(--t);flex-direction:column;display:flex;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-lg),var(--glow);border-color:#f5a62340;transform:translateY(-6px)}.project-image{background:var(--bg-3);height:200px;position:relative;overflow:hidden}.project-img-inner{width:100%;height:100%;transition:transform var(--t);background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);justify-content:center;align-items:center;padding:1.25rem;display:flex}.project-img-2{background:linear-gradient(135deg,#0f2027 0%,#203a43 50%,#2c5364 100%)}.project-img-3{background:linear-gradient(135deg,#1a0533 0%,#2d1b69 50%,#11998e 100%)}.project-card:hover .project-img-inner{transform:scale(1.04)}.fake-browser{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;width:100%;max-width:280px;overflow:hidden}.fake-browser-bar{background:#0000004d;border-bottom:1px solid #ffffff14;align-items:center;gap:5px;padding:8px 10px;display:flex}.fake-browser-bar span{background:#fff3;border-radius:50%;width:8px;height:8px}.fake-browser-bar span:first-child{background:#ff5f57}.fake-browser-bar span:nth-child(2){background:#febc2e}.fake-browser-bar span:nth-child(3){background:#28c840}.fake-browser-content{flex-direction:column;gap:8px;padding:12px;display:flex}.fb-chart{clip-path:polygon(0% 80%,20% 40%,40% 60%,60% 20%,80% 45%,100% 15%,100% 100%,0% 100%);background:linear-gradient(90deg,#f5a62366 0%,#f5a62399 20%,#f5a6234d 40%,#f5a623b3 60%,#f5a62380 80%,#f5a623cc 100%);border-radius:4px;height:50px}.fb-row{align-items:center;gap:6px;display:flex}.fb-block{background:#ffffff26;border-radius:4px;height:8px}.fb-card{background:#ffffff1a;border-radius:4px;flex:1;height:40px}.fb-sidebar{background:#ffffff14;border-radius:4px;width:30%;height:60px}.fb-main{flex-direction:column;flex:1;gap:6px;display:flex}.w30{width:30%}.w35{width:35%}.w40{width:40%}.w50{width:50%}.w55{width:55%}.w60{width:60%}.w75{width:75%}.w80{width:80%}.w90{width:90%}.project-overlay{pointer-events:none;justify-content:flex-end;align-items:flex-end;padding:1rem;display:flex;position:absolute;inset:0}.project-num{font-family:var(--font-display);color:#ffffff0f;font-size:4rem;font-weight:800;line-height:1}.project-info{flex-direction:column;flex:1;gap:.75rem;padding:1.5rem;display:flex}.project-tags{flex-wrap:wrap;gap:.4rem;display:flex}.tag{font-size:.7rem;font-weight:600;font-family:var(--font-display);letter-spacing:.05em;text-transform:uppercase;background:var(--accent-dim);color:var(--accent);border-radius:var(--r-sm);border:1px solid #f5a62333;padding:.2rem .6rem}.project-title{font-family:var(--font-display);color:var(--text);font-size:1.2rem;font-weight:700}.project-desc{color:var(--text-muted);flex:1;font-size:.875rem;line-height:1.6}.project-links{flex-wrap:wrap;gap:.75rem;margin-top:.25rem;display:flex}.experience{background:var(--bg)}.timeline-wrap{grid-template-columns:1fr 1fr;gap:4rem;display:grid}.timeline-col-title{font-family:var(--font-display);color:var(--text);border-bottom:2px solid var(--accent);align-items:center;gap:.6rem;width:fit-content;margin-bottom:2.5rem;padding-bottom:1rem;font-size:1rem;font-weight:700;display:flex}.timeline-col{flex-direction:column;display:flex}.timeline-item{border-left:1px solid var(--border);padding-bottom:2.5rem;padding-left:2rem;position:relative}.timeline-item:last-child{border-left-color:#0000;padding-bottom:0}.timeline-dot{background:var(--accent);width:10px;height:10px;box-shadow:0 0 0 3px var(--accent-dim);transition:box-shadow var(--t);border-radius:50%;position:absolute;top:4px;left:-5px}.timeline-item:hover .timeline-dot{box-shadow:0 0 0 6px var(--accent-dim)}.timeline-content{flex-direction:column;gap:.4rem;display:flex}.timeline-date{color:var(--accent);font-size:.75rem;font-weight:600;font-family:var(--font-display);letter-spacing:.05em}.timeline-role{font-family:var(--font-display);color:var(--text);font-size:1.05rem;font-weight:700}.timeline-company{color:var(--text-muted);font-size:.825rem;font-weight:500}.timeline-desc{color:var(--text-muted);margin-top:.25rem;font-size:.875rem;line-height:1.65}.timeline-list{flex-direction:column;gap:.3rem;margin-top:.5rem;display:flex}.timeline-list li{color:var(--text-muted);padding-left:1rem;font-size:.825rem;position:relative}.timeline-list li:before{content:"→";color:var(--accent);font-size:.75rem;position:absolute;left:0}.contact{background:var(--bg-2)}.contact-wrap{grid-template-columns:1fr 1.4fr;align-items:start;gap:4rem;display:grid}.contact-intro{color:var(--text-muted);margin-bottom:2rem;font-size:1.05rem;line-height:1.75}.contact-details{flex-direction:column;gap:1rem;margin-bottom:2rem;display:flex}.contact-details li{color:var(--text-muted);align-items:center;gap:.75rem;font-size:.9rem;display:flex}.contact-details a{color:var(--accent)}.contact-details a:hover{text-decoration:underline}.contact-icon{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);width:36px;height:36px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.social-links{flex-wrap:wrap;gap:.75rem;display:flex}.social-link{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);font-size:.8rem;font-weight:600;font-family:var(--font-display);color:var(--text-muted);transition:color var(--t),border-color var(--t),transform var(--t-fast);align-items:center;gap:.5rem;padding:.6rem 1.1rem;display:inline-flex}.social-link:hover{color:var(--accent);border-color:var(--accent);transform:translateY(-2px)}.contact-form{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-md);flex-direction:column;gap:1.25rem;padding:2rem;display:flex}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-label{font-family:var(--font-display);letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);font-size:.8rem;font-weight:700}.required{color:var(--accent)}.form-input{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text);transition:border-color var(--t),box-shadow var(--t);outline:none;padding:.75rem 1rem;font-size:.9rem}.form-input::placeholder{color:var(--text-dim)}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-input.error{border-color:#ff4d6d}.form-input.success{border-color:#4ade80}.form-textarea{resize:vertical;min-height:130px}.form-error{color:#ff4d6d;min-height:1.2em;font-size:.78rem;font-weight:500}.form-success{border-radius:var(--r-sm);color:#4ade80;text-align:center;background:#4ade801a;border:1px solid #4ade804d;padding:1rem;font-size:.9rem;font-weight:600;display:none}.form-success.visible{display:block}.footer{background:var(--bg);border-top:1px solid var(--border);padding:2.5rem 0;position:relative}.footer-inner{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;display:flex}.footer-brand{flex-direction:column;align-items:center;gap:.4rem;display:flex}.footer-brand p{color:var(--text-muted);font-size:.875rem}.footer-nav{flex-wrap:wrap;justify-content:center;gap:1.5rem;display:flex}.footer-nav a{font-size:.8rem;font-weight:600;font-family:var(--font-display);color:var(--text-muted);transition:color var(--t)}.footer-nav a:hover{color:var(--accent)}.footer-copy{color:var(--text-dim);font-size:.8rem}.back-to-top{background:var(--accent);color:#000;width:44px;height:44px;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transition:opacity var(--t),visibility var(--t),transform var(--t);z-index:999;border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;bottom:2rem;right:2rem;transform:translateY(12px)}.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}.back-to-top:hover{background:var(--accent-2);transform:translateY(-3px)}.reveal{opacity:0;transition:opacity .75s,transform .75s;transform:translateY(28px)}.reveal.revealed{opacity:1;transform:translateY(0)}@media (max-width:1024px){.projects-grid{grid-template-columns:1fr 1fr}.hero-visual{display:none}.hero{padding-left:clamp(1.25rem,4vw,2.5rem)}.about-grid{grid-template-columns:280px 1fr;gap:2.5rem}.timeline-wrap{gap:2.5rem}}@media (max-width:768px){:root{--nav-h:64px}.hamburger{display:flex}.nav-links{top:var(--nav-h);background:var(--bg-2);border-bottom:1px solid var(--border);z-index:999;flex-direction:column;align-items:stretch;gap:0;max-height:0;padding:0 1rem;transition:max-height .4s,padding .4s;position:fixed;left:0;right:0;overflow:hidden}.nav-links.open{max-height:400px;padding:1rem}.nav-link{border-radius:var(--r-sm);padding:.85rem 1rem;font-size:1rem}.hero{padding-top:calc(var(--nav-h) + 2rem);place-items:center;min-height:100svh;padding-bottom:3rem;padding-left:1.25rem;padding-right:1.25rem}.hero-content{text-align:center;flex-direction:column;align-items:center;width:100%;max-width:100%;display:flex}.hero-eyebrow{text-align:center}.hero-name{word-break:break-word;text-align:center;font-size:clamp(2.6rem,12vw,5rem)}.hero-role{text-align:center;justify-content:center;min-height:1.8em;font-size:clamp(1rem,4.5vw,1.3rem)}.hero-intro{text-align:center;max-width:100%;font-size:1rem}.hero-cta{flex-direction:column;align-items:center;gap:.75rem;width:100%;margin-bottom:2rem}.hero-cta .btn{justify-content:center;width:100%;max-width:320px}.hero-scroll-hint{display:none}.about-grid{grid-template-columns:1fr}.about-image-wrap{display:none}.skills-grid{grid-template-columns:1fr}.tech-grid{grid-template-columns:repeat(4,1fr)}.projects-grid{grid-template-columns:1fr}.timeline-wrap,.contact-wrap{grid-template-columns:1fr;gap:2rem}.contact-form{padding:1.5rem}.back-to-top{bottom:1.25rem;right:1.25rem}}@media (max-width:480px){.hero{padding-left:1rem;padding-right:1rem}.hero-name{font-size:clamp(2.2rem,13vw,3.5rem)}.hero-eyebrow{font-size:.7rem}.hero-intro{font-size:.95rem}.hero-cta{gap:.6rem}.about-stats{gap:1.5rem}.tech-grid{grid-template-columns:repeat(3,1fr)}.project-links{flex-wrap:wrap}.project-links .btn{flex:1;justify-content:center}}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.1ms!important;animation-duration:.01ms!important}.reveal{opacity:1;transform:none}html{scroll-behavior:auto}}
