html,body,#root{background-color:var(--bg-base)}button:focus-visible{outline:2px solid var(--accent-amber);outline-offset:2px}.app{display:flex;flex-direction:row;height:100%;overflow:hidden;background:var(--bg-base)}.app-sidebar{width:56px;background:var(--bg-base);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;transition:width .2s ease;z-index:var(--z-sticky);position:sticky;top:0;height:100vh;overflow:hidden}.sidebar-expanded .app-sidebar{width:200px}.sidebar-logo{display:flex;align-items:center;justify-content:center;padding:10px 8px;border-bottom:1px solid var(--border);overflow:hidden;flex-shrink:0}.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:var(--text-md);font-family:inherit;transition:all .15s;width:100%;gap:var(--space-1);white-space:nowrap;overflow:hidden}.sidebar-expanded .sidebar-tab{flex-direction:row;justify-content:flex-start;padding:10px 16px;gap:var(--space-3)}.sidebar-tab:hover:not(.active){background:var(--bg-surface);color:var(--text-secondary)}.sidebar-tab.active{background:var(--bg-surface);color:var(--accent-amber);font-weight:var(--font-semibold);box-shadow:inset 3px 0 0 var(--accent-amber)}.sidebar-tab-icon{font-size:var(--text-xl);line-height:1}.sidebar-tab-label{display:none;font-size:var(--text-md);line-height:1.2}.sidebar-expanded .sidebar-tab-label{display:inline}.sidebar-bottom{padding:8px 6px 12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-settings-btn{width:100%;padding:7px 4px;font-size:var(--text-lg);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:var(--text-base);font-weight:var(--font-semibold);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:var(--text-base);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);margin-bottom:var(--space-3)}.theme-options{display:flex;flex-direction:column;gap:var(--space-2)}.theme-option{display:flex;align-items:center;gap:var(--space-3);padding:10px 12px;border-radius:var(--radius-md);border:1px solid var(--border);cursor:pointer;background:transparent;font-family:inherit;font-size:var(--text-md);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:var(--text-md);font-weight:var(--font-semibold);cursor:pointer;transition:opacity .15s}.topbar-new-btn:hover{opacity:.85}.timer-strip{height:64px;background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 18px;gap:var(--space-4);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)}.status-text{font-size:var(--text-base);font-weight:var(--font-bold);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:var(--space-3)}.timer-strip .timer-display{font-size:36px;gap:1px}.timer-strip .timer-controls{margin-top:0;gap:var(--space-2)}.timer-strip .timer-btn{padding:6px 18px;font-size:var(--text-base)}.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:var(--text-base);color:var(--text-secondary)}.timer-strip .development-time-display{flex-direction:row;align-items:center;border-top:none;background:transparent;gap:var(--space-4)}.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:var(--text-base)}.timer-strip .dev-time-value{font-size:var(--text-base);font-weight:var(--font-semibold)}.ts-right{margin-left:auto;display:flex;align-items:center;gap:var(--space-3)}.ts-roast-name{font-size:var(--text-md);color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.ts-action-btn{padding:3px 10px;font-size:var(--text-md);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:var(--space-3);padding:0 18px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.rib-name{font-size:var(--text-md);font-weight:var(--font-medium);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:var(--text-md);font-weight:var(--font-medium);color:var(--text-primary);background:var(--bg-elevated);border:1px solid var(--accent-amber);border-radius:var(--radius-sm);padding:2px 6px;min-width:120px;max-width:220px}.rib-viewing-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.rib-new-btn{margin-left:auto}.rib-coffee-btn{margin-left:auto;font-size:var(--text-md);font-weight:var(--font-medium);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:var(--space-3);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:var(--text-base);font-weight:var(--font-semibold);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:var(--text-base);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:var(--space-4)}.empty-state-icon{font-size:64px;line-height:1;opacity:.7}.start-roast-btn{padding:12px 28px;font-size:var(--text-md);font-weight:var(--font-semibold);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:var(--text-base);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);text-align:center;margin-bottom:var(--space-3)}.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:var(--text-md);font-weight:var(--font-medium);color:var(--text-primary)}.recent-roast-date{font-size:var(--text-md);color:var(--text-muted)}.timer-view{display:flex;flex-direction:column;gap:var(--space-4)}.roast-layout{display:flex;gap:var(--space-3);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-left-collapsed{width:32px;min-width:32px}.roast-left-collapsed-toggle{display:flex;align-items:center;justify-content:center;height:100%;padding:12px 0}.roast-left-expand-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:var(--text-sm);padding:6px 4px;border-radius:var(--radius-sm);writing-mode:vertical-rl;transition:color .15s}.roast-left-expand-btn:hover{color:var(--text-primary)}.dev-manual-temp-row{display:flex;gap:var(--space-2);padding:6px 10px 8px;border-top:1px solid var(--border)}.dev-manual-temp-row .manual-temp-input{flex:1}.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;animation:fadeSlideIn .2s ease-out}.events-panel-title{font-size:var(--text-md);font-weight:var(--font-bold);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:var(--space-2);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,var(--accent-amber-lighter),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:var(--text-md);color:var(--text-primary)}.event-tl-btn.done .etb-label{color:var(--text-muted)}.event-tl-btn.next .etb-label{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--accent-amber)}.etb-time{font-size:var(--text-md);color:var(--text-muted);font-variant-numeric:tabular-nums}.etb-next-badge{font-size:var(--text-md);font-weight:var(--font-semibold);background:var(--accent-amber);color:var(--bg-base);padding:2px 6px;border-radius:999px;flex-shrink:0}.sensor-panel{background:var(--instrument-bg);border-top:1px solid var(--instrument-border);padding:var(--space-2) var(--space-3);display:flex;flex-direction:column;gap:var(--space-1);flex-shrink:0}.sensor-row{display:flex;align-items:center;justify-content:space-between}.sensor-indicator{display:flex;align-items:center;gap:var(--space-2)}.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:var(--text-xs);color:var(--text-secondary)}.sensor-indicator.connected .sensor-label{color:var(--text-primary);font-weight:var(--font-medium)}.sensor-btn{padding:3px var(--space-3);font-size:var(--text-xs);border-radius:999px;border:1px solid;background:transparent;cursor:pointer;transition:all .15s;font-weight:var(--font-medium);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:var(--space-2)}.autorecord-label{font-size:var(--text-base);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:var(--text-base);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:var(--text-base);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:var(--text-sm);background:var(--bg-base);color:var(--text-primary);font-family:var(--font-mono)}.manual-temp-input:focus{border-color:var(--accent-amber)}.manual-temp-btn{padding:4px var(--space-3);font-size:var(--text-xs);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(--instrument-border);padding:var(--space-2);display:flex;flex-direction:column;gap:5px;flex-shrink:0}.save-btn-main{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-weight:var(--font-semibold);font-family:inherit;background:var(--accent-amber);color:var(--bg-base);border:none;border-radius:var(--radius-md);cursor:pointer;transition:filter var(--transition-base);letter-spacing:.02em}.save-btn-main:hover{filter:brightness(1.1)}.import-csv-btn{display:block;text-align:center;padding:5px;font-size:var(--text-md);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;animation:fadeSlideIn .2s ease-out}.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:var(--text-display);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:var(--text-base);color:var(--text-muted);margin-top:2px}.dev-time-dtr span{color:var(--accent-green)}.dev-time-warning-text{font-size:var(--text-base);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:var(--text-md);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:var(--accent-red-light);background:#e8604c0f}.dev-log-row{display:flex;justify-content:space-between;align-items:center;font-size:var(--text-md);color:var(--text-muted);padding:2px 0}.dev-log-row.crack{color:var(--accent-amber);opacity:.8}.history-event-row{gap:var(--space-1);flex-wrap:nowrap}.history-event-name{font-size:var(--text-base);color:var(--text-secondary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-event-time{font-size:var(--text-base);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:var(--text-sm);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:var(--text-md);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:var(--text-md);font-weight:var(--font-bold);letter-spacing:.5px;border-color:var(--accent-red-light)}.dev-action-btn.primary:hover{filter:brightness(1.15)}.dev-action-btn.secondary{background:var(--bg-elevated);color:var(--accent-amber);font-size:var(--text-base);border-color:#c8a96e33}.dev-action-btn.secondary:hover{border-color:var(--accent-amber);background:var(--accent-amber-lighter)}.dev-action-btn-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.dev-action-hint{font-size:var(--text-md);opacity:.6;margin-left:auto}.dev-sensor-row{display:flex;align-items:center;gap:var(--space-2);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:var(--text-base);color:var(--text-muted)}.dev-sensor-label.connected{color:var(--text-secondary)}.dev-autorecord-text{font-size:var(--text-base);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 2s ease-in-out infinite;line-height:1;margin-bottom:4px}.timer-controls{display:flex;gap:var(--space-2);justify-content:center;margin-top:14px}.timer-btn{padding:8px 28px;font-size:var(--text-base);font-weight:var(--font-semibold);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:var(--text-md);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.dev-time-value{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--text-primary);font-variant-numeric:tabular-nums}.dev-time-ratio{font-size:var(--text-base);color:var(--text-muted)}.chart-metrics-row{display:flex;gap:var(--space-2);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:var(--text-base);font-weight:var(--font-semibold);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:var(--text-md)}.temperature-chart{width:100%;position:relative}.chart-empty{text-align:center;padding:48px;color:var(--text-muted)}.chart-empty-hint{font-size:var(--text-md);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:var(--font-semibold);font-size:var(--text-md);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.data-table td{font-size:var(--text-base)}.time-cell{font-variant-numeric:tabular-nums;color:var(--text-secondary)}.value-cell{font-weight:var(--font-medium);color:var(--text-primary)}.note-cell{color:var(--text-muted);font-size:var(--text-md)}.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:var(--text-md);color:#fff;background:var(--accent-amber)}.data-badge{display:inline-block;padding:2px 7px;border-radius:var(--radius-sm);font-size:var(--text-md);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:var(--text-md)}.delete-btn:hover{filter:brightness(1.1)}.save-section{display:flex;justify-content:center}.save-btn{padding:11px 40px;font-size:var(--text-md);font-weight:var(--font-semibold);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:var(--space-3)}.curve-editor-header h3{color:var(--accent-amber);font-size:var(--text-md)}.curve-actions{display:flex;gap:var(--space-2)}.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:var(--text-md);font-weight:var(--font-semibold);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:var(--space-3);border:1px solid var(--border)}.form-group{margin-bottom:var(--space-3)}.form-group label{display:block;margin-bottom:3px;font-size:var(--text-md);font-weight:var(--font-medium);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:var(--text-md);font-family:inherit;background:var(--bg-surface);color:var(--text-primary)}.form-group input:focus,.form-group textarea:focus{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:var(--space-3);font-size:var(--text-md)}.file-import-label:hover{filter:brightness(1.1)}.curve-list{display:flex;flex-direction:column;gap:var(--space-2)}.curve-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition-base)}.curve-card:hover{border-color:var(--accent-amber-light)}.curve-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);cursor:pointer;gap:var(--space-3)}.curve-card-info{display:flex;flex-direction:column;gap:2px;min-width:0}.curve-card-name{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--text-primary)}.curve-card-desc{font-size:var(--text-sm);color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.curve-card-actions{display:flex;align-items:center;gap:var(--space-1);flex-shrink:0}.curve-card-toggle{font-size:var(--text-sm);color:var(--text-muted);width:20px;text-align:center}.curve-card-preview{border-top:1px solid var(--border);padding:var(--space-2) var(--space-3)}.history-container{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:20px}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.history-header h3{color:var(--accent-amber);font-size:var(--text-md);margin:0}.history-refresh-btn{padding:6px 12px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-md);background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);transition:all .15s}.history-refresh-btn:hover{border-color:var(--accent-amber);color:var(--accent-amber)}.history-empty{text-align:center;padding:40px;color:var(--text-muted)}.history-list{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4)}.history-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition-base);cursor:pointer}.history-item:hover{border-color:var(--accent-amber-light);box-shadow:var(--shadow-sm)}.history-info{flex:1;min-width:0}.history-info h4{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-1);display:flex;align-items:center;gap:var(--space-2)}.history-meta{display:flex;flex-wrap:wrap;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted)}.history-actions{display:flex;gap:var(--space-1);flex-shrink:0}.history-btn{padding:var(--space-1) var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-md);border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);font-family:inherit}.history-btn:hover{border-color:var(--accent-amber);color:var(--accent-amber)}.history-btn.delete:hover{border-color:var(--accent-red);color:var(--accent-red)}.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:var(--space-3);font-size:var(--text-md)}.gb-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);flex-wrap:wrap;gap:var(--space-3)}.gb-actions{display:flex;gap:var(--space-3);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:var(--text-md);width:180px}.gb-search:focus{border-color:var(--accent-amber)}.gb-btn{padding:8px 14px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-base);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:var(--text-sm)}.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:var(--space-4)}.gb-form-title{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--accent-amber);margin-bottom:var(--space-3)}.gb-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-3)}.gb-form-row{display:flex;flex-direction:column;gap:var(--space-1)}.gb-form-row label{font-size:var(--text-sm);color:var(--text-muted)}.gb-form-row input,.gb-form-row textarea,.gb-form-row select{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-base);color:var(--text-primary);font-size:var(--text-base);font-family:inherit;width:100%}.gb-form-row input:focus,.gb-form-row textarea:focus{border-color:var(--accent-amber)}.gb-form-row textarea{resize:vertical}.gb-form-actions{display:flex;justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-4)}.gb-empty{text-align:center;padding:40px;color:var(--text-muted)}.gb-list{display:flex;flex-direction:column;gap:var(--space-3)}.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:var(--space-2)}.gb-card-name{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--accent-amber)}.gb-card-roast{font-size:var(--text-sm);padding:2px 8px;background:var(--accent-amber);color:#000;border-radius:var(--radius-sm)}.gb-card-info{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}.gb-tag{font-size:var(--text-sm);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:var(--text-base);color:var(--text-primary);margin-bottom:6px}.gb-flavor-label{color:var(--text-muted)}.gb-card-extra{display:flex;gap:var(--space-4);font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-3)}.gb-card-actions{display:flex;gap:var(--space-2);justify-content:flex-end}.gb-card-main{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.gb-card-sub{font-size:var(--text-base);color:var(--text-secondary)}.gb-card-meta{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-1)}.gb-card-note{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.gb-meta-chip{font-size:var(--text-xs);padding:2px 8px;border-radius:var(--radius-full);background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary)}.gb-error{padding:var(--space-3);background:var(--accent-red-lighter);border:1px solid var(--accent-red-light);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--accent-red);margin-bottom:var(--space-4)}.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:var(--space-3)}.roast-summary-section{flex:1;min-width:240px}.roast-summary-title{font-size:var(--text-sm);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-3)}.rdv-params-card .roast-summary{padding:0;background:none;border:none;border-radius:0;margin-bottom:0}.rdv-params-card .roast-summary-title{padding-bottom:0;border-bottom:none}.roast-summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:var(--space-2) 12px}.roast-summary-item{display:flex;flex-direction:column;gap:1px}.rs-label{font-size:var(--text-base);color:var(--text-muted)}.rs-value{font-size:var(--text-md);font-weight:var(--font-medium);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal h3{color:var(--accent-amber);margin-bottom:var(--space-3);font-size:var(--text-md)}.modal-btn{padding:8px 18px;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-base);font-family:inherit;font-weight:var(--font-medium);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:var(--space-5);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:var(--space-3);padding-bottom:7px;border-bottom:1px solid var(--border);font-size:var(--text-md)}.form-row{display:flex;gap:var(--space-3)}.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:var(--text-base);font-family:inherit;resize:vertical;background:var(--bg-surface);color:var(--text-primary)}.coffee-info-section textarea:focus{border-color:var(--accent-amber)}.retro-modal{max-width:340px}.retro-event-list{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:4px}.retro-event-row{display:flex;align-items:center;gap:var(--space-2);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:var(--text-md);color:var(--text-primary)}.retro-time-input{width:56px;padding:3px 6px;font-size:var(--text-md);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{border-color:var(--accent-amber)}.retro-skip-btn{font-size:var(--text-md);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:var(--text-md);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:var(--text-base);color:var(--accent-red);margin-top:1px}.sensor-web-notice{display:flex;align-items:center;gap:var(--space-2);padding:10px 12px;border-radius:6px;background:var(--bg-tertiary);color:var(--text-secondary);font-size:var(--text-base);line-height:1.4}.sensor-web-notice-icon{font-size:var(--text-lg);flex-shrink:0}.sensor-web-hint{font-size:var(--text-sm);color:var(--text-tertiary);padding:2px 0 4px}.profile-panel-wrapper{position:fixed;bottom:60px;z-index:450;width:260px;max-height:calc(100vh - 80px);overflow-y:auto}.profile-panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:var(--space-3);box-shadow:0 4px 20px #0000004d}.profile-section-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:var(--space-2)}.profile-divider{height:1px;background:var(--border)}.profile-loading{font-size:var(--text-base);color:var(--text-secondary);text-align:center;padding:8px 0}.profile-email{font-size:var(--text-base);color:var(--text-primary);margin-bottom:var(--space-2);word-break:break-all}.profile-theme-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:transparent;border:none;cursor:pointer;padding:0;font-family:inherit;color:var(--text-primary)}.profile-theme-current{font-size:var(--text-sm);color:var(--text-secondary)}.profile-logout-btn{width:100%;padding:6px 0;background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);font-size:var(--text-base);cursor:pointer}.profile-logout-btn:hover{border-color:var(--accent-amber);color:var(--accent-amber)}.profile-form{display:flex;flex-direction:column;gap:var(--space-2)}.profile-input{width:100%;padding:7px 10px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);font-size:var(--text-base);box-sizing:border-box}.profile-input:focus{border-color:var(--accent-amber)}.profile-error{font-size:var(--text-sm);color:#e05c5c;padding:2px 0}.profile-submit-btn{width:100%;padding:7px 0;background:var(--accent-amber);border:none;border-radius:4px;color:#fff;font-size:var(--text-base);cursor:pointer;font-weight:var(--font-medium)}.profile-submit-btn:disabled{opacity:.5;cursor:not-allowed}.profile-toggle-btn{background:none;border:none;color:var(--text-tertiary);font-size:var(--text-sm);cursor:pointer;padding:0;text-align:left}.profile-toggle-btn:hover{color:var(--accent-amber)}.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:var(--space-3);color:var(--text-secondary)}.guest-gate-btn{margin-top:4px;padding:8px 24px;border-radius:6px;border:none;background:var(--accent-orange);color:#fff;font-size:var(--text-base);font-weight:var(--font-semibold);cursor:pointer;transition:opacity .15s}.guest-gate-btn:hover{opacity:.85}.save-btn-main.save-btn-guest{background:var(--bg-elevated);color:var(--accent-orange);border:1px solid var(--accent-orange);opacity:.9}.sync-badge{font-size:var(--text-xs);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-elevated);border-bottom:1px solid var(--border);font-size:var(--text-base);color:var(--text-secondary);gap:var(--space-3)}.guest-banner-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:0 4px;font-size:var(--text-md);flex-shrink:0}.guest-banner-close:hover{color:var(--text-primary)}.sidebar-logo-img{width:40px;height:40px;object-fit:cover;object-position:center center;border-radius:6px;transition:all .2s ease;flex-shrink:0}.sidebar-expanded .sidebar-logo-img{width:176px;height:64px;border-radius:8px;object-position:center 30%}.auth-modal-overlay{position:fixed;inset:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:400}.auth-modal{position:relative;width:400px;max-width:calc(100vw - 32px);background:var(--bg-elevated);border-radius:16px;overflow:hidden;box-shadow:0 24px 60px #00000080;border:1px solid var(--border)}.auth-modal-banner{width:100%;height:160px;overflow:hidden}.auth-modal-banner-img{width:100%;height:100%;object-fit:cover;object-position:center 30%;display:block}.auth-modal-body{padding:24px 28px 28px}.auth-modal-title{font-size:20px;font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:6px}.auth-modal-subtitle{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--space-5);line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:var(--space-3)}.auth-form-group{display:flex;flex-direction:column;gap:5px}.auth-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.auth-input{width:100%;padding:10px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:var(--text-md);box-sizing:border-box;transition:border-color .15s}.auth-input:focus{border-color:var(--accent-amber)}.auth-error{font-size:var(--text-sm);color:#e05c5c;padding:4px 0}.auth-submit-btn{width:100%;padding:11px 0;background:var(--accent-amber);border:none;border-radius:8px;color:#fff;font-size:var(--text-md);font-weight:var(--font-semibold);cursor:pointer;margin-top:4px;transition:opacity .15s}.auth-submit-btn:hover:not(:disabled){opacity:.88}.auth-submit-btn:disabled{opacity:.45;cursor:not-allowed}.auth-toggle-btn{display:block;margin-top:14px;background:none;border:none;color:var(--accent-amber);font-size:var(--text-base);cursor:pointer;padding:0;text-align:center;width:100%}.auth-toggle-btn:hover{opacity:.75}.auth-modal-close{position:absolute;top:10px;right:12px;background:#0006;border:none;color:#fff;font-size:var(--text-md);width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.auth-modal-close:hover{background:#000000a6}.profile-user-section{display:flex;align-items:center;gap:var(--space-3);padding:4px 0}.profile-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-amber);color:#fff;font-size:var(--text-xl);font-weight:var(--font-bold);display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-user-info{display:flex;flex-direction:column;gap:3px;min-width:0}.profile-user-email{font-size:var(--text-base);color:var(--text-primary);font-weight:var(--font-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-user-badge{font-size:var(--text-xs);color:var(--accent-green, #2ecc71)}.profile-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);margin-bottom:var(--space-2)}.profile-stat-item{display:flex;flex-direction:column;align-items:center;padding:10px 8px;background:var(--bg-elevated);border-radius:8px;gap:3px}.profile-stat-value{font-size:22px;font-weight:var(--font-bold);color:var(--accent-amber);line-height:1}.profile-stat-label{font-size:var(--text-xs);color:var(--text-secondary)}.profile-last-roast{display:flex;justify-content:space-between;align-items:center;font-size:var(--text-sm);padding:2px 0}.profile-last-label{color:var(--text-secondary)}.profile-last-value{color:var(--text-primary)}.profile-panel-backdrop{position:fixed;inset:0;z-index:400}.profile-avatar-circle{width:40px;height:40px;border-radius:50%;color:#fff;font-size:17px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:-.5px;-webkit-user-select:none;user-select:none;transition:filter .15s}.profile-avatar-circle:hover{filter:brightness(1.12)}.profile-display-name{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:420px;max-width:calc(100vw - 32px);max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border);font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:var(--text-xl);cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);line-height:1;transition:color .15s}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:16px 20px 20px;display:flex;flex-direction:column;gap:var(--space-3)}.profile-edit-avatar-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:4px 0 8px}.avatar-preview{width:72px;height:72px;border-radius:50%;color:#fff;font-size:28px;font-weight:800;display:flex;align-items:center;justify-content:center;letter-spacing:-1px;-webkit-user-select:none;user-select:none;transition:background .2s}.color-swatches{display:flex;gap:7px;flex-wrap:wrap;justify-content:center}.color-swatch{width:26px;height:26px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s,box-shadow .1s;flex-shrink:0;padding:0}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{box-shadow:0 0 0 2px var(--bg-elevated),0 0 0 4px var(--text-primary)}.color-swatch-custom{background:conic-gradient(red,#ff0,#0f0,#0ff,#00f,#f0f,red);display:flex;align-items:center;justify-content:center;position:relative;border-color:#fff3}.profile-edit-char-row{display:flex;align-items:center;gap:var(--space-2)}.profile-edit-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium);display:block;margin-bottom:4px}.profile-edit-hint{font-size:var(--text-xs);color:var(--text-muted)}.profile-edit-input{width:100%;padding:8px 10px;background:var(--bg-surface, var(--bg-base));border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-base);font-family:inherit;box-sizing:border-box;transition:border-color .15s}.profile-edit-input:focus{border-color:var(--accent-amber)}textarea.profile-edit-input{resize:none}.profile-edit-divider{border:none;border-top:1px solid var(--border);margin:2px 0}.profile-edit-fields{display:flex;flex-direction:column;gap:var(--space-3)}.profile-edit-field{display:flex;flex-direction:column}.machine-list{display:flex;flex-direction:column;gap:var(--space-2)}.machine-row{display:flex;gap:var(--space-2);align-items:center}.machine-row .profile-edit-input{flex:1}.machine-remove{background:#e8604c1f;border:1px solid rgba(232,96,76,.3);color:var(--accent-red);border-radius:var(--radius-sm);padding:5px 9px;cursor:pointer;font-size:var(--text-md);line-height:1;flex-shrink:0;transition:background .15s}.machine-remove:hover{background:#e8604c38}.machine-add{background:#c8a96e1a;border:1px solid rgba(200,169,110,.25);color:var(--accent-amber);border-radius:var(--radius-sm);padding:5px 12px;cursor:pointer;font-size:var(--text-sm);font-family:inherit;align-self:flex-start;margin-top:2px;transition:background .15s}.machine-add:hover{background:#c8a96e2e}.profile-edit-error{font-size:var(--text-sm);color:var(--accent-red);background:#e8604c14;border:1px solid rgba(232,96,76,.2);border-radius:var(--radius-sm);padding:6px 10px}.profile-edit-actions{display:flex;gap:var(--space-2);margin-top:4px}.event-sequence{display:flex;flex-direction:column;gap:3px;padding:6px 0;flex:1;overflow-y:auto}.es-row{display:flex;align-items:center;gap:5px;padding:0 8px;min-height:34px;border-radius:6px}.es-row--recorded{opacity:1}.es-row--skipped{opacity:.55}.es-row--history-pending{opacity:.35}.es-indicator{font-size:var(--text-xs);width:14px;flex-shrink:0;color:var(--text-muted)}.es-row--recorded .es-indicator{color:var(--accent-green)}.es-row--skipped .es-indicator{color:var(--text-muted)}.es-row--next .es-indicator{color:var(--accent-amber)}.es-label{flex:1;font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap}.es-time{font-family:var(--font-mono);font-size:var(--text-xs);font-variant-numeric:tabular-nums;color:var(--text-secondary);cursor:pointer;padding:2px 4px;border-radius:3px;transition:background .15s;min-width:38px;text-align:right}.es-time:hover{background:var(--bg-hover)}.es-time--empty{color:var(--text-muted);cursor:default}.es-time-input{width:54px;font-size:var(--text-sm);padding:3px 5px;background:var(--input-bg, var(--bg-surface));border:1px solid var(--accent-amber);border-radius:3px;color:var(--text-primary);font-variant-numeric:tabular-nums}.es-edit-btn,.es-delete-btn{font-size:var(--text-sm);padding:2px 5px;background:none;border:none;cursor:pointer;opacity:0;transition:opacity .15s;border-radius:3px;flex-shrink:0}.es-row:hover .es-edit-btn,.es-row:hover .es-delete-btn{opacity:1}.es-edit-btn{color:var(--text-muted)}.es-edit-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.es-delete-btn{color:var(--text-muted)}.es-delete-btn:hover{background:#e74c3c26;color:var(--accent-red)}.es-record-btn{flex:1;padding:8px 10px;border:none;border-radius:6px;font-size:var(--text-sm);font-family:inherit;cursor:pointer;text-align:left;transition:opacity .15s,transform .1s}.es-record-btn:active{transform:scale(.97)}.es-record-btn--primary{padding:10px 16px;font-size:var(--text-md);font-weight:var(--font-semibold);background:var(--accent-amber);color:#fff;border:2px solid var(--accent-amber);border-radius:var(--radius-md);min-height:44px;flex:1;box-shadow:0 1px 4px #0000002e;text-transform:uppercase;letter-spacing:.06em}.es-record-btn--primary:hover{opacity:.9}.es-row--next{padding:6px 0}.es-record-btn--secondary{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border)}.es-record-btn--secondary:hover{background:var(--bg-hover)}.km-block{padding:12px 12px 8px;border-bottom:1px solid var(--border);margin-bottom:2px;flex-shrink:0}.km-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.km-value{font-size:30px;font-weight:var(--font-bold);font-variant-numeric:tabular-nums;color:var(--text-primary);line-height:1}.km-block--live .km-value{color:var(--accent-amber)}.km-block--development .km-value{color:var(--accent-orange)}.km-block--finished .km-value{color:var(--accent-green)}.km-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:4px}.trim-toggle{display:flex;gap:var(--space-1);justify-content:flex-end;margin-bottom:var(--space-2)}.trim-toggle button{padding:3px 12px;border:1px solid var(--border-color, #444);border-radius:4px;background:transparent;color:var(--text-secondary, #aaa);font-size:var(--text-sm);cursor:pointer;transition:all .15s}.trim-toggle button.active{background:var(--accent-color, #e67e22);border-color:var(--accent-color, #e67e22);color:#fff}.trim-toggle button:hover:not(.active){border-color:var(--accent-color, #e67e22);color:var(--accent-color, #e67e22)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:600;display:flex;flex-direction:column;gap:var(--space-2);align-items:flex-end}.toast{display:flex;align-items:center;gap:var(--space-3);padding:10px 14px;background:var(--bg-elevated);border-radius:var(--radius-md);box-shadow:var(--shadow-md);border-left:3px solid transparent;min-width:240px;max-width:360px;animation:toastSlideIn .2s ease-out}.toast--success{border-left-color:var(--accent-green)}.toast--error{border-left-color:var(--accent-red)}.toast--undo{border-left-color:var(--accent-amber)}.toast-message{flex:1;font-size:var(--text-base);color:var(--text-primary)}.toast-undo-btn{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--accent-amber);background:none;border:1px solid var(--accent-amber);border-radius:var(--radius-sm);padding:2px 8px;cursor:pointer}.toast-undo-btn:hover{background:var(--accent-amber);color:#000}.toast-close-btn{font-size:var(--text-xs);color:var(--text-muted);background:none;border:none;cursor:pointer;padding:0 2px}.toast-close-btn:hover{color:var(--text-primary)}.confirm-modal{max-width:340px}.confirm-modal-message{font-size:var(--text-md);color:var(--text-secondary);margin-bottom:4px;line-height:1.5}.btn{padding:7px 18px;border-radius:var(--radius-sm);font-size:var(--text-base);cursor:pointer;border:1px solid transparent;font-family:inherit}.btn.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border)}.btn.btn-secondary:hover{background:var(--bg-hover)}.btn.btn-danger{background:var(--accent-red);color:#fff}.btn.btn-danger:hover{opacity:.85}.mobile-tab-bar,.mobile-event-chips{display:none}.roast-hero{padding:var(--space-3) var(--space-5) var(--space-2);background:var(--instrument-bg);border-bottom:1px solid var(--instrument-border);flex-shrink:0}.rh-center{display:flex;align-items:baseline;justify-content:center;gap:var(--space-8)}.rh-timer{font-size:32px;font-weight:var(--font-bold);color:var(--text-primary);font-variant-numeric:tabular-nums;font-family:var(--font-mono)}.rh-timer .timer-container{flex-direction:row;align-items:center;padding:0;gap:var(--space-2)}.rh-timer .timer-display{font-size:32px;font-weight:300;font-family:var(--font-mono);letter-spacing:-1px}.rh-timer .timer-unit{color:var(--text-primary)}.rh-timer .timer-controls{display:inline-flex;gap:var(--space-1);margin-top:0;margin-left:var(--space-3)}.rh-timer .timer-btn{padding:4px 12px;font-size:var(--text-sm);min-width:0;border-radius:var(--radius-sm)}.rh-temp{font-size:44px;font-weight:300;color:var(--accent-amber);font-variant-numeric:tabular-nums;font-family:var(--font-mono);letter-spacing:-1px}.rh-temp.dim{opacity:.2}.rh-temp-unit{font-size:var(--text-lg);font-weight:var(--font-normal);margin-left:2px;opacity:.5}.rh-sides{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-1);padding-top:var(--space-1);gap:var(--space-3)}.rh-status{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--text-muted);padding:2px var(--space-2);border-radius:var(--radius-full);background:transparent;border:1px solid var(--border);text-transform:uppercase;letter-spacing:.06em}.rh-status.running{color:var(--accent-green);border-color:var(--accent-green-light)}.rh-status.paused{color:var(--accent-orange);border-color:#f39c124d}.rh-right{display:flex;align-items:center;gap:var(--space-3);margin-left:auto}.rh-roast-name{font-size:var(--text-base);color:var(--text-secondary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.phase-progress{display:flex;align-items:center;gap:2px;padding:var(--space-1) var(--space-5);background:var(--instrument-bg);border-bottom:1px solid var(--instrument-border);flex-shrink:0}.pp-segment{flex:1;text-align:center;padding:3px var(--space-2);border-radius:var(--radius-sm);background:transparent;opacity:.35;transition:all .3s;border:1px solid transparent}.pp-segment.pp-active{opacity:1;border-color:var(--accent-amber);background:var(--accent-amber-lighter)}.pp-segment.pp-done{opacity:.6}.pp-label{font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.04em;text-transform:uppercase}.pp-active .pp-label{color:var(--accent-amber)}.pp-time{font-size:10px;font-family:var(--font-mono);color:var(--text-muted)}.pp-arrow{color:var(--text-muted);font-size:var(--text-md);opacity:.3}.dashboard{padding:var(--space-10) var(--space-6);max-width:640px;margin:0 auto}.dash-greeting{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-6)}.dash-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-bottom:var(--space-6)}.dash-stat{padding:var(--space-4) var(--space-3);text-align:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition-base)}.dash-stat:hover{border-color:var(--accent-amber-light)}.dash-stat-value{font-size:28px;font-weight:var(--font-bold);color:var(--accent-amber);font-variant-numeric:tabular-nums}.dash-stat-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1);text-transform:uppercase;letter-spacing:.05em}.dash-actions{display:flex;gap:var(--space-3);margin-bottom:var(--space-8)}.dash-start-btn{padding:var(--space-3) var(--space-6);font-size:var(--text-md)}.dash-repeat-btn{padding:var(--space-3) var(--space-5);font-size:var(--text-md)}.dash-recent-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.dash-recent-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:10px 14px;border-radius:var(--radius-md);cursor:pointer;transition:background .15s}.dash-recent-item:hover{background:var(--bg-elevated)}.dash-recent-info{display:flex;flex-direction:column;gap:2px;min-width:0}.dash-recent-name{font-size:var(--text-md);font-weight:var(--font-medium);color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-recent-meta{font-size:var(--text-sm);color:var(--text-muted)}.dash-recent-bean{font-size:var(--text-xs);padding:2px 8px;border-radius:10px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);flex-shrink:0}.dash-empty-hint{text-align:center;padding:40px 0;color:var(--text-muted);font-size:var(--text-md);line-height:2}@media(max-width:767px){.app-sidebar{display:none}.mobile-tab-bar{display:flex;position:fixed;bottom:0;left:0;right:0;height:56px;background:var(--bg-surface);border-top:1px solid var(--border);z-index:10;align-items:stretch}.mtb-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;cursor:pointer;color:var(--text-secondary);font-family:inherit;padding:4px 0}.mtb-tab.active{color:var(--accent-amber)}.mtb-icon{font-size:var(--text-xl);line-height:1}.mtb-label{font-size:10px}.app-body{padding-bottom:56px}.timer-strip{position:sticky;top:0;z-index:10;flex-wrap:nowrap;gap:var(--space-2);padding:0 12px;height:52px;overflow:hidden}.timer-strip .development-time-display,.timer-strip .ts-right{display:none}.timer-strip .ts-temp{font-size:var(--text-base)}.roast-hero .rh-center{gap:var(--space-4)}.roast-hero .rh-temp{font-size:36px}.roast-hero .rh-timer .timer-display{font-size:24px}.roast-hero .rh-sides .development-time-display,.roast-hero .rh-roast-name{display:none}.roast-layout{flex-direction:column;height:auto;overflow:visible}.roast-left,.roast-left-collapsed{display:none}.roast-right{flex:none;width:100%}.mobile-event-chips{display:flex;overflow-x:auto;gap:var(--space-2);padding:8px 12px;white-space:nowrap;-webkit-overflow-scrolling:touch}.mec-chip{flex-shrink:0;padding:5px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);font-size:var(--text-sm);font-family:inherit;cursor:pointer;white-space:nowrap}.mec-chip--done{opacity:.5;background:var(--bg-surface);cursor:default}.mec-chip--next{border-color:var(--accent-amber);color:var(--accent-amber);font-weight:var(--font-semibold);min-height:44px;font-size:var(--text-md);padding:8px 16px;border-width:2px}.data-section{padding:0}.history-list{display:flex;flex-direction:column}.history-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-1)}.roast-summary-grid{grid-template-columns:1fr 1fr}.trim-toggle{justify-content:center}.dashboard{padding:var(--space-6) var(--space-4)}.dash-greeting,.dash-stat-value{font-size:var(--text-xl)}.dash-actions{flex-direction:column}.toast-container{bottom:68px;right:50%;transform:translate(50%);align-items:center}}.cupping-modal{width:560px;max-width:95vw;max-height:80vh;overflow-y:auto}.cupping-loading{padding:24px;text-align:center;color:var(--text-muted)}.cupping-empty{padding:24px;text-align:center;color:var(--text-muted);font-size:var(--text-md)}.cupping-list{display:flex;flex-direction:column;gap:var(--space-3);padding:16px}.cupping-add-btn{width:100%;margin-top:8px}.cupping-item{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:12px 14px;display:flex;flex-direction:column;gap:var(--space-2)}.cupping-item-header{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.cupping-date{font-size:var(--text-base);color:var(--text-secondary)}.cupping-rest{font-size:var(--text-sm);color:var(--text-muted);background:var(--bg-elevated);padding:2px 6px;border-radius:4px}.cupping-total-score{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--accent-amber);margin-left:auto}.cupping-text-preview{font-size:var(--text-base);color:var(--text-secondary);margin:0;line-height:1.5}.cupping-item-actions{display:flex;gap:var(--space-2)}.cupping-scores-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2);padding:12px;background:var(--bg-surface);border-radius:8px;border:1px solid var(--border)}.cupping-score-item{display:flex;flex-direction:column;gap:var(--space-1)}.cupping-score-item label{font-size:var(--text-xs);color:var(--text-muted)}.cupping-score-item input{width:100%;font-size:var(--text-md);text-align:center}.cupping-form-total{font-size:var(--text-base);color:var(--text-secondary);text-align:right;padding:4px 0}.cupping-tags-section{display:flex;flex-direction:column;gap:var(--space-2)}.cupping-tags-section>label{font-size:var(--text-base);color:var(--text-secondary)}.cupping-tags-presets,.cupping-tags-row{display:flex;flex-wrap:wrap;gap:var(--space-2)}.flavor-tag{font-size:var(--text-sm);padding:3px 8px;border-radius:12px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:all .15s}.flavor-tag:hover{border-color:var(--accent-amber);color:var(--accent-amber)}.flavor-tag--selected{background:var(--accent-amber);border-color:var(--accent-amber);color:#000}.flavor-tag--display{cursor:default;pointer-events:none}.cupping-custom-tag{display:flex;gap:var(--space-2)}.cupping-custom-tag input{flex:1}.cupping-selected-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center;font-size:var(--text-sm);color:var(--text-muted)}.cupping-form{display:flex;flex-direction:column;gap:14px;padding:16px}.cupping-form-row{display:flex;flex-direction:column;gap:var(--space-2)}.cupping-form-row label{font-size:var(--text-base);color:var(--text-secondary)}.cupping-form-row textarea{resize:vertical;min-height:72px}.cupping-form-actions{display:flex;justify-content:flex-end;gap:var(--space-2);margin-top:4px}.cupping-badge{font-size:var(--text-xs);padding:2px 6px;border-radius:4px;background:var(--accent-amber);color:#000;font-weight:var(--font-semibold)}@media(max-width:767px){.cupping-scores-grid{grid-template-columns:repeat(2,1fr)}.cupping-modal{width:100%;max-width:100vw;border-radius:16px 16px 0 0;max-height:90vh}}.srm-modal{width:560px;max-width:95vw;max-height:85vh;overflow-y:auto;display:flex;flex-direction:column;gap:0}.srm-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border)}.srm-header h3{margin:0;font-size:var(--text-lg)}.modal-close-btn{background:transparent;border:none;font-size:var(--text-lg);cursor:pointer;color:var(--text-muted);padding:2px 6px}.srm-section{padding:14px 20px;border-bottom:1px solid var(--border-color, #e2e8f0)}.srm-section:last-of-type{border-bottom:none}.srm-section-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-secondary);margin-bottom:var(--space-3)}.srm-optional{font-weight:var(--font-normal);opacity:.6}.srm-empty-hint{font-size:var(--text-base);color:var(--text-muted);padding:4px 0}.srm-loading{font-size:var(--text-base);color:var(--text-muted)}.srm-machine-list{display:flex;flex-wrap:wrap;gap:var(--space-2)}.srm-machine-card{padding:8px 14px;border:1px solid var(--border);border-radius:8px;background:transparent;cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;gap:2px;transition:border-color .15s,background .15s,box-shadow .15s;color:var(--text-primary);position:relative}.srm-machine-card:hover{border-color:var(--accent-amber)}.srm-machine-card.selected{border:2px solid var(--accent-amber);background:color-mix(in srgb,var(--accent-amber) 15%,transparent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-amber) 30%,transparent)}.srm-machine-card.selected .srm-machine-name{color:var(--accent-amber);font-weight:var(--font-semibold)}.srm-machine-card.selected:after{content:"✓";position:absolute;top:4px;right:8px;font-size:var(--text-sm);color:var(--accent-amber);font-weight:var(--font-bold)}.srm-machine-name{font-size:var(--text-md);font-weight:var(--font-medium)}.srm-machine-sub{font-size:var(--text-xs);color:var(--text-muted)}.srm-bean-search{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg-elevated);color:var(--text-primary);font-size:var(--text-base);margin-bottom:var(--space-2);box-sizing:border-box}.srm-bean-list{display:flex;flex-wrap:wrap;gap:var(--space-2);max-height:130px;overflow-y:auto}.srm-bean-item{padding:5px 12px;border:1px solid var(--border);border-radius:16px;background:transparent;cursor:pointer;font-size:var(--text-base);display:flex;align-items:center;gap:var(--space-2);color:var(--text-primary);transition:border-color .15s,background .15s}.srm-bean-item:hover{border-color:var(--accent-amber)}.srm-bean-item.selected{border:2px solid var(--accent-amber);background:color-mix(in srgb,var(--accent-amber) 15%,transparent);color:var(--accent-amber);font-weight:var(--font-semibold)}.srm-bean-sub{font-size:var(--text-xs);color:var(--text-muted)}.srm-batch-list{display:flex;flex-wrap:wrap;gap:var(--space-2)}.srm-batch-item{padding:5px 12px;border:1px solid var(--border);border-radius:16px;background:transparent;cursor:pointer;font-size:var(--text-base);color:var(--text-primary);display:flex;align-items:center;gap:var(--space-2);transition:border-color .15s,background .15s}.srm-batch-item:hover{border-color:var(--accent-amber)}.srm-batch-item.selected{border:2px solid var(--accent-amber);background:color-mix(in srgb,var(--accent-amber) 15%,transparent);color:var(--accent-amber);font-weight:var(--font-semibold)}.srm-row{display:flex;gap:var(--space-3)}.srm-field{display:flex;flex-direction:column;gap:var(--space-2)}.srm-field-grow{flex:1}.srm-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.srm-input{padding:7px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg-elevated);color:var(--text-primary);font-size:var(--text-base);width:100%;box-sizing:border-box}.save-modal{width:460px;max-width:95vw}.save-modal-body{display:flex;flex-direction:column;gap:14px;padding:4px 0 8px}.save-modal-loss{justify-content:flex-end}.save-modal-loss-val{padding:7px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg-elevated);font-size:var(--text-md);min-height:36px;display:flex;align-items:center}.save-modal-loss-num{color:var(--accent-amber);font-weight:var(--font-semibold)}.save-modal-loss-placeholder{color:var(--text-muted);font-size:var(--text-sm)}.cupping-brew-section{border:1px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:var(--space-3);background:var(--bg-elevated)}.cupping-brew-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-secondary);margin-bottom:var(--space-3)}.cupping-optional{font-weight:var(--font-normal);opacity:.6}.cupping-brew-row{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-2)}.cupping-brew-row:last-child{margin-bottom:0}.cupping-brew-field{flex:1;min-width:80px}.cupping-brew-ratio-val{padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--accent-amber);background:transparent;text-align:center;min-height:34px;display:flex;align-items:center;justify-content:center}.machine-mgr-list{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-3)}.machine-mgr-item{display:flex;align-items:center;gap:var(--space-2);padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg-elevated)}.machine-mgr-name{flex:1;font-size:var(--text-md)}.machine-mgr-sub{font-size:var(--text-sm);color:var(--text-muted);margin-right:auto}.machine-mgr-input{flex:1;padding:4px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg-surface);color:var(--text-primary);font-size:var(--text-base)}.machine-mgr-btn{padding:3px 8px;border-radius:4px;border:1px solid var(--border);background:transparent;cursor:pointer;font-size:var(--text-base);color:var(--text-secondary)}.machine-mgr-btn.save{color:var(--accent-green, #2ecc71);border-color:var(--accent-green, #2ecc71)}.machine-mgr-btn.delete{color:var(--accent-red, #e05c5c);border-color:var(--accent-red, #e05c5c)}.machine-mgr-btn.edit{color:var(--accent-amber);border-color:var(--accent-amber)}.machine-mgr-btn.cancel{color:var(--text-muted);border-color:var(--border)}.pem-section{margin-bottom:var(--space-4)}.pem-section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.machine-mgr-add-form{display:flex;flex-direction:column;gap:var(--space-2);padding:8px;border:1px dashed var(--border);border-radius:6px}.machine-mgr-add-actions{display:flex;gap:var(--space-2)}.machine-mgr-add-btn{font-size:var(--text-base);color:var(--accent-amber);background:transparent;border:1px dashed var(--accent-amber);border-radius:6px;padding:5px 12px;cursor:pointer;width:100%}.bean-batch-toggle{padding:6px 0 0}.bean-batch-toggle-btn{font-size:var(--text-sm);color:var(--text-muted);background:transparent;border:none;cursor:pointer;padding:2px 0}.bean-batch-toggle-btn:hover{color:var(--text-secondary)}.bean-batch-panel{margin-top:8px;padding:10px 12px;border:1px solid var(--border);border-radius:6px;background:var(--bg-elevated)}.bean-batch-loading,.bean-batch-empty{font-size:var(--text-sm);color:var(--text-muted)}.bean-batch-list{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-2)}.bean-batch-item{display:flex;align-items:center;gap:var(--space-2);padding:5px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg-surface)}.bean-batch-name{flex:1;font-size:var(--text-base)}.bean-batch-date{font-size:var(--text-xs);color:var(--text-muted)}.bean-batch-del-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:0 4px;font-size:var(--text-sm)}.bean-batch-del-btn:hover{color:var(--accent-red, #e05c5c)}.bean-batch-add-form{display:flex;flex-direction:column;gap:var(--space-2)}.bean-batch-input{padding:5px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg-surface);color:var(--text-primary);font-size:var(--text-base)}.bean-batch-add-actions{display:flex;gap:var(--space-2)}.bean-batch-add-confirm{padding:4px 12px;background:var(--accent-amber);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:var(--text-base)}.bean-batch-add-confirm:disabled{opacity:.5;cursor:not-allowed}.bean-batch-add-cancel{padding:4px 12px;background:transparent;border:1px solid var(--border);border-radius:4px;cursor:pointer;font-size:var(--text-base);color:var(--text-secondary)}.bean-batch-add-btn{font-size:var(--text-sm);color:var(--accent-amber);background:transparent;border:1px dashed var(--accent-amber);border-radius:4px;padding:4px 10px;cursor:pointer;width:100%}.rdv-container{display:flex;flex-direction:column;height:100%}.rdv-tab-bar{display:flex;align-items:center;gap:2px;padding:8px 16px 0;border-bottom:1px solid var(--border);background:var(--bg-surface);flex-shrink:0}.rdv-tab-btn{padding:7px 16px;font-size:var(--text-base);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;color:var(--text-muted);transition:color .15s,border-color .15s;margin-bottom:-1px}.rdv-tab-btn:hover{color:var(--text-secondary)}.rdv-tab-btn.active{color:var(--accent-amber);border-bottom-color:var(--accent-amber);font-weight:var(--font-semibold)}.rdv-content{flex:1;overflow:auto}.rdv-loading,.rdv-empty{padding:32px;text-align:center;font-size:var(--text-base);color:var(--text-muted)}.rdv-params-tab{padding:16px 20px;max-width:680px}.rdv-params-card{margin-bottom:var(--space-3);padding:var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.rdv-params-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.rdv-params-card-actions{display:flex;gap:var(--space-2)}.rdv-params-card-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.rdv-params-entity-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.rdv-params-divider{height:1px;background:var(--border);margin:var(--space-3) 0}.rdv-params-card-grid{display:flex;gap:var(--space-6);flex-wrap:wrap}.rdv-params-field{display:flex;flex-direction:column;gap:var(--space-2);min-width:100px}.rdv-params-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.rdv-params-value{font-size:var(--text-md);color:var(--text-primary)}.rdv-params-empty{color:var(--text-muted);font-style:italic}.rdv-params-select{padding:6px 8px;border:1px solid var(--border);border-radius:6px;background:var(--bg-elevated);color:var(--text-primary);font-size:var(--text-base);min-width:160px}.rdv-params-input{padding:6px 8px;border:1px solid var(--border);border-radius:6px;background:var(--bg-elevated);color:var(--text-primary);font-size:var(--text-base);width:100px}.rdv-cupping-tab{padding:16px 20px;display:flex;flex-direction:column;gap:var(--space-3)}.rdv-cupping-list{display:flex;flex-direction:column;gap:var(--space-3)}.rdv-cupping-card{padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg-elevated);display:flex;flex-direction:column;gap:var(--space-2)}.rdv-cupping-card-header{display:flex;align-items:center;gap:var(--space-3)}.rdv-cupping-date{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.rdv-cupping-meta{font-size:var(--text-sm);color:var(--text-muted)}.rdv-cupping-score{margin-left:auto;font-size:var(--text-md);font-weight:var(--font-bold);color:var(--accent-amber)}.rdv-cupping-tags{display:flex;flex-wrap:wrap;gap:var(--space-1)}.rdv-cupping-tag{font-size:var(--text-xs);padding:2px 8px;border-radius:10px;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary)}.rdv-cupping-tag-more{color:var(--text-muted);border-style:dashed}.rdv-cupping-text{font-size:var(--text-base);color:var(--text-secondary);line-height:1.5}.rdv-cupping-card-actions{display:flex;justify-content:flex-end;gap:var(--space-2)}.rdv-cupping-del-btn{font-size:var(--text-sm);padding:2px 8px;background:transparent;border:1px solid var(--border);border-radius:4px;cursor:pointer;color:var(--text-muted)}.rdv-cupping-del-btn:hover{color:var(--accent-red, #e05c5c);border-color:var(--accent-red, #e05c5c)}.rdv-cupping-add-btn{align-self:flex-start;padding:7px 16px;font-size:var(--text-base);background:transparent;border:1px dashed var(--accent-amber);border-radius:6px;cursor:pointer;color:var(--accent-amber)}.rdv-chart-meta{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:8px 16px 4px;border-bottom:1px solid var(--border);flex-shrink:0}.rdv-cm-chip{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);padding:3px 10px;border-radius:20px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary)}.rdv-cm-chip b{font-weight:var(--font-semibold);color:var(--text-primary)}.rdv-cm-chip--bean{border-color:var(--accent-green-light)}.rdv-cm-chip--level{background:var(--accent-amber-lighter);border-color:var(--accent-amber-light);color:var(--accent-amber);font-weight:var(--font-semibold)}.rdv-data-tab{padding:0}.rdv-entity-card{display:flex;flex-direction:column;gap:var(--space-2)}.rdv-entity-main{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2)}.rdv-entity-name{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--text-primary)}.rdv-entity-sub{font-size:var(--text-sm);color:var(--text-muted)}.rdv-entity-badge{font-size:var(--text-xs);padding:2px 8px;border-radius:10px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary)}.rdv-entity-expand-btn{font-size:var(--text-xs);padding:2px 8px;border:none;background:transparent;color:var(--accent-amber);cursor:pointer;margin-left:auto}.rdv-entity-detail{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-2) 0 0}.rdv-entity-row{display:flex;gap:var(--space-3);font-size:var(--text-base)}.rdv-entity-key{color:var(--text-muted);min-width:60px;flex-shrink:0}.rml-container{padding:24px;max-width:720px}.rml-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.rml-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-primary)}.rml-add-btn{padding:7px 16px;font-size:var(--text-base);background:var(--accent-amber);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:var(--font-medium)}.rml-error{padding:10px 14px;background:var(--accent-red-lighter);border:1px solid var(--accent-red-light);border-radius:6px;font-size:var(--text-base);color:#e8604c;margin-bottom:var(--space-4)}.rml-loading,.rml-empty{padding:32px;text-align:center;font-size:var(--text-base);color:var(--text-muted)}.rml-list{display:flex;flex-direction:column;gap:var(--space-3)}.rml-card{padding:16px 18px;background:var(--bg-surface);border:1px solid var(--border);border-radius:10px}.rml-card-main{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.rml-card-info{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.rml-card-name{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.rml-card-sub{font-size:var(--text-base);color:var(--text-secondary)}.rml-card-meta{display:flex;gap:var(--space-2);flex-wrap:wrap}.rml-meta-chip{font-size:var(--text-xs);padding:2px 8px;border-radius:10px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary)}.rml-card-note{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}.rml-card-actions{display:flex;flex-direction:column;gap:var(--space-2);flex-shrink:0}.rml-action-btn{padding:4px 12px;font-size:var(--text-sm);background:transparent;border:1px solid var(--border);border-radius:5px;cursor:pointer;color:var(--text-secondary)}.rml-action-btn:hover{border-color:var(--accent-amber);color:var(--accent-amber)}.rml-action-btn--delete:hover{border-color:var(--accent-red, #e8604c);color:var(--accent-red, #e8604c)}.rml-form-card{padding:16px 18px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;margin-bottom:var(--space-4)}.rml-form-title{font-size:var(--text-md);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-3)}.rml-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.rml-field{display:flex;flex-direction:column;gap:5px}.rml-field--full{grid-column:1 / -1}.rml-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.rml-input{padding:7px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg-surface);color:var(--text-primary);font-size:var(--text-base);font-family:inherit}.rml-input:focus{outline:2px solid var(--accent-amber);outline-offset:1px}.rml-form-actions{display:flex;gap:var(--space-2);margin-top:14px}.rml-btn{padding:7px 16px;font-size:var(--text-base);border:1px solid var(--border);border-radius:6px;background:transparent;cursor:pointer;color:var(--text-secondary);font-family:inherit}.rml-btn--primary{background:var(--accent-amber);border-color:var(--accent-amber);color:#fff;font-weight:var(--font-medium)}.rml-btn:disabled{opacity:.5;cursor:not-allowed}:root{--text-xs: 11px;--text-sm: 12px;--text-base: 13px;--text-md: 14px;--text-lg: 16px;--text-xl: 18px;--text-2xl: 24px;--text-display: 40px;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.2;--leading-normal: 1.5;--leading-relaxed: 1.6;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--bg-base: #0f1117;--bg-surface: #161b22;--bg-elevated: #1e2733;--bg-hover: #243040;--text-primary: #c8cdd6;--text-secondary: #5a6678;--text-muted: #64748b;--accent-amber: #c8a96e;--accent-red: #e8604c;--accent-green: #3de87a;--accent-orange: #f39c12;--accent-blue: #3b82f6;--accent-amber-light: rgba(200, 169, 110, .15);--accent-amber-lighter: rgba(200, 169, 110, .08);--accent-red-light: rgba(232, 96, 76, .15);--accent-red-lighter: rgba(232, 96, 76, .08);--accent-green-light: rgba(61, 232, 122, .15);--accent-green-lighter: rgba(61, 232, 122, .08);--border: #1e2733;--border-subtle: #161b22;--overlay: rgba(0, 0, 0, .6);--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;--phase-drying: rgba(46, 204, 113, .15);--phase-maillard: rgba(243, 156, 18, .18);--phase-development: rgba(231, 76, 60, .22);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .5);--focus-ring: 0 0 0 2px var(--bg-surface), 0 0 0 4px var(--accent-amber);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px;--radius-full: 999px;--transition-fast: .1s ease;--transition-base: .15s ease;--transition-slow: .25s ease;--z-sticky: 10;--z-dropdown: 100;--z-backdrop: 400;--z-profile: 450;--z-modal: 500;--z-toast: 600;--font-mono: "SF Mono", "Menlo", "Consolas", monospace;--instrument-bg: rgba(0, 0, 0, .15);--instrument-border: rgba(255, 255, 255, .06);--sidebar-width: 56px;--sidebar-expanded: 200px;--mobile-tab-height: 56px;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;font-size:16px;line-height:var(--leading-relaxed);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;--accent-amber-light: rgba(146, 64, 14, .12);--accent-amber-lighter: rgba(146, 64, 14, .06);--accent-red-light: rgba(220, 38, 38, .12);--accent-red-lighter: rgba(220, 38, 38, .06);--accent-green-light: rgba(22, 163, 74, .12);--accent-green-lighter: rgba(22, 163, 74, .06);--border: #e5e7eb;--border-subtle: #f3f4f6;--overlay: rgba(0, 0, 0, .4);--phase-drying: rgba(22, 163, 74, .1);--phase-maillard: rgba(217, 119, 6, .12);--phase-development: rgba(220, 38, 38, .1);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .12);--instrument-bg: rgba(0, 0, 0, .03);--instrument-border: 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;--accent-amber-light: rgba(111, 78, 55, .12);--accent-amber-lighter: rgba(111, 78, 55, .06);--accent-red-light: rgba(139, 37, 0, .12);--accent-red-lighter: rgba(139, 37, 0, .06);--accent-green-light: rgba(45, 106, 79, .12);--accent-green-lighter: rgba(45, 106, 79, .06);--border: #e8dfd4;--border-subtle: #f0ebe4;--overlay: rgba(44, 26, 14, .5);--phase-drying: rgba(45, 106, 79, .1);--phase-maillard: rgba(212, 82, 42, .12);--phase-development: rgba(139, 37, 0, .12);--shadow-sm: 0 1px 3px rgba(44, 26, 14, .08);--shadow-md: 0 4px 12px rgba(44, 26, 14, .1);--shadow-lg: 0 12px 32px rgba(44, 26, 14, .15);--instrument-bg: rgba(44, 26, 14, .04);--instrument-border: rgba(44, 26, 14, .08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent-amber);outline-offset:1px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}a{color:var(--accent-amber);text-decoration:none}a:hover{text-decoration:underline}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.6}}@keyframes blink{0%,to{opacity:1}50%{opacity:.2}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-base);font-weight:var(--font-semibold);font-family:inherit;background:var(--accent-amber);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:filter var(--transition-base);white-space:nowrap}.btn-primary:hover{filter:brightness(1.1)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;filter:none}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-base);font-weight:var(--font-medium);font-family:inherit;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.btn-secondary:hover{border-color:var(--accent-amber);color:var(--accent-amber)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-base);font-family:inherit;background:transparent;color:var(--accent-amber);border:none;cursor:pointer;transition:opacity var(--transition-base)}.btn-ghost:hover{opacity:.8}.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-base);font-family:inherit;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.btn-danger:hover{border-color:var(--accent-red);color:var(--accent-red)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-sm)}.btn-lg{padding:var(--space-3) var(--space-5);font-size:var(--text-lg)}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4)}.input{padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);font-size:var(--text-base);font-family:inherit;transition:border-color var(--transition-base)}.input:focus{border-color:var(--accent-amber)}.input::placeholder{color:var(--text-muted)}.select{padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);font-size:var(--text-base);font-family:inherit}.chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--text-sm);border-radius:var(--radius-full);background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);white-space:nowrap}.chip b,.chip strong{font-weight:var(--font-semibold);color:var(--text-primary)}.chip--amber{border-color:var(--accent-amber-light)}.chip--green{border-color:var(--accent-green-light)}.chip--red{border-color:var(--accent-red-light)}.chip--accent{background:var(--accent-amber-lighter);border-color:var(--accent-amber-light);color:var(--accent-amber);font-weight:var(--font-semibold)}.section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.modal-overlay{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:var(--z-backdrop)}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:420px;padding:var(--space-6);box-shadow:var(--shadow-lg);z-index:var(--z-modal);max-height:85vh;overflow-y:auto}.modal-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-5)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-5)}.toast-bar{position:fixed;bottom:var(--space-5);left:50%;transform:translate(-50%);z-index:var(--z-toast);display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);animation:toastSlideIn .2s ease-out}.empty-state-block{text-align:center;padding:var(--space-10) var(--space-4);color:var(--text-muted);font-size:var(--text-md);line-height:2}.web-guest-gate{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-12) var(--space-6);text-align:center}.guest-gate-icon{font-size:48px}.guest-gate-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.guest-gate-desc{font-size:var(--text-md);color:var(--text-muted);max-width:280px}
