:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root{margin:0;padding:0;width:100%;min-height:100vh;overflow-x:hidden}html{scroll-padding-top:120px}:root{--bg: #ffffff;--text: #000000;--grid-light: #e5e5e5;--grid-dark: #cccccc;--header-bg: transparent;font-family:Courier New,Courier,monospace}[data-theme=dark]{--bg: #000000;--text: #ffffff;--grid-light: rgba(255,255,255,.06);--grid-dark: rgba(255,255,255,.12);--header-bg: transparent}.content{padding:100px 80px 80px}.homepage{position:relative;min-height:100vh;width:100%;color:var(--text);background-color:var(--bg);background-image:linear-gradient(var(--grid-light) 1px,transparent 1px),linear-gradient(90deg,var(--grid-light) 1px,transparent 1px),linear-gradient(var(--grid-dark) 1px,transparent 1px),linear-gradient(90deg,var(--grid-dark) 1px,transparent 1px);background-size:20px 20px,20px 20px,100px 100px,100px 100px;transition:all .3s ease}.grid-mark{position:absolute;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-family:Courier New,Courier,monospace;font-size:12px;font-weight:700;pointer-events:none;transform:translate(-50%,-50%);z-index:0;animation:markPop .2s ease-out}.mark-X{color:#e06060}.mark-O{color:#6090e0}[data-theme=dark] .mark-X{color:#ff7070}[data-theme=dark] .mark-O{color:#70a0ff}@keyframes markPop{0%{transform:translate(-50%,-50%) scale(0);opacity:0}70%{transform:translate(-50%,-50%) scale(1.2)}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.win-lines-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.win-line{stroke-width:2;stroke-linecap:round;animation:lineGrow .4s ease-out}.win-line-X{stroke:#e06060}.win-line-O{stroke:#6090e0}[data-theme=dark] .win-line-X{stroke:#ff7070}[data-theme=dark] .win-line-O{stroke:#70a0ff}@keyframes lineGrow{0%{opacity:0}to{opacity:1}}.game-ui{position:fixed;bottom:20px;right:20px;z-index:200;display:flex;align-items:center;gap:16px;font-family:Courier New,Courier,monospace;font-size:14px;padding:8px 16px;background:var(--bg);color:var(--text);border:2px solid var(--text);box-shadow:2px 2px 0 var(--grid-dark)}.game-score{font-weight:700}.game-reset{font-family:Courier New,Courier,monospace;font-size:14px;padding:4px 12px;background:none;color:var(--text);border:1px solid var(--text);cursor:pointer;transition:opacity .2s ease}.game-reset:hover{opacity:.7}.header{display:flex;justify-content:space-between;align-items:center;padding:4px 32px;position:fixed;top:0;left:0;right:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffb3;box-shadow:0 2px 8px #0000000d}[data-theme=dark] .header{background:#000000b3;box-shadow:0 2px 8px #0000004d}.header-logo{display:none;width:32px;height:32px}.theme-toggle{font-size:22px;border:none;background:none;cursor:pointer;transition:transform .2s ease;outline:none}.theme-toggle:focus{outline:none}.theme-toggle:hover{transform:scale(1.2)}.theme-toggle svg{display:block;transition:stroke .2s ease}[data-theme=light] .theme-toggle svg{stroke:#000!important}[data-theme=light] .theme-toggle:hover svg{stroke:#3a8fc2!important}[data-theme=dark] .theme-toggle svg{stroke:currentColor}[data-theme=dark] .theme-toggle:hover svg{stroke:gold}.nav-buttons{display:flex;align-items:center;gap:24px}.nav-btn{font-family:Courier New,Courier,monospace;font-size:16px;color:var(--text);background:none;border:none;cursor:pointer;padding:8px 16px;transition:opacity .2s ease;outline:none}.nav-btn:focus{outline:none}.nav-btn:hover{opacity:.6}.intro-section{max-width:1200px;margin:0 auto}.intro-container{display:flex;gap:32px;align-items:center;margin-top:24px;flex-direction:row-reverse}.ascii-logo{font-family:Courier New,Courier,monospace;font-size:8px;line-height:1;margin:0;white-space:pre;flex-shrink:0}.intro-text{font-size:18px;line-height:1.6;margin:0;opacity:.9}.skills-section{max-width:1200px;margin:60px auto 0}.skills-section h2{font-size:32px;margin-bottom:24px}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}.skill-group{padding:0 16px 0 28px;position:relative;border:1px solid var(--grid-dark);background:repeating-linear-gradient(transparent,transparent 27px,var(--grid-light) 27px,var(--grid-light) 28px),var(--bg);transition:border-color .2s ease,box-shadow .2s ease}.skill-group:before{content:"";position:absolute;left:20px;top:0;bottom:0;width:2px;background:#e06060;opacity:.5}.skill-group:hover{border-color:var(--text);box-shadow:2px 2px 0 var(--grid-dark)}.skill-group-title{font-family:Courier New,Courier,monospace;font-size:14px;margin:0 0 28px;line-height:28px;opacity:.85;font-weight:700;white-space:nowrap}.skill-item{font-size:16px;display:flex;align-items:center;gap:8px;line-height:28px;margin:0;white-space:nowrap}.checkbox{font-family:Courier New,Courier,monospace;font-size:16px;opacity:.7}.projects-section{max-width:1200px;margin:60px auto 0}.projects-section h2{font-size:32px;margin-bottom:40px}.projects-grid{display:flex;flex-wrap:wrap;gap:32px}.project-card{position:relative;width:200px;padding:16px 16px 12px;background:beige;text-decoration:none;color:#333;box-shadow:2px 3px 6px #00000026,0 1px 2px #0000001a;transition:transform .25s ease,box-shadow .25s ease;transform:rotate(-1.5deg)}.project-card:nth-child(2){transform:rotate(2deg)}.project-card:nth-child(3){transform:rotate(-.5deg)}.project-card:nth-child(4){transform:rotate(1.5deg)}[data-theme=dark] .project-card{background:#2a2a28;color:#e0e0e0;box-shadow:2px 3px 8px #0006,0 1px 2px #0000004d}.project-card:hover{transform:rotate(0) translateY(-6px) scale(1.03);box-shadow:4px 8px 20px #0003,0 2px 4px #0000001a}[data-theme=dark] .project-card:hover{box-shadow:4px 8px 24px #00000080,0 2px 4px #0000004d}.tape{position:absolute;top:-8px;left:50%;transform:translate(-50%) rotate(1deg);width:70px;height:20px;background:#c8c8b499;border:1px solid rgba(180,180,160,.4);z-index:2}[data-theme=dark] .tape{background:#64645a80;border-color:#78786e4d}.project-photo{width:100%;aspect-ratio:1 / 1;overflow:hidden;border:1px solid rgba(0,0,0,.1)}[data-theme=dark] .project-photo{border-color:#ffffff1a}.project-thumbnail{width:100%;height:100%;object-fit:cover;filter:grayscale(100%);transition:filter .3s ease}.project-card:hover .project-thumbnail{filter:grayscale(0%)}.project-label{font-family:Courier New,Courier,monospace;font-size:14px;text-align:center;margin:10px 0 0;line-height:1.3;transition:color .2s ease}.project-card:hover .project-label{color:#3a8fc2}[data-theme=dark] .project-card:hover .project-label{color:gold}.project-category{margin-bottom:48px}.category-title{font-family:Courier New,Courier,monospace;font-size:20px;margin-bottom:28px;opacity:.7;font-weight:400}.contact-section{max-width:1200px;margin:60px auto 0;padding-bottom:80px}.contact-section h2{font-size:32px;margin-bottom:32px}.contact-cards{display:flex;flex-wrap:wrap;gap:32px}.contact-card{position:relative;width:140px;padding:24px 16px 16px;background:beige;text-decoration:none;color:#333;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:2px 3px 6px #00000026,0 1px 2px #0000001a;transition:transform .25s ease,box-shadow .25s ease;transform:rotate(-1.5deg)}.contact-card:nth-child(2){transform:rotate(2deg)}.contact-card:nth-child(3){transform:rotate(-.5deg)}[data-theme=dark] .contact-card{background:#2a2a28;color:#e0e0e0;box-shadow:2px 3px 8px #0006,0 1px 2px #0000004d}.contact-card:hover{transform:rotate(0) translateY(-6px) scale(1.03);box-shadow:4px 8px 20px #0003,0 2px 4px #0000001a}[data-theme=dark] .contact-card:hover{box-shadow:4px 8px 24px #00000080,0 2px 4px #0000004d}.contact-card-icon{stroke:#333;opacity:.8;transition:stroke .2s ease}[data-theme=dark] .contact-card-icon{stroke:#e0e0e0}.contact-card:hover .contact-card-icon{stroke:#3a8fc2;opacity:1}[data-theme=dark] .contact-card:hover .contact-card-icon{stroke:gold}.contact-card-label{font-family:Courier New,Courier,monospace;font-size:14px;text-align:center;transition:color .2s ease}.contact-card:hover .contact-card-label{color:#3a8fc2}[data-theme=dark] .contact-card:hover .contact-card-label{color:gold}@media(max-width:1024px){.content{padding:60px 40px}.intro-section,.skills-section,.projects-section,.contact-section{max-width:100%}.intro-container{flex-direction:column;align-items:flex-start}.ascii-logo{font-size:6px;align-self:center}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.project-card{width:170px;padding:12px 12px 10px}.projects-grid{gap:24px}}@media(max-width:768px){.header{padding:12px 16px}.header-name{display:none}.header-logo{display:block!important}.nav-buttons{gap:12px}.nav-btn{font-size:14px;padding:6px 12px}.theme-toggle svg{width:20px;height:20px}.content{padding:80px 20px 70px}.intro-section h1{font-size:32px}.intro-container{flex-direction:column}.ascii-logo{font-size:4px;align-self:center}.intro-text{font-size:16px}.skills-section h2,.projects-section h2,.contact-section h2{font-size:28px}.skills-grid{grid-template-columns:1fr 1fr}.category-title{font-size:20px}.project-card{width:150px;padding:10px 10px 8px}.projects-grid{gap:20px;justify-content:center}.contact-link{font-size:16px}.contact-icon svg{width:20px;height:20px}}@media(max-width:480px){.header h2{font-size:16px}.nav-buttons{gap:8px}.nav-btn{font-size:12px;padding:4px 8px}.intro-section h1{font-size:28px}.intro-text{font-size:14px}.ascii-logo{font-size:3px}.skills-section h2,.projects-section h2,.contact-section h2{font-size:24px}.skills-grid{grid-template-columns:1fr}.skill-item{font-size:14px}.category-title{font-size:18px}.project-card{width:130px;padding:8px 8px 6px}.tape{width:50px;height:16px}.project-label{font-size:12px}.contact-link{font-size:14px}}
