:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f7f5f0;--fg: #1a1a18;--muted: #8a8880;--accent: #c8693a;--accent-light: #f0e6df;--border: #e2ded8;--card: #ffffff;--nav-h: 64px}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--fg);font-family:DM Sans,sans-serif;font-weight:300;line-height:1.6;-webkit-font-smoothing:antialiased}nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 48px;background:#f7f5f0d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:100}.nav-logo{font-family:"DM Serif Display",serif;font-size:1.15rem;color:var(--fg);text-decoration:none;letter-spacing:-.01em}.nav-logo span{color:var(--accent)}.nav-links{display:flex;gap:32px;list-style:none}.nav-links a{font-family:DM Mono,monospace;font-size:.72rem;font-weight:400;color:var(--muted);text-decoration:none;letter-spacing:.08em;text-transform:uppercase;transition:color .2s}.nav-links a:hover{color:var(--accent)}section{padding:calc(var(--nav-h) + 80px) 48px 80px;max-width:1100px;margin:0 auto}.section-label{font-family:DM Mono,monospace;font-size:.68rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:24px}#home{display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding-top:var(--nav-h);position:relative;overflow:hidden}.hero-eyebrow{font-family:DM Mono,monospace;font-size:.72rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;opacity:0;animation:fadeUp .6s ease forwards .1s}.hero-name{font-family:"DM Serif Display",serif;font-size:clamp(2.8rem,6vw,5.2rem);line-height:1;letter-spacing:-.02em;color:var(--fg);margin-bottom:20px}.hero-name em,.about-heading em,.projects-heading em,.links-heading em,.files-heading em{font-style:italic;color:var(--accent)}.hero-tagline{font-size:1.15rem;color:var(--muted);font-weight:300;max-width:560px;margin-bottom:36px;opacity:0;animation:fadeUp .7s ease forwards .7s}.hero-cta{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fadeUp .7s ease forwards .9s}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;font-family:DM Mono,monospace;font-size:.72rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border-radius:4px;transition:all .2s;cursor:pointer;border:none}.btn-primary{background:var(--fg);color:var(--bg)}.btn-primary:hover{background:var(--accent)}.btn-outline{background:transparent;color:var(--fg);border:1px solid var(--border)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.divider{height:1px;background:var(--border);max-width:1004px;margin:0 auto;width:0;transition:width 1.2s cubic-bezier(.25,1,.5,1)}.divider.drawn{width:100%}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.about-heading{font-family:"DM Serif Display",serif;font-size:clamp(2rem,4vw,3.2rem);line-height:1.1;letter-spacing:-.02em;margin-bottom:24px}.about-text{color:var(--muted);font-size:.95rem;line-height:1.8;margin-bottom:16px}.about-skills{margin-top:40px}.skills-label{font-family:DM Mono,monospace;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}.skills-list{display:flex;flex-wrap:wrap;gap:8px}.skill-tag{font-family:DM Mono,monospace;font-size:.7rem;padding:5px 12px;background:var(--accent-light);color:var(--accent);border-radius:3px;letter-spacing:.04em;opacity:0;transform:translateY(8px);transition:opacity .35s ease,transform .35s cubic-bezier(.34,1.56,.64,1)}.skill-tag.visible{opacity:1;transform:none}.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:2px;border:1px solid var(--border);border-radius:8px;overflow:visible;perspective:700px;transform-style:preserve-3d}.stat-num{font-family:"DM Serif Display",serif;font-size:2.4rem;color:var(--fg);line-height:1;margin-bottom:6px}.stat-label{font-family:DM Mono,monospace;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.projects-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px}.projects-heading{font-family:"DM Serif Display",serif;font-size:clamp(2rem,4vw,3.2rem);letter-spacing:-.02em;line-height:1.1}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;overflow:visible;perspective:1200px}.project-card{background:var(--card);padding:32px;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:12px;border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 2px #0000000a,0 4px 12px #0000000f,0 12px 32px #0000000d,inset 0 1px #ffffffe6;transition:box-shadow .35s cubic-bezier(.23,1,.32,1),transform .35s cubic-bezier(.23,1,.32,1),background .2s;position:relative;opacity:0;transform-style:preserve-3d;will-change:transform;overflow:hidden}.project-card:before{content:"";position:absolute;inset:0;border-radius:12px;background:linear-gradient(160deg,rgba(255,255,255,.55) 0%,transparent 50%);pointer-events:none;z-index:1}.project-card.visible{animation:cardReveal .6s cubic-bezier(.23,1,.32,1) forwards}.project-card:hover{background:var(--accent-light);box-shadow:0 2px 4px #0000000a,0 8px 24px #c8693a1f,0 24px 48px #c8693a1a,0 0 0 1.5px var(--accent),inset 0 1px #fffffff2}.project-card:hover .project-arrow{opacity:1;transform:translate(2px,-2px)}.project-type{font-family:DM Mono,monospace;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}.project-name{font-family:"DM Serif Display",serif;font-size:1.3rem;letter-spacing:-.01em;color:var(--fg)}.project-desc{font-size:.875rem;color:var(--muted);line-height:1.65;flex:1}.project-stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.stack-tag{font-family:DM Mono,monospace;font-size:.62rem;padding:3px 8px;background:var(--bg);color:var(--muted);border-radius:3px;border:1px solid var(--border)}.project-arrow{position:absolute;top:24px;right:24px;font-size:1.1rem;color:var(--accent);opacity:0;transition:all .2s}.links-heading{font-family:"DM Serif Display",serif;font-size:clamp(2rem,4vw,3.2rem);letter-spacing:-.02em;margin-bottom:48px}.links-groups{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}.link-group-title{font-family:DM Mono,monospace;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.link-list{list-style:none;display:flex;flex-direction:column;gap:2px}.link-list a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:5px;text-decoration:none;color:var(--fg);font-size:.9rem;font-weight:400;transition:background .15s,color .15s,padding-left .2s ease}.link-list a:hover{background:var(--accent-light);color:var(--accent);padding-left:16px}.link-list li>span,.link-list .link-item-static{display:flex;align-items:center;gap:10px;padding:10px 12px;color:var(--text);font-size:.9rem;font-weight:400}.link-icon{width:28px;height:28px;background:var(--bg);border:1px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0}.files-heading{font-family:"DM Serif Display",serif;font-size:clamp(2rem,4vw,3.2rem);letter-spacing:-.02em;margin-bottom:16px}.files-sub{color:var(--muted);font-size:.9rem;margin-bottom:48px}.files-card{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.files-card-header{padding:20px 28px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.files-dots{display:flex;gap:6px}.dot{width:10px;height:10px;border-radius:50%;background:var(--border)}.dot:nth-child(1){background:#f98080}.dot:nth-child(2){background:#fbbf24}.dot:nth-child(3){background:#6ee7b7}.files-url{font-family:DM Mono,monospace;font-size:.72rem;color:var(--muted);background:var(--bg);padding:5px 16px;border-radius:4px;border:1px solid var(--border);flex:1}.files-body{padding:48px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px}.files-icon{font-size:3rem;line-height:1}.files-body h3{font-family:"DM Serif Display",serif;font-size:1.5rem;color:var(--fg)}.files-body p{font-size:.88rem;color:var(--muted);max-width:380px}footer{border-top:1px solid var(--border);padding:32px 48px;display:flex;align-items:center;justify-content:space-between;max-width:1100px;margin:0 auto}.footer-text{font-family:DM Mono,monospace;font-size:.68rem;color:var(--muted);letter-spacing:.06em}.footer-text span{color:var(--accent)}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes wordReveal{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes cardReveal{0%{opacity:0;transform:perspective(1200px) rotateX(12deg) translateY(32px) scale(.97)}to{opacity:1;transform:perspective(1200px) rotateX(0) translateY(0) scale(1)}}@keyframes orbFloat{0%,to{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 28px))}}.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}.reveal.visible{opacity:1;transform:none}.reveal-left{opacity:0;transform:translate(-32px);transition:opacity .65s ease,transform .65s ease}.reveal-left.visible{opacity:1;transform:none}.reveal-right{opacity:0;transform:translate(32px);transition:opacity .65s ease,transform .65s ease}.reveal-right.visible{opacity:1;transform:none}.reveal-scale{opacity:0;transform:scale(.92);transition:opacity .65s ease,transform .65s cubic-bezier(.34,1.56,.64,1)}.reveal-scale.visible{opacity:1;transform:none}.h-line{display:inline-block;opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s cubic-bezier(.16,1,.3,1)}.reveal-heading.visible .h-line{opacity:1;transform:none}.hero-word{display:inline-block;opacity:0;animation:wordReveal .85s cubic-bezier(.16,1,.3,1) forwards}.hero-word-1{animation-delay:.25s}.hero-word-2{animation-delay:.45s}.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:6px;border-radius:4px}.nav-hamburger span{display:block;width:22px;height:2px;background:var(--fg);border-radius:2px;transition:all .3s ease;transform-origin:center}.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media(max-width:768px){nav{padding:0 24px}section{padding:calc(var(--nav-h) + 48px) 24px 48px}.about-grid{grid-template-columns:1fr;gap:40px}.links-groups{grid-template-columns:1fr;gap:32px}.projects-grid{grid-template-columns:1fr}footer{flex-direction:column;gap:12px;text-align:center;padding:24px}.files-body{padding:32px 24px}.nav-hamburger{display:flex}.nav-links{display:none;position:absolute;top:var(--nav-h);left:0;right:0;background:#f7f5f0f7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex-direction:column;padding:16px 24px 24px;gap:0;border-bottom:1px solid var(--border);box-shadow:0 8px 24px #0000000f}.nav-links.open{display:flex}.nav-links li{border-bottom:1px solid var(--border)}.nav-links li:last-child{border-bottom:none}.nav-links a{font-size:.78rem;padding:14px 0;letter-spacing:.1em}}.nav-links a:hover,.link-list a:hover{color:var(--accent)}.nav-enter{animation:navSlideDown .7s cubic-bezier(.16,1,.3,1) both}@keyframes navSlideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.nav-li{opacity:0;animation:fadeUp .5s ease forwards}.nav-li-1{animation-delay:.55s}.nav-li-2{animation-delay:.68s}.nav-li-3{animation-delay:.81s}.nav-li-4{animation-delay:.94s}body:after{content:"";position:fixed;inset:-200%;width:400%;height:400%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");opacity:.022;pointer-events:none;z-index:9999;animation:grainShift .12s steps(1) infinite}@keyframes grainShift{0%{transform:translate(0)}10%{transform:translate(-5%,3%)}20%{transform:translate(4%,-4%)}30%{transform:translate(-3%,6%)}40%{transform:translate(5%,-2%)}50%{transform:translate(-6%,4%)}60%{transform:translate(2%,-5%)}70%{transform:translate(-4%,2%)}80%{transform:translate(3%,5%)}90%{transform:translate(-2%,-3%)}to{transform:translate(0)}}.particle{position:absolute;border-radius:50%;background:var(--accent);opacity:0;pointer-events:none;z-index:0;animation:particleDrift linear infinite}.p1{width:4px;height:4px;left:12%;bottom:20%;opacity:.25;animation-duration:12s;animation-delay:0s}.p2{width:3px;height:3px;left:28%;bottom:10%;opacity:.18;animation-duration:16s;animation-delay:2s}.p3{width:5px;height:5px;left:55%;bottom:15%;opacity:.2;animation-duration:14s;animation-delay:1s}.p4{width:3px;height:3px;left:70%;bottom:30%;opacity:.22;animation-duration:18s;animation-delay:3.5s}.p5{width:4px;height:4px;left:82%;bottom:12%;opacity:.16;animation-duration:11s;animation-delay:.8s}.p6{width:2px;height:2px;left:42%;bottom:25%;opacity:.3;animation-duration:15s;animation-delay:4.5s}@keyframes particleDrift{0%{transform:translateY(0) translate(0);opacity:0}10%{opacity:var(--p-opacity, .22)}90%{opacity:var(--p-opacity, .22)}to{transform:translateY(-380px) translate(20px);opacity:0}}.stat-box{padding:32px 28px;background:var(--card);border:1px solid var(--border);border-radius:6px;transition:transform .3s cubic-bezier(.23,1,.32,1),box-shadow .3s ease,border-color .3s ease;transform-style:preserve-3d;will-change:transform;cursor:default}.stat-box:hover{box-shadow:0 12px 36px #c8693a2e,0 4px 12px #c8693a14;border-color:var(--accent)}.link-list a{transition:background .15s,color .15s,padding-left .2s ease,transform .35s cubic-bezier(.34,1.56,.64,1)}.skill-tag.ripple{transform:translateY(-5px) scale(1.08)!important;background:var(--accent)!important;color:#fff!important;transition:transform .2s cubic-bezier(.34,1.56,.64,1),background .2s ease,color .2s ease!important}.marquee-wrap{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:14px 0;background:var(--bg)}.marquee-track{display:flex;white-space:nowrap;animation:marqueeScroll 22s linear infinite;font-family:DM Mono,monospace;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);gap:0}.marquee-track span{padding-right:0}.marquee-track:hover{animation-play-state:paused}@keyframes marqueeScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.hero-orb{position:absolute;width:620px;height:620px;border-radius:50%;background:radial-gradient(circle,rgba(200,105,58,.07) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation:orbFloat 7s ease-in-out infinite;pointer-events:none;z-index:0}#home>*:not(.hero-orb):not(.particle){position:relative;z-index:1}.sudoku-project-card{cursor:default;grid-column:1 / -1;overflow:visible!important;opacity:1!important;animation:none!important;transform:none!important}.sudoku-card-open{background:var(--accent-light);border-color:var(--accent)}.project-card-top{cursor:pointer;display:flex;flex-direction:column;gap:12px}.project-card-actions{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.project-gh-link{font-family:DM Mono,monospace;font-size:.65rem;color:var(--accent);text-decoration:none;letter-spacing:.06em}.project-gh-link:hover{text-decoration:underline}.project-play-btn{align-self:flex-start;font-family:DM Mono,monospace;font-size:.68rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:7px 16px;border-radius:4px;border:1px solid var(--accent);background:transparent;color:var(--accent);cursor:pointer;transition:all .2s}.project-play-btn:hover{background:var(--accent);color:#fff}.project-card-game{margin-top:24px;border-top:1px solid var(--border);padding-top:20px}.project-arrow{transition:transform .2s ease!important}.term-outer{background:#1e1e1e;border-radius:10px;overflow:hidden;border:1px solid #3a3a3a;box-shadow:0 8px 40px #00000059,0 2px 8px #0003;cursor:text;max-width:860px;position:relative}.term-titlebar{background:#2d2d2d;padding:10px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid #3a3a3a;-webkit-user-select:none;user-select:none}.term-dots{display:flex;gap:6px}.term-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.dot-red{background:#ff5f57}.dot-yellow{background:#ffbd2e}.dot-green{background:#28c940}.term-title{font-family:DM Mono,monospace;font-size:.72rem;color:#888;letter-spacing:.04em;flex:1;text-align:center}.term-clock{font-family:DM Mono,monospace;font-size:.72rem;color:#ffbd2e;letter-spacing:.06em}.term-body{padding:16px 20px 20px;height:520px;overflow-y:auto;font-family:DM Mono,monospace;font-size:.72rem;line-height:1.55;color:#d4d4d4;scrollbar-width:thin;scrollbar-color:#444 transparent}.term-body::-webkit-scrollbar{width:6px}.term-body::-webkit-scrollbar-thumb{background:#444;border-radius:3px}.term-line{white-space:pre;min-height:1.1em}.term-red{color:#e74c3c}.term-green{color:#2ecc71}.term-yellow{color:#f1c40f}.term-blue{color:#5dade2}.term-white{color:#d4d4d4}.term-input-line{display:flex;align-items:center;color:#d4d4d4}.term-cursor-text{white-space:pre}.term-cursor{display:inline-block;color:#d4d4d4;animation:termBlink 1s step-end infinite;line-height:1;margin-left:1px}@keyframes termBlink{0%,to{opacity:1}50%{opacity:0}}.term-hidden-input{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px;bottom:0;right:0}@media(max-width:768px){.term-body{font-size:.6rem;height:420px;padding:12px 14px 16px}.term-line{white-space:pre-wrap;word-break:break-all}}
