@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=Space+Grotesk:wght@400;500;700&display=swap";.software-page{--bg-soft: rgba(9, 14, 27, .84);--surface: rgba(12, 20, 38, .9);--surface-strong: rgba(19, 31, 58, .96);--text: #eef5ff;--muted: #9bb0d4;--accent: #75b7ff;--accent-2: #a6d9ff;--border: rgba(117, 183, 255, .18);--shadow: 0 26px 70px rgba(0, 0, 0, .48)}.software-page:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-2;background:linear-gradient(rgba(117,183,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(117,183,255,.04) 1px,transparent 1px),radial-gradient(circle at 15% 20%,rgba(117,183,255,.18),transparent 25%),radial-gradient(circle at 85% 10%,rgba(166,217,255,.1),transparent 22%),linear-gradient(180deg,#06091259,#060912e6);background-size:48px 48px,48px 48px,auto,auto,auto;-webkit-mask-image:linear-gradient(180deg,#000000f2,#0000008c);mask-image:linear-gradient(180deg,#000000f2,#0000008c)}.software-page .backdrop-one{background:#75b7ff33}.software-page .backdrop-two{background:#a6d9ff1f}.software-page .panel{border-color:#75b7ff29;box-shadow:0 20px 60px #0006,inset 0 1px #ffffff08}.software-page .nav{background:#070c17db;border-color:#75b7ff2e;box-shadow:0 18px 50px #00000047}.software-page .hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#0f172cf2,#080c18db),radial-gradient(circle at 10% 18%,rgba(117,183,255,.16),transparent 26%),radial-gradient(circle at 88% 24%,rgba(166,217,255,.12),transparent 28%)}.software-page .hero:after{content:"";position:absolute;top:18px;right:18px;bottom:18px;left:18px;border-radius:22px;border:1px solid rgba(117,183,255,.08);pointer-events:none}.software-page .hero-copy h1{text-shadow:0 0 24px rgba(117,183,255,.18)}.software-page .hero-text{max-width:56ch}.software-page .hero-visual{position:relative;min-height:320px;padding:22px;border-radius:26px;border:1px solid rgba(117,183,255,.18);background:linear-gradient(135deg,rgba(117,183,255,.08),transparent 42%),linear-gradient(180deg,#0a1224fa,#040812eb);overflow:hidden}.software-page .hero-visual:before{content:"";position:absolute;top:12px;right:12px;bottom:12px;left:12px;border-radius:20px;border:1px solid rgba(166,217,255,.12);background:linear-gradient(135deg,rgba(117,183,255,.15),transparent 30%),linear-gradient(45deg,rgba(255,255,255,.06) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,rgba(255,255,255,.05) 75%);background-size:auto,20px 20px,20px 20px;background-position:center,0 0,10px 10px;opacity:.55}.software-page .hero-character{position:relative;z-index:1;width:min(100%,360px);max-height:460px;object-fit:contain;filter:saturate(.9) contrast(1.07) brightness(.93) hue-rotate(8deg) drop-shadow(0 0 24px rgba(117,183,255,.24)) drop-shadow(0 22px 28px rgba(0,0,0,.42))}.software-page .hero-metrics article{background:linear-gradient(180deg,#121e39e6,#0a1121f2);border-color:#75b7ff29;box-shadow:inset 0 1px #ffffff0a}.software-page .hero-metrics strong{color:#c7e3ff}.software-page .button-dark{background:linear-gradient(135deg,#7dc0ff,#55e6d6);box-shadow:0 12px 26px #3aa3ff2e}.software-page .button-light{border-color:#75b7ff33;background:#75b7ff0f;color:#c7e3ff}.software-page .button-light:hover{background:#75b7ff1c}.software-page .section-heading h2{text-shadow:0 0 18px rgba(117,183,255,.08)}.software-page .projects-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.software-page .projects-grid .thumbnail-placeholder{min-height:220px}.software-page .project-card{position:relative;overflow:hidden;border-color:#75b7ff2e;background:linear-gradient(180deg,#0e172bfa,#090e1bf0),radial-gradient(circle at top right,rgba(117,183,255,.08),transparent 28%);box-shadow:0 18px 52px #0000005c,inset 0 1px #ffffff0a;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}@media(hover:hover)and (pointer:fine){.software-page .project-card:hover{transform:translateY(-5px);border-color:#75b7ff57;box-shadow:0 26px 58px #0000006b,0 0 0 1px #75b7ff1f,inset 0 1px #ffffff0d}}.software-page .project-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(117,183,255,.07),transparent 18%,transparent 82%,rgba(117,183,255,.06));pointer-events:none}.software-page .project-card:after{content:"";position:absolute;inset:auto 16px 16px 16px;height:1px;background:linear-gradient(90deg,transparent,rgba(117,183,255,.5),transparent);opacity:.65}.software-page .project-kicker{color:#9bd2ff}.software-page .tags span{background:#75b7ff14;border-color:#75b7ff2e;box-shadow:0 0 0 1px #ffffff05}.software-page .media-placeholder,.software-page .media-carousel,.software-page .media-card-link{border-color:#75b7ff2e}.software-page .media-placeholder{background:#75b7ff08}.software-page .media-placeholder p,.software-page .carousel-counter{color:#9bd2ff}.software-page .contact-panel{background:linear-gradient(180deg,#0d1527eb,#090e1bf5)}@media(max-width:980px){.software-page .hero-visual{min-height:260px}.software-page .projects-grid{grid-template-columns:1fr;gap:16px}.software-page .projects-grid .thumbnail-placeholder{min-height:190px}}@media(max-width:640px){.software-page .projects-grid .thumbnail-placeholder{min-height:170px}}.motorcycle-page{--bg-soft: rgba(24, 16, 34, .82);--surface: rgba(38, 24, 52, .9);--surface-strong: rgba(52, 30, 66, .97);--text: #fff4ea;--muted: #e8c7aa;--accent: #ffb25c;--accent-2: #ffe07f;--border: rgba(255, 186, 102, .18);--shadow: 0 30px 100px rgba(5, 2, 10, .42)}.motorcycle-page:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;pointer-events:none;background:radial-gradient(circle at 50% 14%,rgba(255,223,127,.28),transparent 12%),radial-gradient(circle at 70% 28%,rgba(255,178,92,.18),transparent 20%),radial-gradient(circle at 15% 20%,rgba(160,110,255,.18),transparent 18%),linear-gradient(180deg,#10061a,#1a1230 32%,#27233d 58%,#f08f46)}.motorcycle-page .backdrop-one{background:#ffdf7f42}.motorcycle-page .backdrop-two{background:#a06eff29}.motorcycle-page .nav{background:#140c1ad1;border-color:#ffba6629}.motorcycle-hero,.journey-board,.sunset-panel{position:relative;overflow:hidden}.motorcycle-hero{padding:40px;background:radial-gradient(circle at 78% 24%,rgba(255,223,127,.22),transparent 18%),radial-gradient(circle at 20% 18%,rgba(160,110,255,.16),transparent 20%),linear-gradient(180deg,#1d1027eb,#140c1af5)}.motorcycle-hero:after,.journey-board:after,.sunset-panel:after{content:"";position:absolute;top:14px;right:14px;bottom:14px;left:14px;border-radius:22px;border:1px solid rgba(255,223,127,.08);pointer-events:none}.motorcycle-hero-layout{align-items:stretch}.motorcycle-hero-copy{justify-content:center}.journey-badges{display:flex;flex-wrap:wrap;gap:10px}.journey-badges span{padding:8px 12px;border-radius:999px;border:1px solid rgba(255,223,127,.16);background:#ffffff0a;color:var(--text);font-size:.84rem}.journey-sky{position:relative;min-height:360px;border-radius:28px;border:1px solid rgba(255,223,127,.14);background:linear-gradient(180deg,#10081a33,#08050c4d),radial-gradient(circle at top center,rgba(255,223,127,.3),transparent 18%),linear-gradient(180deg,#2a204080,#1a1027e6);overflow:hidden}.journey-sun{position:absolute;top:28px;right:34px;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle,#fff7ba,#ffe37c 36%,#ffb25c 70%,#ffb25c00 72%);box-shadow:0 0 60px #ffdf7fb3}.journey-road{position:absolute;top:22px;right:54px;bottom:22px;left:54px}.journey-road:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;background:linear-gradient(180deg,#120c19fa,#0f0a14eb);clip-path:polygon(46% 0,54% 0,68% 100%,32% 100%)}.journey-road-center{position:absolute;left:50%;top:0;bottom:0;width:4px;transform:translate(-50%);background:repeating-linear-gradient(180deg,rgba(255,223,127,.9) 0 24px,transparent 24px 48px);opacity:.65}.journey-bike{position:absolute;left:50%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;display:grid;place-items:center;border:1px solid rgba(255,223,127,.24);background:#140c1ae0;box-shadow:0 18px 40px #0000005c;transition:top .38s ease}.journey-bike span{font-size:1.8rem;filter:drop-shadow(0 0 16px rgba(255,223,127,.32))}.journey-board,.sunset-panel{margin-top:20px;padding:28px;background:linear-gradient(180deg,#1d1027e6,#120a19f5)}.journey-track{position:relative;display:grid;gap:24px}.journey-track:before{content:"";position:absolute;top:0;bottom:0;left:50%;width:4px;transform:translate(-50%);background:linear-gradient(180deg,#ffdf7f80,#ffb25c2e);opacity:.7}.journey-stop{display:grid;grid-template-columns:minmax(0,1fr) 92px minmax(0,1fr);align-items:center;gap:0}.journey-stop-card{position:relative;width:min(100%,460px);padding:22px;border-radius:24px;border:1px solid rgba(255,223,127,.16);background:radial-gradient(circle at top right,rgba(255,223,127,.08),transparent 30%),linear-gradient(180deg,#281836fa,#170c20f2);box-shadow:0 18px 48px #00000047}.journey-stop-card h3{font-size:1.4rem;margin-bottom:8px}.journey-stop-card-active{border-color:#ffdf7f6b;box-shadow:0 0 0 1px #ffdf7f1a,0 24px 56px #00000052}.journey-stop-card-clickable{cursor:pointer}.journey-stop-card-clickable:hover{transform:translateY(-1px);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.journey-stop-left .journey-stop-card{justify-self:end}.journey-stop-right .journey-stop-card{justify-self:start}.journey-spine{position:relative;display:grid;place-items:center}.journey-spine-year{position:relative;z-index:1;width:56px;height:56px;display:grid;place-items:center;border-radius:50%;border:1px solid rgba(255,223,127,.24);background:#180c19f5;color:var(--accent-2);font-family:IBM Plex Mono,ui-monospace,monospace;font-size:.86rem;letter-spacing:.08em;box-shadow:0 0 0 6px #ffdf7f14}.journey-stop-left .journey-spine-year:after,.journey-stop-right .journey-spine-year:after{content:"";position:absolute;top:50%;width:36px;height:2px;background:#ffdf7f47}.journey-stop-left .journey-spine-year:after{right:100%}.journey-stop-right .journey-spine-year:after{left:100%}.journey-reward{margin-top:14px;padding:12px 14px;border-radius:16px;border:1px solid rgba(255,223,127,.14);background:#ffffff0a;display:grid;gap:4px}.journey-reward span{font-weight:700}.journey-reward small{color:var(--muted)}.journey-reward-complete{background:#ffdf7f0f}.journey-stop-actions{margin-top:14px;display:grid;gap:10px}.journey-stop-hint{color:var(--muted);font-size:.9rem;line-height:1.45}.playable-lab-teaser{margin-top:20px;padding:28px}.playable-lab-grid{display:grid;gap:18px;grid-template-columns:minmax(0,1.2fr) minmax(240px,.8fr);align-items:center}.playable-lab-actions,.sunset-actions{display:flex;flex-wrap:wrap;gap:12px}.sunset-layout{display:grid;gap:18px}.journey-runner-page{--runner-bg: rgba(12, 10, 24, .88);--runner-panel: rgba(26, 18, 40, .92);--runner-glow: rgba(255, 220, 122, .2);--runner-road: #25192f;--runner-road-line: #f6d88a;--runner-text: #fff5e8;--runner-muted: #e5c7a8;--runner-accent: #ffbc62;--runner-border: rgba(255, 219, 142, .16);color:var(--runner-text)}.journey-runner-page:before{background:radial-gradient(circle at 50% 12%,rgba(255,227,134,.32),transparent 14%),radial-gradient(circle at 84% 18%,rgba(255,188,98,.18),transparent 22%),linear-gradient(180deg,#11081b,#1a1330 42%,#302446 72%,#f19c54)}.journey-runner-page .nav{background:#120b1ae0;border-color:#ffdb8e29}.runner-hero,.runner-stage,.runner-summary{position:relative;overflow:hidden;margin-top:20px;padding:28px;background:linear-gradient(180deg,#170e22eb,#100a19f5)}.runner-hero:after,.runner-stage:after,.runner-summary:after{content:"";position:absolute;top:14px;right:14px;bottom:14px;left:14px;border:1px solid rgba(255,219,142,.08);border-radius:22px;pointer-events:none}.runner-hero-layout{display:grid;gap:20px;grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);align-items:start}.runner-hero-copy{gap:18px}.runner-actions{display:flex;flex-wrap:wrap;gap:12px}.runner-hud{display:flex;flex-wrap:wrap;gap:10px}.runner-status,.runner-badge{padding:8px 12px;border-radius:999px;background:#ffffff0d;border:1px solid rgba(255,219,142,.16);font-family:IBM Plex Mono,ui-monospace,monospace;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase}.runner-status-running{color:#9ef2b0}.runner-status-won{color:#ffe89b}.runner-status-lost{color:#ffb4a1}.runner-instructions{display:grid;gap:12px;align-content:center;min-height:100%;padding:20px;border-radius:24px;border:1px solid rgba(255,219,142,.14);background:#ffffff0a}.runner-instructions p,.runner-instructions li,.runner-summary p{color:var(--runner-muted);line-height:1.7}.runner-instructions ul{margin:0;padding-left:20px;display:grid;gap:8px}.runner-stage{padding-bottom:22px}.runner-scene{position:relative;min-height:460px;overflow:hidden;border-radius:24px;border:1px solid rgba(255,219,142,.14);background:linear-gradient(180deg,#120a1ceb,#0b0710fa)}.runner-background{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url(/media/lab/backgroundcity.png);background-repeat:repeat-x;background-position:0 bottom;background-size:auto 100%;opacity:.9;filter:saturate(1.1) contrast(.95)}.runner-sky-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 52% 20%,rgba(255,225,127,.28),transparent 16%),linear-gradient(180deg,rgba(255,255,255,.02),transparent 38%);pointer-events:none}.runner-world{position:absolute;top:0;left:0;width:100000px;height:100%;transform:translate(0);will-change:transform}.runner-overlay-ui{position:absolute;top:0;right:0;bottom:0;left:0;z-index:8;pointer-events:none}.runner-score-overlay{position:absolute;top:12px;left:50%;transform:translate(-50%);display:flex;flex-wrap:nowrap;justify-content:center;align-items:center;gap:8px;pointer-events:auto}.runner-score-overlay .runner-status,.runner-score-overlay .runner-badge{white-space:nowrap}.runner-score-overlay .runner-status,.runner-score-overlay .runner-badge{background:#0b0714b8;border-color:#ffdb8e47;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.runner-jump-overlay{position:absolute;right:14px;bottom:14px;width:68px;height:68px;min-height:68px;min-width:68px;padding:0;border-radius:50%;box-shadow:0 10px 24px #00000052;pointer-events:auto}.runner-ending-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;text-align:center;font-size:clamp(1.2rem,2.7vw,2rem);font-weight:700;letter-spacing:.02em;color:#fff6e8;background:radial-gradient(circle at center,#08050eb8,#08050ed1);text-shadow:0 0 16px rgba(255,225,127,.22);pointer-events:none}.runner-ending-overlay-lost{background:radial-gradient(circle at center,#200808bd,#120606d6);text-shadow:0 0 14px rgba(255,148,136,.28)}.runner-road{position:absolute;left:0;right:0;bottom:2px;height:122px;background:linear-gradient(180deg,#2f1f36f2,#1c1225fa),repeating-linear-gradient(90deg,rgba(255,255,255,.02) 0 36px,transparent 36px 84px);border-top:1px solid rgba(255,219,142,.1);box-shadow:inset 0 8px 24px #00000038}.runner-road:before{content:"";position:absolute;left:0;right:0;top:50%;height:4px;transform:translateY(-50%);background:repeating-linear-gradient(90deg,var(--runner-road-line) 0 34px,transparent 34px 68px);opacity:.7}.runner-hazard{position:absolute;display:grid;place-items:end center;pointer-events:none}.runner-hazard img{width:100%;height:auto;max-height:54px;object-fit:contain;filter:drop-shadow(0 8px 12px rgba(0,0,0,.35));image-rendering:pixelated;-webkit-user-select:none;user-select:none}.runner-pickup{position:absolute;width:64px;height:64px;border-radius:50%;display:grid;place-items:center;border:1px solid rgba(255,219,142,.28);background:#140c1ae6;box-shadow:0 0 0 8px #ffdb8e14}.runner-pickup span{font-size:1.5rem}.runner-pickup-knowledge{color:#9de7ff}.runner-pickup-tools{color:#8ef2aa}.runner-pickup-people{color:#ffd07f}.runner-pickup-collected{opacity:.2;transform:scale(.8)}.runner-sun{position:absolute;bottom:190px;width:112px;height:112px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle,#fff9cd,#ffe27d 38%,#ffb25c 72%,#ffb25c00 74%);box-shadow:0 0 70px #ffdf7fb8}.runner-sun span{font-size:2.25rem;color:#140c1ae6}.runner-bike{position:absolute;width:176px;height:112px;transform-origin:center bottom;filter:drop-shadow(0 14px 20px rgba(0,0,0,.34));transition:filter .18s ease}.runner-bike img{width:100%;height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none}.runner-bike-jumping{filter:drop-shadow(0 18px 22px rgba(0,0,0,.42))}.runner-progress{margin-top:14px;display:grid;gap:8px}.runner-progress-track{width:100%;height:10px;border-radius:999px;overflow:hidden;background:#ffffff14;border:1px solid rgba(255,219,142,.12)}.runner-progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#8ef2aa,#ffe27d 55%,#ffb25c)}.runner-progress-labels{display:flex;justify-content:space-between;color:var(--runner-muted);font-family:IBM Plex Mono,ui-monospace,monospace;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase}.runner-summary-grid{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.runner-summary-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}@media(max-width:980px){.runner-hero,.runner-stage,.runner-summary{padding:22px}.runner-hero-layout,.runner-summary-grid{grid-template-columns:1fr}.runner-scene{min-height:380px}}@media(max-width:720px){.runner-bike{width:146px;height:92px}.runner-sun{width:88px;height:88px}.runner-progress-labels{font-size:.68rem}.runner-scene{min-height:340px}.runner-score-overlay{top:10px;max-width:calc(100% - 20px);flex-wrap:nowrap;gap:4px}.runner-score-overlay .runner-status,.runner-score-overlay .runner-badge{padding:5px 7px;font-size:.62rem;letter-spacing:.04em}.runner-score-overlay .runner-status{display:none}.runner-jump-overlay{right:10px;bottom:10px;width:58px;height:58px;min-height:58px;min-width:58px;font-size:.82rem}}.runner-controls{margin-top:14px;display:flex;flex-wrap:wrap;gap:12px}@media(max-width:980px){.motorcycle-hero,.journey-board,.sunset-panel,.playable-lab-teaser{padding:22px}.playable-lab-grid,.motorcycle-hero-layout{grid-template-columns:1fr}.journey-stop{grid-template-columns:1fr 72px 1fr}.journey-stop-card{width:min(100%,100%)}}@media(max-width:720px){.journey-track:before{left:26px;transform:none}.journey-stop{grid-template-columns:1fr;gap:12px}.journey-stop-left .journey-stop-card,.journey-stop-right .journey-stop-card{justify-self:stretch}.journey-spine{display:none}.journey-stop-card{width:100%}.journey-road{top:22px;right:24px;bottom:22px;left:24px}.journey-sun{width:88px;height:88px;right:12px;top:18px}}.game-page{--bg-soft: rgba(34, 22, 12, .8);--surface: rgba(48, 29, 16, .9);--surface-strong: rgba(69, 41, 21, .96);--text: #fff6e7;--muted: #f1cf9d;--accent: #ff9f42;--accent-2: #ffe06a;--border: rgba(255, 198, 102, .24);--shadow: 0 24px 72px rgba(0, 0, 0, .42)}.game-page:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-2;background:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px),radial-gradient(circle at 10% 12%,rgba(129,255,137,.2),transparent 18%),radial-gradient(circle at 90% 14%,rgba(255,225,106,.22),transparent 20%),radial-gradient(circle at 50% 86%,rgba(255,159,66,.1),transparent 22%),linear-gradient(180deg,#03060c66,#03060ceb);background-size:32px 32px,32px 32px,auto,auto,auto,auto;opacity:.95}.game-page .backdrop-one{background:#81ff892e}.game-page .backdrop-two{background:#ffe16a2e}.game-page .panel{border-color:#ffc6662e;box-shadow:0 20px 60px #00000061,inset 0 1px #ffffff0a}.game-page .nav{background:#120d09d6;border-color:#ffc6662e}.game-page .hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#25160eeb,#120b08eb),radial-gradient(circle at 16% 18%,rgba(129,255,137,.12),transparent 22%),radial-gradient(circle at 82% 22%,rgba(255,225,106,.12),transparent 24%)}.game-page .hero:after{content:"";position:absolute;top:16px;right:16px;bottom:16px;left:16px;border-radius:22px;border:1px dashed rgba(255,225,106,.12);pointer-events:none}.game-page .hero-copy h1{text-shadow:0 0 18px rgba(255,225,106,.12)}.hero:after{content:"";position:absolute;top:14px;right:14px;bottom:14px;left:14px;border-radius:20px;border:1px dashed rgba(255,211,102,.1);pointer-events:none}.hero-inner{display:grid;grid-template-columns:1.3fr .7fr;gap:32px;align-items:center;position:relative;z-index:1}.eyebrow{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);margin-bottom:14px}h1{font-family:var(--font-display);font-size:clamp(3rem,7vw,5.6rem);font-weight:800;line-height:.92;letter-spacing:-.04em;color:var(--text);margin-bottom:20px}h1 em{font-style:normal;color:var(--gold)}.hero-subtitle{font-size:1.08rem;line-height:1.7;color:var(--muted);max-width:54ch;margin-bottom:28px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 22px;border-radius:var(--r-pill);border:1px solid transparent;font-family:var(--font-body);font-size:.92rem;font-weight:500;cursor:pointer;text-decoration:none;transition:transform .15s,box-shadow .15s,background .15s,border-color .15s}.btn:hover{transform:translateY(-2px)}.btn-primary{background:linear-gradient(135deg,var(--gold),var(--amber));color:#1a1000;font-weight:700;box-shadow:0 8px 24px #ffd16633}.btn-primary:hover{box-shadow:0 12px 32px #ffd16652}.btn-ghost{background:var(--surface);border-color:var(--border);color:var(--text)}.btn-ghost:hover{background:var(--surface-2);border-color:var(--border-2)}.game-page .hero-visual{position:relative;display:flex;justify-content:center;align-items:center;min-height:320px;padding:22px;border-radius:26px;border:2px solid rgba(255,225,106,.16);background:linear-gradient(135deg,rgba(129,255,137,.253),transparent 34%),linear-gradient(180deg,#6e3d20fa,#22150ceb);overflow:hidden}.game-page .hero-visual:before{content:"";position:absolute;top:12px;right:12px;bottom:12px;left:12px;border-radius:20px;border:1px solid rgba(255,225,106,.12);opacity:.45;pointer-events:none}.game-page .hero-character{position:relative;z-index:1;width:min(70%,320px);filter:drop-shadow(0 0 24px rgba(255,159,66,.24)) drop-shadow(0 18px 24px rgba(0,0,0,.42))}.game-page .button-dark{background:linear-gradient(135deg,#7bff83,#ffe06a);color:#181108;box-shadow:0 12px 26px #88ff9629}.game-page .button-light{background:#ffffff0a;border-color:#ffe16a2e}.game-page .button-light:hover{background:#ffffff14}.game-page .game-gate{position:relative;overflow:hidden;background:linear-gradient(180deg,#392112e6,#1e1109f0),radial-gradient(circle at top left,rgba(129,255,137,.08),transparent 26%)}.game-page .game-gate:after{content:"";position:absolute;inset:auto 18px 18px 18px;height:10px;border-radius:999px;background:linear-gradient(90deg,transparent,rgba(255,225,106,.45),transparent);opacity:.6}.game-page .journey-grid{position:relative;grid-template-columns:1fr;gap:18px;padding:8px 0 28px}.game-page .journey-grid:before{content:"";position:absolute;top:0;bottom:0;left:50%;width:4px;transform:translate(-50%);background:linear-gradient(180deg,transparent,rgba(255,225,106,.32),transparent);opacity:.4}.game-page .journey-grid .journey-card{position:relative;overflow:visible;padding:0;border:0;background:transparent;box-shadow:none}.game-page .journey-grid .journey-card:first-child{grid-column:auto}.game-page .journey-grid .preview-card{position:relative;width:min(560px,calc(50% - 44px));min-height:310px;padding:16px;border:2px solid rgba(255,198,102,.22);border-radius:24px;background:linear-gradient(180deg,#492b16fa,#21130bf5),radial-gradient(circle at top right,rgba(129,255,137,.1),transparent 24%);box-shadow:0 18px 48px #00000057,inset 0 1px #ffffff0a;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}@media(hover:hover)and (pointer:fine){.game-page .journey-grid .preview-card:hover{transform:translateY(-6px);border-color:#ffc66666;box-shadow:0 24px 56px #0006,0 0 0 1px #ffe16a24,inset 0 1px #ffffff0d}}.game-page .journey-grid .journey-card:nth-child(odd) .preview-card{margin-right:auto}.game-page .journey-grid .journey-card:nth-child(2n) .preview-card{margin-left:auto}.game-page .journey-grid .preview-card{display:grid;grid-template-rows:auto auto}.game-page .journey-grid .thumbnail-placeholder{min-height:0;width:100%;aspect-ratio:4 / 3;height:auto}.game-page .journey-grid .preview-copy{min-height:96px}.game-page .journey-grid .preview-description{line-clamp:2;-webkit-line-clamp:2}.game-page .journey-grid .preview-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:22px;background:linear-gradient(135deg,rgba(255,225,106,.1),transparent 22%,transparent 78%,rgba(129,255,137,.06));pointer-events:none}.game-page .journey-grid .preview-card:after{content:"";position:absolute;top:28px;right:-38px;width:38px;height:2px;background:linear-gradient(90deg,#ffe16a80,#ffe16a38)}.game-page .journey-grid .journey-card:nth-child(2n) .preview-card:after{right:auto;left:-38px}.game-page .timeline-year{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:2;min-width:56px;padding:5px 10px;border-radius:999px;border:1px solid rgba(255,225,106,.34);background:#1a100af0;color:#ffe06a;font-size:.74rem;line-height:1;letter-spacing:.08em;text-align:center;font-family:IBM Plex Mono,ui-monospace,monospace}.game-page .project-kicker{color:#ffe06a}.game-page .tags span{background:#ffe16a14;border-color:#ffe16a2e}.game-page .media-placeholder,.game-page .media-carousel,.game-page .media-card-link{border-color:#ffc6662e}.game-page .media-placeholder{background:#ffe16a0a}.game-page .media-placeholder p,.game-page .carousel-counter{color:#ffe06a}.game-page .contact-panel{background:linear-gradient(180deg,#2f1c0feb,#190f08f5)}.game-page .playable-lab-teaser{background:linear-gradient(180deg,#341e10eb,#1b100af2),radial-gradient(circle at top left,rgba(129,255,137,.08),transparent 28%)}.game-page .playable-lab-teaser .journey-runner-page{display:grid;gap:14px;margin-top:6px}.game-page .runner-section{position:relative;overflow:hidden;margin-top:0;padding:24px;border:1px solid rgba(255,198,102,.16);border-radius:24px;background:linear-gradient(180deg,#2b190ff5,#180e08f2),radial-gradient(circle at top left,rgba(129,255,137,.08),transparent 30%);box-shadow:0 18px 48px #0000004d,inset 0 1px #ffffff08}.game-page .runner-card{position:relative;z-index:1;display:grid;gap:14px;width:100%}.game-page .runner-card .hero-text{max-width:68ch;margin:0;color:var(--muted);font-size:1.03rem;line-height:1.72}.game-page .status-text{display:inline-flex;width:fit-content;padding:.5rem .9rem;border-radius:999px;border:1px solid rgba(255,225,106,.18);background:#ffe16a14;color:var(--accent-2);font-size:.92rem;line-height:1.45;font-weight:600}.game-page .instructions-list{margin:0;padding:0;display:grid;gap:10px;list-style:none}.game-page .instructions-list li{position:relative;padding:12px 14px 12px 28px;border-radius:14px;border:1px solid rgba(255,198,102,.12);background:#ffffff08;color:var(--muted);line-height:1.55}.game-page .instructions-list li:before{content:"•";position:absolute;left:14px;top:12px;color:var(--accent-2)}.game-page .about-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(280px,.9fr);gap:28px;align-items:start;position:relative;z-index:1}.game-page .about-grid p{color:var(--muted);font-size:1.03rem;line-height:1.78}.game-page .about-grid ul{margin:0;padding:0;list-style:none;display:grid;gap:12px}.game-page .about-grid li{padding:14px 16px;border:1px solid rgba(255,198,102,.14);border-radius:14px;background:#ffffff08;color:var(--text);line-height:1.55}.game-page .about-grid li:before{content:"•";color:var(--accent-2);margin-right:8px}.game-page .about-grid strong{color:var(--text)}.game-page .about-panel{background:linear-gradient(180deg,#311c0ff0,#160c07f7),radial-gradient(circle at top right,rgba(255,225,106,.06),transparent 28%)}.game-page .about-panel .section-heading{margin-bottom:22px}.game-page .playable-lab-teaser .runner-stage{margin-top:0;padding:18px;border:1px solid rgba(255,198,102,.16);border-radius:22px;background:#100a188f;box-shadow:0 14px 36px #0000003d,inset 0 1px #ffffff08}.game-page .playable-lab-teaser .runner-hero:after,.game-page .playable-lab-teaser .runner-stage:after{display:none}.game-page .playable-lab-teaser .runner-instructions{background:#ffffff08}.game-page .playable-lab-teaser .runner-stage{padding-bottom:16px}@media(max-width:980px){.game-page .hero-visual{min-height:260px}.game-page .journey-grid{grid-template-columns:1fr;gap:14px;padding-bottom:36px}.game-page .journey-grid:before{left:18px;transform:none}.game-page .journey-grid .preview-card{width:calc(100% - 42px);margin-left:auto;min-height:260px}.game-page .journey-grid .journey-card:nth-child(odd) .preview-card,.game-page .journey-grid .journey-card:nth-child(2n) .preview-card{margin-left:auto;margin-right:0}.game-page .journey-grid .preview-card:after{right:auto;left:-26px;width:26px}.game-page .timeline-year{left:18px;transform:translate(-50%);top:18px}.game-page .playable-lab-teaser .runner-hero,.game-page .playable-lab-teaser .runner-stage{padding:16px}.game-page .about-grid{grid-template-columns:1fr;gap:20px}.game-page .about-grid p{font-size:1rem;line-height:1.85}}.game-page .button-white{background:linear-gradient(180deg,#fff8e8f5,#ffecc6eb);color:#24160b;border:1px solid rgba(255,225,142,.65);box-shadow:0 8px 18px #00000029,inset 0 1px #ffffffb3}.game-page .button-white:hover{background:linear-gradient(180deg,#fffcf4fa,#fff0d0f2);border-color:#ffe496d1;box-shadow:0 10px 22px #0003,inset 0 1px #fffc;transform:translateY(-2px)}.game-page .card-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;padding:clamp(10px,2.8vh,28px);display:grid;place-items:center;overflow-y:auto;background:#03060cbd;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.game-page .card-overlay-panel{width:min(1080px,96vw);min-height:78vh;max-height:92vh;overflow-y:auto;border-radius:22px;border:1px solid var(--border);background:var(--surface-strong);box-shadow:0 28px 80px #c2991385;padding:22px}.game-page .card-overlay-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}:root{--bg: #100c08;--surface: rgba(255,255,255,.035);--surface-2: rgba(255,255,255,.055);--border: rgba(255,200,100,.14);--border-2: rgba(255,200,100,.26);--text: #fdf5e8;--muted: #c4a97a;--amber: #ffb347;--gold: #ffd166;--green: #8fffaa;--shadow: 0 32px 80px rgba(0,0,0,.55);--r-card: 22px;--r-pill: 999px;--font-display: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "DM Mono", monospace}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,rgba(124,243,197,.08),transparent 30%),radial-gradient(circle at top right,rgba(255,191,105,.07),transparent 28%),linear-gradient(180deg,#08101f,#0b1020 45%,#060912);color:var(--text);font-family:Space Grotesk,system-ui,sans-serif}a{color:inherit;text-decoration:none}button,a{-webkit-tap-highlight-color:transparent}button{font:inherit}#root{min-height:100vh}.app-shell{position:relative;min-height:100vh;isolation:isolate}.app-shell:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:120;opacity:0;background:linear-gradient(0deg,#7dffd60f,#7dffd60f),repeating-linear-gradient(90deg,#ff50500f 0,#ff50500f 1px,#0000 1px,#0000 4px),repeating-linear-gradient(180deg,#ffffff24 0,#ffffff24 1px,#0000 1px,#0000 3px);mix-blend-mode:screen}.page{position:relative;width:min(1160px,calc(100% - 32px));margin:0 auto;padding:28px 0 48px}.panel-reveal{opacity:0;transform:translateY(18px) scale(.985);filter:blur(4px);transition:opacity .52s ease,transform .52s cubic-bezier(.22,1,.36,1),filter .52s ease;transition-delay:var(--reveal-delay, 0ms)}.panel-reveal.is-visible{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}.app-shell.app-transition-out .page{animation:page-glitch-out .19s steps(4,end) both}.app-shell.app-transition-in .page{animation:page-glitch-in .24s steps(4,end) both}.app-shell.app-transition-out:after{animation:glitch-overlay-out .19s ease-out both}.app-shell.app-transition-in:after{animation:glitch-overlay-in .24s ease-out both}@keyframes page-glitch-out{0%{opacity:1;transform:translateZ(0);filter:saturate(1)}22%{transform:translate3d(2px,-1px,0);filter:saturate(1.18) contrast(1.08) hue-rotate(7deg) drop-shadow(1px 0 0 rgba(255,70,70,.5))}48%{transform:translate3d(-2px,1px,0);filter:saturate(.9) contrast(1.12) hue-rotate(-6deg) drop-shadow(-1px 0 0 rgba(80,230,255,.45))}70%{transform:translate3d(1px,0,0);filter:saturate(1.12) contrast(1.06)}to{opacity:0;transform:translate3d(0,3px,0);filter:saturate(.86) contrast(1.08)}}@keyframes page-glitch-in{0%{opacity:0;transform:translate3d(0,-4px,0);filter:saturate(1.24) contrast(1.1)}24%{opacity:.68;transform:translate3d(-2px,1px,0);filter:hue-rotate(-8deg) drop-shadow(-1px 0 0 rgba(80,230,255,.5))}54%{opacity:.9;transform:translate3d(2px,-1px,0);filter:hue-rotate(7deg) drop-shadow(1px 0 0 rgba(255,70,70,.45))}78%{opacity:.96;transform:translate3d(-1px,0,0);filter:saturate(1.12) contrast(1.06)}to{opacity:1;transform:translateZ(0);filter:saturate(1) contrast(1)}}@keyframes glitch-overlay-out{0%{opacity:0;transform:translateZ(0)}26%{opacity:.3}60%{opacity:.2}to{opacity:0;transform:translate3d(0,5px,0)}}@keyframes glitch-overlay-in{0%{opacity:0;transform:translate3d(0,-6px,0)}18%{opacity:.34}46%{opacity:.22}to{opacity:0;transform:translateZ(0)}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.panel-reveal{opacity:1;transform:none;filter:none;transition:none}.app-shell.app-transition-out .page,.app-shell.app-transition-in .page,.app-shell.app-transition-out:after,.app-shell.app-transition-in:after{animation:none}}.backdrop{position:fixed;inset:auto;pointer-events:none;border-radius:999px;filter:blur(60px);opacity:.45;z-index:-1}.backdrop-one{top:40px;right:8vw;width:220px;height:220px;background:#7cf3c533}.backdrop-two{top:320px;left:2vw;width:280px;height:280px;background:#ffbf6924}.panel{background:var(--bg-soft);border:1px solid var(--border);border-radius:28px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.nav{position:sticky;top:10px;z-index:40;margin-bottom:16px;padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:16px;border:1px solid rgba(255,255,255,.12);border-radius:14px;background:#090e1bc7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nav-brand{display:flex;align-items:center}.nav-title{font-size:.84rem;letter-spacing:.08em;text-transform:uppercase;font-family:IBM Plex Mono,ui-monospace,monospace;color:var(--muted)}.nav-links{display:flex;gap:6px;justify-content:center;align-items:center;flex-wrap:wrap}.nav-link{border:0;min-height:32px;padding:0 8px;display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--muted);font-size:.84rem;font-family:inherit;text-decoration:none;cursor:pointer;transition:color .16s ease,opacity .16s ease}.nav-link:hover,.nav-link-active{color:var(--text)}.nav-link:focus-visible,.nav-switch:focus-visible,.button:focus-visible,.carousel-arrow:focus-visible,.media-card-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.nav-switch{min-height:32px;padding:0;display:inline-flex;align-items:center;gap:8px;border-radius:999px;border:0;background:transparent;color:var(--text);font-family:inherit;font-size:.75rem;letter-spacing:.02em;cursor:pointer;text-transform:uppercase;transition:opacity .16s ease}.nav-switch-text{color:var(--muted);font-size:.7rem;font-family:IBM Plex Mono,ui-monospace,monospace;letter-spacing:.08em}.nav-switch-track{width:42px;height:24px;border-radius:999px;border:1px solid rgba(255,255,255,.28);background:#ffffff14;padding:2px;display:flex;align-items:center}.nav-switch-thumb{width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 2px 8px #00000059;transform:translate(0);transition:transform .18s ease}.nav-switch[aria-checked=true] .nav-switch-track{background:#7cf3c538;border-color:#7cf3c580}.nav-switch[aria-checked=true] .nav-switch-thumb{transform:translate(18px)}.nav-switch[aria-checked=false] .nav-switch-text:first-child,.nav-switch[aria-checked=true] .nav-switch-text:last-child{color:var(--text)}.hero{padding:40px;display:grid;gap:20px}.hero-layout{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);gap:28px;align-items:center}.hero-copy{display:grid;gap:20px;justify-items:start}.hero-visual{display:flex;justify-content:flex-end;align-items:center}.hero-character{width:min(100%,340px);height:auto;object-fit:contain;filter:drop-shadow(0 24px 40px rgba(0,0,0,.32));-webkit-user-select:none;user-select:none;pointer-events:none}.eyebrow{margin:0;color:var(--accent);text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;font-family:IBM Plex Mono,ui-monospace,monospace}h1,h2,h3,p{margin:0}h1{font-size:clamp(2.8rem,7vw,5.8rem);line-height:.94;max-width:10ch;letter-spacing:-.05em}h2{font-size:clamp(1.6rem,3vw,2.4rem);letter-spacing:-.03em}.hero-text,.about-grid p,.project-card p,.contact-panel p,.game-copy p,.gate-text{color:var(--muted);font-size:1.03rem;line-height:1.7}.hero-text{max-width:62ch}.hero-actions{display:flex;flex-wrap:wrap;gap:12px}.button{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 18px;border-radius:999px;border:1px solid transparent;transition:transform .16s ease,border-color .16s ease,background-color .16s ease,box-shadow .16s ease}.button:hover{transform:translateY(-1px)}.button-dark{background:linear-gradient(135deg,var(--accent) 0%,#47d3ac 100%);color:#07111d;font-weight:700}.button-light{background:#ffffff0a;border-color:#ffffff14}.button-small{min-height:36px;padding:0 14px;font-size:.9rem;font-weight:600}.project-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.project-links .button-small{background:#ffffff0f;border-color:#ffffff1f;color:var(--text);text-decoration:none}.project-links .button-small:hover{background:#ffffff1a;border-color:#fff3}.hero-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.hero-metrics article,.project-card,.about-panel,.contact-panel,.game-panel,.game-gate,.journey-card,.locked-state{background:var(--surface)}.hero-metrics article{border:1px solid var(--border);border-radius:20px;padding:16px}.hero-metrics strong{display:block;font-size:1.7rem}.hero-metrics span{color:var(--muted);font-size:.92rem}.about-panel,.contact-panel,.game-panel,.game-gate,.projects-grid{margin-top:20px}#projects{margin-top:28px}.about-panel,.contact-panel,.game-panel,.game-gate,#projects{padding:28px}.section-heading{display:grid;gap:8px;margin-bottom:18px}.about-grid{display:flex;gap:24px;align-items:start}.contact-stack{display:grid;gap:12px}.contact-item{display:grid;gap:6px;padding:14px 16px;border:1px solid var(--border);border-radius:14px;background:#ffffff08}.contact-label{font-family:IBM Plex Mono,ui-monospace,monospace;font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.contact-value{color:var(--text);font-weight:500;word-break:break-word}.contact-linkedin{display:inline-flex;align-items:center;gap:10px;width:fit-content;max-width:100%;min-height:42px;padding:8px 12px;border:1px solid var(--border);border-radius:12px;background:#ffffff0a;color:var(--text);transition:border-color .15s ease,background-color .15s ease,transform .15s ease}.contact-linkedin:hover{transform:translateY(-1px);border-color:#ffffff4d;background:#ffffff14}.contact-linkedin svg{width:22px;height:22px;flex:0 0 22px;fill:#0a66c2}.contact-linkedin span{overflow-wrap:anywhere;line-height:1.4}.projects-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.project-card{border:1px solid var(--border);border-radius:24px;padding:22px}.preview-card{width:100%;border:0;padding:0;margin:0;background:transparent;color:inherit;text-align:left;display:grid;gap:14px;cursor:pointer}.preview-copy{display:grid;gap:8px}.preview-description{color:var(--muted);font-size:.95rem;line-height:1.45;display:-webkit-box;-webkit-box-orient:vertical;line-clamp:1;-webkit-line-clamp:1;overflow:hidden}.thumbnail-placeholder{border-radius:14px;min-height:136px;border:1px dashed rgba(255,255,255,.26);background:linear-gradient(135deg,rgba(255,255,255,.08),transparent 45%),linear-gradient(180deg,#ffffff08,#ffffff03);display:grid;place-items:center}.preview-thumbnail-with-image{overflow:hidden;border-style:solid;aspect-ratio:4 / 3;width:100%}.preview-thumbnail-image{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1);transition:transform .22s ease}@media(hover:hover)and (pointer:fine){.project-card:hover .preview-thumbnail-image,.journey-card .preview-card:hover .preview-thumbnail-image{transform:scale(1.03)}}.thumbnail-placeholder span{font-family:IBM Plex Mono,ui-monospace,monospace;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}.card-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;padding:clamp(10px,2.8vh,28px);display:grid;place-items:center;overflow-y:auto;background:#03060cdb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.card-overlay-panel{width:min(1080px,96vw);min-height:78vh;max-height:92vh;overflow-y:auto;border-radius:22px;border:1px solid var(--border);background:var(--surface-strong);box-shadow:0 20px 52px #0000006b;padding:22px}.card-overlay-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}.card-overlay-close{color:var(--text);border-color:#ffffff52;background:#ffffff1f;box-shadow:inset 0 0 0 1px #00000014}.card-overlay-close:hover{background:#ffffff2e;border-color:#ffffff70}body:has(.software-page) .card-overlay{background:#040a16e0;-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px)}body:has(.software-page) .card-overlay-panel{border-color:#75b7ff3d;background:linear-gradient(180deg,#131f3af7,#0b1326fa);box-shadow:0 20px 52px #3178d133}body:has(.software-page) .card-overlay-close{border-color:#75b7ff6b;background:#75b7ff33;color:#eff7ff}body:has(.game-page) .card-overlay{background:#0a0704db;-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px)}body:has(.game-page) .card-overlay-panel{border-color:#ffc6663d;background:linear-gradient(180deg,#452915fa,#21130bf7);box-shadow:0 20px 52px #c299134d}body:has(.game-page) .card-overlay-close{border-color:#ffc6666b;background:#ffc66629;color:#fff4df}body:has(.motorcycle-page) .card-overlay{background:#0c0712e0;-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px)}body:has(.motorcycle-page) .card-overlay-panel{border-color:#ffba663d;background:linear-gradient(180deg,#341e42fa,#1c1027fa);box-shadow:0 20px 52px #b56dff38}body:has(.motorcycle-page) .card-overlay-close{border-color:#ffba666b;background:#ffba6629;color:#fff1df}.project-kicker{color:var(--accent-2);font-size:.8rem;font-family:IBM Plex Mono,ui-monospace,monospace;text-transform:uppercase;letter-spacing:.12em;margin-bottom:10px}.project-card h3{font-size:1.35rem;margin-bottom:10px}.detail-row{margin-top:10px;color:var(--muted)}.detail-row strong{color:var(--text)}.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.tags span{border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:6px 10px;font-size:.82rem;color:var(--text)}.media-placeholder{margin-top:16px;border:1px dashed rgba(255,255,255,.3);border-radius:14px;padding:12px;display:grid;gap:6px;background:#ffffff05}.media-card-link{display:block;border-radius:14px;outline:1px solid rgba(255,255,255,.2);outline-offset:2px}.media-card-link:hover{outline:2px solid rgba(255,255,255,.38)}.media-placeholder p{font-family:IBM Plex Mono,ui-monospace,monospace;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-size:.75rem}.media-placeholder span{color:var(--muted);font-size:.92rem;line-height:1.5}.media-gallery{margin-top:16px;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.media-gallery-item{border:1px solid rgba(255,255,255,.14);border-radius:10px;overflow:hidden;display:grid;gap:6px}.media-gallery-item img{width:100%;max-height:140px;object-fit:cover}.media-gallery-item .image-caption{padding:6px 8px;background:#ffffff05;color:var(--muted);font-size:.8rem;line-height:1.4}.jam-title-image{width:100%;max-height:180px;object-fit:cover;border-radius:10px;border:1px solid rgba(255,255,255,.14);transition:transform .15s ease}.media-card-link:hover .jam-title-image{transform:translateY(-2px)}.media-card-link:hover .media-placeholder{background:#ffffff0a}.image-caption{color:var(--muted);font-size:.88rem}.media-carousel{margin-top:16px;display:grid;gap:14px;border:1px solid rgba(255,255,255,.14);border-radius:10px;overflow:hidden;padding:0}.card-overlay-panel .media-carousel{margin-top:20px}.card-overlay-panel .carousel-viewport{min-height:260px;max-height:420px}.carousel-viewport{width:100%;min-height:200px;max-height:280px;display:flex;align-items:center;justify-content:center;background:#ffffff05;overflow:hidden}@media(min-width:981px){.carousel-viewport{min-height:320px;max-height:320px}.card-overlay-panel .carousel-viewport{min-height:380px;max-height:460px}}.carousel-viewport img,.carousel-viewport video{width:100%;height:100%;object-fit:contain}.carousel-image-default{transform:scale(1);transition:transform .18s ease;cursor:zoom-in}.carousel-controls{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:14px 16px;background:#ffffff05}.carousel-arrow{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#ffffff0f;color:var(--text);font-size:1.1rem;cursor:pointer;transition:all .15s ease;flex-shrink:0}.carousel-arrow:hover{background:#ffffff1f;border-color:#ffffff4d;transform:scale(1.05)}.carousel-arrow:active{transform:scale(.95)}.carousel-info{display:flex;flex-direction:column;gap:6px;min-width:0}.carousel-zoom-toggle{align-self:center;min-height:30px;padding:0 10px;border:1px solid rgba(255,255,255,.24);border-radius:999px;background:#ffffff0f;color:var(--text);font-family:IBM Plex Mono,ui-monospace,monospace;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background-color .15s ease,border-color .15s ease}.carousel-zoom-toggle:hover{background:#ffffff1f;border-color:#ffffff57}.carousel-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10020;background:#03060cd6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;padding:24px}.carousel-lightbox-frame{width:min(1400px,94vw);max-height:92vh;border:1px solid rgba(255,255,255,.18);border-radius:16px;background:#0c1222f0;box-shadow:0 24px 64px #0000008c;padding:14px;display:grid;gap:10px}.carousel-lightbox-close{justify-self:end;min-height:32px;padding:0 12px;border:1px solid rgba(255,255,255,.2);border-radius:999px;background:#ffffff0f;color:var(--text);font-family:IBM Plex Mono,ui-monospace,monospace;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;cursor:pointer}.carousel-lightbox-image{width:100%;max-height:calc(92vh - 90px);object-fit:contain;border-radius:10px}.carousel-lightbox-caption{margin:0;color:var(--muted);text-align:center;font-size:.9rem;line-height:1.5}.carousel-counter{font-size:.8rem;color:var(--muted);font-family:IBM Plex Mono,monospace;text-align:center}.carousel-info .image-caption{font-size:.85rem;line-height:1.4;text-align:center}.journey-shell{margin-top:14px;display:grid;gap:20px}.journey-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.journey-grid .journey-card:first-child{grid-column:span 2}.journey-card{border:1px solid var(--border);border-radius:24px;padding:22px}.locked-state{border:1px solid var(--border);border-radius:24px;padding:24px}@media(max-width:980px){.nav{position:sticky;top:10px;display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"brand switch" "links links";align-items:center;row-gap:8px;column-gap:12px}.nav-brand{grid-area:brand}.nav-switch{grid-area:switch;justify-self:end}.nav-links{grid-area:links;justify-content:center}.hero-layout,.about-grid,.projects-grid,.journey-grid{grid-template-columns:1fr}.hero-visual{justify-content:center}.journey-grid .journey-card:first-child{grid-column:auto}.hero{padding:28px 22px}.about-panel,.contact-panel,.game-panel,.game-gate,#projects{padding:22px}.hero-character{width:min(100%,280px)}.card-overlay{padding:12px}.card-overlay-panel{padding:18px;width:min(1080px,100%);min-height:80vh;max-height:94vh}}@media(max-width:640px){.page{width:min(100% - 20px,1160px);padding:18px 0 28px}.hero-metrics{grid-template-columns:1fr}.carousel-controls{grid-template-columns:auto 1fr auto;gap:10px;padding:12px}}
