:root{font-family:system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg-dark: #171a1f;--bg-mid: #20252c;--bg-card: #2a3038;--bg-elev: #333b45;--bg-soft: #242b33;--grey-outline: #465161;--grey-outline-strong: #5d6a7d;--green: #22c55e;--green-glow: rgba(34, 197, 94, .5);--green-dim: #16a34a;--text: #e5e7eb;--text-muted: #9ca3af;--white: #ffffff}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 18% -12%,rgba(255,255,255,.05),transparent 42%),radial-gradient(circle at 82% -18%,rgba(34,197,94,.08),transparent 36%),var(--bg-dark);color:var(--text)}#root{min-height:100vh}a{color:var(--green);text-decoration:none}a:hover{color:var(--green-dim)}button{font-family:inherit;cursor:pointer}.app-layout{display:flex;min-height:100vh}.app-content{flex:1;display:flex;flex-direction:column;min-height:100vh;margin-left:64px;background:linear-gradient(180deg,rgba(255,255,255,.03),transparent 220px)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:64px;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--bg-soft),var(--bg-mid));border-right:1px solid var(--grey-outline);z-index:100;overflow:hidden;transition:width .3s cubic-bezier(.4,0,.2,1)}.sidebar:hover{width:220px;box-shadow:4px 0 24px #0006}.sidebar-profile{display:flex;align-items:center;gap:12px;padding:16px;min-height:64px;border-bottom:1px solid var(--grey-outline);cursor:pointer;transition:background .2s}.sidebar-profile:hover{background:#ffffff0d}.sidebar-avatar{flex-shrink:0;width:32px;height:32px;border-radius:50%;overflow:hidden;background:var(--bg-card)}.sidebar-avatar img{width:100%;height:100%;object-fit:cover;display:block}.sidebar-profile-info{opacity:0;white-space:nowrap;transition:opacity .2s .05s}.sidebar:hover .sidebar-profile-info{opacity:1}.sidebar-profile-name{font-size:.85rem;font-weight:500;color:var(--text)}.sidebar-nav{display:flex;flex-direction:column;gap:4px;padding:12px 8px;flex:1}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:1px solid transparent;border-radius:10px;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:color .2s,background .2s,box-shadow .2s}.sidebar-item:hover{color:var(--text);background:#ffffff0d}.sidebar-item:focus-visible{outline:2px solid var(--green);outline-offset:2px}.sidebar-item-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px}.sidebar-item:not(.sidebar-item--active) .sidebar-item-icon{color:var(--grey-outline)}.sidebar-item:hover:not(.sidebar-item--active) .sidebar-item-icon{color:var(--text-muted)}.sidebar-item-label{font-size:.85rem;font-weight:500;letter-spacing:.02em;opacity:0;transition:opacity .2s .05s}.sidebar:hover .sidebar-item-label{opacity:1}.sidebar-item--active{background:var(--green-dim);color:var(--white);box-shadow:0 0 16px var(--green-glow)}.sidebar-item--active .sidebar-item-icon{color:var(--white)}.sidebar-item--developer.sidebar-item--active{background:#b91c1c;box-shadow:0 0 16px #b91c1c80}.header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;background:var(--bg-soft);border-bottom:1px solid var(--grey-outline);min-height:56px}.header-left{display:flex;align-items:center;gap:.6rem}.header-logo-icon{width:30px;height:30px;border-radius:6px}.logo-text{margin:0;font-size:1.25rem;font-weight:700;color:var(--text);letter-spacing:.02em}.header-right{display:flex;align-items:center;gap:.5rem}.header-account{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--grey-outline);background:var(--bg-elev);color:var(--text-muted);cursor:pointer;transition:color .2s,border-color .2s,background .2s}.header-account:hover{color:var(--text);border-color:var(--grey-outline-strong);background:var(--bg-card)}.api-status{display:inline-flex;align-items:center;gap:.35rem;font-size:.75rem;font-weight:500;padding:.25rem .5rem;border-radius:6px}.api-status .api-status-icon{flex-shrink:0}.api-status-label{display:inline}.db-status{display:inline-flex;align-items:center;gap:.25rem;margin-left:.5rem;padding-left:.5rem;border-left:1px solid rgba(255,255,255,.3)}.db-status .db-status-icon{flex-shrink:0;color:inherit}.api-status--pending{color:var(--text-muted);background:var(--bg-elev)}.api-status--ok{color:var(--green);background:#22c55e26}.api-status--error{color:#ef4444;background:#ef444426}.bottom-nav{display:none}.main{flex:1;display:flex;flex-direction:column;padding:2rem;background:transparent}.tab-panel h2{margin:0 0 .5rem;font-size:1.5rem;color:var(--text)}.tab-panel .muted{margin:0;color:var(--text-muted);font-size:.95rem}.store-error{margin:.5rem 0 0;color:#fca5a5;font-size:.9rem}.tab-panel--store{position:relative;padding:.75rem .75rem 0;border-radius:16px;overflow:hidden;background:linear-gradient(180deg,rgba(34,197,94,.16) 0%,rgba(34,197,94,.06) 24%,transparent 52%),linear-gradient(180deg,rgba(255,255,255,.06) 0%,transparent 36%)}.store-hero{margin-bottom:1.5rem}.store-hero-media{position:relative;width:100%;aspect-ratio:16 / 8;border-radius:14px;overflow:hidden;background:var(--bg-card);border:1px solid var(--grey-outline-strong);box-shadow:inset 0 -70px 120px #00000059}.store-hero-video,.store-hero-image{width:100%;height:100%;object-fit:cover;display:block}.store-hero-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--bg-mid) 0%,var(--bg-card) 100%)}.store-hero-top{position:absolute;top:0;left:0;right:0;padding:.9rem 1.15rem;z-index:3;background:linear-gradient(180deg,rgba(0,0,0,.7),transparent)}.store-hero-kicker{display:inline-block;font-size:.9rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--white)}.store-hero-overlay{position:absolute;inset:0;display:grid;place-items:center;padding:1.25rem;background:radial-gradient(circle at 50% 46%,#0000001f,#0000008f 78%),linear-gradient(180deg,transparent 28%,rgba(0,0,0,.65) 100%)}.store-hero-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;width:min(420px,100%);margin-top:1.5rem}.store-hero-icon{width:92px;height:92px;border-radius:20px;object-fit:cover;flex-shrink:0;border:1px solid rgba(255,255,255,.55);background:linear-gradient(150deg,#ffffff40,#ffffff0a);box-shadow:inset 0 2px #ffffff42,inset 0 -6px 14px #00000059,0 14px 30px #00000073}.store-hero-icon--placeholder{display:flex;align-items:center;justify-content:center;background:var(--bg-mid);border:1px solid var(--grey-outline);color:var(--text-muted);font-size:1.25rem;font-weight:600}.store-hero-name{font-size:1.2rem;font-weight:700;text-align:center;max-width:90%;line-height:1.25;color:var(--white)}.store-hero-actions{margin-top:.35rem;display:flex;gap:.55rem;align-items:center;justify-content:center;flex-wrap:wrap}.store-hero-download{padding:.56rem 1rem;background:var(--green);color:var(--bg-dark);font-size:.85rem;font-weight:600;border-radius:8px;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:opacity .2s}.store-hero-download:hover{opacity:.9;color:var(--bg-dark)}.store-hero-secondary{padding:.56rem 1rem;background:#ffffff1f;color:var(--white);border:1px solid rgba(255,255,255,.36);font-size:.82rem;font-weight:600;border-radius:8px;transition:background .2s,border-color .2s}.store-hero-secondary:hover{background:#fff3;border-color:#ffffff8c}.store-row{margin-bottom:1.5rem}.store-row-head{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;margin-bottom:.25rem}.store-row-label{margin:0;font-size:1.1rem;font-weight:600;color:var(--text);letter-spacing:.02em}.store-row-count{font-size:.8rem;font-weight:600;color:var(--text-muted);background:var(--bg-elev);border:1px solid var(--grey-outline);border-radius:999px;padding:.1rem .5rem}.store-row-desc{margin:0 0 .6rem;font-size:.82rem;color:var(--text-muted)}.store-row-empty{margin:0}.store-row-scroll{display:flex;gap:.75rem;overflow-x:auto;padding:.25rem 0 .75rem;margin:0;list-style:none;scrollbar-width:thin;scrollbar-color:var(--grey-outline) transparent}.store-row-scroll::-webkit-scrollbar{height:6px}.store-row-scroll::-webkit-scrollbar-track{background:transparent}.store-row-scroll::-webkit-scrollbar-thumb{background:var(--grey-outline);border-radius:3px}.store-card{flex-shrink:0;width:140px;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.7rem;background:linear-gradient(180deg,var(--bg-elev),var(--bg-card));border-radius:10px;border:1px solid var(--grey-outline);text-align:center;transition:border-color .2s,box-shadow .2s;cursor:pointer}.store-row-scroll--large .store-card{width:178px;padding:.85rem;border-radius:12px}.store-row-scroll--medium .store-card{width:146px}.store-row-scroll--small .store-card{width:116px;padding:.55rem;gap:.35rem;border-radius:9px}.store-card:hover{border-color:var(--grey-outline-strong);background:linear-gradient(180deg,var(--bg-elev),var(--bg-soft));box-shadow:0 0 12px #22c55e26}.store-card--selected{border-color:var(--green);box-shadow:0 0 16px #22c55e4d;background:var(--green-dim)}.store-card-icon{width:74px;height:74px;border-radius:12px;object-fit:cover}.store-row-scroll--large .store-card-icon{width:96px;height:96px;border-radius:14px}.store-row-scroll--medium .store-card-icon{width:76px;height:76px}.store-row-scroll--small .store-card-icon{width:54px;height:54px;border-radius:10px}.store-card-icon--placeholder{display:flex;align-items:center;justify-content:center;background:var(--bg-mid);border:1px solid var(--grey-outline);color:var(--text-muted);font-size:1.5rem;font-weight:600}.store-card-name{font-size:.84rem;font-weight:500;color:var(--text);line-height:1.25;min-height:2.1em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-wrap:balance}.store-card-size{font-size:.72rem;color:var(--text-muted)}.store-row-scroll--large .store-card-name{font-size:.92rem}.store-row-scroll--small .store-card-name{font-size:.74rem;min-height:2em}.store-row-scroll--small .store-card-size{font-size:.66rem}.store-game-list{margin:1rem 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.5rem}.store-game-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;background:linear-gradient(180deg,var(--bg-elev),var(--bg-card));border-radius:8px;border:1px solid var(--grey-outline)}.store-game-info{display:flex;align-items:center;gap:.65rem;min-width:0}.store-game-icon{width:36px;height:36px;border-radius:8px;object-fit:cover;flex-shrink:0}.store-game-icon--placeholder{display:flex;align-items:center;justify-content:center;background:var(--bg-mid);border:1px solid var(--grey-outline);color:var(--text-muted);font-size:1rem;font-weight:600}.store-game-name{font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.store-game-actions{display:flex;align-items:center;gap:.6rem;flex-shrink:0}.store-game-size{font-size:.9rem;color:var(--text-muted)}.store-game-download{padding:.35rem .6rem;background:var(--green-dim);color:var(--white);font-size:.8rem;font-weight:500;border-radius:6px;text-decoration:none;white-space:nowrap;transition:opacity .2s}.store-game-download:hover{opacity:.9;color:var(--white)}.settings-panel{--pcb-mask: url(/pcb-mask.svg);position:relative;flex:1;min-height:0;overflow:hidden;background:var(--bg-dark);margin:-2rem}.settings-pcb-reveal{position:absolute;inset:0;-webkit-mask-image:var(--pcb-mask);mask-image:var(--pcb-mask);-webkit-mask-size:192px 192px;mask-size:192px 192px;-webkit-mask-repeat:repeat;mask-repeat:repeat;pointer-events:none}.settings-blob{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(34,197,94,.35) 0%,rgba(34,197,94,.1) 40%,transparent 70%);will-change:transform}.settings-blob--1{top:-10%;left:-5%;animation:blob-drift-1 18s ease-in-out infinite}.settings-blob--2{top:40%;right:-10%;width:450px;height:450px;animation:blob-drift-2 22s ease-in-out infinite}.settings-blob--3{bottom:-5%;left:30%;width:400px;height:400px;animation:blob-drift-3 25s ease-in-out infinite}.settings-blob--4{top:20%;left:50%;width:350px;height:350px;animation:blob-drift-4 20s ease-in-out infinite}@keyframes blob-drift-1{0%,to{transform:translate(0) scale(1)}25%{transform:translate(120px,80px) scale(1.1)}50%{transform:translate(60px,180px) scale(.9)}75%{transform:translate(-40px,100px) scale(1.05)}}@keyframes blob-drift-2{0%,to{transform:translate(0) scale(1)}25%{transform:translate(-100px,-60px) scale(.95)}50%{transform:translate(-160px,40px) scale(1.1)}75%{transform:translate(-60px,80px) scale(1)}}@keyframes blob-drift-3{0%,to{transform:translate(0) scale(1)}25%{transform:translate(80px,-100px) scale(1.05)}50%{transform:translate(-60px,-140px) scale(.95)}75%{transform:translate(40px,-60px) scale(1.1)}}@keyframes blob-drift-4{0%,to{transform:translate(0) scale(.9)}25%{transform:translate(-80px,60px) scale(1.05)}50%{transform:translate(40px,120px) scale(1)}75%{transform:translate(100px,-40px) scale(.95)}}.settings-pcb-dim{position:absolute;inset:0;background:#ffffff08;-webkit-mask-image:var(--pcb-mask);mask-image:var(--pcb-mask);-webkit-mask-size:192px 192px;mask-size:192px 192px;-webkit-mask-repeat:repeat;mask-repeat:repeat;pointer-events:none}.settings-body{position:relative;z-index:1;padding:2rem}.add-game-form{max-width:420px;margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.add-game-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.add-game-title{margin:0 0 .25rem;font-size:1.15rem;color:var(--text)}.add-game-randomize{padding:.4rem .75rem;background:transparent;color:var(--text-muted);border:1px solid var(--grey-outline);border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:color .2s,border-color .2s}.add-game-randomize:hover:not(:disabled){color:var(--text);border-color:var(--text-muted)}.add-game-randomize:disabled{opacity:.5;cursor:not-allowed}.add-game-desc{margin:0 0 .5rem;font-size:.85rem}.add-game-label{display:flex;flex-direction:column;gap:.25rem;font-size:.9rem;color:var(--text)}.add-game-label .required{color:var(--green)}.add-game-input,.add-game-file{padding:.5rem .6rem;border:1px solid var(--grey-outline);border-radius:6px;background:var(--bg-elev);color:var(--text);font-size:.95rem}.add-game-input:focus,.add-game-file:focus{outline:none;border-color:var(--green)}.add-game-file{cursor:pointer}.add-game-filename{font-size:.8rem;color:var(--text-muted)}.add-game-icon-row{display:flex;align-items:center;gap:.75rem}.add-game-icon-preview{width:40px;height:40px;border-radius:8px;object-fit:cover;border:1px solid var(--grey-outline);flex-shrink:0}.add-game-message{margin:0;padding:.5rem;border-radius:6px;font-size:.9rem}.add-game-message--error{background:#ef444426;color:#fca5a5}.add-game-message--success{background:#22c55e26;color:var(--green)}.add-game-submit{margin-top:.5rem;padding:.6rem 1rem;background:var(--green-dim);color:var(--white);border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:opacity .2s}.add-game-submit:hover:not(:disabled){opacity:.9}.add-game-submit:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.sidebar{display:none}.app-content{margin-left:0;padding-bottom:72px}.header{padding:.6rem 1rem}.logo-text{font-size:1.1rem}.header-logo-icon{width:26px;height:26px}.api-status-label{display:none}.main{padding:1.25rem}.tab-panel--store{padding:.5rem .5rem 0;border-radius:12px}.store-hero-media{aspect-ratio:16 / 9}.store-hero-center{margin-top:1.25rem}.store-hero-icon{width:78px;height:78px;border-radius:16px}.store-hero-name{font-size:1.02rem}.store-row-scroll--large .store-card{width:156px}.store-row-scroll--large .store-card-icon{width:82px;height:82px}.store-row-scroll--medium .store-card{width:134px}.store-row-scroll--small .store-card{width:108px}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--bg-mid);border-top:1px solid var(--grey-outline);z-index:100;padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:6px 0;transition:color .2s;-webkit-tap-highlight-color:transparent}.bottom-nav-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px}.bottom-nav-icon svg{width:22px;height:22px}.bottom-nav-label{font-size:.65rem;font-weight:500;letter-spacing:.02em}.bottom-nav-item:not(.bottom-nav-item--active) .bottom-nav-icon{color:var(--grey-outline)}.bottom-nav-item--active,.bottom-nav-item--active .bottom-nav-icon{color:var(--green)}.bottom-nav-item--developer.bottom-nav-item--active,.bottom-nav-item--developer.bottom-nav-item--active .bottom-nav-icon{color:#ef4444}.settings-panel{margin:-1.25rem}}
