:root{--bg-primary: #f6f5f1;--bg-surface: #ffffff;--bg-soft: #f0f4f1;--bg-hover: #eef4f1;--border: #d7ded9;--border-strong: #b8c5bf;--text-primary: #18201d;--text-secondary: #52645d;--text-muted: #7d8a85;--accent: #2f6f73;--accent-soft: #dceceb;--success: #28784f;--warning: #9a6417;--error: #a54432;--mono: "SF Mono", "Fira Code", "Cascadia Code", monospace;--sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);font-family:var(--sans);font-size:13px;line-height:1.4;-webkit-font-smoothing:antialiased}button,input,select{font:inherit}button{cursor:pointer}button:disabled,input:disabled,select:disabled{cursor:wait;opacity:.55}.token-screen{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:16px}.token-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;max-width:360px;padding:28px;text-align:center;width:100%}.token-card h1{font-size:22px;font-weight:650;margin-bottom:4px}.subtitle{color:var(--text-secondary);font-size:13px;margin-bottom:22px}.token-card input{background:var(--bg-primary);border:1px solid var(--border);border-radius:5px;color:var(--text-primary);font-size:14px;margin-bottom:10px;padding:10px 12px;width:100%}.token-card input:focus,.filters input:focus,.filters select:focus,.priority-table input:focus,.priority-table select:focus{border-color:var(--accent);outline:none}.token-card button{background:var(--accent);border:1px solid var(--accent);border-radius:5px;color:#fff;font-size:14px;font-weight:600;padding:10px;width:100%}.token-card .back-link{background:transparent;border:0;color:var(--text-muted);font-size:12px;margin-top:8px;padding:6px}.token-card .back-link:hover{color:var(--text-primary);text-decoration:underline}.otp-input{font-family:var(--mono);font-size:24px!important;text-align:center}.token-card .error{color:var(--error);font-size:12px;margin-top:10px}.dashboard{display:flex;flex-direction:column;min-height:100vh}.topbar{align-items:center;background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;height:44px;justify-content:space-between;padding:0 14px;position:sticky;top:0;z-index:100}.topbar-left,.topbar-right,.topbar-status,.user-info{align-items:center;display:flex}.topbar-left{gap:14px;min-width:0}.topbar-title{color:var(--text-primary);font-size:14px;font-weight:650;white-space:nowrap}.topbar-subtitle{color:var(--text-muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-right{gap:10px}.topbar-status{color:var(--text-muted);font-family:var(--mono);font-size:11px;gap:6px}.status-dot-live{animation:pulse 2s ease-in-out infinite;background:var(--success);border-radius:50%;height:7px;width:7px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.refresh-spinner{animation:spin 1s linear infinite;border:1.5px solid var(--border-strong);border-radius:50%;border-top-color:var(--accent);height:12px;width:12px}@keyframes spin{to{transform:rotate(360deg)}}.user-info{gap:8px}.user-email{color:var(--text-muted);font-size:11px}.logout-btn{background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);font-size:11px;padding:3px 8px}.logout-btn:hover{border-color:var(--error);color:var(--error)}.main-content{flex:1;padding:12px}.tab-content{margin-top:4px}.panel,.summary-bar{background:var(--bg-surface);border:1px solid var(--border);border-radius:6px}.panel{overflow:hidden}.panel-header{align-items:center;background:#fbfcfb;border-bottom:1px solid var(--border);color:var(--text-secondary);display:flex;font-size:12px;font-weight:650;justify-content:space-between;padding:9px 12px;text-transform:uppercase}.panel-body-flush{padding:0}.loading{color:var(--text-muted);font-size:13px;padding:48px;text-align:center}.error-banner{background:#fff8ed;border:1px solid #e2c6ac;border-radius:5px;color:var(--error);font-size:12px;margin-bottom:8px;padding:8px 12px}.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}.right{text-align:right}.badge{align-items:center;border-radius:4px;display:inline-flex;font-family:var(--mono);font-size:10px;font-weight:650;justify-content:center;padding:1px 6px;text-transform:uppercase}.badge-error{background:#f5e7df;color:var(--error)}.badge-warning{background:#f5ead4;color:var(--warning)}.badge-neutral{background:#edf1ef;color:#60706a}.summary-bar{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:8px;padding:8px 12px}.summary-item{align-items:center;color:var(--text-secondary);display:flex;gap:4px}.summary-value{color:var(--text-primary);font-family:var(--mono);font-weight:650}.filters{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.filters input,.filters select{background:var(--bg-surface);border:1px solid var(--border);border-radius:5px;color:var(--text-primary);font-size:12px;min-height:30px;padding:5px 8px}.filters input{flex:1;min-width:180px}.priority-table-wrap{max-height:calc(100vh - 196px);overflow:auto}.priority-table{border-collapse:separate;border-spacing:0;min-width:940px;table-layout:fixed;width:100%}.priority-table th,.priority-table td{border-bottom:1px solid var(--border);font-size:12px;padding:7px 10px;text-align:left;vertical-align:top}.priority-table th{background:#fbfcfb;box-shadow:0 1px 0 var(--border);color:var(--text-muted);font-size:11px;font-weight:650;overflow:hidden;position:sticky;text-overflow:ellipsis;text-transform:uppercase;top:0;white-space:nowrap;z-index:10}.priority-table tr:hover{background:var(--bg-hover)}.priority-table th:nth-child(1),.priority-table td:nth-child(1){width:39%}.priority-table th:nth-child(2),.priority-table td:nth-child(2){width:118px}.priority-table th:nth-child(3),.priority-table td:nth-child(3){width:246px}.priority-table th:nth-child(4),.priority-table td:nth-child(4){width:116px}.priority-table th:nth-child(5),.priority-table td:nth-child(5){width:72px}.priority-table th:nth-child(6),.priority-table td:nth-child(6){width:122px}.priority-table input,.priority-table select{background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);font-size:12px;min-height:28px;padding:4px 6px;width:100%}.priority-kind-select{text-transform:capitalize}.priority-title-cell{min-width:0}.priority-title{color:var(--text-primary);font-weight:600;line-height:1.3;overflow-wrap:anywhere}.priority-meta{align-items:center;color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:10px;gap:5px;margin-top:5px;min-width:0}.priority-tag{background:var(--bg-soft);border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);padding:0 4px}.priority-date-cell,.priority-sync-cell{display:flex;flex-direction:column}.priority-date-cell{gap:4px}.priority-date-buttons{display:grid;gap:3px;grid-template-columns:repeat(4,minmax(0,1fr))}.priority-date-buttons button{background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);font-family:var(--mono);font-size:10px;min-width:0;padding:3px 2px}.priority-date-buttons button:hover{border-color:var(--accent);color:var(--text-primary)}.priority-sync-cell{align-items:flex-start;color:var(--text-muted);font-size:10px;gap:4px}.empty-cell{color:var(--text-muted);padding:28px!important;text-align:center}tr.priority-due-overdue{background:#fffaf4;box-shadow:inset 3px 0 0 var(--error)}tr.priority-due-today{background:#fff9e9;box-shadow:inset 3px 0 0 var(--warning)}@media(max-width:768px){.topbar{align-items:flex-start;flex-direction:column;gap:6px;height:auto;padding:8px}.topbar-right{justify-content:space-between;width:100%}.main-content{padding:8px}.summary-bar{gap:10px}}@media(max-width:480px){.topbar-status,.user-email{display:none}}
