.landing-wrapper{display:flex;flex-direction:column;align-items:center;font-family:Courier New,monospace;color:var(--text)}.landing-container{min-height:60vh;width:100vw;display:flex;justify-content:center;align-items:center;background-color:var(--bg);color:var(--accent);overflow:hidden;text-align:center;font-family:Courier New,monospace}.typewriter{font-size:clamp(2rem,6vw,4rem);border-right:2px solid var(--accent);white-space:nowrap;overflow:hidden;width:0;color:#ea96e9;animation:typing 4s steps(11,end) forwards,blink .8s step-end infinite}@keyframes typing{0%{width:0}to{width:11ch}}@keyframes blink{50%{border-color:transparent}}.intro-text{text-align:center;margin-top:3rem;max-width:700px;padding:2rem;font-family:Courier New,monospace}.intro-text h2{margin-bottom:1rem;color:var(--accent)}.intro-text h3{line-height:1.6;font-weight:400}.cv-page{padding:4rem 2rem;max-width:900px;margin:0 auto;color:var(--text-color);display:flex;flex-direction:column;align-items:center;text-align:center}.about-list{display:flex;justify-content:center;width:100%}.about-card{background:var(--card-bg, #fff);border-radius:12px;padding:2rem;max-width:800px;width:100%;box-shadow:0 4px 12px #00000014;text-align:left}.cv-page h1{font-size:2.5rem;margin-bottom:2rem;text-align:center;width:100%}.about-page{padding:4rem 2rem;max-width:900px;margin:0 auto;color:var(--text-color);font-family:Arial,sans-serif;line-height:1.6}.cv-page h1,.about-page h1{font-size:2.5rem;margin-bottom:1rem;text-align:center}.cv-intro,.about-page p{font-size:1.2rem;text-align:center;max-width:60ch;margin:0 auto 3rem}.cv-section{margin-bottom:2.5rem}.cv-section h2,.skills-section h2{font-size:1.5rem;color:var(--heading-color);margin-bottom:1rem;text-align:center}@media (prefers-color-scheme: light){:root{--heading-color: #5a3d9a}}@media (prefers-color-scheme: dark){:root{--heading-color: #d8b9ff}}.cv-section ul{list-style-type:none;padding-left:0}.cv-section li{margin-bottom:1rem;line-height:1.6}.skills-section{margin-top:2rem;text-align:center}.skills{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;margin-top:1rem;padding:0}.skill{display:inline-block;padding:.4rem .9rem;border-radius:999px;font-size:.85rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.skill.language{background-color:#cba4f9}.skill.framework{background-color:#ffb3d1}.skill.style{background-color:#8ecaff}.skill.design{background-color:#a2f4c5;color:#1a1a1a}.skill.other{background-color:#fff3b0;color:#1a1a1a}@media (prefers-color-scheme: light){:root{--hover-start: #b39ddb;--text-color: #1a1a1a}}@media (prefers-color-scheme: dark){:root{--hover-start: #d1c4e9;--text-color: #f5f5f5}.about-page,.cv-page{color:#f5f5f5}}.project-card{opacity:0;transform:translateY(40px);transition:opacity .6s ease,transform .6s ease;will-change:opacity,transform;background-color:var(--card-bg, white);padding:1.5rem;border-radius:1rem;box-shadow:0 4px 20px #0000001a;transition:transform .3s ease,box-shadow .3s ease,background .3s ease;color:var(--text-color, #1a1a1a);max-width:600px;width:90%}.project-card.visible{opacity:1;transform:translateY(0)}.project-card:hover{transform:translateY(-6px) scale(1.02);background:linear-gradient(135deg,var(--hover-start, #ffe0f0),var(--hover-end, #e0f7fa));box-shadow:0 8px 30px #00000026;cursor:pointer}@media (prefers-color-scheme: light){:root{--card-bg: white;--text-color: #1a1a1a;--hover-start: #ffe0f0;--hover-end: #e0f7fa;--github-bg: #6c5ce7;--github-hover: #a29bfe}}@media (prefers-color-scheme: dark){:root{--card-bg: #1e1e1e;--text-color: #f5f5f5;--hover-start: #3d2a45;--hover-end: #2d3c4a;--github-bg: #b388ff;--github-hover: #d1b3ff}}.projects-page{padding:2rem;display:flex;flex-direction:column;align-items:center}.projects-page h1{margin-bottom:2rem}.project-list{display:flex;flex-direction:column;align-items:center;gap:2rem}.project-card p{white-space:pre-wrap;margin-top:.5rem}.project-header{text-align:center;margin-bottom:1rem}.project-title{font-size:1.5rem;margin:.5rem}.project-badges-centered{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.project-badge{font-size:.75rem;font-weight:700;padding:.25rem .75rem;border-radius:999px;white-space:nowrap;letter-spacing:.5px;text-transform:uppercase}.github-link{display:inline-block;margin-top:1rem;padding:.6rem 1.2rem;font-weight:700;border-radius:999px;background:var(--github-bg, #6c5ce7);color:#fff;text-decoration:none;box-shadow:0 4px 12px #0003;transition:background .3s ease,transform .2s ease}.github-link:hover{background:var(--github-hover, #a29bfe);transform:scale(1.05);text-decoration:none}.tag-hobby{background-color:#ffe3ed;color:#d63384}.tag-frontend{background-color:#e0f7ff;color:#0096c7}.tag-react{background-color:#dfe7fd;color:#3b82f6}.tag-fullstack{background-color:#f3e5f5;color:#8e44ad}.tag-universitet{background-color:#f1ffe3;color:#5b8c00}.tag-kotlin{background-color:#fff0e5;color:#ff6f00}.tag-spill{background-color:#e5fdeb;color:#2ecc71}.tag-phaser{background-color:#fceeff;color:#b043d1}.tag-smidig{background-color:#fffde1;color:#ffb300}.tag-css{background-color:#e3edff;color:#2962ff}.custom-cursor{position:fixed;top:0;left:0;width:18px;height:18px;background-color:#f9cc;border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:background-color .2s ease,transform .15s ease}.custom-cursor.hover{background-color:#cc99ffe6;transform:translate(-50%,-50%) scale(1.4)}*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #ffffff;--text: #0d0d0d;--accent: #8ACE00;--accent-dark: #a7bd7c;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme: dark){:root{--bg: #0d0d0d;--text: #ffffff;--accent: #ffffff;--accent-dark: #464646}}body{background-color:var(--bg);color:var(--text);font-family:inherit;min-height:100vh;display:flex;flex-direction:column;cursor:none}h1{font-size:clamp(2rem,5vw,3rem);line-height:1.2}p{font-size:clamp(1rem,2.5vw,1.25rem);line-height:1.6}a{font-weight:500;color:var(--accent);text-decoration:none}a:hover{color:var(--accent-dark)}nav{background-color:var(--bg);text-align:center;padding:1rem;border-bottom:1px solid #333}nav a{color:var(--accent);margin:0 1rem;font-weight:700;transition:color .3s ease}nav a:hover{color:var(--text)}.page{width:100%;max-width:960px;margin:0 auto;padding:5vw;background-color:var(--bg);color:var(--text);font-size:clamp(1rem,2.5vw,1.25rem)}button,.game-link-button{display:inline-block;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--accent);color:var(--bg);border:none;border-radius:8px;cursor:pointer;transition:all .3s ease}button:hover,.game-link-button:hover{background-color:var(--accent-dark);transform:scale(1.05)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.scroll-to-top{position:fixed;bottom:2rem;right:2rem;padding:.6rem 1.2rem;background-color:var(--github-bg, #6c5ce7);color:#fff;border:none;border-radius:999px;font-weight:700;cursor:pointer;z-index:1000;box-shadow:0 4px 12px #0003;transition:background .3s ease,transform .2s ease}.scroll-to-top:hover{background-color:var(--github-hover, #a29bfe);transform:scale(1.1)}*,*:before,*:after{cursor:none!important}#root{margin:0 auto;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}nav{opacity:0;animation:fadein .5s ease-in forwards;animation-delay:.1s}@keyframes fadein{to{opacity:1}}
