:root{--bg-base: #0f1117;--bg-surface: #161b22;--bg-elevated: #1e2733;--bg-hover: #243040;--text-primary: #c8cdd6;--text-secondary: #5a6678;--text-muted: #3d4a5c;--accent-amber: #c8a96e;--accent-red: #e8604c;--accent-green: #3de87a;--accent-orange: #f39c12;--accent-blue: #3b82f6;--border: #1e2733;--border-subtle: #161b22;--color-bean-drop: #2ecc71;--color-yellowing: #f1c40f;--color-first-crack: #f39c12;--color-first-crack-end: #e67e22;--color-second-crack: #e74c3c;--color-second-crack-end: #c0392b;--color-bean-discard: #e67e22;--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;font-size:16px;line-height:1.6;color:var(--text-primary);background-color:var(--bg-base)}[data-theme=theme-light]{--bg-base: #f8f9fb;--bg-surface: #ffffff;--bg-elevated: #f0f2f5;--bg-hover: #e8eaed;--text-primary: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--accent-amber: #92400e;--accent-red: #dc2626;--accent-green: #16a34a;--accent-orange: #d97706;--accent-blue: #2563eb;--border: #e5e7eb;--border-subtle: #f3f4f6;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.08)}[data-theme=theme-warm]{--bg-base: #faf7f2;--bg-surface: #ffffff;--bg-elevated: #f0ebe4;--bg-hover: #e8dfd4;--text-primary: #2c1a0e;--text-secondary: #8b6342;--text-muted: #a07c5c;--accent-amber: #6f4e37;--accent-red: #8b2500;--accent-green: #2d6a4f;--accent-orange: #d4522a;--accent-blue: #1a4a6b;--border: #e8dfd4;--border-subtle: #f0ebe4;--shadow-sm: 0 1px 3px rgba(44,26,14,.08);--shadow-md: 0 4px 12px rgba(44,26,14,.1)}*{box-sizing:border-box;margin:0;padding:0}button:focus-visible{outline:2px solid var(--accent-amber);outline-offset:2px}.app{display:flex;flex-direction:row;height:100vh;overflow:hidden;background:var(--bg-base)}.app-sidebar{width:88px;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;z-index:20}.sidebar-logo{display:flex;flex-direction:column;align-items:center;padding:14px 8px 10px;border-bottom:1px solid var(--border);gap:3px}.sidebar-logo-icon{font-size:20px;line-height:1}.sidebar-logo-text{font-size:14px;font-weight:600;color:var(--text-secondary);letter-spacing:.04em;white-space:nowrap}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px;padding:8px 6px}.sidebar-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 4px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;font-size:14px;font-family:inherit;transition:all .15s;width:100%;gap:4px}.sidebar-tab:hover{background:var(--bg-elevated);color:var(--text-secondary)}.sidebar-tab.active{background:var(--bg-elevated);color:var(--accent-amber);font-weight:600;box-shadow:inset 2px 0 0 var(--accent-amber)}.sidebar-tab-icon{font-size:18px;line-height:1}.sidebar-tab-label{font-size:14px;line-height:1.2}.sidebar-bottom{padding:8px 6px 12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:4px}.sidebar-settings-btn{width:100%;padding:7px 4px;font-size:16px;background:transparent;color:var(--text-muted);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s;text-align:center}.sidebar-settings-btn:hover{background:var(--bg-elevated);color:var(--text-secondary)}.sidebar-new-btn{width:100%;padding:7px 4px;font-size:13px;font-weight:600;font-family:inherit;background:var(--accent-amber);color:var(--bg-base);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s;white-space:nowrap;letter-spacing:.02em}.sidebar-new-btn:hover{filter:brightness(1.1)}.settings-panel{position:fixed;left:88px;bottom:0;width:220px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:14px;z-index:100}.settings-panel-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);margin-bottom:10px}.theme-options{display:flex;flex-direction:column;gap:6px}.theme-option{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);border:1px solid var(--border);cursor:pointer;background:transparent;font-family:inherit;font-size:14px;color:var(--text-primary);transition:all .15s;text-align:left;width:100%}.theme-option:hover{background:var(--bg-elevated)}.theme-option.active{border-color:var(--accent-amber);background:var(--bg-elevated)}.theme-swatch{width:20px;height:20px;border-radius:50%;flex-shrink:0;border:2px solid transparent}.theme-option.active .theme-swatch{border-color:var(--accent-amber)}.app-body{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.app-topbar{height:64px;background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;padding:0 18px;flex-shrink:0}.topbar-new-btn{background:var(--accent-amber);color:#000;border:none;border-radius:6px;padding:10px 22px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s}.topbar-new-btn:hover{opacity:.85}.rib-new-btn{padding:4px 14px;font-size:13px;margin-left:8px}.timer-strip{height:64px;background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 18px;gap:16px;flex-shrink:0}.ts-sep{width:1px;height:28px;background:var(--border);margin:0 2px;flex-shrink:0}.ts-status{display:flex;align-items:center;gap:7px;min-width:80px}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.timer-status-indicator.running .status-dot{background:var(--accent-green);box-shadow:0 0 6px var(--accent-green);animation:pulse-dot 1.5s ease-in-out infinite}.timer-status-indicator.paused .status-dot{background:var(--accent-orange)}@keyframes pulse-dot{0%,to{box-shadow:0 0 #3de87a80}50%{box-shadow:0 0 0 4px #3de87a00}}.status-text{font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted)}.timer-status-indicator.running .status-text{color:var(--accent-green)}.timer-status-indicator.paused .status-text{color:var(--accent-orange)}.timer-strip .timer-container{flex-direction:row;align-items:center;padding:0;gap:12px}.timer-strip .timer-display{font-size:36px;gap:1px}.timer-strip .timer-controls{margin-top:0;gap:6px}.timer-strip .timer-btn{padding:6px 18px;font-size:13px}.ts-temp{display:flex;align-items:baseline;gap:2px}.ts-temp.dim .ts-temp-val,.ts-temp.dim .ts-temp-unit{color:var(--text-muted)}.ts-temp-val{font-size:36px;font-weight:200;color:var(--accent-red);font-variant-numeric:tabular-nums;line-height:1}.ts-temp-unit{font-size:13px;color:var(--text-secondary)}.timer-strip .development-time-display{flex-direction:row;align-items:center;border-top:none;background:transparent;gap:16px}.timer-strip .dev-time-item{flex-direction:row;align-items:center;gap:5px;padding:0;border-right:none}.timer-strip .dev-time-label{font-size:13px}.timer-strip .dev-time-value{font-size:13px;font-weight:600}.ts-right{margin-left:auto;display:flex;align-items:center;gap:10px}.ts-roast-name{font-size:14px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.ts-action-btn{padding:3px 10px;font-size:14px;font-family:inherit;background:transparent;color:var(--accent-amber);border:1px solid var(--accent-amber);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;white-space:nowrap}.ts-action-btn:hover{background:var(--accent-amber);color:var(--bg-base)}.roast-info-bar{height:36px;display:flex;align-items:center;gap:10px;padding:0 18px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.rib-name{font-size:14px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rib-name-editable{cursor:pointer;border-bottom:1px dashed var(--border)}.rib-name-editable:hover{color:var(--accent-amber)}.rib-name-input{font-size:14px;font-weight:500;color:var(--text-primary);background:var(--bg-elevated);border:1px solid var(--accent-amber);border-radius:var(--radius-sm);padding:2px 6px;outline:none;min-width:120px;max-width:220px}.roast-editing-badge{font-size:13px;font-weight:600;background:var(--accent-red);color:#fff;padding:2px 7px;border-radius:var(--radius-sm)}.rib-coffee-btn{margin-left:auto;font-size:14px;font-weight:500;background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:3px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.rib-coffee-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.phase-banner{height:28px;display:flex;align-items:center;gap:10px;padding:0 18px;background:var(--bg-base);border-bottom:1px solid var(--border);flex-shrink:0}.phase-chip{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:999px;font-size:13px;font-weight:600;letter-spacing:.5px}.phase-chip.drying{background:#f1c40f1f;color:#f1c40f}.phase-chip.maillard{background:#f39c121f;color:var(--accent-orange)}.phase-chip.development{background:#e8604c1f;color:var(--accent-red)}.phase-chip.finished{background:#3de87a1f;color:var(--accent-green)}.phase-chip-dot{width:5px;height:5px;border-radius:50%;background:currentColor}.phase-start-time{font-size:13px;color:var(--text-muted)}.app-main{flex:1;overflow-y:auto;padding:14px 18px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.empty-state-icon{font-size:64px;line-height:1;opacity:.7}.start-roast-btn{padding:12px 28px;font-size:15px;font-weight:600;font-family:inherit;background:var(--accent-amber);color:var(--bg-base);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;letter-spacing:.02em}.start-roast-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.recent-roasts{width:100%;max-width:380px;margin-top:8px}.recent-roasts-title{font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);text-align:center;margin-bottom:10px}.recent-roast-item{display:flex;justify-content:space-between;align-items:center;padding:9px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:5px;cursor:pointer;transition:all .15s}.recent-roast-item:hover{background:var(--bg-elevated);border-color:var(--accent-amber)}.recent-roast-name{font-size:14px;font-weight:500;color:var(--text-primary)}.recent-roast-date{font-size:14px;color:var(--text-muted)}.timer-view{display:flex;flex-direction:column;gap:16px}.roast-layout{display:flex;gap:12px;align-items:stretch}.roast-left{width:260px;flex-shrink:0;display:flex;flex-direction:column;gap:0;background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden}.roast-right{flex:1;min-width:0;background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:8px;overflow:hidden}.events-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.events-panel-title{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);padding:7px 10px 5px;border-bottom:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0}.events-timeline{display:flex;flex-direction:column;flex:1;overflow-y:auto}.event-tl-btn{display:flex;align-items:center;gap:8px;padding:8px 10px;border:none;background:transparent;cursor:pointer;width:100%;text-align:left;border-bottom:1px solid var(--border);transition:background .12s;font-family:inherit}.event-tl-btn:last-child{border-bottom:none}.event-tl-btn:not(.done):hover{background:var(--bg-elevated)}.event-tl-btn.done{cursor:default}.event-tl-btn.next{background:linear-gradient(to right,rgba(200,169,110,.08),transparent);border-left:2px solid var(--accent-amber);padding-left:8px}.event-tl-btn.next:hover{background:linear-gradient(to right,rgba(200,169,110,.14),transparent)}.etb-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.event-tl-btn.bean-drop .etb-dot{background:var(--color-bean-drop)}.event-tl-btn.yellowing .etb-dot{background:var(--color-yellowing)}.event-tl-btn.first-crack .etb-dot{background:var(--color-first-crack)}.event-tl-btn.first-crack-end .etb-dot{background:var(--color-first-crack-end)}.event-tl-btn.second-crack .etb-dot{background:var(--color-second-crack)}.event-tl-btn.second-crack-end .etb-dot{background:var(--color-second-crack-end)}.event-tl-btn.bean-discard .etb-dot{background:var(--color-bean-discard)}.event-tl-btn.done .etb-dot{opacity:.35}.event-tl-btn.next .etb-dot{transform:scale(1.2)}.etb-label{flex:1;font-size:14px;color:var(--text-primary)}.event-tl-btn.done .etb-label{color:var(--text-muted)}.event-tl-btn.next .etb-label{font-size:15px;font-weight:600;color:var(--accent-amber)}.etb-time{font-size:14px;color:var(--text-muted);font-variant-numeric:tabular-nums}.etb-next-badge{font-size:14px;font-weight:600;background:var(--accent-amber);color:var(--bg-base);padding:2px 6px;border-radius:999px;flex-shrink:0}.sensor-panel{background:var(--bg-elevated);border-top:1px solid var(--border);padding:8px 10px;display:flex;flex-direction:column;gap:7px;flex-shrink:0}.sensor-row{display:flex;align-items:center;justify-content:space-between}.sensor-indicator{display:flex;align-items:center;gap:6px}.sensor-dot{width:6px;height:6px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.sensor-indicator.connected .sensor-dot{background:var(--accent-green)}.sensor-indicator.connecting .sensor-dot{background:var(--accent-orange);animation:pulse-dot 1s infinite}.sensor-label{font-size:13px;color:var(--text-secondary)}.sensor-indicator.connected .sensor-label{color:var(--text-primary);font-weight:500}.sensor-btn{padding:5px 12px;font-size:13px;border-radius:999px;border:1px solid;background:transparent;cursor:pointer;transition:all .15s;font-weight:500;font-family:inherit}.sensor-btn:disabled{opacity:.4;cursor:default}.sensor-btn.connect{border-color:var(--accent-amber);color:var(--accent-amber)}.sensor-btn.connect:not(:disabled):hover{background:var(--accent-amber);color:var(--bg-base)}.sensor-btn.disconnect{border-color:var(--accent-red);color:var(--accent-red)}.sensor-btn.disconnect:hover{background:var(--accent-red);color:#fff}.autorecord-row{display:flex;align-items:center;gap:8px}.autorecord-label{font-size:13px;color:var(--text-secondary);flex:1}.toggle-switch{position:relative;display:inline-block;width:30px;height:18px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:var(--bg-base);border-radius:18px;cursor:pointer;transition:.2s;border:1px solid var(--border)}.toggle-slider:before{content:"";position:absolute;height:12px;width:12px;left:2px;bottom:2px;background:var(--text-muted);border-radius:50%;transition:.2s}.toggle-switch input:checked+.toggle-slider{background:var(--accent-amber);border-color:var(--accent-amber)}.toggle-switch input:checked+.toggle-slider:before{background:var(--bg-base);transform:translate(12px)}.toggle-switch input:disabled+.toggle-slider{opacity:.4;cursor:default}.interval-select-sm{font-size:13px;padding:3px 6px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-primary);cursor:pointer;font-family:inherit}.sensor-error{font-size:13px;color:var(--accent-red);background:#e8604c14;padding:4px 7px;border-radius:var(--radius-sm)}.manual-temp-row{display:flex;gap:5px;border-top:1px solid var(--border);padding-top:6px;flex-wrap:nowrap}.manual-temp-input{flex:1;min-width:0;padding:6px 9px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--bg-base);color:var(--text-primary);font-family:inherit}.manual-temp-input:focus{outline:none;border-color:var(--accent-amber)}.manual-temp-btn{padding:6px 10px;font-size:13px;font-family:inherit;flex-shrink:0;background:var(--accent-amber);color:var(--bg-base);border:none;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap}.manual-temp-btn:hover{filter:brightness(1.1)}.left-bottom-actions{border-top:1px solid var(--border);padding:8px;display:flex;flex-direction:column;gap:5px;flex-shrink:0}.save-btn-main{width:100%;padding:11px;font-size:14px;font-weight:600;font-family:inherit;background:var(--accent-amber);color:var(--bg-base);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s}.save-btn-main:hover{filter:brightness(1.1)}.import-csv-btn{display:block;text-align:center;padding:5px;font-size:14px;color:var(--text-muted);border:1px dashed var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .15s}.import-csv-btn:hover{border-color:var(--accent-amber);color:var(--accent-amber)}.dev-panel{display:flex;flex-direction:column;flex:1;overflow:hidden}.dev-time-header{padding:10px 10px 8px;border-bottom:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0}.dev-time-header.warning{background:#e8604c0f;border-bottom-color:#e8604c33}.dev-time-label-sm{font-size:8px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:2px}.dev-time-header.warning .dev-time-label-sm{color:var(--accent-red);opacity:.7}.dev-time-big{font-size:40px;font-weight:200;line-height:1;color:var(--accent-amber);font-variant-numeric:tabular-nums;letter-spacing:-2px}.dev-time-header.warning .dev-time-big{color:var(--accent-red)}.dev-time-dtr{font-size:13px;color:var(--text-muted);margin-top:2px}.dev-time-dtr span{color:var(--accent-green)}.dev-time-warning-text{font-size:13px;color:var(--accent-red);opacity:.7;margin-top:2px}.dev-log-section{padding:7px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.dev-log-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}.dev-log-title{font-size:8px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted)}.retro-trigger-btn{font-size:14px;color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px 6px;cursor:pointer;font-family:inherit;transition:all .15s}.retro-trigger-btn:hover{color:var(--accent-amber);border-color:var(--accent-amber)}.retro-trigger-btn.warning-pulse{color:var(--accent-red);border-color:#e8604c4d;background:#e8604c0f}.dev-log-row{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:var(--text-muted);padding:2px 0}.dev-log-row.crack{color:var(--accent-amber);opacity:.8}.history-event-row{gap:4px;flex-wrap:nowrap}.history-event-name{font-size:13px;color:var(--text-secondary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-event-time{font-size:13px;color:var(--text-muted);white-space:nowrap}.history-event-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);padding:1px 5px;cursor:pointer;font-size:12px;flex-shrink:0;transition:all .15s}.history-event-btn.edit:hover{color:var(--accent-amber);border-color:var(--accent-amber)}.history-event-btn.delete:hover{color:var(--accent-red);border-color:var(--accent-red)}.dev-actions-section{padding:8px;flex:1;display:flex;flex-direction:column;gap:5px}.dev-actions-hint{font-size:14px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}.dev-action-btn{width:100%;border-radius:var(--radius-md);padding:10px 12px;cursor:pointer;text-align:left;font-family:inherit;display:flex;align-items:center;gap:7px;transition:all .15s;border:1px solid transparent}.dev-action-btn.primary{background:linear-gradient(135deg,#8b2500cc,#e8604cb3);color:#fcb;font-size:14px;font-weight:700;letter-spacing:.5px;border-color:#e8604c4d}.dev-action-btn.primary:hover{filter:brightness(1.15)}.dev-action-btn.secondary{background:var(--bg-elevated);color:var(--accent-amber);font-size:13px;border-color:#c8a96e33}.dev-action-btn.secondary:hover{border-color:var(--accent-amber);background:#c8a96e14}.dev-action-btn-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.dev-action-hint{font-size:14px;opacity:.6;margin-left:auto}.dev-sensor-row{display:flex;align-items:center;gap:6px;padding:5px 10px;border-top:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0}.dev-sensor-dot{width:5px;height:5px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.dev-sensor-dot.connected{background:var(--accent-green)}.dev-sensor-label{font-size:13px;color:var(--text-muted)}.dev-sensor-label.connected{color:var(--text-secondary)}.dev-autorecord-text{font-size:13px;color:var(--text-muted);margin-left:auto}.timer-container{display:flex;flex-direction:column;align-items:center;padding:20px 16px 14px;gap:0}.timer-display{display:flex;align-items:center;gap:3px;font-size:56px;font-weight:200;font-variant-numeric:tabular-nums;letter-spacing:-2px}.timer-unit{display:inline-block;min-width:1.1em;text-align:center;color:var(--accent-amber)}.timer-separator{color:var(--text-muted);animation:blink 1s infinite;line-height:1;margin-bottom:4px}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:.2}}.timer-controls{display:flex;gap:8px;justify-content:center;margin-top:14px}.timer-btn{padding:8px 28px;font-size:13px;font-weight:600;font-family:inherit;border:none;border-radius:999px;cursor:pointer;transition:all .15s;letter-spacing:.03em}.timer-btn.start{background:var(--accent-amber);color:var(--bg-base)}.timer-btn.pause{background:var(--accent-orange);color:#fff}.timer-btn.reset{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.timer-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.timer-btn.reset:hover{filter:none;background:var(--bg-elevated);transform:none}.development-time-display{display:flex;width:100%;border-top:1px solid var(--border);background:var(--bg-elevated)}.dev-time-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 6px;border-right:1px solid var(--border)}.dev-time-item:last-child{border-right:none}.dev-time-label{font-size:14px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.dev-time-value{font-size:15px;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.dev-time-ratio{font-size:13px;color:var(--text-muted)}.chart-metrics-row{display:flex;gap:6px;padding:6px 8px 4px;border-bottom:1px solid var(--border);flex-shrink:0}.chart-metric{display:flex;flex-direction:column;gap:1px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 8px;min-width:64px}.chart-metric.warn{border-color:#f9731659;background:#f973160f}.chart-metric.alert{border-color:#e8604c59;background:#e8604c0f}.cm-label{font-size:8px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted)}.cm-value{font-size:13px;font-weight:600;color:var(--accent-amber);font-variant-numeric:tabular-nums}.cm-value.warn{color:var(--accent-orange)}.cm-value.alert{color:var(--accent-red)}.cm-trend{font-size:14px}.temperature-chart{width:100%;position:relative}.chart-empty{text-align:center;padding:48px;color:var(--text-muted)}.chart-empty-hint{font-size:14px;margin-top:6px}.data-section{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:14px;overflow:hidden}.data-table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:9px 10px;text-align:left;border-bottom:1px solid var(--border)}.data-table th{background:var(--bg-elevated);font-weight:600;font-size:14px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.data-table td{font-size:13px}.time-cell{font-variant-numeric:tabular-nums;color:var(--text-secondary)}.value-cell{font-weight:500;color:var(--text-primary)}.note-cell{color:var(--text-muted);font-size:14px}.data-table-empty{text-align:center;padding:24px;color:var(--text-muted)}.event-badge{display:inline-block;padding:2px 7px;border-radius:var(--radius-sm);font-size:14px;color:#fff;background:var(--accent-amber)}.data-badge{display:inline-block;padding:2px 7px;border-radius:var(--radius-sm);font-size:14px;color:#fff;background:var(--accent-blue)}.delete-btn{padding:3px 7px;background:var(--accent-red);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:14px}.delete-btn:hover{filter:brightness(1.1)}.save-section{display:flex;justify-content:center}.save-btn{padding:11px 40px;font-size:14px;font-weight:600;font-family:inherit;background:var(--accent-amber);color:var(--bg-base);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .18s}.save-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.curve-editor{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:20px}.curve-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.curve-editor-header h3{color:var(--accent-amber);font-size:14px}.curve-actions{display:flex;gap:6px}.curve-btn{padding:6px 14px;font-family:inherit;background:var(--accent-amber);color:var(--bg-base);border:none;border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:600;transition:all .15s}.curve-btn.export{background:var(--accent-blue);color:#fff}.curve-btn.delete{background:var(--accent-red);color:#fff}.curve-btn:hover{filter:brightness(1.1)}.curve-form{background:var(--bg-elevated);padding:14px;border-radius:var(--radius-md);margin-bottom:14px;border:1px solid var(--border)}.form-group{margin-bottom:10px}.form-group label{display:block;margin-bottom:3px;font-size:14px;font-weight:500;color:var(--text-secondary)}.form-group input,.form-group textarea{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:15px;font-family:inherit;background:var(--bg-surface);color:var(--text-primary)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-amber)}.file-import-label{display:inline-block;padding:6px 14px;background:var(--accent-blue);color:#fff;border-radius:var(--radius-md);cursor:pointer;margin-bottom:10px;font-size:14px}.file-import-label:hover{filter:brightness(1.1)}.curve-list{margin-bottom:20px}.curve-list h4{margin:12px 0 6px;color:var(--text-secondary);font-size:14px;text-transform:uppercase;letter-spacing:.5px}.curve-items{display:flex;flex-direction:column;gap:6px}.curve-item{display:flex;flex-direction:column;padding:10px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .15s}.curve-item:hover{border-color:var(--accent-amber)}.curve-item.selected{border-color:var(--accent-amber);background:#c8a96e0f}.curve-name{font-weight:600;color:var(--text-primary);font-size:14px}.curve-desc{font-size:14px;color:var(--text-muted);margin-top:2px}.curve-preview{border-top:1px solid var(--border);padding-top:14px}.curve-preview h4{margin-bottom:12px;color:var(--accent-amber);font-size:14px}.history-container{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:20px}.history-container h3{color:var(--accent-amber);margin-bottom:14px;font-size:14px}.history-empty{text-align:center;padding:40px;color:var(--text-muted)}.history-list{display:flex;flex-direction:column;gap:8px}.history-item{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);transition:all .15s}.history-item:hover{border-color:var(--accent-amber)}.history-info{cursor:pointer;flex:1}.history-info h4{color:var(--accent-amber);margin-bottom:3px;font-size:13px}.history-meta{display:flex;gap:12px;font-size:14px;color:var(--text-muted)}.history-actions{display:flex;gap:6px}.history-btn{padding:6px 12px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-family:inherit;transition:all .15s}.history-btn.view{background:var(--accent-green);color:var(--bg-base)}.history-btn.info{background:var(--accent-amber);color:#000}.history-btn.export{background:var(--accent-blue);color:#fff}.history-btn.delete{background:var(--accent-red);color:#fff}.history-btn:hover{filter:brightness(1.1)}.green-bean-library{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:20px}.green-bean-library h3{color:var(--accent-amber);margin-bottom:14px;font-size:14px}.gb-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.gb-actions{display:flex;gap:10px;align-items:center}.gb-search{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-primary);font-size:14px;width:180px}.gb-search:focus{outline:none;border-color:var(--accent-amber)}.gb-btn{padding:8px 14px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-family:inherit;transition:all .15s;background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.gb-btn.primary{background:var(--accent-green);color:var(--bg-base);border-color:var(--accent-green)}.gb-btn.danger{background:var(--accent-red);color:#fff;border-color:var(--accent-red)}.gb-btn.small{padding:4px 10px;font-size:12px}.gb-btn:hover{filter:brightness(1.1)}.gb-form{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;margin-bottom:16px}.gb-form-title{font-size:14px;font-weight:600;color:var(--accent-amber);margin-bottom:12px}.gb-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.gb-form-row{display:flex;flex-direction:column;gap:4px}.gb-form-row label{font-size:12px;color:var(--text-muted)}.gb-form-row input{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-base);color:var(--text-primary);font-size:13px}.gb-form-row input:focus{outline:none;border-color:var(--accent-amber)}.gb-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.gb-empty{text-align:center;padding:40px;color:var(--text-muted)}.gb-list{display:flex;flex-direction:column;gap:10px}.gb-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;transition:all .15s}.gb-card:hover{border-color:var(--accent-amber)}.gb-card.selectable{cursor:pointer}.gb-card.selectable:hover{background:var(--bg-surface)}.gb-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.gb-card-name{font-size:15px;font-weight:600;color:var(--accent-amber)}.gb-card-roast{font-size:12px;padding:2px 8px;background:var(--accent-amber);color:#000;border-radius:var(--radius-sm)}.gb-card-info{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.gb-tag{font-size:12px;padding:2px 8px;background:var(--bg-base);color:var(--text-muted);border-radius:var(--radius-sm);border:1px solid var(--border)}.gb-card-flavor{font-size:13px;color:var(--text-primary);margin-bottom:6px}.gb-flavor-label{color:var(--text-muted)}.gb-card-extra{display:flex;gap:16px;font-size:12px;color:var(--text-muted);margin-bottom:10px}.gb-card-actions{display:flex;gap:8px;justify-content:flex-end}.roast-summary{display:flex;flex-wrap:wrap;gap:14px;padding:12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:12px}.roast-summary-section{flex:1;min-width:240px}.roast-summary-title{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:8px;padding-bottom:5px;border-bottom:1px solid var(--border)}.roast-summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:6px 12px}.roast-summary-item{display:flex;flex-direction:column;gap:1px}.rs-label{font-size:13px;color:var(--text-muted)}.rs-value{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:var(--bg-surface);padding:20px;border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:380px;box-shadow:var(--shadow-md)}.modal h3{color:var(--accent-amber);margin-bottom:14px;font-size:14px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.modal-btn{padding:8px 18px;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-family:inherit;font-weight:500;transition:all .15s}.modal-btn.cancel{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border)}.modal-btn.confirm{background:var(--accent-amber);color:var(--bg-base)}.modal-btn:hover{filter:brightness(1.1)}.modal-large{max-width:760px;max-height:90vh;overflow-y:auto}.coffee-info-container{max-height:60vh;overflow-y:auto}.coffee-info-section{margin-bottom:20px;padding:14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md)}.coffee-info-section h4{color:var(--accent-amber);margin-bottom:12px;padding-bottom:7px;border-bottom:1px solid var(--border);font-size:14px}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.coffee-info-section textarea{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;font-family:inherit;resize:vertical;background:var(--bg-surface);color:var(--text-primary)}.coffee-info-section textarea:focus{outline:none;border-color:var(--accent-amber)}.retro-modal{max-width:340px}.retro-event-list{display:flex;flex-direction:column;gap:6px;margin-bottom:4px}.retro-event-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md)}.retro-event-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.retro-event-name{flex:1;font-size:14px;color:var(--text-primary)}.retro-time-input{width:56px;padding:3px 6px;font-size:14px;font-family:inherit;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--accent-amber);text-align:center;font-variant-numeric:tabular-nums}.retro-time-input:focus{outline:none;border-color:var(--accent-amber)}.retro-skip-btn{font-size:14px;color:var(--text-muted);background:none;border:none;cursor:pointer;font-family:inherit;padding:2px 4px;border-radius:var(--radius-sm);transition:color .15s}.retro-skip-btn:hover{color:var(--text-secondary)}.retro-confirm-btn{font-size:14px;background:var(--accent-amber);color:var(--bg-base);border:none;border-radius:var(--radius-sm);padding:3px 8px;cursor:pointer;font-family:inherit}.retro-error{font-size:13px;color:var(--accent-red);margin-top:1px}.sensor-web-notice{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:6px;background:var(--bg-tertiary);color:var(--text-secondary);font-size:13px;line-height:1.4}.sensor-web-notice-icon{font-size:16px;flex-shrink:0}.sensor-web-hint{font-size:12px;color:var(--text-tertiary);padding:2px 0 4px}.profile-panel-wrapper{width:240px}.profile-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:0 4px 20px #0000004d}.profile-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:8px}.profile-divider{height:1px;background:var(--border-color)}.profile-loading{font-size:13px;color:var(--text-secondary);text-align:center;padding:8px 0}.profile-email{font-size:13px;color:var(--text-primary);margin-bottom:8px;word-break:break-all}.profile-logout-btn{width:100%;padding:6px 0;background:transparent;border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);font-size:13px;cursor:pointer}.profile-logout-btn:hover{border-color:var(--accent-color);color:var(--accent-color)}.profile-form{display:flex;flex-direction:column;gap:8px}.profile-input{width:100%;padding:7px 10px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:13px;box-sizing:border-box}.profile-input:focus{outline:none;border-color:var(--accent-color)}.profile-error{font-size:12px;color:#e05c5c;padding:2px 0}.profile-submit-btn{width:100%;padding:7px 0;background:var(--accent-color);border:none;border-radius:4px;color:#fff;font-size:13px;cursor:pointer;font-weight:500}.profile-submit-btn:disabled{opacity:.5;cursor:not-allowed}.profile-toggle-btn{background:none;border:none;color:var(--text-tertiary);font-size:12px;cursor:pointer;padding:0;text-align:left}.profile-toggle-btn:hover{color:var(--accent-color)}.sidebar-tab-dot{width:6px;height:6px;border-radius:50%;margin-left:2px;display:inline-block}.sidebar-tab-dot.synced{background:#4caf50}.green-bean-guest-gate{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;gap:12px;color:var(--text-secondary)}.guest-gate-icon{font-size:40px}.guest-gate-title{font-size:16px;font-weight:600;color:var(--text-primary)}.guest-gate-desc{font-size:13px;text-align:center;max-width:240px;line-height:1.6}.sync-badge{font-size:11px;margin-left:4px;opacity:.7}.sync-badge.synced{color:#4caf50}.sync-badge.failed{color:#e05c5c}.sync-badge.local{color:var(--text-tertiary)}.guest-banner{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);font-size:13px;color:var(--text-secondary);gap:12px}.guest-banner-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:0 4px;font-size:14px;flex-shrink:0}.guest-banner-close:hover{color:var(--text-primary)}
