:root{--bg-primary:#0a0a1a;--bg-secondary:#0e0e24;--bg-card:#1a1a3ea6;--bg-card-hover:#1f1f48bf;--bg-input:#0c0c1e;--border:#7c3aed2e;--border-focus:#7c3aed;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#475569;--accent-primary:#7c3aed;--accent-secondary:#818cf8;--accent-sleep:#818cf8;--accent-heart:#f472b6;--accent-workout:#34d399;--accent-stress:#fb923c;--accent-danger:#ef4444;--accent-weather:#67e8f9;--accent-mind:#c4b5fd;--shadow:0 4px 32px #7c3aed1f,0 1px 8px #00000080;--radius:14px;--radius-sm:10px;--transition:.3s ease;--glow:0 0 20px #7c3aed40}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;background:var(--bg-primary);font-size:16px}body{color:var(--text-primary);background:linear-gradient(160deg,#0a0a1a 0%,#1a1a3e 35%,#2d1b69 65%,#0a0a1a 100%) fixed;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;line-height:1.6;overflow-x:hidden}body:before,body:after{content:"";pointer-events:none;z-index:0;width:100%;height:100%;position:fixed;top:0;left:0}body:before{opacity:.9;background-image:radial-gradient(1.5px 1.5px at 10% 15%,#ffffffb3 50%,#0000 50%),radial-gradient(1px 1px at 25% 35%,#ffffff80 50%,#0000 50%),radial-gradient(1.5px 1.5px at 40% 10%,#fff9 50%,#0000 50%),radial-gradient(1px 1px at 55% 45%,#fff6 50%,#0000 50%),radial-gradient(2px 2px at 70% 20%,#818cf8cc 50%,#0000 50%),radial-gradient(1px 1px at 85% 55%,#ffffff80 50%,#0000 50%),radial-gradient(1.5px 1.5px at 15% 65%,#fff6 50%,#0000 50%),radial-gradient(1px 1px at 30% 80%,#c4b5fd99 50%,#0000 50%),radial-gradient(2px 2px at 50% 70%,#ffffff4d 50%,#0000 50%),radial-gradient(1px 1px at 65% 85%,#ffffff80 50%,#0000 50%),radial-gradient(1.5px 1.5px at 80% 75%,#818cf880 50%,#0000 50%),radial-gradient(1px 1px at 95% 30%,#fff9 50%,#0000 50%),radial-gradient(1px 1px at 5% 90%,#ffffff59 50%,#0000 50%),radial-gradient(1.5px 1.5px at 45% 95%,#c4b5fd73 50%,#0000 50%),radial-gradient(1px 1px at 75% 5%,#ffffff80 50%,#0000 50%);animation:90s linear infinite starfield-drift}body:after{opacity:.6;background-image:radial-gradient(1px 1px at 12% 28%,#ffffff59 50%,#0000 50%),radial-gradient(1.5px 1.5px at 33% 52%,#818cf866 50%,#0000 50%),radial-gradient(1px 1px at 48% 18%,#ffffff73 50%,#0000 50%),radial-gradient(1px 1px at 62% 72%,#c4b5fd59 50%,#0000 50%),radial-gradient(2px 2px at 78% 42%,#ffffff80 50%,#0000 50%),radial-gradient(1px 1px at 88% 88%,#818cf84d 50%,#0000 50%),radial-gradient(1px 1px at 8% 48%,#fff6 50%,#0000 50%),radial-gradient(1.5px 1.5px at 22% 92%,#ffffff4d 50%,#0000 50%),radial-gradient(1px 1px at 58% 38%,#c4b5fd66 50%,#0000 50%),radial-gradient(1px 1px at 92% 62%,#ffffff73 50%,#0000 50%);animation:120s linear infinite starfield-drift-reverse}@keyframes starfield-drift{0%{transform:translateY(0)translate(0)}to{transform:translateY(-30px)translate(15px)}}@keyframes starfield-drift-reverse{0%{transform:translateY(0)translate(0)}to{transform:translateY(20px)translate(-10px)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes glow-pulse{0%,to{box-shadow:0 0 15px #7c3aed26}50%{box-shadow:0 0 30px #7c3aed59,0 0 60px #818cf81a}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}.bg-canvas{z-index:0;pointer-events:none;width:100vw;height:100vh;transition:opacity .5s;position:fixed;top:0;left:0}.bg-canvas.art-mode{z-index:0;pointer-events:auto;opacity:1}.app-layout{z-index:1;min-height:100vh;display:flex;position:relative}.main-content{z-index:1;flex:1;margin-left:220px;padding:20px;position:relative}.sidebar{-webkit-backdrop-filter:blur(20px)saturate(1.4);z-index:20;background:#0a0a1ae0;border-right:1px solid #7c3aed1f;flex-direction:column;width:220px;height:100vh;padding:20px 0;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-nav{flex-direction:column;gap:4px;margin-top:24px;padding:0 12px;display:flex}.sidebar-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:background var(--transition),color var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:12px 16px;font-size:.9rem;font-weight:500;display:flex}.sidebar-item:hover{color:var(--text-primary);background:#7c3aed1a}.sidebar-item.active{color:#fff;box-shadow:inset 3px 0 0 var(--accent-primary);text-shadow:0 0 12px #7c3aed66;background:#7c3aed2e}.sidebar-icon{text-align:center;flex-shrink:0;width:24px;font-size:1.2rem}.sidebar-label{white-space:nowrap}.dash-header{-webkit-backdrop-filter:blur(20px)saturate(1.3);border-radius:var(--radius);z-index:10;background:#0a0a1abf;border:1px solid #7c3aed1f;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px 24px;display:flex;position:sticky;top:10px;box-shadow:0 4px 30px #0000004d,0 0 40px #7c3aed0f}.logo{background:linear-gradient(135deg,#7c3aed,#818cf8,#c4b5fd);-webkit-text-fill-color:transparent;letter-spacing:.02em;text-shadow:0 0 30px #7c3aed4d;-webkit-background-clip:text;background-clip:text;font-size:1.4rem;font-weight:700}.header-center{align-items:center;gap:20px;display:flex}.month-nav{align-items:center;gap:16px;display:flex}.header-date-picker{align-items:center;gap:8px;display:flex}.header-today-btn{white-space:nowrap;padding:8px 14px;font-size:.85rem}.month-label{text-align:center;min-width:180px;font-size:1.1rem;font-weight:600}.icon-btn{border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;width:40px;height:40px;transition:var(--transition);background:0 0;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.icon-btn:hover{border-color:var(--accent-primary);background:#7c3aed1a;box-shadow:0 0 12px #7c3aed33}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;padding:10px 20px;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary{color:#fff;background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 2px 12px #7c3aed4d}.btn-primary:hover{background:linear-gradient(135deg,#8b5cf6,#7c3aed);transform:translateY(-1px);box-shadow:0 4px 20px #7c3aed80}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent-primary)}.btn-danger{color:var(--accent-danger);border:1px solid var(--accent-danger);background:0 0}.btn-danger:hover{background:var(--accent-danger);color:#fff}.settings-panel{-webkit-backdrop-filter:blur(24px)saturate(1.3);z-index:100;width:400px;height:100vh;transition:right var(--transition);background:#0a0a1aeb;border-left:1px solid #7c3aed1a;position:fixed;top:0;right:-420px;overflow-y:auto}.settings-panel.open{right:0}.settings-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.settings-header h2{font-size:1.2rem}.version-label{color:var(--text-muted);margin-left:auto;margin-right:12px;font-size:.7rem}.settings-body{padding:24px}.setting-group{margin-bottom:32px}.setting-hint{color:var(--text-muted);margin-bottom:12px;font-size:.8rem;line-height:1.4}.setting-hint a{color:var(--accent-secondary);text-decoration:none}.setting-hint a:hover{text-decoration:underline}.connected-badge{border-radius:var(--radius-sm);color:var(--accent-workout);background:#55efc41a;border:1px solid #55efc44d;align-items:center;gap:8px;margin:12px 0;padding:8px 12px;font-size:.85rem;display:flex}.connected-dot{background:var(--accent-workout);border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.setting-group h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:16px;font-size:.9rem}.setting-group label{color:var(--text-secondary);margin-top:12px;margin-bottom:6px;font-size:.85rem;display:block}.setting-group label:first-of-type{margin-top:0}.setting-group input[type=text],.setting-group input[type=password],.setting-group input[type=date],.setting-group select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:var(--transition);padding:10px 14px;font-size:.9rem}.setting-group input:focus,.setting-group select:focus{border-color:var(--accent-primary);outline:none}.setting-row{margin-top:12px}.date-range{align-items:center;gap:8px;display:flex}.date-range input{flex:1}.date-range span{color:var(--text-muted);font-size:.85rem}.setting-group .btn{width:100%;margin-top:16px}.status-msg{min-height:20px;margin-top:10px;font-size:.85rem}.status-msg.success{color:var(--accent-workout)}.status-msg.error{color:var(--accent-danger)}.status-msg.loading{color:var(--accent-secondary)}.import-section{margin-bottom:24px}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;transition:var(--transition);background:#0a0a1a8c;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:32px;display:flex}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent-primary);background:#7c3aed14}.drop-zone p{color:var(--text-secondary);font-size:.95rem}.drop-zone-hint{color:var(--text-muted);font-size:.8rem}.file-label{cursor:pointer}.share-key-url{align-items:center;gap:8px;display:flex}.share-key-url input{flex:1;font-family:monospace;font-size:.8rem}.share-scopes{flex-wrap:wrap;gap:12px;margin-top:12px;display:flex}.share-scopes label{color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;font-size:.85rem;display:flex}.share-scopes input[type=checkbox]{accent-color:var(--accent-primary)}.metric-section{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:var(--radius);background:#0a0a1ab8;margin-bottom:32px;padding:24px}.section-title{border-bottom:1px solid var(--border);margin-bottom:20px;padding-bottom:12px;font-size:1.3rem;font-weight:700}.section-title.sleep{color:var(--accent-sleep)}.section-title.heart{color:var(--accent-heart)}.section-title.workout{color:var(--accent-workout)}.section-title.stress{color:var(--accent-stress)}.section-title.weather{color:var(--accent-weather)}.section-title.mind{color:var(--accent-mind)}.stats-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:14px 16px}.stat-value{font-size:1.6rem;font-weight:700;line-height:1.2}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:4px;font-size:.75rem}.stat-value.sleep{color:var(--accent-sleep)}.stat-value.heart{color:var(--accent-heart)}.stat-value.workout{color:var(--accent-workout)}.stat-value.stress{color:var(--accent-stress)}.charts-grid{grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:16px;margin-bottom:20px;display:grid}.chart-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}.chart-card h3{color:var(--text-secondary);margin-bottom:12px;font-size:.85rem;font-weight:500}.chart-card canvas{max-height:250px;width:100%!important}.overlay-chart-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);margin-top:16px;padding:16px}.overlay-chart-card h3{color:var(--text-secondary);margin-bottom:12px;font-size:.85rem;font-weight:500}.overlay-chart-card canvas{max-height:350px;width:100%!important}.sample-data-notice{border-radius:var(--radius-sm);color:var(--accent-secondary);text-align:center;background:#7c3aed1f;border:1px solid #7c3aed40;margin-bottom:8px;padding:6px 12px;font-size:.78rem}.debug-data-toggle{cursor:pointer;color:var(--text-primary);align-items:center;gap:8px;font-size:.9rem;display:flex}.debug-data-toggle input[type=checkbox]{accent-color:var(--accent-primary);width:16px;height:16px}.overlay-fallback{color:var(--text-muted);text-align:center;padding:32px 16px;font-size:.85rem;font-style:italic}.viz-3d-container{margin-top:16px}.viz-3d-container h3{color:var(--text-secondary);margin-bottom:12px;font-size:.85rem;font-weight:500}.viz-3d-canvas{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);width:100%;height:300px}.future-section{opacity:.6}.coming-soon-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.coming-soon-card{background:var(--bg-input);border:1px dashed var(--border);border-radius:var(--radius-sm);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:32px 16px;display:flex}.coming-soon-icon{opacity:.5;font-size:2rem}.coming-soon-card p{color:var(--text-muted);font-size:.9rem}@media (max-width:768px){.sidebar{border-right:none;border-top:1px solid var(--border);z-index:30;flex-direction:row;width:100%;height:auto;padding:0;position:fixed;top:auto;bottom:0;left:0}.sidebar-nav{flex-direction:row;justify-content:space-around;gap:0;width:100%;margin-top:0;padding:0}.sidebar-item{border-radius:0;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:10px 4px;font-size:.7rem}.sidebar-item.active{box-shadow:inset 0 2px 0 var(--accent-primary);background:#7c3aed1f}.sidebar-icon{font-size:1.1rem}.sidebar-label{font-size:.65rem}.main-content{margin-left:0;padding:12px 12px 80px}.dash-header{flex-wrap:wrap;justify-content:center;gap:12px;position:static}.charts-grid,.coming-soon-grid{grid-template-columns:1fr}.settings-panel,.chat-panel{width:100%;right:-100%}.stats-row{grid-template-columns:repeat(2,1fr)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#7c3aed40;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#7c3aed73}.settings-overlay{z-index:99;opacity:0;pointer-events:none;transition:opacity var(--transition);background:#00000080;position:fixed;inset:0}.settings-overlay.active{opacity:1;pointer-events:auto}.chat-panel{-webkit-backdrop-filter:blur(24px)saturate(1.3);z-index:100;width:400px;height:100vh;transition:right var(--transition);background:#0a0a1aeb;border-left:1px solid #7c3aed1a;flex-direction:column;display:flex;position:fixed;top:0;right:-420px}.chat-panel.open{right:0}.chat-overlay{z-index:99;opacity:0;pointer-events:none;transition:opacity var(--transition);background:#00000080;position:fixed;inset:0}.chat-overlay.active{opacity:1;pointer-events:auto}.chat-header{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:20px 24px;display:flex}.chat-header h2{margin:0;font-size:1.2rem}.chat-header .icon-btn{margin-left:auto}.chat-context-badge{background:var(--accent-primary);color:var(--bg-primary);border-radius:12px;padding:2px 8px;font-size:.7rem}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.chat-empty{color:var(--text-secondary);text-align:center;margin-top:40px;font-size:.95rem}.chat-msg{display:flex}.chat-msg.user{justify-content:flex-end}.chat-msg.assistant{justify-content:flex-start}.chat-msg-bubble{white-space:pre-wrap;word-break:break-word;border-radius:12px;max-width:80%;padding:10px 14px;font-size:.9rem;line-height:1.5}.chat-msg.user .chat-msg-bubble{background:var(--accent-primary);color:var(--bg-primary);border-bottom-right-radius:4px}.chat-msg.assistant .chat-msg-bubble{background:var(--bg-card);color:var(--text-primary);border-bottom-left-radius:4px}.chat-loading{gap:4px;display:flex;padding:12px 16px!important}.chat-loading span{background:var(--text-secondary);border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite chat-bounce}.chat-loading span:nth-child(2){animation-delay:.2s}.chat-loading span:nth-child(3){animation-delay:.4s}@keyframes chat-bounce{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.chat-input-bar{border-top:1px solid var(--border);background:var(--bg-secondary);gap:8px;padding:12px 16px;display:flex}.chat-input-bar input{border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);border-radius:8px;flex:1;padding:8px 12px;font-size:.9rem}.chat-input-bar input:focus{border-color:var(--accent-primary);outline:none}.chat-input-bar .btn{padding:8px 16px;font-size:.85rem}.header-actions{align-items:center;gap:8px;display:flex}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{-webkit-backdrop-filter:blur(20px)saturate(1.3);border-radius:var(--radius);background:#0a0a1acc;border:1px solid #7c3aed26;width:100%;max-width:400px;padding:40px 32px;animation:6s ease-in-out infinite glow-pulse;box-shadow:0 8px 40px #0006,0 0 60px #7c3aed14}.auth-title{background:linear-gradient(135deg,#7c3aed,#818cf8,#c4b5fd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:4px;font-size:1.6rem;font-weight:700}.auth-subtitle{color:var(--text-secondary);margin-bottom:28px;font-size:.9rem}.auth-form label{color:var(--text-secondary);margin-top:16px;margin-bottom:6px;font-size:.85rem;display:block}.auth-form label:first-of-type{margin-top:0}.auth-form input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:var(--transition);padding:10px 14px;font-size:.9rem}.auth-form input:focus{border-color:var(--accent-primary);outline:none}.auth-error{color:var(--accent-danger);margin-top:12px;font-size:.85rem}.auth-password-errors{color:var(--accent-danger);margin-top:6px;font-size:.8rem;list-style:none}.auth-password-errors li:before{content:"•"}.auth-submit{width:100%;margin-top:24px}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-divider{color:var(--text-muted);align-items:center;gap:12px;margin:20px 0;font-size:.8rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-social{width:100%}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:16px;font-size:.85rem}.auth-footer a{color:var(--accent-secondary);text-decoration:none}.auth-footer a:hover{text-decoration:underline}.user-signin-btn{padding:8px 16px;font-size:.85rem;text-decoration:none}.user-menu{position:relative}.user-avatar-btn{border:2px solid var(--border);background:var(--bg-card);cursor:pointer;width:36px;height:36px;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex;overflow:hidden}.user-avatar-btn:hover{border-color:var(--accent-primary)}.user-avatar-img{object-fit:cover;width:100%;height:100%}.user-avatar-initials{color:var(--accent-secondary);font-size:.75rem;font-weight:700}.user-dropdown{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);width:220px;box-shadow:var(--shadow);z-index:50;position:absolute;top:calc(100% + 8px);right:0}.user-dropdown-header{flex-direction:column;gap:2px;padding:12px 16px;display:flex}.user-dropdown-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.user-dropdown-email{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.user-dropdown-divider{background:var(--border);height:1px}.user-dropdown-item{width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;transition:var(--transition);background:0 0;border:none;padding:10px 16px;font-size:.85rem}.user-dropdown-item:hover{background:var(--bg-card);color:var(--text-primary)}.sync-prompt{border-radius:var(--radius-sm);color:var(--text-primary);background:#7c3aed1f;border:1px solid #7c3aed4d;align-items:center;gap:12px;margin-bottom:16px;padding:12px 20px;font-size:.9rem;display:flex}.sync-prompt.sync-done{background:#55efc41a;border-color:#55efc44d}.sync-prompt span{flex:1}.sync-btn{white-space:nowrap;padding:8px 16px;font-size:.85rem}.sync-dismiss{padding:8px 12px;font-size:.85rem}.account-info{flex-direction:column;gap:8px;display:flex}.account-detail{border-bottom:1px solid #2a2a4080;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.account-label{color:var(--text-muted);font-size:.8rem}.account-value{color:var(--text-primary);font-size:.85rem}.account-cloud{color:var(--accent-workout)}.day-detail-overlay{z-index:99;opacity:0;pointer-events:none;transition:opacity var(--transition);background:#00000080;position:fixed;inset:0}.day-detail-overlay.active{opacity:1;pointer-events:auto}.day-detail-panel{-webkit-backdrop-filter:blur(24px)saturate(1.3);z-index:100;width:460px;height:100vh;transition:right var(--transition);background:#0a0a1aeb;border-left:1px solid #7c3aed1a;position:fixed;top:0;right:-480px;overflow-y:auto}.day-detail-panel.open{right:0}.day-header{border-bottom:1px solid var(--border);background:var(--bg-secondary);z-index:1;align-items:center;gap:8px;padding:16px 20px;display:flex;position:sticky;top:0}.day-date{text-align:center;flex:1;font-size:1rem;font-weight:600}.day-nav-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;transition:background var(--transition);justify-content:center;align-items:center;font-size:1rem;display:flex}.day-nav-btn:hover{background:var(--bg-card-hover)}.day-close{margin-left:4px}.day-body{padding:20px}.day-section{margin-bottom:28px}.day-section-title{text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border);margin-bottom:12px;padding-bottom:6px;font-size:.85rem;font-weight:600}.day-section-title.sleep{color:var(--accent-sleep);border-color:var(--accent-sleep)}.day-section-title.heart{color:var(--accent-heart);border-color:var(--accent-heart)}.day-section-title.workout{color:var(--accent-workout);border-color:var(--accent-workout)}.day-section-title.stress{color:var(--accent-stress);border-color:var(--accent-stress)}.day-stat-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px;display:grid}.day-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:2px;padding:10px 12px;display:flex}.day-stat-value{color:var(--text-primary);font-size:1.2rem;font-weight:700}.day-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.7rem}.day-comparison{border-radius:4px;width:fit-content;margin-top:2px;padding:2px 6px;font-size:.65rem;font-weight:500}.day-comparison.above{color:#55efc4;background:#55efc41a}.day-comparison.below{color:#ff6b6b;background:#ff6b6b1a}.day-comparison.neutral{color:var(--text-muted);background:#55556a26}.day-chart-wrap{margin-top:12px}.donut-container{width:180px;height:180px;margin:0 auto;position:relative}.donut-center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.donut-value{color:var(--text-primary);font-size:1.3rem;font-weight:700}.donut-label{color:var(--text-muted);font-size:.7rem}.donut-legend{flex-wrap:wrap;justify-content:center;gap:8px 14px;margin-top:10px;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:4px;font-size:.72rem;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.hr-range{padding:12px 0}.hr-range-bar{background:linear-gradient(90deg,var(--accent-sleep),var(--accent-heart));border-radius:6px;height:12px;margin-bottom:8px;position:relative}.hr-range-marker{flex-direction:column;align-items:center;display:flex;position:absolute;top:-8px;transform:translate(-50%)}.hr-range-marker:after{content:"";background:var(--text-primary);border-radius:2px;width:3px;height:28px}.hr-range-label{color:var(--text-primary);margin-bottom:2px;font-size:.7rem;font-weight:600}.hr-range-ends{justify-content:space-between;display:flex}.hr-range-min,.hr-range-max{color:var(--text-muted);font-size:.7rem}.day-empty{text-align:center;color:var(--text-muted);padding:40px 0;font-size:.9rem}.heatmap-container{margin-top:16px;position:relative;overflow-x:auto}.heatmap-grid{gap:2px;min-width:fit-content;display:grid}.heatmap-corner{background:0 0}.heatmap-day-label{color:var(--text-muted);text-align:center;padding:2px 0 4px;font-size:.65rem}.heatmap-row-label{color:var(--text-secondary);white-space:nowrap;align-items:center;padding-right:8px;font-size:.7rem;display:flex}.heatmap-cell{aspect-ratio:1;cursor:default;border-radius:3px;min-width:18px;min-height:18px;transition:transform .15s}.heatmap-cell:hover{z-index:1;transform:scale(1.2)}.heatmap-tooltip{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);pointer-events:none;white-space:nowrap;z-index:50;box-shadow:var(--shadow);border-radius:6px;padding:6px 10px;font-size:.75rem}.day-picker-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);max-width:180px;color:var(--text-primary);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;padding:8px 12px;font-size:.85rem}.day-picker-input:focus{border-color:var(--accent-primary);outline:none}.day-intraday{flex-direction:column;gap:16px;margin-bottom:24px;display:flex}.intraday-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.intraday-header h3{white-space:nowrap;margin-bottom:0}.intraday-toggles{gap:6px;display:flex}.intraday-toggle{cursor:pointer;border:1.5px solid var(--toggle-color,#888);color:var(--toggle-color,#888);opacity:.45;background:0 0;border-radius:14px;padding:4px 12px;font-size:.78rem;font-weight:600;transition:opacity .15s,background .15s}.intraday-toggle.active{opacity:1;background:color-mix(in srgb,var(--toggle-color)18%,transparent)}.intraday-view-select{border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;padding:4px 8px;font-size:.78rem;font-weight:600}.intraday-view-select:focus{border-color:var(--accent-primary);outline:none}.hypnogram-start-label{color:var(--text-secondary);align-items:center;gap:6px;font-size:.8rem;display:flex}.hypnogram-start-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:48px;color:var(--text-primary);text-align:center;padding:4px 6px;font-size:.8rem}.hypnogram-start-input:focus{border-color:var(--accent-primary);outline:none}.intraday-add-btn{cursor:pointer;border:1.5px solid var(--text-muted);color:var(--text-muted);opacity:.6;background:0 0;border-radius:14px;padding:4px 10px;font-size:.85rem;font-weight:700;line-height:1;transition:opacity .15s,background .15s}.intraday-add-btn:hover{opacity:1;background:#ffffff0f}.intraday-dream-btn{cursor:pointer;opacity:.6;background:0 0;border:1.5px solid #74b9ff;border-radius:14px;padding:4px 10px;font-size:.85rem;line-height:1;transition:opacity .15s,background .15s}.intraday-dream-btn:hover{opacity:1;background:#74b9ff1a}.event-popup-overlay{z-index:49;position:fixed;inset:0}.event-popup{z-index:50;background:var(--bg-card,#1a1a2e);border:1px solid var(--border,#2a2a40);border-radius:var(--radius-sm,8px);flex-direction:column;gap:6px;width:240px;padding:12px;display:flex;position:absolute;box-shadow:0 8px 24px #0006}.event-popup-header{align-items:center;gap:8px;display:flex}.event-popup-time{color:var(--text-secondary,#8888a0);margin-left:auto;font-size:.8rem}.event-popup-duration{opacity:.7}.event-popup-close{color:var(--text-muted,#55556a);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:1.1rem;line-height:1}.event-popup-close:hover{color:var(--text-primary)}.event-popup-title{color:var(--text-primary,#e8e8f0);font-size:.9rem;font-weight:600}.event-popup-desc{color:var(--text-secondary,#8888a0);font-size:.78rem}.event-auto-badge{color:#55efc4;background:#55efc426;border-radius:10px;width:fit-content;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-block}.event-popup-actions{gap:8px;margin-top:4px;display:flex}.event-popup-actions button{border-radius:var(--radius-sm,8px);cursor:pointer;border:1px solid var(--border,#2a2a40);background:var(--bg-input,#12121e);color:var(--text-primary,#e8e8f0);padding:4px 12px;font-size:.78rem;font-weight:600;transition:background .15s}.event-popup-actions button:hover{background:#ffffff14}.event-popup-delete{color:#ff6b6b!important;border-color:#ff6b6b4d!important}.event-popup-delete:hover{background:#ff6b6b26!important}.event-category-badge{color:#1a1a2e;text-transform:capitalize;border-radius:10px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-block}.event-form{border:1px solid var(--border,#2a2a40);border-radius:var(--radius-sm,8px);background:#12121e99;flex-direction:column;gap:8px;margin-bottom:12px;padding:12px;display:flex}.event-form label{color:var(--text-secondary,#8888a0);flex-direction:column;gap:2px;font-size:.78rem;font-weight:600;display:flex}.event-form-optional{opacity:.6;font-weight:400}.event-form-row{gap:12px;display:flex}.event-form-row label{flex:1}.event-form input,.event-form select{background:var(--bg-input,#12121e);border:1px solid var(--border,#2a2a40);border-radius:var(--radius-sm,8px);color:var(--text-primary,#e8e8f0);padding:6px 8px;font-size:.82rem}.event-form input:focus,.event-form select:focus{border-color:var(--accent-primary,#74b9ff);outline:none}.event-form-actions{gap:8px;margin-top:4px;display:flex}.event-form-save,.event-form-cancel{border-radius:var(--radius-sm,8px);cursor:pointer;border:1px solid var(--border,#2a2a40);padding:6px 16px;font-size:.8rem;font-weight:600;transition:background .15s}.event-form-save{background:var(--accent-primary,#74b9ff);color:#1a1a2e;border-color:#0000}.event-form-save:hover{opacity:.9}.event-form-cancel{color:var(--text-secondary,#8888a0);background:0 0}.event-form-cancel:hover{background:#ffffff0f}.event-form-dream{border-color:#74b9ff4d}.event-form-dream-header{align-items:center;gap:8px;display:flex}.event-form-dream-icon{font-size:1.2rem}.event-form-dream-title{color:#74b9ff;font-size:.9rem;font-weight:700}.event-form-dream-time{color:var(--text-secondary,#8888a0);margin-left:auto;font-size:.78rem}.event-form-dream-hint{color:var(--text-muted,#55556a);font-size:.78rem;font-style:italic}.event-form-voice-prominent{justify-content:center;padding:8px 0}.event-form-mic-lg{width:48px;height:48px;font-size:1.3rem}.event-form-textarea{background:var(--bg-input,#12121e);border:1px solid var(--border,#2a2a40);border-radius:var(--radius-sm,8px);color:var(--text-primary,#e8e8f0);resize:vertical;min-height:60px;padding:8px;font-family:inherit;font-size:.82rem}.event-form-textarea:focus{border-color:var(--accent-primary,#74b9ff);outline:none}.event-form-voice{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.event-form-mic{border:1px solid var(--border,#2a2a40);width:34px;height:34px;color:var(--text-primary,#e8e8f0);cursor:pointer;background:#12121ecc;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;transition:background .15s,box-shadow .15s;display:flex}.event-form-mic:hover{background:#74b9ff26}.event-form-mic.recording{background:#ff6b6b33;border-color:#ff6b6b;animation:1.2s ease-in-out infinite mic-pulse;box-shadow:0 0 8px #ff6b6b66}@keyframes mic-pulse{0%,to{box-shadow:0 0 4px #ff6b6b4d}50%{box-shadow:0 0 12px #ff6b6b99}}.event-form-recording-label{color:#ff6b6b;font-size:.75rem;animation:1.2s ease-in-out infinite mic-pulse-text}@keyframes mic-pulse-text{0%,to{opacity:.6}50%{opacity:1}}.event-form-transcript{align-items:flex-start;gap:8px;width:100%;margin-top:4px;display:flex}.event-form-transcript-text{color:var(--text-secondary,#8888a0);border:1px solid var(--border,#2a2a40);border-radius:var(--radius-sm,8px);background:#12121e80;flex:1;max-height:60px;padding:6px 8px;font-size:.78rem;font-style:italic;overflow-y:auto}.event-form-transcript-apply{border-radius:var(--radius-sm,8px);cursor:pointer;background:var(--accent-primary,#74b9ff);color:#1a1a2e;border:1px solid #0000;flex-shrink:0;padding:4px 12px;font-size:.75rem;font-weight:600}.event-form-transcript-apply:hover{opacity:.9}.stress-gauge{border-radius:var(--radius-sm);height:32px;margin-top:8px;display:flex;overflow:hidden}.stress-gauge-segment{color:#fff;justify-content:center;align-items:center;min-width:40px;font-size:.75rem;display:flex}.stress-gauge-neutral{color:var(--text-muted);background:#2a2a4099}.stress-badge{border-radius:12px;margin-top:8px;padding:4px 12px;font-size:.8rem;font-weight:600;display:inline-block}.stress-badge.restored{color:#55efc4;background:#55efc433}.stress-badge.normal{color:#74b9ff;background:#74b9ff33}.stress-badge.stressful{color:orange;background:#ffa50033}@media (max-width:768px){.auth-card{padding:28px 20px}.sync-prompt{flex-wrap:wrap}.header-actions{gap:6px}.day-detail-panel{width:100%;right:-100%}.heatmap-cell{min-width:14px;min-height:14px}.heatmap-row-label{font-size:.6rem}.header-center{flex-direction:column;gap:10px}.header-date-picker{width:100%}.day-picker-input{flex:1;max-width:100%}}.gcal-picker{margin-top:12px}.gcal-picker-label{color:var(--text-secondary);margin-bottom:8px;font-size:.85rem;display:block}.gcal-calendar-list{flex-direction:column;gap:6px;display:flex}.gcal-calendar-item{border-radius:var(--radius-sm);background:var(--bg-input);border:1px solid var(--border);cursor:pointer;transition:background var(--transition);align-items:center;gap:8px;padding:6px 10px;font-size:.85rem;display:flex}.gcal-calendar-item:hover{background:var(--bg-card-hover)}.gcal-calendar-item input[type=checkbox]{accent-color:var(--accent-primary)}.gcal-color-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.event-gcal-badge{color:#4285f4;background:#4285f42e}.event-popup-room{color:#e056fd;margin:2px 0 4px;font-size:.8rem;font-weight:600}.viewer-selector-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:12px;margin-bottom:16px;padding:10px 16px;display:flex}.viewer-label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.viewer-select{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;min-width:180px;padding:6px 12px;font-size:.85rem}.viewer-select:focus{border-color:var(--border-focus);outline:none}.viewer-badge{color:var(--accent-secondary);background:#7c3aed33;border-radius:12px;padding:3px 10px;font-size:.75rem;font-weight:600}.viewer-mode-toggle{border:1px solid var(--border);border-radius:6px;gap:0;margin-right:4px;display:flex;overflow:hidden}.viewer-mode-btn{background:var(--bg-input);color:var(--text-secondary);cursor:pointer;transition:background var(--transition),color var(--transition);border:none;padding:5px 14px;font-size:.8rem;font-weight:500}.viewer-mode-btn:not(:last-child){border-right:1px solid var(--border)}.viewer-mode-btn.active{background:var(--accent-primary);color:#fff}.viewer-mode-btn:hover:not(.active){background:var(--bg-card-hover)}.consent-toggle{cursor:pointer;color:var(--text-primary);align-items:center;gap:8px;margin-top:8px;font-size:.9rem;display:flex}.consent-toggle input[type=checkbox]{accent-color:var(--accent-primary)}.consent-hint{color:var(--text-muted);margin:2px 0 10px 26px;font-size:.78rem}.consent-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);margin-top:10px;padding:12px 14px}.consent-details{color:var(--text-muted);margin:8px 0 0 26px;font-size:.78rem;line-height:1.6}.consent-details p{margin-bottom:2px}.consent-details strong{color:var(--text-secondary)}.app-layout.art-mode{z-index:1;position:relative}.app-layout.art-mode .dash-header{-webkit-backdrop-filter:blur(12px);background:#0a0a0f99}.art-view{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;gap:12px;height:calc(100vh - 100px);padding:4px 0;display:grid}@media (max-width:768px){.art-view{grid-template-rows:repeat(4,1fr);grid-template-columns:1fr;height:auto}}.art-window{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);min-height:200px;position:relative;overflow:hidden}.art-window-label{text-transform:uppercase;letter-spacing:1.5px;color:#ffffff40;z-index:1;pointer-events:none;font-size:.7rem;font-weight:600;position:absolute;top:10px;left:14px}.art-canvas{width:100%;height:100%;display:block}.mind-actions{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}.mind-action-btn{-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);color:var(--text-primary);text-align:center;background:#0a0a1a9e;flex-direction:column;align-items:center;gap:8px;padding:20px 12px;font-size:.85rem;font-weight:600;display:flex}.mind-action-btn:hover{border-color:var(--btn-accent,var(--accent-mind));box-shadow:0 0 16px color-mix(in srgb,var(--btn-accent,var(--accent-mind))30%,transparent);background:#0a0a1ad9}.mind-action-icon{font-size:1.6rem}.mind-action-label{color:var(--text-secondary);font-size:.8rem}@media (max-width:768px){.mind-actions{grid-template-columns:repeat(2,1fr)}}.placeholder-page{flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.placeholder-content{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:60px 20px;display:flex}.placeholder-icon{opacity:.3;font-size:3rem}.placeholder-text{color:var(--text-secondary);font-size:1.2rem;font-weight:600}.placeholder-subtext{color:var(--text-muted);max-width:400px;font-size:.9rem;line-height:1.6}.weather-location-label{color:var(--text-secondary);margin-bottom:12px;font-size:.82rem}.goals-panel{padding:8px 0}.goals-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.goals-title{color:var(--text-primary);font-size:1.4rem;font-weight:700}.goals-edit-btn{padding:5px 14px;font-size:.8rem}.goals-section{margin-bottom:28px}.goals-section-title{color:var(--text-secondary);margin-bottom:12px;font-size:1rem;font-weight:600}.goals-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.goal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition);padding:14px 16px}.goal-card.goal-hit{border-color:var(--accent-workout)}.goal-card-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.goal-card-label{color:var(--text-primary);font-size:.85rem;font-weight:600}.goal-check{color:var(--accent-workout);font-size:1.1rem;font-weight:700}.goal-progress-bar{background:var(--bg-input);border-radius:3px;height:6px;margin-bottom:8px;overflow:hidden}.goal-progress-fill{background:var(--accent-primary);border-radius:3px;height:100%;transition:width .4s}.goal-card.goal-hit .goal-progress-fill{background:var(--accent-workout)}.goal-card-values{align-items:baseline;gap:4px;display:flex}.goal-current{color:var(--text-primary);font-size:1.1rem;font-weight:700}.goal-target{color:var(--text-muted);font-size:.8rem}.streaks-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;display:grid}.streak-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px}.streak-label{color:var(--text-primary);margin-bottom:10px;font-size:.85rem;font-weight:600;display:block}.streak-values{gap:20px;display:flex}.streak-stat{flex-direction:column;align-items:center;display:flex}.streak-number{color:var(--text-secondary);font-size:1.3rem;font-weight:700}.streak-number.active{color:var(--accent-workout)}.streak-number.best{color:var(--accent-primary)}.streak-caption{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:.7rem}.goals-editor{flex-direction:column;gap:10px;display:flex}.goal-edit-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:10px;padding:10px 14px;display:flex}.goal-edit-label{color:var(--text-primary);flex:1;font-size:.9rem;font-weight:500}.goal-edit-input{background:var(--bg-input);width:80px;color:var(--text-primary);border:1px solid var(--border);text-align:right;border-radius:6px;padding:4px 8px;font-size:.9rem}.goal-edit-input:focus{border-color:var(--border-focus);outline:none}.goal-edit-unit{color:var(--text-muted);min-width:30px;font-size:.8rem}.goal-remove-btn{color:var(--accent-danger);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.2rem;line-height:1}.goal-add-row{align-items:center;gap:8px;margin-top:4px;display:flex}.goal-add-row select{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;flex:1;padding:6px 10px;font-size:.85rem}.goal-add-btn{padding:6px 16px;font-size:.8rem}.goal-add-period{width:100px}.goals-editor-section{margin-bottom:8px}.goals-editor-period{color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.5px;border-top:1px solid var(--border);margin-bottom:6px;padding-top:8px;font-size:.85rem;font-weight:600}.goals-editor-section:first-child .goals-editor-period{border-top:none;padding-top:0}.goals-section-subtitle{color:var(--text-muted);margin:-8px 0 12px;font-size:.75rem;display:block}.goal-fill-weekly{background:var(--accent-sleep)}.goal-fill-monthly{background:var(--accent-stress)}.goal-agg-hint{color:var(--text-muted);margin-left:4px;font-size:.7rem;font-style:italic}.installation-manager{margin-top:8px}.installation-list{flex-direction:column;gap:12px;margin-bottom:12px;display:flex}.installation-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition);padding:14px 16px}.installation-card.inactive{opacity:.6;border-color:var(--text-muted)}.installation-card-header{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px;display:flex}.installation-card-header strong{color:var(--text-primary);font-size:.95rem}.installation-room{color:var(--accent-secondary);background:#7c3aed26;border-radius:10px;margin-left:8px;padding:2px 8px;font-size:.75rem;display:inline-block}.installation-card-actions{flex-shrink:0;gap:6px;display:flex}.installation-meta{color:var(--text-secondary);gap:14px;margin-bottom:8px;font-size:.78rem;display:flex}.installation-sessions{color:var(--accent-workout);font-weight:600}.installation-scopes{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.scope-tag{text-transform:uppercase;letter-spacing:.5px;color:var(--accent-secondary);background:#7c3aed1f;border-radius:10px;padding:2px 8px;font-size:.7rem;font-weight:600}.scope-tag.scope-sleep{color:var(--accent-sleep);background:#74b9ff1f}.scope-tag.scope-heart{color:var(--accent-heart);background:#ff6b6b1f}.scope-tag.scope-workout{color:var(--accent-workout);background:#55efc41f}.scope-tag.scope-stress{color:var(--accent-stress);background:#ffa5001f}.installation-api-key{align-items:center;gap:8px;margin-top:6px;font-size:.8rem;display:flex}.installation-api-key label{color:var(--text-muted);flex-shrink:0;font-size:.75rem}.installation-api-key code{color:var(--text-secondary);background:var(--bg-primary);text-overflow:ellipsis;white-space:nowrap;border-radius:4px;max-width:200px;padding:3px 8px;font-family:SF Mono,Fira Code,monospace;font-size:.75rem;overflow:hidden}.installation-api-key code.masked{color:var(--text-muted);letter-spacing:1px}.installation-api-key code.checkin-url{max-width:260px}.installation-create-form,.installation-edit-form{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:10px;margin-top:10px;padding:14px;display:flex}.installation-create-form h4{color:var(--text-primary);margin-bottom:4px;font-size:.9rem}.installation-create-form input[type=text],.installation-create-form input[type=number],.installation-create-form select,.installation-edit-form input[type=text],.installation-edit-form input[type=number],.installation-edit-form select{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-size:.85rem}.installation-create-form input:focus,.installation-create-form select:focus,.installation-edit-form input:focus,.installation-edit-form select:focus{border-color:var(--border-focus);outline:none}.installation-scopes-edit{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.installation-scopes-edit>label:first-child{color:var(--text-secondary);font-size:.8rem}.scope-checkbox{color:var(--text-primary);cursor:pointer;align-items:center;gap:4px;font-size:.85rem;display:flex}.scope-checkbox input[type=checkbox]{accent-color:var(--accent-primary)}.timeout-edit{align-items:center;gap:8px;display:flex}.timeout-edit label{color:var(--text-secondary);font-size:.8rem}.timeout-edit input[type=number]{width:80px}.timeout-edit span{color:var(--text-muted);font-size:.8rem}.installation-form-actions{gap:8px;margin-top:4px;display:flex}.device-assign-form{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:8px;margin-top:10px;padding:12px;display:flex}.assign-row{gap:8px;display:flex}.assign-row input{flex:1}.device-assign-form input,.device-assign-form select{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:.85rem}.device-assign-form input:focus,.device-assign-form select:focus{border-color:var(--border-focus);outline:none}.device-manager{margin-top:4px}.device-list{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.device-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.device-info{align-items:center;gap:10px;display:flex}.device-type-badge{text-transform:uppercase;letter-spacing:.5px;color:var(--accent-secondary);background:#7c3aed26;border-radius:8px;padding:2px 8px;font-size:.65rem;font-weight:700}.device-label{color:var(--text-primary);font-size:.85rem}.device-hash{color:var(--text-muted);font-family:SF Mono,Fira Code,monospace;font-size:.75rem}.device-pair-form{margin-top:12px}.device-pair-form label{color:var(--text-secondary);margin-bottom:6px;font-size:.8rem;display:block}.pair-input-row{align-items:center;gap:8px;display:flex}.pairing-code-input{background:var(--bg-input);width:100px;color:var(--text-primary);border:1px solid var(--border);letter-spacing:3px;text-align:center;text-transform:uppercase;border-radius:6px;padding:6px 10px;font-family:SF Mono,Fira Code,monospace;font-size:1rem}.pairing-code-input:focus{border-color:var(--border-focus);outline:none}.btn-sm{padding:4px 10px;font-size:.75rem}.audit-log{margin-top:8px}.audit-entries{flex-direction:column;gap:2px;max-height:320px;display:flex;overflow-y:auto}.audit-entry{border-radius:var(--radius-sm);background:var(--bg-input);align-items:flex-start;gap:10px;padding:8px 10px;font-size:.82rem;display:flex}.audit-entry:nth-child(2n){background:0 0}.audit-icon{background:var(--text-muted);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.audit-icon-eye{background:var(--accent-primary)}.audit-icon-shield{background:var(--accent-stress)}.audit-icon-login{background:var(--accent-workout)}.audit-icon-logout{background:var(--text-muted)}.audit-icon-key{background:var(--accent-secondary)}.audit-icon-warning,.audit-icon-trash{background:var(--accent-danger)}.audit-entry-content{flex-direction:column;flex:1;gap:1px;display:flex}.audit-label{color:var(--text-primary);font-weight:500}.audit-resource{color:var(--text-muted);font-family:monospace;font-size:.75rem}.audit-time{color:var(--text-muted);font-size:.75rem}.audit-ip{color:var(--text-muted);flex-shrink:0;font-family:monospace;font-size:.72rem}.audit-pagination{border-top:1px solid var(--border);justify-content:center;align-items:center;gap:12px;margin-top:10px;padding-top:8px;display:flex}.audit-page-info{color:var(--text-muted);font-size:.78rem}.delete-account-form label{color:var(--text-secondary);margin-top:12px;margin-bottom:4px;font-size:.85rem;display:block}.delete-account-form input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);margin-top:4px;padding:8px 12px;font-size:.9rem}.delete-account-form input:focus{border-color:var(--accent-danger);outline:none}.legal-page{justify-content:center;align-items:flex-start;min-height:100vh;padding:40px 20px;display:flex}.legal-card{-webkit-backdrop-filter:blur(20px)saturate(1.3);border-radius:var(--radius);background:#0a0a1acc;border:1px solid #7c3aed1f;width:100%;max-width:720px;padding:40px 36px;box-shadow:0 8px 40px #0000004d}.legal-updated{color:var(--text-muted);margin-bottom:24px;font-size:.85rem}.legal-nav{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px;margin-bottom:32px;padding-bottom:16px;display:flex}.legal-nav a{color:var(--accent-secondary);border-radius:var(--radius-sm);background:var(--bg-input);transition:background var(--transition);padding:4px 10px;font-size:.85rem;text-decoration:none}.legal-nav a:hover{background:var(--bg-card-hover)}.legal-card section{margin-bottom:28px}.legal-card h2{color:var(--text-primary);margin-bottom:10px;font-size:1.1rem;font-weight:600}.legal-card p,.legal-card li{color:var(--text-secondary);font-size:.9rem;line-height:1.7}.legal-card ul{margin-top:8px;padding-left:20px}.legal-card li{margin-bottom:6px}.legal-card a{color:var(--accent-secondary);text-decoration:none}.legal-card a:hover{text-decoration:underline}.legal-footer-links{border-top:1px solid var(--border);justify-content:center;gap:16px;margin-top:32px;padding-top:20px;display:flex}.legal-footer-links a{color:var(--accent-secondary);font-size:.85rem;text-decoration:none}.legal-footer-links a:hover{text-decoration:underline}@media (max-width:600px){.legal-card{padding:28px 20px}}.gate-page{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.gate-card{text-align:center;-webkit-backdrop-filter:blur(24px)saturate(1.3);border-radius:var(--radius);background:#0a0a1acc;border:1px solid #7c3aed26;width:100%;max-width:380px;padding:48px 36px;animation:6s ease-in-out infinite glow-pulse;box-shadow:0 8px 48px #0006,0 0 80px #7c3aed14}.gate-title{background:linear-gradient(135deg,#7c3aed,#818cf8,#c4b5fd);-webkit-text-fill-color:transparent;letter-spacing:.02em;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:2rem;font-weight:700}.gate-subtitle{color:var(--text-secondary);margin-bottom:32px;font-size:.9rem}.gate-form{flex-direction:column;gap:14px;display:flex}.gate-form input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);text-align:center;letter-spacing:.15em;transition:border-color var(--transition),box-shadow var(--transition);outline:none;padding:12px 16px;font-size:1rem}.gate-form input:focus{border-color:var(--accent-primary);box-shadow:0 0 16px #7c3aed40}.gate-form button{color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;padding:12px 24px;font-size:.95rem;font-weight:600;box-shadow:0 2px 16px #7c3aed4d}.gate-form button:hover{background:linear-gradient(135deg,#8b5cf6,#7c3aed);transform:translateY(-1px);box-shadow:0 4px 24px #7c3aed80}.gate-form button:disabled{opacity:.6;cursor:not-allowed;transform:none}.gate-error{color:var(--accent-danger);font-size:.85rem}
