/* Overview */
.overview-grid{display:grid;gap:12px}.battery-card{padding:18px}.battery-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.battery-meter{height:12px;background:var(--surface-3);border-radius:999px;overflow:hidden;margin:18px 0}.battery-meter span{display:block;height:100%}.battery-meter-fill{background:var(--accent);border-radius:999px}.battery-meter.is-segmented{display:flex;gap:0}.battery-meter-segment{position:relative;flex:0 0 auto;min-width:0;background:transparent;overflow:hidden}.battery-meter-segment-fill{width:0%;border-radius:0}.battery-meter-segment:first-child .battery-meter-segment-fill{border-top-left-radius:999px;border-bottom-left-radius:999px}.battery-meter-segment:last-child .battery-meter-segment-fill{border-top-right-radius:999px;border-bottom-right-radius:999px}.metric-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;border-top:1px solid var(--border-soft);padding-top:14px}.metric-row div{min-width:0}.metric-row small{display:block;color:var(--muted);font-size:12px}.metric-row strong{font-size:14px}.mini-card{padding:16px;min-height:148px}.mini-card .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px}.phase-list{display:grid;gap:4px;margin-top:12px;color:var(--muted);font-size:14px}.insight-strip{display:grid;grid-template-columns:1fr 1fr;gap:0;overflow:hidden}.insight-strip>div{padding:14px}.insight-strip>div+div{border-left:1px solid var(--border-soft)}
/* Schedule */
.summary-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:0;overflow:hidden}.summary-strip>div{padding:14px}.summary-strip>div+div{border-left:1px solid var(--border-soft)}.summary-strip small{display:block;color:var(--muted);font-size:12px}.summary-strip strong{font-size:22px}.schedule-toolbar{display:grid;gap:12px;margin:14px 0}.schedule-list{display:grid;gap:10px}.slot{background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden}.slot-main{display:grid;grid-template-columns:72px 1fr 78px 1.15fr 28px;gap:10px;align-items:center;padding:14px}.slot-time{font-size:21px}.slot-power{font-size:18px;font-weight:700}.slot-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.slot-stats small{display:block;color:var(--muted);font-size:11px}.slot-stats strong{font-size:14px}.slot-extra{border-top:1px solid var(--border-soft);padding:12px 14px;display:grid;grid-template-columns:repeat(5,1fr);gap:8px;text-align:center}.slot-extra small{display:block;color:var(--muted);margin-bottom:5px}.slot-extra .chip{justify-content:center;width:100%;padding-left:4px;padding-right:4px}.detail-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.detail-head button{border:0;background:transparent;color:var(--accent);font-size:16px}.detail-summary{display:grid;grid-template-columns:repeat(5,1fr);gap:0;overflow:hidden}.detail-summary div{padding:12px;text-align:center}.detail-summary div+div{border-left:1px solid var(--border-soft)}.detail-summary small{display:block;color:var(--muted);font-size:12px}.detail-summary strong{font-size:22px}.device-list{display:grid;gap:0;overflow:hidden}.device-row{display:grid;grid-template-columns:52px 92px 1fr;gap:10px;align-items:center;padding:12px 14px}.device-row+.device-row{border-top:1px solid var(--border-soft)}.device-icon{width:40px;height:40px;border-radius:14px;background:var(--surface-3);display:grid;place-items:center;color:var(--accent)}.device-name small{display:block;color:var(--muted)}.device-options{display:flex;gap:6px;overflow:auto;padding-bottom:2px}.device-options button{border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--muted);min-height:36px;padding:0 12px;white-space:nowrap}.device-options button.is-active{color:var(--accent-2);border-color:var(--accent-2);background:#102033}.save-bar{position:sticky;bottom:calc(var(--nav-h) + 8px);z-index:5;padding:10px 0}.save-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px}.mode-actions{grid-template-columns:repeat(4,1fr)}
/* Savings */
.filter-row{display:grid;grid-template-columns:1.2fr 1.4fr auto;gap:10px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.kpi{padding:14px;min-height:118px}.kpi small{color:var(--muted)}.chart-card{padding:16px}.chart-bars{height:210px;display:flex;align-items:end;gap:5px;border-left:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);padding:10px 0 0 10px}.bar-pair{flex:1;display:flex;align-items:end;gap:2px;height:100%;min-width:7px}.bar{width:50%;border-radius:4px 4px 0 0;background:var(--blue)}.bar.with{background:var(--accent)}.savings-table{overflow:hidden}.table-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr;gap:8px;align-items:center;padding:11px 12px}.table-row.header{color:var(--muted);font-size:12px}.table-row:not(.header)+.table-row{border-top:1px solid var(--border-soft)}.table-row.total{border-top:1px solid var(--accent);background:var(--surface-2);font-weight:700}.pos{color:var(--green)}.neg{color:var(--red)}
/* Settings */
.settings-list{display:grid;gap:12px}.settings-row{padding:18px;border:1px solid var(--border);background:var(--surface);border-radius:20px;width:100%;color:var(--text);text-align:left;display:flex;align-items:center;justify-content:space-between}.settings-row small{display:block;color:var(--muted);margin-top:4px}.settings-card{padding:18px}.option-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.radio-option{min-height:54px;border:1px solid var(--border);border-radius:14px;background:var(--surface);color:var(--muted);padding:0 12px;text-align:left}.radio-option.is-active{color:var(--text);border-color:var(--accent);background:#0c2629}
@media (max-width:420px){.slot-main{grid-template-columns:62px 1fr 64px 1fr 22px;gap:7px;padding:12px}.slot-time{font-size:18px}.slot-stats{gap:4px}.slot-stats strong{font-size:12px}.slot-extra{grid-template-columns:repeat(3,1fr)}.metric-row{grid-template-columns:repeat(2,1fr)}.filter-row{grid-template-columns:1fr 1fr}.filter-row .btn{grid-column:1/-1}.kpi-grid{grid-template-columns:repeat(2,1fr)}.detail-summary{grid-template-columns:repeat(3,1fr)}.mode-actions{grid-auto-flow:row;grid-template-columns:repeat(2,1fr)}}

/* Fixes v3: schedule colors, native button reset, price visibility, full-width insight */
.insight-strip-single{grid-template-columns:1fr}.insight-strip-single>div+div{display:none}.insight-strip-single p{font-size:18px;line-height:1.35;margin:12px 0 2px}
.slot{position:relative;background:var(--surface);border-color:var(--border);color:var(--text)}
.slot:before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--price-color,var(--border));opacity:.95}
.slot-main{width:100%;border:0;background:transparent;color:var(--text);text-align:left;appearance:none;-webkit-appearance:none}
.slot-main:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}
.slot-chevron{font-size:18px;text-align:center;color:var(--muted)}
.slot.price-cheap{border-color:rgba(69,230,164,.45)}
.slot.price-mid{border-color:rgba(255,214,102,.35)}
.slot.price-expensive{border-color:rgba(255,92,100,.55)}
.slot.price-cheap .price-buy,.slot.price-cheap .slot-time{color:var(--green)}
.slot.price-mid .price-buy{color:#ffd166}
.slot.price-expensive .price-buy,.slot.price-expensive .slot-time{color:var(--red)}
.slot-stats em{display:block;font-style:normal;font-size:10px;color:var(--muted);margin-top:2px}
.orange-text{color:var(--orange)}
.slot-extra{align-items:center}.slot-edit{grid-column:1/-1;margin-top:4px;min-height:38px}
.slot-data-grid{display:grid;grid-template-columns:repeat(5,1fr);overflow:hidden}.slot-data-grid>div{padding:12px;text-align:center}.slot-data-grid>div+div{border-left:1px solid var(--border-soft)}.slot-data-grid small{display:block;color:var(--muted);font-size:12px}.slot-data-grid strong{font-size:15px}
@media (max-width:420px){.slot-data-grid{grid-template-columns:repeat(2,1fr)}.slot-data-grid>div{border-left:0!important;border-top:1px solid var(--border-soft)}.slot-data-grid>div:first-child{border-top:0}.slot-extra{grid-template-columns:repeat(2,1fr)}}

/* Schedule matrix v4 */
.schedule-day-head{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;text-align:center;margin:2px 0 4px}.schedule-day-head strong{font-size:22px}.ghost-icon{border:0;background:transparent;color:var(--accent);font-size:30px;min-height:44px}.matrix-summary{display:grid;grid-template-columns:1fr 1fr 1fr;overflow:hidden}.matrix-summary>div{padding:12px}.matrix-summary>div+div{border-left:1px solid var(--border-soft)}.matrix-summary strong{display:block;font-size:15px;margin:8px 0 4px}.matrix-summary small{display:block;color:var(--muted);font-size:12px;line-height:1.25}.schedule-view-switch{margin:2px 0 8px}.matrix-card{overflow:hidden;box-shadow:none}.matrix-scroll{overflow-x:auto;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;scrollbar-width:none}.matrix-scroll::-webkit-scrollbar{display:none}.matrix-row{display:grid;grid-template-columns:94px max-content;min-width:max-content;border-bottom:1px solid var(--border-soft)}.matrix-row:last-child{border-bottom:0}.matrix-label{position:sticky;left:0;z-index:2;background:var(--surface);border-right:1px solid var(--border-soft);padding:10px 10px;min-height:58px;display:flex;flex-direction:column;justify-content:center}.matrix-label strong{font-size:15px}.matrix-label small{color:var(--muted);font-size:12px;margin-top:2px}.matrix-cells{display:grid;grid-auto-flow:column;grid-auto-columns:68px;gap:4px;padding:6px}.mhead-hour{height:34px;display:grid;place-items:center;color:var(--text);font-weight:700}.mcell{width:100%;height:58px;border:1px solid var(--border-soft);border-radius:10px;background:var(--surface-2);color:var(--text);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;text-align:center;padding:4px;appearance:none;-webkit-appearance:none}.mcell strong{font-size:13px;line-height:1.05;white-space:normal;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.mcell small{font-size:10px;color:rgba(255,255,255,.72)}.mcell.price strong{font-size:15px}.mcell.price.cheap{background:#1d522f;border-color:#41966a}.mcell.price.mid{background:#67551b;border-color:#a48427}.mcell.price.expensive{background:#703417;border-color:#bb6428}.mcell.bat.orange{background:#613714;border-color:#b86b25;color:#ffb66e}.mcell.bat.blue{background:#112f5f;border-color:#2c72cc;color:#7bbcff}.mcell.bat.green{background:#143d2d;border-color:#2d9b6c;color:#76e5ac}.mcell.bat.normal,.mcell.bat{background:#202938;border-color:#37465f}.mcell.load.off{background:#0b1220;color:#6f7d92;border-color:#16243a}.mcell.load.neutral{background:#1a2230;color:#cbd5e1}.mcell.load.active{background:#102a48;color:#66bdff;border-color:#2d75bd}.mcell.load.on{background:#0f3a33;color:#4be6d3;border-color:#1aa694}.mcell.load.warn{background:#4c3b14;color:#ffd166;border-color:#9c7a2a}.mcell.load.danger{background:#461b20;color:#ff9298;border-color:#a9444d}.mcell.load.is-selected{outline:2px solid var(--accent);outline-offset:1px;background:#0f766e!important;color:white!important;border-color:#2dd4bf!important;box-shadow:0 0 0 4px rgba(45,212,191,.12)}.matrix-hint{padding:10px;color:var(--muted);text-align:center;font-size:13px}.matrix-batch-spacer{height:96px}.matrix-batch{position:fixed;left:50%;bottom:calc(var(--nav-h) + 10px);transform:translateX(-50%);z-index:20;width:min(820px,calc(100vw - 28px));padding:12px;display:grid;grid-template-columns:1.2fr auto auto auto;gap:10px;align-items:center;box-shadow:0 16px 42px rgba(0,0,0,.55)}.batch-title small{display:block;color:var(--muted);margin-top:4px}.batch-options{display:flex;gap:8px;overflow:auto}.batch-option{min-height:44px;min-width:58px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:14px;padding:0 12px}.batch-option.is-active{border-color:var(--accent);color:var(--accent);background:#0c2629}.matrix-batch.is-saving{opacity:.75;pointer-events:none}.price-list{overflow:hidden}.price-line{display:grid;grid-template-columns:70px 1fr auto;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border-soft)}.price-line:last-child{border-bottom:0}.price-line small{color:var(--muted)}.price-line.cheap span{color:var(--green)}.price-line.mid span{color:#ffd166}.price-line.expensive span{color:var(--red)}
@media (max-width:520px){.matrix-summary{grid-template-columns:1fr}.matrix-summary>div+div{border-left:0;border-top:1px solid var(--border-soft)}.matrix-row{grid-template-columns:84px max-content}.matrix-cells{grid-auto-columns:62px}.matrix-label{padding:8px;min-height:54px}.mcell{height:54px}.mcell strong{font-size:12px}.matrix-batch{grid-template-columns:1fr;bottom:calc(var(--nav-h) + 6px)}.batch-options{width:100%}.batch-option{flex:1}.matrix-batch .btn{width:100%}}


/* Schedule matrix v5 tweaks */
.schedule-view-switch--two{grid-template-columns:repeat(2,1fr)}
.mcell.bat{cursor:default}
.matrix-batch-spacer{height:74px}
.matrix-batch{bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + 6px);padding:10px;grid-template-columns:1fr auto auto;gap:8px;align-items:center}
.matrix-batch .batch-title{min-width:0}.matrix-batch .batch-title strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.matrix-batch .batch-title small{font-size:12px}.batch-options{gap:6px}.batch-option{min-height:40px;min-width:54px;border-radius:12px;padding:0 10px}.matrix-batch #clear-selection{min-height:40px;padding:0 10px}.matrix-batch #apply-selection{min-height:40px;padding:0 14px;white-space:nowrap}
@media (max-width:520px){
  .matrix-batch{grid-template-columns:1fr auto;grid-template-areas:"title apply" "options clear";width:calc(100vw - 20px);bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + 4px);padding:9px}
  .matrix-batch .batch-title{grid-area:title}.matrix-batch .batch-options{grid-area:options;display:flex;width:100%;overflow-x:auto}.matrix-batch #clear-selection{grid-area:clear}.matrix-batch #apply-selection{grid-area:apply;width:auto;align-self:stretch}.batch-option{flex:0 0 auto;min-width:58px}.matrix-batch-spacer{height:116px}
}
@media (max-width:390px){
  .matrix-batch{grid-template-columns:1fr auto;gap:7px}.batch-option{min-width:52px;padding:0 8px}.matrix-batch #clear-selection{font-size:13px}.matrix-batch #apply-selection{font-size:14px;padding:0 12px}
}

/* v6 plan + compact overview/savings tweaks */
.schedule-matrix-view--compact{gap:8px}
.schedule-matrix-view--compact .schedule-view-switch{margin-top:0}
.mcell.bat.is-selected{outline:2px solid var(--accent);outline-offset:1px;background:#0f766e!important;color:#fff!important;border-color:#2dd4bf!important;box-shadow:0 0 0 4px rgba(45,212,191,.12)}
.chart-legend{display:flex;gap:14px;align-items:center;margin:10px 0 4px;color:var(--muted);font-size:12px;flex-wrap:wrap}.chart-legend span{display:inline-flex;align-items:center;gap:6px}.legend-box{width:10px;height:10px;border-radius:3px;background:var(--blue);display:inline-block}.legend-box.legend-with{background:var(--accent)}
.overview-grid .grid-2 .mini-card:first-child{min-height:auto}.overview-grid .grid-2 .mini-card:first-child .value-lg{margin-top:8px}
@media (max-width:520px){.schedule-matrix-view--compact .segmented button{padding:8px 10px}.schedule-matrix-view--compact .matrix-card{margin-top:0}}


/* v7 compact overview, power formatting, price/battery reset, savings chart */
.overview-compact{gap:8px}
.overview-compact .card.pad{padding:10px 12px}
.overview-compact .battery-card{padding:12px}
.overview-compact .battery-head{gap:10px}
.overview-compact .section-title,.overview-compact .mini-card .label{font-size:11px;letter-spacing:.07em;margin-bottom:6px}
.overview-compact .value-xl{font-size:42px}
.overview-compact .value-lg{font-size:25px}
.overview-compact #battery-power{margin-top:10px!important}
.overview-compact .battery-meter{height:9px;margin:10px 0}
.overview-compact .metric-row{gap:6px;padding-top:9px;grid-template-columns:repeat(4,1fr)}
.overview-compact .metric-row small{font-size:10px}.overview-compact .metric-row strong{font-size:12px}
.overview-compact .grid-2{gap:8px}
.overview-compact .mini-card{padding:11px;min-height:96px}
.overview-compact .mini-card .muted{font-size:12px}
.overview-compact .phase-list{margin-top:6px;font-size:11px;gap:2px;grid-template-columns:1fr 1fr}
.overview-compact .insight-strip>div{padding:11px}.overview-compact .insight-strip-single p{font-size:15px;margin:7px 0 0;line-height:1.25}
@media (max-width:420px){.overview-compact .metric-row{grid-template-columns:repeat(2,1fr)}.overview-compact .value-xl{font-size:38px}.overview-compact .value-lg{font-size:23px}.overview-compact .mini-card{min-height:88px}}
.mcell.price{gap:1px}.mcell.price small{font-size:10px;color:rgba(255,255,255,.82)}
.batch-option[data-batch-value="Reset"]{border-color:rgba(255,92,100,.55);color:var(--red)}
.price-line{grid-template-columns:64px 1fr 1fr auto}.price-line span small{display:block;color:var(--muted);font-size:11px;margin-bottom:2px}.price-line.expensive span:last-of-type,.price-line.expensive span:first-of-type{color:var(--red)}
.savings-filter-row{grid-template-columns:1fr 1.2fr}.chart-empty{height:140px;display:grid;place-items:center}.chart-wrap{width:100%;overflow:hidden}.savings-svg{width:100%;height:auto;display:block}.svg-grid{stroke:rgba(154,168,189,.18);stroke-width:1}.svg-axis{stroke:rgba(154,168,189,.35);stroke-width:1}.svg-label,.svg-unit{fill:var(--muted);font-size:12px}.svg-bar.no{fill:var(--blue);opacity:.82}.svg-bar.with{fill:var(--accent);opacity:.78}.svg-line{stroke:var(--green);stroke-width:3;stroke-linejoin:round;stroke-linecap:round}.svg-dot{fill:var(--green);stroke:var(--surface);stroke-width:2}.legend-line{width:18px;height:3px;border-radius:999px;background:var(--green);display:inline-block}
@media (max-width:420px){.savings-filter-row{grid-template-columns:1fr}.price-line{grid-template-columns:56px 1fr 1fr}.price-line>small{grid-column:1/-1}}

/* v8 savings, compact overview and settings groups */
.overview-compact{gap:6px}
.overview-compact .battery-card{padding:10px}
.overview-compact .battery-head{align-items:center}
.overview-compact .value-xl{font-size:36px}
.overview-compact .value-lg{font-size:22px}
.overview-compact .battery-meter{height:7px;margin:8px 0}
.overview-compact .metric-row{padding-top:8px;gap:5px}
.overview-compact .metric-row small{font-size:9px}.overview-compact .metric-row strong{font-size:11px}
.overview-compact .grid-2{gap:6px}
.overview-compact .mini-card{padding:9px 10px;min-height:68px;display:flex;flex-direction:column;justify-content:center}
.overview-compact .mini-card .label{font-size:10px;margin-bottom:4px}
.overview-compact .phase-list{font-size:10px;margin-top:4px}
.overview-compact .insight-strip>div{padding:9px 10px}.overview-compact .insight-strip-single p{font-size:13px;margin-top:5px}
@media (max-width:420px){.overview-compact .value-xl{font-size:33px}.overview-compact .value-lg{font-size:20px}.overview-compact .mini-card{min-height:62px}.overview-compact .battery-card .muted{font-size:12px}.overview-compact .metric-row{grid-template-columns:repeat(4,1fr)}}

.savings-filter-row{grid-template-columns:1fr;justify-items:center;gap:10px}
.date-field-wrap{width:min(100%,220px)}
.date-input{text-align:center;min-height:42px;padding:0 10px;font-size:16px}
.savings-filter-row .segmented{width:100%;max-width:420px}
.svg-label,.svg-unit{font-size:18px;font-weight:650}.svg-unit{font-size:17px}.chart-card{padding:14px}.chart-legend{font-size:14px;gap:12px}.savings-svg{min-height:190px}
@media (max-width:420px){.svg-label,.svg-unit{font-size:20px}.chart-card{padding:12px}.kpi{min-height:106px;padding:12px}.kpi-grid{gap:8px}.date-field-wrap{width:min(100%,190px)}}

.settings-root h1{margin:2px 0 2px}.settings-group-row strong{font-size:18px}.settings-group-row{min-height:78px}.settings-detail-head{position:sticky;top:0;z-index:6;background:var(--bg);padding:4px 0 8px;margin-bottom:0}.settings-detail .small-copy{font-size:12px}.field-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.textarea{min-height:150px;padding:12px 14px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;line-height:1.35;resize:vertical}.check-card{border:1px solid var(--border);border-radius:14px;background:var(--surface);padding:14px;display:flex;gap:10px;align-items:center;color:var(--text)}.integration-list{display:grid;gap:8px}.integration-card{width:100%;border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:16px;padding:12px;display:grid;grid-template-columns:1fr auto 20px;gap:10px;align-items:center;text-align:left}.integration-card small{display:block;color:var(--muted);margin-top:3px}.integration-steps{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}.planning-grid-wrap{overflow:auto;border:1px solid var(--border);border-radius:16px;background:var(--surface);max-height:360px}.planning-grid{display:grid;grid-template-columns:54px repeat(var(--hours),38px);min-width:max-content}.planning-corner,.planning-hour,.planning-day{position:sticky;background:var(--surface);z-index:2;color:var(--muted);border-right:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);display:grid;place-items:center;min-height:34px;font-size:12px}.planning-corner{left:0;z-index:4}.planning-day{left:0;z-index:3;color:var(--text);font-weight:700}.planning-hour{top:0}.planning-cell{height:34px;border:0;border-right:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);background:var(--surface-2);color:var(--text);font-size:11px}.planning-cell.is-selected{outline:2px solid var(--accent);outline-offset:-2px;background:#0c2629}.planning-cell.has-value{background:#0f766e;color:#fff}.planning-actions{display:grid;gap:8px}.planning-actions .batch-options{display:flex;gap:8px;overflow:auto}.planning-actions .batch-option.is-active{border-color:var(--accent);color:var(--accent)}
@media (max-width:420px){.field-grid-2,.option-grid{grid-template-columns:1fr}.integration-card{grid-template-columns:1fr 20px}.integration-steps{grid-column:1/-1;justify-content:flex-start}.planning-grid{grid-template-columns:48px repeat(var(--hours),34px)}}

/* v9 settings cleanup */
.settings-detail-head{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;position:sticky;top:0;z-index:6;background:var(--bg);padding:6px 0 10px;margin-bottom:2px}
.settings-detail-head strong{font-size:20px}.settings-detail-head button{text-align:left;padding:0;color:var(--accent)}
.form-status{min-height:20px;color:var(--accent);font-size:13px;text-align:center;margin-top:2px}.settings-card h2{margin-top:0}.settings-card .row{align-items:center}.settings-card .switch{flex:0 0 auto}
.steps-list{display:grid;gap:10px}.step-row{display:grid;grid-template-columns:1fr .9fr .9fr auto 38px;gap:8px;align-items:end;padding:10px;border:1px solid var(--border-soft);border-radius:16px;background:var(--surface-2)}.step-row .field{gap:4px}.step-preview{min-height:48px;min-width:72px;border-radius:14px;display:grid;place-items:center;padding:0 10px;font-weight:700;border:1px solid var(--border);white-space:nowrap}.icon-btn{border:1px solid var(--border);background:var(--surface);color:var(--muted);border-radius:12px;min-height:48px;font-size:24px}.step-pill{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;border:1px solid var(--border);font-size:12px;font-weight:700;white-space:nowrap}.step-color-green-select,.step-color-greenDark-select{background:#0f3a33!important;border-color:#1aa694!important;color:#4be6d3!important}.step-color-blue-select,.step-color-blueDark-select{background:#102a48!important;border-color:#2d75bd!important;color:#66bdff!important}.step-color-yellow-select,.step-color-yellowDark-select{background:#4c3b14!important;border-color:#9c7a2a!important;color:#ffd166!important}.step-color-orange-select{background:#613714!important;border-color:#b86b25!important;color:#ffb66e!important}.step-color-red-select{background:#461b20!important;border-color:#a9444d!important;color:#ff9298!important}.step-color-darkGrey-select{background:#202938!important;border-color:#37465f!important;color:#cbd5e1!important}.step-color-purple-select{background:#2c1d46!important;border-color:#7047aa!important;color:#d4b9ff!important}
.integration-editor .field-grid-2{align-items:end}.integration-editor h2{font-size:22px}.integration-editor .settings-card{padding:16px}.integration-card .step-pill{margin:1px}
@media (max-width:640px){.step-row{grid-template-columns:1fr 1fr}.step-row .field:nth-child(3){grid-column:1/2}.step-preview{grid-column:2/3}.step-remove{grid-column:1/-1}.settings-detail-head strong{font-size:18px}}
@media (max-width:420px){.settings-detail-head{grid-template-columns:1fr auto 1fr}.settings-detail-head strong{font-size:17px}.settings-card{padding:14px}.step-row{grid-template-columns:1fr}.step-preview{grid-column:auto;min-height:42px}.step-remove{grid-column:auto}}

/* v10 integration settings fixes */
select.input,
.select-control{
  -webkit-appearance:none;
  appearance:none;
  background-color:var(--surface);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%239aa8bd' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  background-size:18px 18px;
  padding-right:44px;
}
.fixed-steps-preview{display:flex;gap:8px;flex-wrap:wrap}
.step-pill-large{border-radius:14px;min-height:48px;padding:6px 14px;display:inline-flex;flex-direction:column;justify-content:center;align-items:center;gap:2px;font-size:18px;min-width:72px}
.step-pill-large small{font-size:11px;opacity:.68;text-transform:none;font-weight:600}
.integration-editor .field-grid-2{gap:12px}
.integration-editor .field label{font-size:13px}
.integration-editor select.input{min-height:54px;border-radius:14px;font-size:18px}
.integration-editor .steps-list .step-row select.input{font-size:15px;min-height:44px;border-radius:12px}

/* v16: Profile/settings feedback modal */
.form-status.is-error{color:#ff8a8a}
.form-status.is-ok{color:var(--accent)}
.app-dialog-backdrop{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.58);display:flex;align-items:center;justify-content:center;padding:22px;backdrop-filter:blur(6px)}
.app-dialog{width:min(420px,100%);background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:22px;box-shadow:0 20px 80px rgba(0,0,0,.45);display:grid;gap:14px;text-align:left}
.app-dialog.is-error{border-color:rgba(255,90,90,.72)}
.app-dialog.is-ok{border-color:rgba(45,212,191,.72)}
.app-dialog h3{margin:0;font-size:22px;line-height:1.15}
.app-dialog p{margin:0;color:var(--muted);font-size:16px;line-height:1.35}
.app-dialog .btn{margin-top:4px;width:100%}

/* v18 planning settings */
.planning-settings .planning-grid-wrap{max-height:430px}.planning-settings .planning-cell{min-width:38px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700;border:1px solid transparent}.planning-settings .planning-cell.has-value{color:var(--text)}.planning-settings .planning-cell.is-dirty{box-shadow:inset 0 0 0 1px var(--accent)}.planning-settings .planning-cell.is-selected{outline:2px solid var(--accent);outline-offset:-2px}.planning-settings .batch-option[data-plan-step="__clear__"]{border-style:dashed;color:var(--muted)}

/* v19: make empty fixed-planning cells visible without looking like a broken blank grid */
.planning-settings .planning-cell.is-empty{
  color:var(--muted);
  background:rgba(12,20,34,.72);
  border-color:var(--border-soft);
  font-weight:600;
}
.planning-settings .planning-cell.is-empty:hover,
.planning-settings .planning-cell.is-empty.is-selected{
  color:var(--text);
}


/* v23: keep Planning action chips inside the card on narrow screens */
.planning-settings .planning-actions{min-width:0;overflow:hidden;}
.planning-settings .planning-actions .batch-options{max-width:100%;min-width:0;overflow-x:auto;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;padding:2px 0 8px;scrollbar-width:none;}
.planning-settings .planning-actions .batch-options::-webkit-scrollbar{display:none;}
.planning-settings .planning-actions .batch-option{flex:0 0 auto;min-width:58px;max-width:92px;min-height:42px;padding:6px 10px;white-space:normal;line-height:1.05;overflow:hidden;text-overflow:ellipsis;}
.planning-settings .planning-actions .batch-option[data-plan-step="__clear__"]{min-width:56px;}
@media (max-width:420px){
  .planning-settings .planning-actions .batch-option{max-width:82px;min-width:54px;font-size:14px;padding:6px 8px;}
}


/* v45: keep Plan > Batteri columns aligned on phone widths. */
.battery-schedule-list .battery-line{
  grid-template-columns:58px minmax(86px,1fr) minmax(76px,1fr) 124px;
  gap:8px;
}
.battery-schedule-list .battery-line .battery-measure{
  min-width:0;
}
.battery-schedule-list .battery-line .battery-setting{
  justify-self:end;
  width:124px;
  text-align:left;
}
.battery-schedule-list .battery-line .battery-setting .chip{
  min-width:112px;
  justify-content:center;
  white-space:nowrap;
}
@media (max-width:420px){
  .battery-schedule-list .battery-line{
    grid-template-columns:54px minmax(74px,1fr) minmax(64px,1fr) 118px;
    gap:6px;
    padding-left:12px;
    padding-right:10px;
  }
  .battery-schedule-list .battery-line .battery-setting{
    width:118px;
  }
  .battery-schedule-list .battery-line .battery-setting .chip{
    min-width:106px;
    font-size:11px;
  }
}

/* v73: forecast price rows */
.forecast-badge{display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(45,212,191,.55);background:rgba(45,212,191,.12);color:var(--accent);border-radius:999px;padding:2px 7px;font-size:11px;font-weight:800;letter-spacing:.02em;white-space:nowrap}.price-line.is-forecast{background:linear-gradient(90deg,rgba(45,212,191,.055),transparent 42%)}.price-line.is-forecast>strong::after{content:'Prognose';display:block;margin-top:3px;color:var(--accent);font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.price-tags{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.slot.is-forecast{box-shadow:inset 0 0 0 1px rgba(45,212,191,.18)}.slot .forecast-badge{margin-top:2px}

/* v74: price chart at the top of the price view */
.price-chart-card{padding:14px 14px 10px;overflow:hidden}.price-chart-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}.price-chart-head strong{display:block;font-size:17px}.price-chart-head small{display:block;color:var(--muted);font-size:12px;margin-top:2px}.price-chart-legend{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;color:var(--muted);font-size:12px}.price-chart-legend span{display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.price-chart-legend span::before{content:"";width:9px;height:9px;border-radius:999px;background:currentColor}.price-chart-legend .buy{color:var(--accent)}.price-chart-legend .sell{color:#ffd166}.price-chart-legend .forecast{color:#a8b3c7}.price-chart{display:block;width:100%;height:180px}.price-chart .forecast-zone{fill:rgba(45,212,191,.08)}.price-chart .grid{stroke:rgba(148,163,184,.18);stroke-width:1}.price-chart .axis-line{stroke:rgba(148,163,184,.2);stroke-width:1}.price-chart .axis{fill:var(--muted);font-size:10px;font-weight:700}.price-chart .line{fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.price-chart .line.buy{stroke:var(--accent)}.price-chart .line.sell{stroke:#ffd166}.price-chart circle{stroke:var(--surface);stroke-width:1.5;vector-effect:non-scaling-stroke}.price-chart circle.buy{fill:var(--accent)}.price-chart circle.sell{fill:#ffd166}@media (max-width:420px){.price-chart-head{flex-direction:column}.price-chart-legend{justify-content:flex-start}.price-chart{height:160px}}

/* v82: clearer price graph horizon and forecast marker */
.price-chart-card{padding:14px 14px 10px;overflow:hidden}
.price-chart-head{align-items:flex-start}
.price-chart-head strong{font-size:16px;line-height:1.15}
.price-chart-head small{max-width:230px;line-height:1.25}
.price-chart{height:190px}
.price-chart .forecast-zone{fill:rgba(148,163,184,.10)}
.price-chart .forecast-line{stroke:rgba(168,179,199,.45);stroke-width:1;stroke-dasharray:3 3;vector-effect:non-scaling-stroke}
.price-chart .forecast-label{fill:#a8b3c7;font-size:9px;font-weight:800;letter-spacing:.03em}
.price-chart .line{stroke-width:2.5}
.price-chart circle{stroke-width:1.25}
@media (max-width:420px){
  .price-chart-head{gap:8px}
  .price-chart-head small{max-width:none;font-size:11px}
  .price-chart{height:180px}
  .price-chart .axis.x{font-size:9px}
  .price-chart .forecast-label{font-size:8px}
}

/* v88: robust forecast marker in timeline matrix */
.schedule-forecast-note{
  display:flex;
  align-items:center;
  gap:8px;
  width:100%;
  box-sizing:border-box;
  padding:9px 12px;
  margin:0;
  border:1px solid rgba(45,212,191,.22);
  background:rgba(45,212,191,.08);
  color:var(--muted);
  border-radius:16px;
  font-size:12px;
  line-height:1.25;
  overflow:hidden;
}
.schedule-forecast-note .forecast-chip{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(45,212,191,.55);
  background:rgba(45,212,191,.12);
  color:var(--accent);
  border-radius:999px;
  padding:2px 8px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.02em;
  white-space:nowrap;
}
.schedule-forecast-note span:last-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mhead-hour.is-forecast{background:rgba(148,163,184,.07);border-radius:10px;color:#d8dee9}
.mcell.is-forecast{
  background-image:linear-gradient(135deg,rgba(148,163,184,.10),rgba(45,212,191,.035));
  box-shadow:inset 0 0 0 1px rgba(148,163,184,.20);
}
.mcell.is-forecast::before,.mcell.is-forecast::after{content:none!important;display:none!important}
@media (max-width:420px){
  .schedule-forecast-note{font-size:11px;padding:8px 10px;border-radius:14px}
  .schedule-forecast-note span:last-child{white-space:normal;overflow:visible;text-overflow:clip}
}
