html,body,#root{min-height:100vh;margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}:root{--bg:#0f1115;--panel:#181b22;--panel-2:#20242d;--text:#e7e9ee;--muted:#8b93a3;--border:#2a2f3a;--green:#2ecc71;--green-soft:#1a3b29;--yellow:#f1c40f;--yellow-soft:#443a13;--red:#e74c3c;--red-soft:#4a1f1c;--accent:#6aa1ff}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.app{max-width:1100px;margin:0 auto;padding:24px}.header{align-items:center;gap:16px;margin-bottom:20px;display:flex}.header h1{margin:0;font-size:24px;font-weight:600}.nav{gap:4px;margin-left:16px;display:flex}.nav button{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;padding:6px 12px;font-size:14px}.nav button.nav-on{background:var(--panel-2);color:var(--text);border-color:var(--accent)}.header-actions{gap:8px;margin-left:auto;display:flex}.header-user{color:var(--muted);align-items:center;gap:10px;margin-left:12px;font-size:13px;display:flex}.header-user .user-email{text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.btn-link{color:var(--accent);cursor:pointer;font:inherit;background:0 0;border:none;padding:4px 0}.btn-link:hover{text-decoration:underline}.loading{min-height:60vh;color:var(--muted);justify-content:center;align-items:center;font-size:14px;display:flex}.login{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--panel);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:16px;width:100%;max-width:360px;padding:28px;display:flex}.login-card h1{margin:0 0 4px;font-size:22px;font-weight:600}.login-card label{color:var(--muted);flex-direction:column;gap:6px;font-size:13px;display:flex}.login-card input{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:10px 12px;font-size:14px}.login-card input:focus{border-color:var(--accent);outline:none}.login-error{color:var(--red);font-size:13px}.btn-primary{background:var(--accent);color:#0a0d14;cursor:pointer;border:none;border-radius:6px;padding:8px 14px;font-weight:600}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:var(--muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;padding:8px 14px}.empty{text-align:center;color:var(--muted);border:1px dashed var(--border);border-radius:8px;padding:40px}.grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.card{text-align:left;font:inherit;color:inherit;border:1px solid var(--border);background:var(--panel);cursor:pointer;border-radius:10px;flex-direction:column;gap:6px;padding:18px;transition:transform .12s,background .2s,border-color .2s,box-shadow .2s;display:flex;position:relative}.card:hover{transform:translateY(-1px)}.card:active{transform:translateY(0)}.card.zone-green{background:linear-gradient(180deg, var(--green-soft), var(--panel));border-color:var(--green)}.card.zone-yellow{background:linear-gradient(180deg, var(--yellow-soft), var(--panel));border-color:var(--yellow)}.card.zone-red{background:linear-gradient(180deg, var(--red-soft), var(--panel));border-color:var(--red)}.card-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.card-name{text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:600;overflow:hidden}.card-actions{gap:4px;display:flex}.icon-btn{width:26px;height:26px;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:6px;justify-content:center;align-items:center;font-size:14px;display:inline-flex}.icon-btn:hover{color:var(--text);background:#ffffff0f}.card-days{letter-spacing:-1px;font-variant-numeric:tabular-nums;margin-top:2px;font-size:44px;font-weight:700}.card.zone-green .card-days{color:var(--green)}.card.zone-yellow .card-days{color:var(--yellow)}.card.zone-red .card-days{color:var(--red)}.unit{color:var(--muted);margin-left:6px;font-size:14px;font-weight:500}.card-thresholds{color:var(--muted);font-size:12px}.card-eta{color:var(--muted);font-variant-numeric:tabular-nums;margin-top:2px;font-size:12px}.card-progress{background:linear-gradient(90deg, var(--green) 0, var(--green) var(--t1-pct), var(--yellow) var(--t1-pct), var(--yellow) var(--t2-pct), var(--red) var(--t2-pct));opacity:.55;border-radius:3px;height:6px;margin-top:8px;position:relative}.card-progress-mark{top:-2px;bottom:-2px;left:var(--mark-pct);background:#fff;border-radius:1px;width:3px;position:absolute;transform:translate(-50%);box-shadow:0 0 4px #fff9}.card-progress-mark.overflow{background:var(--red);box-shadow:0 0 8px var(--red);animation:1.4s ease-in-out infinite mark-pulse}@keyframes mark-pulse{0%,to{box-shadow:0 0 6px var(--red)}50%{box-shadow:0 0 14px var(--red)}}.card-hint{color:var(--muted);opacity:.6;margin-top:4px;font-size:11px}.card.inactive{opacity:.45;filter:saturate(.55)}.card.inactive:hover{opacity:.7}.card.cycling{border-color:var(--accent);z-index:1;transform:scale(1.03);box-shadow:0 0 14px #6aa1ff80}.card.picked{border-color:var(--accent);box-shadow:0 0 18px #6aa1ff73}.card.picked.inactive{opacity:1;filter:none}.card-crosshair{background:var(--bg);border:2px solid var(--accent);z-index:2;pointer-events:none;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;animation:1.6s ease-in-out infinite crosshair-pulse;display:inline-flex;position:absolute;top:-10px;right:-10px}@keyframes crosshair-pulse{0%,to{box-shadow:0 0 6px #6aa1ff80}50%{box-shadow:0 0 16px #6aa1fff2}}.btn-spin{background:var(--panel-2);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:8px 14px;font-weight:600}.btn-spin:not(:disabled):hover{border-color:var(--accent)}.btn-spin:disabled{opacity:.4;cursor:not-allowed}.card-inactive{color:var(--muted);font-variant-numeric:tabular-nums;font-size:12px;font-style:italic}.card.just-reset{animation:.6s just-reset}@keyframes just-reset{0%{transform:scale(1);box-shadow:0 0 #fff9}40%{transform:scale(1.025);box-shadow:0 0 0 10px #fff0}to{transform:scale(1);box-shadow:0 0 #fff0}}.toolbar{align-items:center;gap:12px;margin-bottom:14px;display:flex}.search-input{background:var(--panel);border:1px solid var(--border);color:var(--text);border-radius:6px;flex:1;padding:8px 12px;font-size:14px}.search-input:focus{border-color:var(--accent);outline:none}.seg-toggle{border:1px solid var(--border);border-radius:6px;display:inline-flex;overflow:hidden}.seg-toggle button{color:var(--muted);cursor:pointer;background:0 0;border:0;padding:6px 12px;font-size:13px}.seg-toggle button+button{border-left:1px solid var(--border)}.seg-toggle button.seg-on{background:var(--panel-2);color:var(--text)}.seg-toggle button:hover:not(.seg-on){color:var(--text)}.kbd-hint{color:var(--muted);font-size:12px}kbd{background:var(--panel-2);border:1px solid var(--border);border-radius:4px;margin:0 2px;padding:1px 6px;font-family:ui-monospace,Consolas,monospace;font-size:11px;display:inline-block}.form{background:var(--panel);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:12px;margin-bottom:18px;padding:18px;display:flex}.form h2{margin:0;font-size:16px;font-weight:600}.form label{color:var(--muted);flex-direction:column;gap:4px;font-size:13px;display:flex}.form input{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:8px 10px;font-size:14px}.form input:focus{border-color:var(--accent);outline:none}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-error{color:var(--red);font-size:13px}.form-actions{gap:8px;display:flex}.stats{flex-direction:column;gap:8px;display:flex}.stats-row{background:var(--panel);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.stats-name{font-weight:600}.stats-meta{color:var(--muted);flex-wrap:wrap;align-items:center;gap:10px;font-size:13px;display:flex}.zone-pill{border:1px solid;border-radius:999px;padding:2px 8px;font-size:12px;font-weight:600}.zone-pill.zone-green{color:var(--green);border-color:var(--green)}.zone-pill.zone-yellow{color:var(--yellow);border-color:var(--yellow)}.zone-pill.zone-red{color:var(--red);border-color:var(--red)}.hopper{flex-direction:column;gap:14px;display:flex}.hopper-add{align-items:center;gap:8px;display:flex}.hopper-add .search-input{flex:1}.hopper-divider{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;border-top:1px solid var(--border);margin-top:8px;padding-top:12px;font-size:12px}.hopper-card{min-height:96px}.hopper-layout{grid-template-columns:1fr 240px;align-items:start;gap:20px;display:grid}.hopper-main{flex-direction:column;gap:14px;min-width:0;display:flex}@media (width<=720px){.hopper-layout{grid-template-columns:1fr}}.reward-side{background:var(--panel);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:14px;padding:14px;display:flex;position:sticky;top:12px}.reward-summary{flex-direction:column;align-items:center;gap:8px;display:flex}.reward-tokens{align-items:baseline;gap:6px;display:flex}.reward-tokens-num{color:var(--gold,#f5c542);letter-spacing:-1px;font-variant-numeric:tabular-nums;font-size:32px;font-weight:700}.reward-tokens-label{color:var(--muted);font-size:13px}.reward-progress-text{color:var(--muted);text-align:center;font-size:12px}.btn-award{color:#1a1408;cursor:pointer;background:linear-gradient(#f5c542,#c89a1f);border:1px solid #d9ad2a;border-radius:6px;width:100%;padding:8px 14px;font-weight:700}.btn-award:disabled{background:var(--panel-2);color:var(--muted);border-color:var(--border);cursor:not-allowed}.btn-award:not(:disabled):hover{filter:brightness(1.1)}.reward-stack{background:var(--panel-2);border-radius:8px;flex-direction:column;gap:3px;max-height:260px;padding:10px;display:flex;overflow-y:auto}.stack-line{background:#2a2f3a;border-radius:2px;height:6px;transition:background .2s,box-shadow .2s}.stack-line.reward{background:#2a2415;height:8px}.stack-line.filled{background:var(--green)}.stack-line.filled.reward{background:#f5c542;box-shadow:0 0 6px #f5c54280}.reward-manage{flex-direction:column;gap:8px;display:flex}.reward-manage-title{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:12px}.reward-add{gap:6px;display:flex}.reward-add .search-input{flex:1;padding:6px 10px;font-size:13px}.reward-add .btn-primary{padding:6px 12px}.reward-list{flex-direction:column;gap:4px;max-height:200px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.reward-row{background:var(--panel-2);border-radius:6px;justify-content:space-between;align-items:center;padding:6px 10px;font-size:13px;display:flex}.reward-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.reward-empty{color:var(--muted);font-size:12px;font-style:italic}.award-banner{background:linear-gradient(90deg,#f5c54226,#f5c5420d);border:1px solid #d9ad2a;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;animation:1.6s ease-in-out award-glow;display:flex}.award-emoji{font-size:22px}.award-text{color:var(--text);flex:1;font-size:14px}.award-text strong{color:#f5c542;font-weight:700}@keyframes award-glow{0%{box-shadow:0 0 #f5c54200}40%{box-shadow:0 0 20px 4px #f5c54280}to{box-shadow:0 0 #f5c54200}}
