*,:before,:after{box-sizing:border-box;margin:0;padding:0}::selection{background:var(--gold);color:var(--bg);opacity:1}:root{--bg:#0d0d14;--surface:#13131e;--border:#1e1e30;--border2:#2a2a42;--text:#eae8f6;--muted:#7a7898;--sub:#9390b0;--gold:#a78bfa;--red:#f87171;--green:#86efac;--blue:#7dd3fc;--font:system-ui, -apple-system, "Segoe UI", sans-serif;--mono:"SF Mono", "Fira Code", "Consolas", monospace;--table-head:#0f0f18;--row-hover:#17172a;--secret-bg:#09090f;--btn-gold-text:#0d0d14}html,body{background:var(--bg);height:100%;color:var(--text);font-family:var(--font);font-size:15px;line-height:1.5}input,textarea,select,button{font-family:inherit}input,textarea{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:6px;outline:none;width:100%;padding:9px 13px;font-size:15px}input:focus,textarea:focus{border-color:var(--border2)}button{cursor:pointer;background:0 0;border:none}a{color:var(--gold)}#app{height:100vh}.screen{justify-content:center;align-items:center;min-height:100vh;display:flex}.screen-box{width:420px;padding:52px 44px}.screen-tag{color:var(--gold);margin-bottom:8px;font-size:12px;font-weight:500}.screen-title{color:var(--text);letter-spacing:-.02em;margin-bottom:32px;font-size:28px;font-weight:300}.field{margin-bottom:16px}.field label{color:var(--muted);margin-bottom:6px;font-size:12px;font-weight:500;display:block}.field input{font-size:15px}.field-hint{color:var(--muted);margin-top:6px;font-size:13px;line-height:1.55}.error-msg{color:var(--red);margin:8px 0;font-size:13px}.success-msg{color:var(--green);margin:8px 0;font-size:13px}.btn{cursor:pointer;border:1px solid;border-radius:6px;padding:8px 18px;font-size:13px;font-weight:500;transition:all .15s;display:inline-block}.btn-gold{background:var(--gold);color:var(--btn-gold-text);border-color:var(--gold)}.btn-ghost{color:var(--muted);border-color:var(--border2);background:0 0}.btn-ghost:hover{color:var(--text);border-color:var(--sub)}.btn-danger{color:var(--red);background:0 0;border-color:#f8717144}.btn-sm{padding:4px 10px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-row{gap:8px;margin-top:10px;display:flex}.secret-box{background:var(--secret-bg);border:1px solid var(--border);font-family:var(--mono);color:var(--text);letter-spacing:.18em;text-align:center;border-radius:6px;margin:12px 0;padding:14px 16px;font-size:18px}#main-app{flex-direction:column;height:100vh;display:flex}.top-bar{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 32px;display:flex}.top-bar h1{letter-spacing:-.01em;font-size:18px;font-weight:500}.top-bar .meta{color:var(--muted);margin-left:12px;font-size:13px}.nav{display:flex}.nav-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:6px 16px;font-size:14px;font-weight:400;transition:all .15s}.nav-btn.active{color:var(--gold);border-bottom-color:var(--gold)}.content{flex:1;width:100%;max-width:1300px;margin:0 auto;padding:28px 32px;overflow-y:auto}.cat-tabs{border-bottom:1px solid var(--border);align-items:center;margin-bottom:18px;display:flex}.cat-btn{color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 14px;font-size:13px;transition:all .15s}.cat-btn.active{border-bottom-color:var(--gold);color:var(--gold)}.cat-meta{color:var(--muted);margin-left:auto;font-size:13px}.filters-toggle-row{display:none}.filters{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:14px;display:flex}.filters label{color:var(--muted);font-size:13px}.filter-btn{border:1px solid var(--border2);color:var(--muted);cursor:pointer;background:0 0;border-radius:20px;padding:3px 10px;font-size:12px;transition:all .15s}.filter-btn.active{color:var(--btn-gold-text)}.game-table{border:1px solid var(--border);border-radius:8px;overflow:hidden}.table-header{background:var(--table-head);border-bottom:1px solid var(--border);gap:12px;padding:8px 16px;display:grid}.table-header span{color:var(--muted);font-size:12px;font-weight:500}.game-row{border-bottom:1px solid var(--border);align-items:start;gap:12px;padding:12px 16px;transition:background .12s;display:grid}.game-row>*{min-width:0}.game-row:last-child{border-bottom:none}.game-row:hover{background:var(--row-hover)}.game-row:hover .game-note{color:var(--sub)!important}.game-title{color:var(--text);font-size:15px;font-weight:400;line-height:1.35}.game-hours{color:var(--sub);padding-top:2px;font-size:13px}.game-note{color:var(--note-color,#3e3c58);font-size:13px;font-style:italic;line-height:1.65;transition:color .12s}.game-rank{color:var(--muted);padding-top:2px;font-size:13px}.game-rank.top{color:var(--gold);font-weight:600}.tag{white-space:nowrap;border-radius:20px;margin-bottom:4px;margin-right:2px;padding:3px 9px;font-size:12px;font-weight:500;display:inline-block}.game-actions{flex-direction:column;gap:5px;display:flex}.action-btn{cursor:pointer;background:0 0;border:1px solid;border-radius:5px;padding:3px 8px;font-size:12px;transition:all .12s}.action-played{color:var(--green);border-color:#86efac30}.action-played:hover{background:#86efac15}.game-actions select{background:var(--surface);color:var(--muted);border:1px solid var(--border2);cursor:pointer;border-radius:5px;padding:3px 6px;font-size:12px}.empty-state{text-align:center;color:var(--muted);padding:40px;font-size:14px;font-style:italic}.profile-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.profile-meta{color:var(--muted);margin-top:4px;font-size:13px;font-style:italic}.profile-view{max-height:75vh;overflow-y:auto}.profile-section-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:14px;padding:20px 24px}.profile-section-header{align-items:center;gap:10px;margin-bottom:10px;display:flex}.profile-section-name{letter-spacing:.08em;text-transform:uppercase;color:var(--gold);flex:1;font-size:11px;font-weight:600}.profile-section-actions{opacity:0;gap:6px;transition:opacity .15s;display:flex}.profile-section-card:hover .profile-section-actions{opacity:1}.profile-body{color:var(--sub);white-space:pre-wrap;font-size:14px;line-height:1.8}.profile-section-edit{width:100%}.profile-name-input{background:var(--surface);border:1px solid var(--border);width:100%;color:var(--gold);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;border-radius:6px;margin-bottom:8px;padding:6px 10px;font-size:11px;font-weight:600}.profile-text-textarea{background:var(--surface);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--mono);resize:vertical;border-radius:6px;min-height:100px;padding:12px;font-size:13px;line-height:1.7}.profile-section-edit-btns{gap:8px;margin-top:8px;display:flex}.profile-add-section{margin-top:8px}.pending-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:14px;padding:18px 22px}.pending-type-badge{border-radius:20px;margin-bottom:12px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.pending-desc{color:var(--text);margin-bottom:6px;font-size:15px;line-height:1.45}.pending-reason{color:var(--sub);margin-bottom:10px;font-size:13px;font-style:italic;line-height:1.65}.pending-meta{color:var(--muted);margin-bottom:14px;font-size:12px}.pending-badge{background:var(--gold);color:var(--btn-gold-text);vertical-align:middle;border-radius:10px;margin-left:4px;padding:1px 6px;font-size:11px;font-weight:600}.history-card{background:var(--surface);border:1px solid var(--border);opacity:.65;border-radius:8px;margin-bottom:8px;padding:12px 16px}.empty-pending{color:var(--muted);text-align:center;padding:48px 0;font-size:14px;font-style:italic}.settings-section{max-width:480px;margin-bottom:36px}.settings-title{letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;font-size:12px;font-weight:600}.settings-desc{color:var(--muted);margin-bottom:12px;font-size:14px;line-height:1.65}.settings-fields{flex-direction:column;gap:10px;display:flex}.theme-btn{color:var(--muted);border-color:var(--border2);min-width:64px}.theme-btn.active{color:var(--gold);border-color:var(--gold)}.theme-btn:hover{color:var(--text);border-color:var(--sub)}.legend{flex-wrap:wrap;align-items:center;gap:14px;margin-top:16px;display:flex}.legend-item{align-items:center;gap:5px;display:flex}.legend-dot{border-radius:50%;width:7px;height:7px}.legend-label{color:var(--muted);font-size:12px}.global-search-wrap{align-items:center;gap:10px;margin-bottom:14px;display:flex}.global-search-input{background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:var(--mono);border-radius:2px;width:280px;padding:6px 12px;font-size:12px}.global-search-input:focus{border-color:var(--border2);outline:none}.global-results-header{align-items:center;gap:10px;margin-bottom:10px;display:flex}.global-results-header span{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-size:9px}.cat-badge{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border-radius:2px;padding:2px 6px;font-size:8px;display:inline-block}.note-edit-wrap{flex-direction:column;gap:4px;display:flex}.note-textarea{background:var(--surface);border:1px solid var(--border2);width:100%;min-height:64px;color:var(--text);font-size:11px;font-family:var(--font);resize:vertical;border-radius:2px;padding:5px 8px;line-height:1.55}.note-textarea:focus{border-color:var(--gold);outline:none}.game-note-editable{cursor:pointer}.game-note-editable:hover{color:var(--sub)!important}.rank-btn{font-family:var(--mono);border:1px solid var(--border2);color:var(--muted);cursor:pointer;background:0 0;border-radius:2px;padding:1px 5px;font-size:10px;line-height:1.4}.rank-btn:hover{color:var(--text);border-color:var(--sub)}.rank-input{width:38px;font-family:var(--mono);border:1px solid var(--border2);background:var(--surface);color:var(--text);text-align:center;border-radius:3px;padding:1px 4px;font-size:11px}.rank-input:focus{border-color:var(--gold);outline:none}.game-link{color:var(--blue);opacity:.7;margin-left:6px;font-size:12px;text-decoration:none}.game-link:hover{opacity:1;text-decoration:underline}.row-edit-btn,.row-delete-btn{border:1px solid var(--border2);cursor:pointer;color:var(--muted);background:0 0;border-radius:4px;padding:2px 7px;font-size:11px}.row-edit-btn:hover{color:var(--text);border-color:var(--sub)}.row-delete-btn{color:var(--red);border-color:#f8717130}.row-delete-btn:hover{background:#f8717115}.modal-backdrop{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg);border:1px solid var(--border2);border-radius:10px;width:440px;max-width:calc(100vw - 32px);max-height:calc(100vh - 32px);padding:28px 32px;overflow-y:auto}.modal-title{color:var(--text);margin-bottom:6px;font-size:15px;font-weight:500}.modal-sub{color:var(--muted);margin-bottom:18px;font-size:12px}.modal-row{justify-content:flex-end;gap:8px;margin-top:14px;display:flex}#toast-container{z-index:200;pointer-events:none;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;bottom:22px;left:50%;transform:translate(-50%)}.toast{background:var(--surface);border:1px solid var(--border2);color:var(--text);pointer-events:auto;border-radius:6px;align-items:center;gap:14px;padding:10px 16px;font-size:13px;animation:.18s ease-out toast-in;display:flex;box-shadow:0 4px 16px #0006}.toast button{color:var(--gold);border:1px solid var(--gold);cursor:pointer;background:0 0;border-radius:4px;padding:2px 8px;font-size:12px}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{vertical-align:middle;opacity:.7;border:2px solid;border-top-color:#0000;border-radius:50%;width:11px;height:11px;margin-right:5px;animation:.6s linear infinite spin;display:inline-block}.sort-select{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:4px 8px;font-size:12px}.inbox-hint{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--gold);color:var(--sub);border-radius:6px;margin-bottom:14px;padding:12px 16px;font-size:13px;line-height:1.6}.inbox-hint strong{color:var(--text);font-weight:500}.game-thumb{object-fit:cover;border-radius:4px;width:36px;height:36px;margin-top:4px;display:block}.tag-platform{background:var(--surface);border:1px solid var(--border2);color:var(--muted);white-space:nowrap;border-radius:3px;margin-right:3px;padding:2px 7px;font-size:11px}.recovery-codes{grid-template-columns:1fr 1fr;gap:6px;margin:10px 0;display:grid}.recovery-code{background:var(--secret-bg);border:1px solid var(--border);font-family:var(--mono);letter-spacing:.05em;color:var(--text);text-align:center;border-radius:5px;padding:6px 10px;font-size:13px}.bottom-nav{display:none}@media (width<=768px){.top-bar{padding:10px 16px}.top-bar .nav{display:none}#main-app{padding-bottom:64px}.content{padding:16px}.screen-box{width:100%;padding:36px 20px}.settings-section{max-width:100%}.btn,.cat-btn{justify-content:center;align-items:center;min-height:40px;display:inline-flex}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);z-index:50;padding-bottom:env(safe-area-inset-bottom,0);display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-btn{min-height:56px;color:var(--muted);cursor:pointer;background:0 0;border:none;border-top:2px solid #0000;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:8px 4px;font-size:11px;display:flex;position:relative}.bottom-nav-btn.active{color:var(--gold);border-top-color:var(--gold)}.bottom-nav-icon{font-size:17px;line-height:1}.cat-tabs-outer{position:relative}.cat-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;overflow-x:auto}.cat-tabs::-webkit-scrollbar{display:none}.cat-tabs-arrow{width:28px;color:var(--sub);cursor:pointer;z-index:2;border:none;justify-content:center;align-items:center;padding:0;font-size:18px;display:flex;position:absolute;top:0;bottom:1px}.cat-tabs-arrow-left{background:linear-gradient(to right, var(--bg) 60%, transparent);left:0}.cat-tabs-arrow-right{background:linear-gradient(to left, var(--bg) 60%, transparent);right:0}.global-search-wrap{flex-wrap:wrap}.global-search-input{flex:1;min-width:0;width:auto!important}.btn-add-game{z-index:40;width:52px;height:52px;min-height:unset;border-radius:50%;padding:0;font-size:24px;font-weight:300;line-height:1;position:fixed;bottom:76px;right:16px;box-shadow:0 4px 20px #00000080}.btn-add-game .btn-label{display:none}.btn-add-game:after{content:"+";font-size:26px;font-weight:300;line-height:1}.game-table{background:0 0;border:none}.table-header{display:none!important}.game-row{background:var(--surface);border-radius:10px;margin-bottom:10px;padding:14px 16px;position:relative;border:1px solid var(--border)!important;grid-template-columns:1fr!important;gap:0!important}.game-row:last-child{border-bottom:1px solid var(--border)!important}.game-rank{position:absolute;top:14px;right:14px}.game-title{padding-right:36px}.game-hours{margin-top:2px}.game-note,.note-edit-wrap{border-top:1px solid var(--border);margin-top:10px;padding-top:10px}.game-actions{border-top:1px solid var(--border);flex-wrap:wrap;margin-top:10px;padding-top:10px;flex-direction:row!important;gap:6px!important}.action-btn{min-height:36px;padding:6px 12px!important;font-size:13px!important}.row-edit-btn,.row-delete-btn{min-height:36px;padding:6px 12px!important;font-size:12px!important}.game-actions select{flex:1;min-height:36px}.action-played{flex:1}.filters-sort-desktop{display:none}.filters-toggle-row{align-items:center;gap:8px;margin-bottom:10px;display:flex}.filters-toggle-btn{border:1px solid var(--border2);color:var(--muted);cursor:pointer;background:0 0;border-radius:20px;min-height:36px;padding:6px 14px;font-size:13px}.filters-toggle-btn.has-active{color:var(--gold);border-color:var(--gold)}.filters{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:10px;margin-bottom:14px;padding:14px 16px;display:none}.filters.open{display:flex}.filters-group{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.filter-btn{min-height:36px;padding:6px 14px;font-size:13px}.modal-backdrop{align-items:flex-end}.modal{padding:24px 20px;padding-bottom:max(24px, env(safe-area-inset-bottom,24px));border-bottom:none;border-left:none;border-right:none;border-radius:16px 16px 0 0;max-height:90vh;width:100%!important;max-width:100%!important}}
