.asb-root{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:#0f172a}
.asb-shell{display:flex;flex-direction:column;gap:18px}
.asb-topbar{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;padding:22px;border:1px solid #d7dde5;border-radius:22px;background:linear-gradient(180deg,#fff,#f8fafc)}
.asb-kicker{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#0e766e;margin-bottom:6px}
.asb-title{margin:0 0 6px 0;font-size:28px;line-height:1.1;color:#0e766e}
.asb-muted{color:#475569;font-size:14px;line-height:1.5}
.asb-actions{display:flex;gap:10px;flex-wrap:wrap}
.asb-main{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(320px,.95fr);gap:18px;align-items:start}
.asb-left{display:flex;flex-direction:column;gap:16px}
.asb-side{display:flex;flex-direction:column;gap:16px;position:sticky;top:20px}
.asb-banner,.asb-card,.asb-side-card{padding:18px;border:1px solid #d7dde5;border-radius:22px;background:#fff;box-shadow:0 6px 20px rgba(15,23,42,.05)}
.asb-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:14px}
.asb-card-title{font-size:20px;font-weight:700;color:#0e766e}
.asb-banner-note{margin-top:10px;padding:10px 12px;border-radius:14px;background:#f8fafc;color:#334155;font-size:13px}
.asb-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}
.asb-fields-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.asb-fields-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.asb-field,.asb-stepper-wrap{display:flex;flex-direction:column;gap:6px}
.asb-label{font-size:12px;color:#64748b;font-weight:600}
.asb-root input,.asb-root select{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:12px;background:#fff;min-height:42px}
.asb-area-grid-wrap{padding:12px;border:1px solid #e2e8f0;border-radius:16px;background:#f8fafc;overflow:auto}.asb-area-grid-wrap.is-large{padding:18px;min-height:360px;display:flex;align-items:center;justify-content:center}.asb-area-grid{display:flex;flex-direction:column;gap:8px;align-items:flex-start;justify-content:flex-start;min-width:max-content}.asb-area-grid-row-wrap{display:flex;align-items:center;gap:12px}.asb-area-grid-row{display:flex;gap:4px;align-items:center}.asb-area-grid-wrap.is-large .asb-area-grid{align-items:center}.asb-area-grid-wrap.is-large .asb-area-grid-row-wrap{justify-content:center}.asb-area-grid-wrap.is-large .asb-area-grid-row{will-change:transform}
.asb-panel{box-sizing:border-box;border:1px solid #cbd5e1;border-radius:4px;background:#e2e8f0}
.asb-panel.portrait{width:28px;height:56px}
.asb-panel.landscape{width:56px;height:28px}
.asb-stepper{display:flex;align-items:center;gap:8px}
.asb-stepper .button{min-width:40px;display:flex;justify-content:center;align-items:center}
.asb-stepper-value{min-width:56px;text-align:center;font-weight:700}
.asb-note-box{padding:10px 12px;border-radius:14px;background:#f8fafc;border:1px solid #e2e8f0;display:flex;flex-direction:column;justify-content:center}
.asb-note-k{font-size:12px;color:#64748b;margin-bottom:4px}
.asb-side-title{font-size:18px;font-weight:700;margin-bottom:14px;color:#0e766e}
.asb-metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.asb-metric{padding:12px;border:1px solid #e2e8f0;border-radius:16px;background:#f8fafc}
.asb-metric-label{font-size:12px;color:#64748b;margin-bottom:6px}
.asb-metric-value{font-size:22px;font-weight:700;line-height:1.1}
.asb-gauge-wrap{margin-top:14px;padding:14px;border-radius:16px;background:#f8fafc;border:1px solid #e2e8f0}
.asb-gauge-label{font-weight:600;margin-bottom:10px}
.asb-gauge{position:relative;height:12px;border-radius:999px;background:#dbe2ea;overflow:hidden}
.asb-gauge-good{position:absolute;left:25%;width:35%;top:0;bottom:0;background:#86efac}
.asb-gauge-marker{position:absolute;top:50%;width:3px;height:22px;background:#0f172a;border-radius:999px;transform:translate(-50%,-50%)}
.asb-gauge-ticks{display:flex;justify-content:space-between;font-size:11px;color:#64748b;margin-top:8px}
.asb-summary-list{display:flex;flex-direction:column;gap:8px}
.asb-sum-line{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border-bottom:1px solid #eef2f7}
.asb-sum-line.strong{font-weight:700;font-size:16px}
.asb-table{width:100%;border-collapse:collapse}
.asb-table th,.asb-table td{padding:8px 6px;border-bottom:1px solid #eef2f7;text-align:left;font-size:13px;vertical-align:top}
.asb-error{padding:14px 16px;border-radius:16px;border:1px solid #fecaca;background:#fff1f2;color:#9f1239}
@media (max-width: 1100px){
  .asb-main{grid-template-columns:1fr}
  .asb-side{position:static}
}
@media (max-width: 860px){
  .asb-topbar{flex-direction:column}
  .asb-fields-4,.asb-fields-2,.asb-fields,.asb-metric-grid{grid-template-columns:1fr}
  .asb-title{font-size:24px}
}

.asb-mini-title{margin:14px 0 8px;font-size:13px;font-weight:700;color:#0e766e}
.asb-profit-card{margin-top:12px;padding:12px;border:1px solid #e2e8f0;border-radius:16px;background:#f8fafc}
.asb-profit-card-title{font-weight:700;margin-bottom:10px;color:#0e766e}
.asb-profit-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
@media (max-width: 860px){.asb-profit-card-grid{grid-template-columns:1fr}}

.asb-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.45);display:flex;align-items:center;justify-content:center;padding:24px;z-index:9999}
.asb-modal{background:#fff;border-radius:18px;box-shadow:0 20px 60px rgba(15,23,42,.25);width:min(1100px,100%);max-height:90vh;display:flex;flex-direction:column;overflow:hidden}
.asb-modal-head,.asb-modal-actions{padding:16px 20px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;gap:12px}
.asb-modal-actions{border-top:1px solid #e5e7eb;border-bottom:0;justify-content:flex-end}
.asb-modal-body{padding:20px;overflow:auto;display:grid;gap:16px;background:#f8fafc}

.asb-consumption-modal{width:min(920px,100%)}
.asb-profile-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.asb-consumption-section-title{margin:8px 0 10px;font-size:15px}
.asb-slider-row{display:grid;grid-template-columns:90px 1fr 74px;gap:8px;align-items:center;margin:6px 0}
.asb-slider-label{font-size:14px;color:#0f172a}.asb-slider-range{width:100%}.asb-slider-value{text-align:right}.asb-slider-sum{font-size:12px;margin:6px 0 10px;color:#334155}
@media (max-width:700px){.asb-slider-row{grid-template-columns:80px 1fr 68px}}

.asb-overview-modal{width:min(1240px,100%)}
.asb-overview-table td{white-space:pre-wrap}
.asb-overview-strong{font-weight:700;color:#0f172a}

.asb-inline-warning{margin-top:4px;font-size:12px;color:#b91c1c;font-weight:600}
.asb-root input.asb-input-warning{border-color:#dc2626;background:#fff5f5;box-shadow:0 0 0 1px rgba(220,38,38,.08)}
.asb-az-preview{margin-top:12px;padding:14px 16px;border:1px solid #d7dde5;border-radius:16px;background:#fff}
.asb-az-preview.is-missing{border-color:#fecaca;background:#fff5f5}
.asb-az-preview-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:10px}
.asb-az-preview-value{font-size:13px;font-weight:700;color:#0f172a}
.asb-az-preview-stage{position:relative;height:170px;border-radius:16px;background:linear-gradient(180deg,#f8fafc,#eef2f7);border:1px solid #e2e8f0;overflow:hidden}
.asb-az-preview-ring{position:absolute;left:50%;top:50%;width:104px;height:104px;border:2px dashed #cbd5e1;border-radius:999px;transform:translate(-50%,-50%)}
.asb-az-preview-arrow-wrap{position:absolute;left:50%;top:50%;width:1px;height:1px;transform-origin:center center;z-index:4}
.asb-az-preview-arrow-line{position:absolute;left:50%;top:-42px;width:3px;height:42px;border-radius:999px;background:#dc2626;box-shadow:0 0 0 1px rgba(127,29,29,.08);transform:translateX(-50%)}
.asb-az-preview-arrow-head{position:absolute;left:50%;top:-55px;transform:translateX(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:14px solid #dc2626;filter:drop-shadow(0 1px 0 rgba(127,29,29,.15))}
.asb-az-preview-panel-wrap{position:absolute;left:50%;top:50%;width:1px;height:1px;transform-origin:center center;z-index:3}
.asb-az-preview-shadow{position:absolute;left:50%;top:50%;width:84px;height:30px;border-radius:999px;background:rgba(15,23,42,.12);filter:blur(5px)}
.asb-az-preview-panel{position:absolute;left:50%;top:50%;border-radius:10px;border:2px solid #0f172a;background:linear-gradient(180deg,rgba(255,255,255,.45),rgba(148,163,184,.18)),linear-gradient(135deg,#dbeafe,#e2e8f0);box-shadow:0 10px 18px rgba(15,23,42,.12);transform-origin:center center;overflow:hidden}
.asb-az-preview-panel.portrait{width:34px;height:74px}
.asb-az-preview-panel.landscape{width:74px;height:34px}
.asb-az-preview-panel-grid{position:absolute;inset:5px;border-radius:6px;background:repeating-linear-gradient(90deg,rgba(15,23,42,.08) 0 1px, transparent 1px 10px),repeating-linear-gradient(180deg,rgba(15,23,42,.08) 0 1px, transparent 1px 10px)}
.asb-az-preview-panel-front{position:absolute;left:8%;right:8%;bottom:4px;height:7px;border-radius:999px;background:#ef4444;box-shadow:0 0 0 1px rgba(127,29,29,.10)}
.asb-az-preview-panel-arrow{position:absolute;left:50%;top:8px;width:2px;height:16px;background:#0f172a;transform:translateX(-50%)}
.asb-az-preview-panel-arrow:after{content:'';position:absolute;left:50%;top:-2px;transform:translateX(-50%);border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:8px solid #0f172a}
.asb-az-preview-north,.asb-az-preview-east,.asb-az-preview-south,.asb-az-preview-west{position:absolute;font-size:12px;font-weight:700;color:#64748b}
.asb-az-preview-north{left:50%;top:10px;transform:translateX(-50%)}
.asb-az-preview-south{left:50%;bottom:10px;transform:translateX(-50%)}
.asb-az-preview-east{right:12px;top:50%;transform:translateY(-50%)}
.asb-az-preview-west{left:12px;top:50%;transform:translateY(-50%)}


.asb-cta-orange{position:relative;display:inline-flex !important;align-items:center;justify-content:center;gap:12px;width:80%;max-width:420px;min-width:0;padding:14px 62px 14px 26px !important;border:1px solid #edc18c !important;border-radius:999px !important;background:#f7ddb8 !important;color:#b96a1a !important;font-size:16px !important;line-height:1.2 !important;font-weight:800 !important;letter-spacing:.01em;text-align:center;cursor:pointer;box-shadow:none !important;text-shadow:none !important;margin:0 auto;transition:background .15s ease,border-color .15s ease,color .15s ease}
.asb-cta-orange:hover:not(:disabled),.asb-cta-orange:focus:not(:disabled){color:#a75e15;border-color:#e2b67d;background:#fae5c7;outline:none}
.asb-cta-orange:after{content:'';position:absolute;right:14px;top:50%;width:38px;height:38px;transform:translateY(-50%);border-radius:50%;background:#f3e1c9;border:1px solid #e3c49a;box-shadow:none}
.asb-cta-orange:before{content:'';position:absolute;right:27px;top:50%;width:0;height:0;transform:translateY(-50%);border-top:9px solid transparent;border-bottom:9px solid transparent;border-left:12px solid #bf6d17;z-index:1}
.asb-cta-orange:disabled{opacity:1;cursor:not-allowed;color:#b96a1a !important;background:#f4e3c6 !important;border-color:#e7cda8 !important}
.asb-cta-orange-secondary{margin-top:2px;background:#f7ddb8}
.asb-side-card .asb-cta-orange + .asb-muted{margin-top:8px;text-align:center}
.asb-profit-action{margin:10px 0;display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.asb-profit-action .asb-cta-orange{align-self:center}
.asb-profit-status{font-size:13px;color:#4b5563;text-align:left}
.asb-profit-divider{margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.asb-profit-divider .asb-cta-orange{align-self:center}
.asb-profit-note{font-size:13px;color:#4b5563;text-align:left;line-height:1.4}
.asb-side-card .asb-side-title + .asb-muted{line-height:1.4}


.asb-panel{display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;position:relative}
.asb-panel.is-removed{background:#fff7ed;border-style:dashed;border-color:#f59e0b;opacity:.55}
.asb-panel-index{font-size:10px;font-weight:700;color:#64748b;pointer-events:none}
.asb-layout-summary{margin-top:14px;padding:12px;border:1px solid #e2e8f0;border-radius:16px;background:#fff}
.asb-layout-summary-stats{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 10px}
.asb-layout-pill{padding:6px 10px;border-radius:999px;background:#f8fafc;border:1px solid #e2e8f0;font-size:12px;font-weight:600;color:#334155}
.asb-layout-table th,.asb-layout-table td{font-size:12px}

.asb-layout-inline-actions{margin-top:12px;display:flex;justify-content:flex-start}
.asb-layout-editor-modal{width:min(1320px,100%)}
.asb-layout-editor-body{grid-template-columns:minmax(0,1.5fr) minmax(300px,.9fr);align-items:start}
.asb-layout-editor-grid{min-width:0}
.asb-layout-editor-side{display:flex;flex-direction:column;gap:14px}
.asb-layout-editor-rows{display:flex;flex-direction:column;gap:10px}
.asb-layout-editor-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid #e2e8f0;border-radius:14px;background:#fff}
.asb-layout-editor-row-title{font-size:13px;font-weight:700;color:#0f172a}
.asb-layout-editor-row-controls{display:flex;align-items:center;gap:8px}
.asb-layout-editor-row-controls .button{min-width:42px}
.asb-panel.is-large.portrait{width:36px;height:72px}
.asb-panel.is-large.landscape{width:72px;height:36px}
.asb-panel:disabled{cursor:default;opacity:1}
@media (max-width: 980px){.asb-layout-editor-body{grid-template-columns:1fr}}

.asb-layout-editor-modal{width:min(96vw,1600px);max-height:94vh}
.asb-layout-editor-body{grid-template-columns:minmax(0,1.8fr) minmax(360px,.9fr)}
.asb-area-visual-grid.is-large{display:flex;flex-direction:column;align-items:center;gap:12px;min-height:420px;padding:20px 10px}
.asb-area-row-wrap{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%}
.asb-area-row-line{display:flex;gap:4px;transition:transform .15s ease}
.asb-area-row-offset-label{font-size:12px;color:#64748b;font-weight:600}
.asb-layout-editor-settings{padding:12px;border:1px solid #e2e8f0;border-radius:16px;background:#fff}


.asb-panel.is-large.is-discretion{background:#fde68a;border-color:#f59e0b}
.asb-panel.is-large.is-overflow{background:#fca5a5;border-color:#dc2626}
.asb-area-row-fit-label{min-width:170px;text-align:left;font-size:12px;font-weight:700;margin-left:12px}
.asb-area-row-fit-label.is-ok{color:#0f766e}
.asb-area-row-fit-label.is-discretion{color:#b45309}
.asb-area-row-fit-label.is-overflow{color:#b91c1c}
.asb-layout-editor-row-controls{justify-content:flex-start}
.asb-layout-editor-row-controls .button{min-width:48px}

.asb-roof-canvas{position:relative;overflow:visible;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-radius:12px}.asb-roof-svg{position:absolute;inset:0;overflow:visible}.asb-roof-outline{fill:rgba(148,163,184,.06);stroke:#94a3b8;stroke-width:2}.asb-roof-usable{fill:rgba(251,191,36,.08);stroke:#f59e0b;stroke-dasharray:6 4;stroke-width:2}.asb-area-grid-wrap.is-large{overflow:auto}.asb-roof-canvas .asb-panel{box-shadow:none}.asb-roof-canvas .asb-panel.is-large.is-ok{background:#cbd5e1;border-color:#94a3b8}
.asb-roof-canvas{overflow:hidden}.asb-roof-canvas .asb-panel.is-removed{opacity:.18}.asb-layout-editor-grid{display:flex;justify-content:center;align-items:center}

.asb-layout-editor-row-controls{flex-wrap:wrap;gap:6px}.asb-layout-editor-row-controls .button{min-width:0;padding:6px 10px;font-size:12px;line-height:1.2}.asb-layout-editor-row-title{min-width:58px}.asb-roof-canvas{cursor:default}.asb-roof-canvas .asb-panel{cursor:pointer}


.asb-project-toolbar{display:flex;gap:12px;align-items:end;flex-wrap:wrap;margin:12px 0 18px}
.asb-project-field{display:flex;flex-direction:column;gap:4px;min-width:160px}
.asb-project-field-current{min-width:220px}
.asb-project-current-name{font-weight:700;padding:8px 0;background:transparent;border:none}
.asb-project-id{margin-left:auto;font-size:12px;color:#666;align-self:center}
.asb-project-run{align-self:end;min-width:100px}
.asb-production-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.asb-production-head .button{white-space:nowrap}
@media (max-width: 980px){
  .asb-project-id{margin-left:0;width:100%}
  .asb-production-head{flex-direction:column;align-items:stretch}
}

.asb-roof-canvas .asb-panel{transform:translateZ(0);contain:layout paint;backface-visibility:hidden}
.asb-roof-canvas .asb-panel.is-large{box-shadow:0 0 0 1px rgba(148,163,184,.15)}

.asb-layout-editor-body{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.asb-layout-editor-grid,
.asb-layout-editor-side{
  width:100%;
  max-width:none;
}
.asb-layout-editor-grid{
  order:1;
}
.asb-layout-editor-side{
  order:2;
}
.asb-roof-canvas{
  width:100% !important;
  max-width:100%;
}
.asb-layout-editor-settings{
  width:100%;
}

.asb-modal-body.asb-layout-editor-body{
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  gap:16px !important;
}
.asb-layout-editor-body .asb-layout-editor-grid,
.asb-layout-editor-body .asb-layout-editor-side{
  width:100% !important;
  max-width:none !important;
  min-width:0 !important;
}
.asb-layout-editor-body .asb-layout-editor-grid{order:1 !important;}
.asb-layout-editor-body .asb-layout-editor-side{order:2 !important;}
.asb-layout-editor-body .asb-layout-editor-grid .asb-area-grid-wrap.is-large{
  width:100% !important;
}
.asb-layout-editor-body .asb-roof-canvas{
  display:block !important;
  margin:0 auto !important;
  max-width:100% !important;
}
.asb-layout-editor-modal{
  width:min(96vw,1700px) !important;
  max-height:94vh !important;
}

.asb-layout-editor-body .asb-panel{border-radius:2px}

.asb-layout-editor-body .asb-panel.is-portrait{border-radius:2px}

@media (max-width: 900px){
  .asb-layout-editor-modal{
    width:100vw !important;
    max-width:100vw !important;
    height:100vh !important;
    max-height:100vh !important;
    margin:0 !important;
    border-radius:0 !important;
  }
  .asb-layout-editor-settings .asb-fields{
    grid-template-columns:1fr !important;
  }
  .asb-layout-editor-grid{
    position:sticky;
    top:0;
    background:#fff;
    z-index:2;
  }
}

.asb-layout-editor-modal{ width:min(98vw,1820px) !important; }
.asb-layout-editor-body{ gap:10px !important; }
.asb-layout-editor-side{ max-width:420px; }
.asb-layout-editor-grid{ flex:1 1 auto; }
