.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-fields-5{grid-template-columns:repeat(5,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-5,.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; }


/* 0.3.129: Tag-design reorganization */
.asb-main{
  grid-template-columns:minmax(0, 1fr) minmax(340px, 420px);
  align-items:start;
}
.asb-left{
  min-width:0;
}
.asb-side{
  min-width:0;
}
.asb-az-edit-row{
  display:grid;
  grid-template-columns:minmax(260px, 0.72fr) minmax(180px, 0.28fr);
  gap:12px;
  align-items:stretch;
  margin:12px 0;
}
.asb-az-edit-graphic{
  min-width:0;
}
.asb-az-edit-graphic .asb-az-preview{
  height:100%;
}
.asb-az-edit-fields{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.asb-az-edit-fields .asb-field{
  margin:0;
}
.asb-az-preview{
  padding:10px 12px;
}
.asb-az-preview-stage{
  min-height:190px;
}
.asb-az-preview .asb-muted{
  display:none;
}
.asb-side .asb-card-live-results,
.asb-side .asb-card-system-strategy,
.asb-side .asb-card-consumption-assumptions{
  display:none;
}
@media (max-width: 1100px){
  .asb-main{
    grid-template-columns:1fr;
  }
  .asb-az-edit-row{
    grid-template-columns:1fr;
  }
}


/* 0.3.129: Tagområde lower layout */
.asb-panel-count-row{
  margin-top:12px;
}
.asb-panel-count-row .asb-stepper-wrap{
  min-height:54px;
  align-self:end;
}
.asb-pv-edit-row{
  align-items:end;
  margin-top:12px;
}
.asb-pv-edit-row .asb-layout-inline-actions{
  margin:0;
  display:flex;
  align-items:end;
}
.asb-pv-edit-row .asb-layout-inline-actions .button{
  width:100%;
}


/* 0.3.129: Orientering placed with Azimut/Hældning controls */
.asb-az-edit-fields .asb-field{
  width:100%;
}
.asb-az-edit-fields select,
.asb-az-edit-fields input{
  width:100%;
}
.asb-topbar{
  display:none;
}


/* 0.3.129: Forbrug tab dedicated layout */
.elitag-consumption-title h3{
  margin:0 0 16px;
  font-size:26px;
  color:#5f6b7a;
}
.sdu-shell__panel[data-panel="consumption"] .elitag-consumption-host{
  display:none !important;
}
.sdu-shell__panel[data-panel="consumption"] .elitag-asb-host{
  display:block !important;
}
.sdu-shell__panel[data-panel="consumption"] #asb-shell-wrapper{
  display:block !important;
}
.sdu-shell__panel[data-panel="consumption"] .asb-project-toolbar,
.sdu-shell__panel[data-panel="consumption"] .asb-left,
.sdu-shell__panel[data-panel="consumption"] .asb-card-live-results,
.sdu-shell__panel[data-panel="consumption"] .asb-card-system-strategy,
.sdu-shell__panel[data-panel="consumption"] .asb-card-bom-preview,
.sdu-shell__panel[data-panel="consumption"] .asb-side > .asb-side-card:first-child{
  display:none !important;
}
.sdu-shell__panel[data-panel="consumption"] .asb-main{
  display:block !important;
}
.sdu-shell__panel[data-panel="consumption"] .asb-side{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  width:100%;
  max-width:none;
}
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions,
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-overview,
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-graphs{
  display:block !important;
}
.asb-consumption-graph-block{
  margin-top:12px;
}
.asb-consumption-graph-title{
  font-weight:800;
  color:#334155;
  margin-bottom:8px;
}
.asb-consumption-bar-row{
  display:grid;
  grid-template-columns:130px minmax(90px,1fr) 90px;
  gap:8px;
  align-items:center;
  margin:7px 0;
  font-size:12px;
}
.asb-consumption-bar-track{
  height:10px;
  background:#e5edf3;
  border-radius:999px;
  overflow:hidden;
}
.asb-consumption-bar-fill{
  height:100%;
  background:#6ca0a6;
  border-radius:999px;
}
.asb-consumption-bar-value{
  text-align:right;
  font-weight:700;
  color:#15313a;
}
@media(max-width:900px){
  .sdu-shell__panel[data-panel="consumption"] .asb-side{
    grid-template-columns:1fr;
  }
}


/* 0.3.129: Forbrug cards only belong in Forbrug tab */
.sdu-shell__panel[data-panel="roof"] .asb-card-consumption-overview,
.sdu-shell__panel[data-panel="roof"] .asb-card-consumption-graphs{
  display:none !important;
}
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-overview,
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-graphs{
  display:block !important;
}


/* 0.3.129: Tag-design BOM uses MBR recalculated montage BOM; financial cards are tab-specific */
.asb-financial-only,
.asb-card-financial-overview{
  display:none;
}
.sdu-shell__panel[data-panel="financial"] .asb-financial-only,
.sdu-shell__panel[data-panel="financial"] .asb-card-financial-overview{
  display:block !important;
}
.sdu-shell__panel[data-panel="roof"] .asb-financial-only,
.sdu-shell__panel[data-panel="roof"] .asb-card-financial-overview,
.sdu-shell__panel[data-panel="roof"] .asb-card-consumption-overview,
.sdu-shell__panel[data-panel="roof"] .asb-card-consumption-graphs{
  display:none !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-left,
.sdu-shell__panel[data-panel="financial"] .asb-project-toolbar,
.sdu-shell__panel[data-panel="financial"] .asb-card-live-results,
.sdu-shell__panel[data-panel="financial"] .asb-card-system-strategy,
.sdu-shell__panel[data-panel="financial"] .asb-card-bom-preview{
  display:none !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-main{
  display:block !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-side{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  width:100%;
  max-width:none;
}
.sdu-shell__panel[data-panel="financial"] .asb-side > .asb-side-card:first-child,
.sdu-shell__panel[data-panel="financial"] .asb-card-consumption-assumptions,
.sdu-shell__panel[data-panel="financial"] .asb-card-consumption-overview{
  display:block !important;
}
@media(max-width:900px){
  .sdu-shell__panel[data-panel="financial"] .asb-side{
    grid-template-columns:1fr;
  }
}


/* 0.3.129: panel pricing + sheet JSON inspection */
.asb-json-textarea{
  width:100%;
  min-height:260px;
  font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size:11px;
  line-height:1.35;
  border:1px solid #d6e2e8;
  border-radius:10px;
  padding:10px;
  resize:vertical;
  background:#f8fafc;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-json-debug{
  grid-column:1 / -1;
}



/* 0.3.132: mobile viewport fit improvements */
@media (max-width: 768px){
  html,
  body{
    overflow-x:hidden !important;
  }

  .entry-content,
  .site-content,
  .content-area,
  .wp-site-blocks,
  .elitag-tabs-shell,
  .sdu-shell,
  #mbr-root,
  #asb-shell-wrapper,
  .asb-root,
  .mbr-root{
    max-width:100% !important;
    width:100% !important;
    box-sizing:border-box !important;
  }

  .entry-content > *,
  .site-main > *,
  .elitag-tabs-shell *,
  .sdu-shell *,
  #mbr-root *,
  #asb-shell-wrapper *{
    box-sizing:border-box !important;
  }

  .elitag-tabs-shell,
  .sdu-shell{
    padding:12px !important;
    border-radius:12px !important;
    overflow:hidden !important;
  }

  .sdu-shell__title{
    font-size:30px !important;
    line-height:1.12 !important;
    overflow-wrap:break-word !important;
    word-break:normal !important;
  }

  .sdu-shell__version{
    font-size:14px !important;
    line-height:1.35 !important;
  }

  .sdu-shell__tabs{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px !important;
    width:100% !important;
  }

  .sdu-shell__tab,
  .mbr-actions .button,
  .mbr-actions button,
  .mbr-card-nav-btn,
  #mbr-root .button,
  #mbr-root button,
  .asb-root .button,
  .asb-root button{
    max-width:100% !important;
    white-space:normal !important;
    overflow-wrap:break-word !important;
  }

  .sdu-shell__tab{
    width:100% !important;
    min-height:46px !important;
    padding:10px 14px !important;
    text-align:center !important;
  }

  .mbr-card-grid,
  .mbr-row,
  .mbr-system-grid,
  .mbr-montage-card-flow,
  .mbr-native-system-fields,
  .mbr-native-system-fields-clean,
  .mbr-native-system-strategy .mbr-system-mode-row,
  .mbr-system-strategy-selector .mbr-system-mode-row,
  .asb-main,
  .asb-fields,
  .asb-fields-2,
  .asb-fields-4{
    grid-template-columns:1fr !important;
  }

  .mbr-card,
  .mbr-unified-card,
  .mbr-summary-card,
  .mbr-roof-graphics,
  .mbr-bom-static,
  .mbr-system-material-card,
  .asb-card,
  .asb-side-card,
  .asb-banner,
  .asb-topbar{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    padding:14px !important;
    border-radius:16px !important;
    overflow:hidden !important;
  }

  .mbr-card-title-row{
    align-items:flex-start !important;
    gap:8px !important;
  }

  .mbr-card-title-row h2,
  .mbr-card-title-row h3,
  .mbr-summary-card h3,
  .mbr-bom-drawer-title,
  .asb-title,
  .asb-card-title{
    font-size:clamp(22px, 7vw, 32px) !important;
    line-height:1.15 !important;
    overflow-wrap:break-word !important;
  }

  .mbr-card-nav-btn{
    flex:0 0 auto !important;
    width:auto !important;
    min-width:0 !important;
    padding:8px 10px !important;
    font-size:12px !important;
  }

  .mbr-actions,
  .asb-actions{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px !important;
    width:100% !important;
  }

  .mbr-actions .button,
  .mbr-actions button,
  .asb-actions .button,
  .asb-actions button{
    width:100% !important;
    min-height:46px !important;
  }

  #mbr-root input,
  #mbr-root select,
  #asb-shell-wrapper input,
  #asb-shell-wrapper select,
  .mbr-root input,
  .mbr-root select,
  .asb-root input,
  .asb-root select{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    font-size:16px !important;
  }

  .mbr-roof-graphics .mbr-roof-area-card,
  .mbr-roof-graphics .mbr-roof-card,
  .mbr-roof-graphics .mbr-card{
    width:100% !important;
    max-width:100% !important;
    overflow-x:auto !important;
  }

  .mbr-roof-graphics .mbr-roof-panels-grid,
  .mbr-area-table-wrap,
  .mbr-table-wrap,
  .asb-area-grid-wrap{
    max-width:100% !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch !important;
  }

  .mbr-table{
    min-width:520px;
  }

  .mbr-global-sidebar{
    left:10px !important;
    right:10px !important;
    bottom:10px !important;
    top:auto !important;
    width:auto !important;
    max-width:none !important;
    max-height:46vh !important;
    border-radius:16px !important;
    z-index:9999 !important;
  }

  .mbr-global-sidebar.is-collapsed{
    max-height:72px !important;
  }

  .mbr-global-sidebar-body{
    max-height:calc(46vh - 58px) !important;
    overflow:auto !important;
    -webkit-overflow-scrolling:touch !important;
  }

  .mbr-global-sidebar-title,
  .mbr-bom-drawer-title{
    white-space:normal !important;
    overflow-wrap:break-word !important;
  }

  .mbr-bom-item-top{
    grid-template-columns:minmax(0, 1fr) minmax(54px, auto) auto !important;
    gap:6px !important;
  }

  .mbr-bom-sku-select{
    min-width:0 !important;
  }

  .mbr-system-roof-line{
    grid-template-columns:1fr !important;
  }

  .asb-topbar,
  .asb-card-head{
    flex-direction:column !important;
    align-items:stretch !important;
  }

  .asb-side{
    position:static !important;
  }
}

@media (max-width: 480px){
  .elitag-tabs-shell,
  .sdu-shell{
    padding:10px !important;
    margin-left:0 !important;
    margin-right:0 !important;
  }

  .sdu-shell__title{
    font-size:28px !important;
  }

  .mbr-card,
  .mbr-unified-card,
  .mbr-summary-card,
  .mbr-roof-graphics,
  .mbr-bom-static,
  .asb-card,
  .asb-side-card,
  .asb-banner{
    padding:12px !important;
    border-radius:14px !important;
  }

  .mbr-table{
    min-width:460px;
  }

  .mbr-global-sidebar{
    left:8px !important;
    right:8px !important;
    bottom:8px !important;
    max-height:42vh !important;
  }

  .mbr-global-sidebar-body{
    max-height:calc(42vh - 56px) !important;
  }
}


/* 0.3.136: ASB mobile compact typography */
@media (max-width: 768px){
  .asb-root{
    font-size:14px !important;
    line-height:1.35 !important;
  }

  .asb-card,
  .asb-side-card,
  .asb-banner,
  .asb-topbar{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    padding:10px !important;
    border-radius:12px !important;
  }

  .asb-title{
    font-size:24px !important;
    line-height:1.12 !important;
  }

  .asb-card-title,
  .asb-root h3{
    font-size:18px !important;
    line-height:1.18 !important;
  }

  .asb-root label,
  .asb-root p,
  .asb-root span,
  .asb-root div{
    font-size:13px !important;
    line-height:1.35 !important;
  }

  .asb-root input,
  .asb-root select,
  .asb-root textarea{
    min-height:42px !important;
    padding:8px 10px !important;
    font-size:16px !important;
  }

  .asb-root button,
  .asb-root .button{
    min-height:38px !important;
    padding:8px 10px !important;
    font-size:12px !important;
    line-height:1.15 !important;
  }
}

/* 0.3.138: Android mobile select normalization */
@media (max-width: 768px){
  .sdu-shell select,
  .elitag-tabs-shell select,
  #mbr-root select,
  #asb-shell-wrapper select,
  .mbr-root select,
  .mbr-app select,
  .mbr-native select,
  .asb-root select{
    -webkit-appearance:none !important;
    -moz-appearance:none !important;
    appearance:none !important;
    box-sizing:border-box !important;
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    min-height:46px !important;
    padding:10px 44px 10px 13px !important;
    border:1px solid #cbd5e1 !important;
    border-radius:13px !important;
    background-color:#ffffff !important;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
    background-repeat:no-repeat !important;
    background-position:right 13px center !important;
    background-size:18px 18px !important;
    box-shadow:0 1px 2px rgba(15,23,42,.08), inset 0 1px 0 rgba(255,255,255,.75) !important;
    color:#0f172a !important;
    color-scheme:light !important;
    font-size:16px !important;
    line-height:1.25 !important;
    font-weight:500 !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }
  .sdu-shell select:focus,
  .elitag-tabs-shell select:focus,
  #mbr-root select:focus,
  #asb-shell-wrapper select:focus,
  .mbr-root select:focus,
  .mbr-app select:focus,
  .mbr-native select:focus,
  .asb-root select:focus{
    outline:none !important;
    border-color:#5f9ea6 !important;
    box-shadow:0 0 0 3px rgba(95,158,166,.2), 0 1px 2px rgba(15,23,42,.08) !important;
  }
}


/* 0.3.145: Mobile fixes for Tag-design layout editor modal */
@media (max-width: 768px){
  body:has(.asb-layout-editor-modal){overflow:hidden;}
  .asb-modal-backdrop{
    z-index:2147483000 !important;
    align-items:stretch !important;
    justify-content:stretch !important;
    padding:0 !important;
    background:rgba(15,23,42,.55) !important;
  }
  .asb-layout-editor-modal{
    width:100vw !important;
    max-width:100vw !important;
    height:100dvh !important;
    max-height:100dvh !important;
    min-height:100dvh !important;
    margin:0 !important;
    border-radius:0 !important;
    display:flex !important;
    flex-direction:column !important;
    overflow:hidden !important;
  }
  .asb-layout-editor-modal .asb-modal-head{
    position:sticky !important;
    top:0 !important;
    z-index:10 !important;
    padding:10px 12px !important;
    gap:8px !important;
    background:#fff !important;
    box-shadow:0 1px 0 rgba(15,23,42,.08) !important;
  }
  .asb-layout-editor-modal .asb-modal-head h3,
  .asb-layout-editor-modal .asb-modal-head h2{
    font-size:16px !important;
    line-height:1.2 !important;
    margin:0 !important;
  }
  .asb-layout-editor-modal .asb-modal-body.asb-layout-editor-body{
    flex:1 1 auto !important;
    min-height:0 !important;
    overflow:auto !important;
    -webkit-overflow-scrolling:touch !important;
    padding:10px !important;
    gap:10px !important;
    background:#f8fafc !important;
    display:flex !important;
    flex-direction:column !important;
  }
  .asb-layout-editor-modal .asb-layout-editor-grid{
    position:relative !important;
    top:auto !important;
    z-index:1 !important;
    order:1 !important;
    width:100% !important;
    padding:0 !important;
    background:transparent !important;
  }
  .asb-layout-editor-modal .asb-layout-editor-side{
    order:2 !important;
    width:100% !important;
    max-width:none !important;
    min-width:0 !important;
    gap:10px !important;
  }
  .asb-layout-editor-modal .asb-area-grid-wrap.is-large,
  .asb-layout-editor-modal .asb-roof-canvas{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    overflow:auto !important;
  }
  .asb-layout-editor-modal .asb-area-visual-grid.is-large{
    min-height:260px !important;
    padding:10px 4px !important;
    transform-origin:top center !important;
  }
  .asb-layout-editor-modal .asb-layout-editor-settings,
  .asb-layout-editor-modal .asb-side-card{
    border-radius:14px !important;
    padding:10px !important;
  }
  .asb-layout-editor-modal .asb-fields,
  .asb-layout-editor-modal .asb-fields-2,
  .asb-layout-editor-modal .asb-fields-4,
  .asb-layout-editor-modal .asb-fields-5{
    grid-template-columns:1fr !important;
    gap:8px !important;
  }
  .asb-layout-editor-modal label,
  .asb-layout-editor-modal .asb-muted{font-size:12px !important;line-height:1.35 !important;}
  .asb-layout-editor-modal input,
  .asb-layout-editor-modal select,
  .asb-layout-editor-modal textarea{font-size:16px !important;min-height:42px !important;}
  .asb-layout-editor-modal .asb-layout-editor-row{
    padding:8px !important;
    gap:8px !important;
    align-items:flex-start !important;
    flex-direction:column !important;
  }
  .asb-layout-editor-modal .asb-layout-editor-row-controls{width:100% !important;}
  .asb-layout-editor-modal .asb-layout-editor-row-controls .button{flex:1 1 auto !important;min-height:36px !important;}
  .asb-layout-editor-modal .asb-modal-actions{
    position:sticky !important;
    bottom:0 !important;
    z-index:10 !important;
    padding:10px 12px !important;
    gap:8px !important;
    background:#fff !important;
    box-shadow:0 -1px 0 rgba(15,23,42,.08) !important;
    justify-content:stretch !important;
  }
  .asb-layout-editor-modal .asb-modal-actions .button{flex:1 1 auto !important;min-height:42px !important;font-size:13px !important;}
}

/* 0.3.151: On mobile, Forbrug profile opens inline instead of as a modal popup */
@media (max-width: 768px){
  .sdu-shell__panel[data-panel="consumption"] #asb-shell-wrapper .asb-modal-backdrop{
    position:static !important;
    inset:auto !important;
    display:block !important;
    width:100% !important;
    min-height:0 !important;
    padding:0 !important;
    margin:8px 0 16px !important;
    background:transparent !important;
    z-index:auto !important;
    overflow:visible !important;
  }
  .sdu-shell__panel[data-panel="consumption"] #asb-shell-wrapper .asb-modal.asb-consumption-modal{
    position:relative !important;
    width:100% !important;
    max-width:none !important;
    height:auto !important;
    max-height:none !important;
    margin:0 !important;
    border-radius:16px !important;
    box-shadow:none !important;
    border:1px solid #d9e4ea !important;
    overflow:visible !important;
  }
  .sdu-shell__panel[data-panel="consumption"] #asb-shell-wrapper .asb-consumption-modal .asb-modal-head{
    position:static !important;
    padding:12px 14px !important;
    gap:10px !important;
  }
  .sdu-shell__panel[data-panel="consumption"] #asb-shell-wrapper .asb-consumption-modal .asb-modal-head .button{
    display:none !important;
  }
  .sdu-shell__panel[data-panel="consumption"] #asb-shell-wrapper .asb-consumption-modal .asb-modal-body{
    max-height:none !important;
    overflow:visible !important;
    padding:12px !important;
  }
  .sdu-shell__panel[data-panel="consumption"] #asb-shell-wrapper .asb-consumption-modal .asb-modal-actions{
    position:sticky !important;
    bottom:0 !important;
    padding:10px 12px !important;
    background:rgba(255,255,255,.96) !important;
    border-top:1px solid #d9e4ea !important;
  }
  .sdu-shell__panel[data-panel="consumption"] #asb-shell-wrapper .asb-consumption-modal .asb-modal-actions .button-secondary{
    display:none !important;
  }
  .sdu-shell__panel[data-panel="consumption"] #asb-shell-wrapper .asb-consumption-modal .asb-side-card{
    margin-bottom:12px !important;
  }
}

/* v0.3.151 mobile fixes: layout editor canvas + Forbrug controls */
@media (max-width: 760px){
  .asb-layout-editor-modal{width:100vw!important;max-width:100vw!important;height:100dvh!important;max-height:100dvh!important;margin:0!important;border-radius:0!important;overflow:hidden!important;}
  .asb-layout-editor-modal .asb-modal-head{padding:12px 14px!important;gap:10px!important;align-items:flex-start!important;}
  .asb-layout-editor-modal .asb-modal-head strong{font-size:15px!important;line-height:1.15!important;}
  .asb-layout-editor-modal .asb-muted{font-size:12px!important;line-height:1.25!important;}
  .asb-layout-editor-body{display:block!important;overflow:auto!important;padding:10px 10px 92px!important;}
  .asb-layout-editor-grid{width:100%!important;overflow:auto!important;background:#f8fafc!important;border-radius:14px!important;border:1px solid #dbe4ea!important;}
  .asb-roof-canvas{max-width:100%!important;margin:0 auto!important;}
  .asb-roof-svg{width:100%!important;height:auto!important;display:block!important;}
  .asb-layout-editor-side{width:100%!important;margin-top:12px!important;}
  .asb-modal-actions{position:sticky!important;bottom:0!important;background:#fff!important;padding:10px!important;border-top:1px solid #e5e7eb!important;z-index:4!important;}
  .asb-card-consumption-assumptions .button-secondary{background:#eef6f7!important;color:#1f5960!important;border:1px solid #cfe1e5!important;box-shadow:none!important;text-transform:none!important;letter-spacing:0!important;}
  .asb-card-consumption-assumptions .asb-fields{gap:14px!important;}
  .asb-card-consumption-assumptions .asb-field{background:#fff!important;border:0!important;padding:0!important;box-shadow:none!important;}
  .asb-card-consumption-assumptions select,
  .asb-card-consumption-assumptions input{font-size:16px!important;min-height:50px!important;border-radius:12px!important;}
  .asb-modal-backdrop:has(.asb-consumption-modal){position:fixed!important;inset:0!important;z-index:99998!important;background:rgba(15,23,42,.38)!important;display:flex!important;align-items:flex-end!important;}
  .asb-consumption-modal{width:100vw!important;max-width:100vw!important;max-height:88dvh!important;border-radius:22px 22px 0 0!important;overflow:hidden!important;}
  .asb-consumption-modal .asb-modal-body{max-height:calc(88dvh - 138px)!important;overflow:auto!important;padding:12px!important;}
  .asb-consumption-modal .asb-side-card{padding:14px!important;margin-bottom:12px!important;border-radius:14px!important;}
}

/* v0.3.151: Android mobile Tag-design graphics visibility fix. */
@media (max-width: 760px){
  .asb-layout-editor-modal .asb-layout-editor-grid{display:block !important;min-height:360px !important;overflow:auto !important;-webkit-overflow-scrolling:touch !important;}
  .asb-layout-editor-modal .asb-area-grid-wrap.is-large{display:block !important;width:100% !important;min-height:360px !important;overflow:auto !important;-webkit-overflow-scrolling:touch !important;}
  .asb-layout-editor-modal .asb-roof-canvas{position:relative !important;display:block !important;visibility:visible !important;opacity:1 !important;min-width:320px !important;max-width:none !important;margin:0 auto !important;background:linear-gradient(180deg,#f8fafc,#f1f5f9) !important;}
  .asb-layout-editor-modal .asb-roof-svg{position:absolute !important;inset:0 !important;width:100% !important;height:100% !important;min-height:100% !important;display:block !important;overflow:visible !important;pointer-events:none !important;}
  .asb-layout-editor-modal .asb-roof-canvas .asb-panel{display:flex !important;align-items:center !important;justify-content:center !important;visibility:visible !important;opacity:1;min-width:1px !important;min-height:1px !important;z-index:2 !important;}
  .asb-layout-editor-modal .asb-roof-canvas .asb-panel.is-removed{opacity:.18 !important;}
  .asb-layout-editor-modal .asb-area-row-fit-label{display:none !important;}
}

/* v0.3.151: mobile layout-editor stability + row drag */
.asb-roof-canvas {
  overscroll-behavior: contain;
  touch-action: pan-y;
}
.asb-layout-editor-modal .asb-modal-body,
.asb-layout-editor-body {
  overscroll-behavior: contain;
}
@media (max-width: 760px) {
  .asb-layout-editor-modal {
    height: 100dvh !important;
    max-height: 100dvh !important;
    overflow: hidden !important;
  }
  .asb-layout-editor-modal .asb-modal-body,
  .asb-layout-editor-body {
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 96px !important;
  }
  .asb-layout-editor-grid {
    min-height: auto !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
    -webkit-overflow-scrolling: touch;
  }
  .asb-area-grid-wrap.is-large {
    width: 100% !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
  }
  .asb-area-grid-wrap.is-large .asb-roof-canvas {
    margin: 0 auto !important;
    max-width: none !important;
  }
  .asb-area-row-fit-label {
    font-size: 9px !important;
    white-space: nowrap !important;
  }
}

/* v0.3.152 layout editor polish */
.asb-layout-editor-tools{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 12px;}
.asb-area-row-fit-label{z-index:30;position:absolute;white-space:nowrap;}
.asb-roof-canvas .asb-panel{z-index:10;}


/* v0.3.153 layout editor refinements */
.asb-roof-canvas { position: relative; }
.asb-autofill-canvas-btn {
  position: absolute !important;
  left: 14px;
  bottom: 14px;
  z-index: 300;
  box-shadow: 0 8px 24px rgba(15, 32, 46, 0.18);
}
.asb-area-row-fit-label { z-index: 250 !important; }
@media (max-width: 760px) {
  .asb-autofill-canvas-btn { left: 10px; bottom: 10px; padding: 10px 14px !important; font-size: 12px !important; }
}


/* v0.3.154-r2: keep roof SVG and panel hitboxes in one fixed editor surface.
   The wrapper scrolls on narrow screens instead of scaling only the SVG. */
.asb-layout-editor-modal .asb-area-grid-wrap.is-large{
  overflow:auto !important;
  align-items:flex-start !important;
  justify-content:flex-start !important;
}
.asb-layout-editor-modal .asb-roof-canvas{
  max-width:none !important;
  flex:0 0 auto !important;
}
.asb-layout-editor-modal .asb-roof-svg{
  position:absolute !important;
  inset:0 auto auto 0 !important;
  max-width:none !important;
  height:auto;
}
@media (max-width:760px){
  .asb-layout-editor-modal .asb-area-grid-wrap.is-large{
    -webkit-overflow-scrolling:touch !important;
  }
  .asb-layout-editor-modal .asb-roof-canvas{
    max-width:none !important;
  }
}

/* TAG layout PDF export */
.asb-pdf-export-mode .asb-autofill-canvas-btn,
.asb-pdf-export-mode .asb-area-row-fit-label,
.asb-pdf-export-mode .button,
.asb-pdf-export-mode .asb-layout-editor-side,
.asb-pdf-export-mode .asb-modal-head,
.asb-pdf-export-mode .asb-modal-actions { display: none !important; }
.asb-pdf-export-mode .asb-layout-editor-body,
.asb-pdf-export-mode .asb-layout-editor-grid { display: block !important; width: auto !important; max-width: none !important; overflow: visible !important; }
.asb-pdf-export-mode .asb-roof-canvas { background: #ffffff !important; }


/* v0.3.169 TAG layout polish */
.asb-card-head-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.asb-production-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.asb-area-grid-wrap:not(.is-large){display:flex;justify-content:center;align-items:center;cursor:pointer}
.asb-area-grid-wrap:not(.is-large) .asb-area-grid{align-items:center;margin-left:auto;margin-right:auto}
.asb-area-grid-wrap:not(.is-large) .asb-area-grid-row-wrap{justify-content:center;width:100%}
.asb-area-grid-wrap:not(.is-large) .asb-area-grid-row{justify-content:center}
.asb-area-grid-wrap:not(.is-large) .asb-panel{cursor:pointer}
.asb-pdf-export-mode button,.asb-pdf-export-mode .asb-layout-inline-actions,.asb-pdf-export-mode .asb-card-head-actions{display:none!important}
@media(max-width:760px){.asb-card-head-actions,.asb-production-actions{width:100%;justify-content:stretch}.asb-card-head-actions .button,.asb-production-actions .button{flex:1 1 auto}}


/* v0.3.169 real fixes */
.asb-area-grid .asb-panel.portrait,
.asb-area-grid button.asb-panel.portrait {
  width: 28px !important;
  height: 64px !important;
  min-width: 28px !important;
  min-height: 64px !important;
  aspect-ratio: auto !important;
}

.asb-area-grid .asb-panel.landscape,
.asb-area-grid button.asb-panel.landscape {
  width: 56px !important;
  height: 28px !important;
  min-width: 56px !important;
  min-height: 28px !important;
  aspect-ratio: auto !important;
}

.asb-layout-editor-modal input,
.asb-layout-editor-modal select,
.asb-layout-editor-modal textarea {
  scroll-margin-top: 120px;
}

.asb-pdf-capture-mode .asb-area-grid-wrap,
.asb-pdf-capture-mode .asb-area-grid,
.asb-pdf-capture-mode .asb-panel {
  visibility: visible !important;
  opacity: 1 !important;
}


/* v0.3.169: System G supports portrait default + landscape option. PDF graphics are vector-drawn in JS. */

/* v0.3.169: Roof PDF includes detailed measurements and distances. */

/* v0.3.169 clean project rebuild */
.asb-project-compact,.mbr-project-compact{display:inline-flex!important;align-items:center!important;gap:10px!important;flex-wrap:nowrap!important;margin:0 0 12px auto!important;vertical-align:top!important;float:right!important}
.asb-project-compact-current,.mbr-project-compact-current{display:inline-flex;flex-direction:column;gap:2px;min-width:220px;max-width:min(360px,42vw);padding:7px 12px;border:1px solid #d1dce7;border-radius:10px;background:#fff}
.asb-project-compact-label,.mbr-project-compact-label{font-size:11px;color:#64748b;font-weight:700}.asb-project-compact-current strong,.mbr-project-compact-current strong{font-size:13px;color:#102a43;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asb-project-open-btn,.mbr-project-open-btn{white-space:nowrap!important;min-height:38px!important;line-height:38px!important;padding-top:0!important;padding-bottom:0!important}
.asb-project-manager-modal{width:min(92vw,560px)!important;max-width:560px!important}.asb-project-modal-active,.mbr-project-modal-active{padding:12px;border:1px solid #dbe5ee;border-radius:12px;background:#f8fafc;margin-bottom:12px;display:flex;flex-direction:column;gap:4px}.asb-project-modal-active span,.mbr-project-modal-active span,.asb-project-modal-field span,.mbr-project-modal-field span{color:#64748b;font-size:12px;font-weight:700}.asb-project-modal-field,.mbr-project-modal-field{display:flex;flex-direction:column;gap:6px}.asb-project-modal-select,.mbr-project-modal-select{width:100%}.asb-project-modal-actions,.mbr-project-modal-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px}.asb-project-modal-actions .button,.mbr-project-modal-actions .button{width:100%;text-align:center}.asb-danger,.mbr-danger{background:#f8e9e9!important;color:#9f1d1d!important}.mbr-project-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.35);display:flex;align-items:center;justify-content:center;z-index:9999}.mbr-project-manager-modal{background:#fff;border-radius:16px;padding:20px;width:min(92vw,560px);max-width:560px;box-shadow:0 24px 80px rgba(15,23,42,.22)}.mbr-project-modal-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.mbr-project-modal-body{display:flex;flex-direction:column;gap:12px}@media(max-width:760px){.asb-project-compact,.mbr-project-compact{float:none!important;display:flex!important;width:100%!important;margin-left:0!important}.asb-project-compact-current,.mbr-project-compact-current{flex:1 1 auto;min-width:0;max-width:none}.asb-project-modal-actions,.mbr-project-modal-actions{grid-template-columns:1fr}}


/* v0.3.169 financial/consumption layout admin cleanup */
.asb-json-debug-hidden{
  display:none !important;
}

/* Consumption tab: show overview + monthly consumption chart side-by-side, then consumption overview full width if needed */
.sdu-shell__panel[data-panel="consumption"] .asb-consumption-only,
.elitag-tabs-shell .sdu-shell__panel[data-panel="consumption"] .asb-consumption-only{
  display:block !important;
}
.sdu-shell__panel[data-panel="consumption"] .asb-card-financial-consumption-chart{
  display:block !important;
}

/* Financial tab cleanup: remove consumption graphs and monthly consumption graph */
.sdu-shell__panel[data-panel="financial"] .asb-card-consumption-graphs,
.sdu-shell__panel[data-panel="financial"] .asb-card-financial-consumption-chart{
  display:none !important;
}

/* Financial tab ordering in 2-column grid */
.sdu-shell__panel[data-panel="financial"] .asb-card-area-production{
  order:1;
}
.sdu-shell__panel[data-panel="financial"] .asb-financial-profitability-wrap{
  order:2;
}
.sdu-shell__panel[data-panel="financial"] .asb-financial-investment-wrap{
  order:3;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-sheet-summary{
  order:4;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-json-debug{
  order:50;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-financial-overview{
  order:60;
}

/* Keep admin JSON full width only when visible */
.sdu-shell__panel[data-panel="financial"] .asb-card-json-debug:not(.asb-json-debug-hidden){
  grid-column:1 / -1;
}

@media(min-width:901px){
  .sdu-shell__panel[data-panel="consumption"] .asb-side{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:16px;
  }
  .sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions{
    grid-column:1 / -1;
  }
  .sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-overview{
    order:1;
  }
  .sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-graphs{
    order:2;
  }
  .sdu-shell__panel[data-panel="consumption"] .asb-card-financial-consumption-chart{
    order:3;
  }
}


/* v0.3.169 cleanup and graph suggestions */
.sdu-shell__panel[data-panel="financial"] .asb-card-sheet-summary{
  display:none !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-compact-production{
  align-self:start !important;
  min-height:0 !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-compact-production .asb-table{
  margin-bottom:0 !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-compact-production .asb-table td,
.sdu-shell__panel[data-panel="financial"] .asb-card-compact-production .asb-table th{
  padding-top:6px !important;
  padding-bottom:6px !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-financial-investment-wrap{
  order:2 !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-financial-profitability-wrap{
  order:3 !important;
}

.elitag-graphs-suggestions{
  background:#f8fafc;
  border:1px solid #dbe5ee;
  border-radius:14px;
  padding:14px 16px;
  margin:0 0 16px;
}
.elitag-graphs-suggestions h3,
.elitag-graphs-raw-title{
  margin:0 0 10px;
  color:#0f766e;
}
.elitag-graphs-suggestions ol{
  margin:0 0 0 18px;
  padding:0;
}
.elitag-graphs-suggestions li{
  margin:5px 0;
}
.elitag-graphs-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  margin-bottom:18px;
}
.elitag-graph-card{
  border:1px solid #dbe5ee;
  border-radius:14px;
  padding:14px;
  background:#fff;
}
.elitag-graph-card-title{
  font-weight:800;
  color:#0f766e;
  margin-bottom:4px;
}
.elitag-graph-card-note{
  font-size:12px;
  color:#64748b;
  margin-bottom:12px;
}
.elitag-graph-plot{
  display:flex;
  align-items:end;
  gap:6px;
  height:150px;
  padding:8px 4px 0;
  border-top:1px solid #eef3f7;
}
.elitag-graph-col{
  flex:1 1 0;
  min-width:16px;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
}
.elitag-graph-bars{
  width:100%;
  height:122px;
  display:flex;
  align-items:end;
  justify-content:center;
  gap:2px;
}
.elitag-graph-bar{
  display:block;
  width:100%;
  max-width:12px;
  min-height:3px;
  background:#6aa3aa;
  border-radius:4px 4px 0 0;
  opacity:.85;
}
.elitag-graph-bars .elitag-graph-bar:nth-child(2){background:#f0b45b;}
.elitag-graph-bars .elitag-graph-bar:nth-child(3){background:#94a3b8;}
.elitag-graph-bars .elitag-graph-bar:nth-child(4){background:#0f766e;}
.elitag-graph-col em{
  font-style:normal;
  font-size:10px;
  color:#64748b;
  margin-top:4px;
  transform:rotate(-35deg);
}
.elitag-graph-plot.is-line .elitag-graph-bar{
  border-radius:999px;
  max-width:8px;
}
@media(max-width:900px){
  .elitag-graphs-grid{
    grid-template-columns:1fr;
  }
}


/* v0.3.169 deterministic financial grid */
.sdu-shell__panel[data-panel="financial"] .asb-side{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
  gap:16px !important;
  align-items:start !important;
}

/* Remove old order-based behavior on financial tab */
.sdu-shell__panel[data-panel="financial"] .asb-side > *{
  order:initial !important;
}

/* Row 1 */
.sdu-shell__panel[data-panel="financial"] .asb-card-consumption-assumptions{
  grid-column:1 !important;
  grid-row:1 !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-anlaegsoversigt,
.sdu-shell__panel[data-panel="financial"] .asb-card-consumption-overview{
  grid-column:2 !important;
  grid-row:1 !important;
}

/* Row 2 */
.sdu-shell__panel[data-panel="financial"] .asb-card-area-production{
  grid-column:1 !important;
  grid-row:2 !important;
  align-self:start !important;
  min-height:0 !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-financial-profitability-wrap{
  grid-column:2 !important;
  grid-row:2 !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-profitability{
  height:auto !important;
}

/* Row 3 */
.sdu-shell__panel[data-panel="financial"] .asb-financial-investment-wrap{
  grid-column:1 !important;
  grid-row:3 !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-sheet-summary{
  display:block !important;
  grid-column:2 !important;
  grid-row:3 !important;
}

/* Hide duplicate / obsolete financial mini-card */
.sdu-shell__panel[data-panel="financial"] .asb-card-financial-overview{
  display:none !important;
}

/* Keep JSON admin debug at bottom only when visible */
.sdu-shell__panel[data-panel="financial"] .asb-card-json-debug:not(.asb-json-debug-hidden){
  grid-column:1 / -1 !important;
  grid-row:99 !important;
}

/* Compact production card to content height */
.sdu-shell__panel[data-panel="financial"] .asb-card-compact-production .asb-card-head{
  align-items:flex-start !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-compact-production .asb-table{
  margin-bottom:0 !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-compact-production .asb-table td,
.sdu-shell__panel[data-panel="financial"] .asb-card-compact-production .asb-table th{
  padding-top:6px !important;
  padding-bottom:6px !important;
}

/* On mobile keep natural single column */
@media(max-width:900px){
  .sdu-shell__panel[data-panel="financial"] .asb-side{
    grid-template-columns:1fr !important;
  }
  .sdu-shell__panel[data-panel="financial"] .asb-side > *{
    grid-column:1 !important;
    grid-row:auto !important;
  }
}


/* v0.3.169 layout/graph cleanup */

/* Montage: keep global project control in normal header position, not as a full extra column */
.sdu-shell[data-active-tab="montage"] .sdu-shell__header,
.elitag-tabs-shell[data-active-tab="montage"] .sdu-shell__header{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) auto !important;
  grid-template-areas:
    "title project"
    "guide guide" !important;
  align-items:start !important;
}
.sdu-shell[data-active-tab="montage"] .elitag-shell-project-control,
.elitag-tabs-shell[data-active-tab="montage"] .elitag-shell-project-control{
  grid-area:project !important;
  justify-self:end !important;
  align-self:start !important;
  width:auto !important;
  max-width:360px !important;
  margin-left:12px !important;
}
.sdu-shell[data-active-tab="montage"] .elitag-shell-project-current,
.elitag-tabs-shell[data-active-tab="montage"] .elitag-shell-project-current{
  min-width:210px !important;
  max-width:250px !important;
}

/* Montage tag type pictures: use full card width */
.mbr-roof-type-card img,
.mbr-roof-card img,
.mbr-card img,
[data-roof-type] img{
  width:100% !important;
  max-width:100% !important;
  object-fit:cover !important;
  display:block !important;
}

/* Financial tab: remove wasted grid holes and keep compact content */
.sdu-shell__panel[data-panel="financial"] .asb-side{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
  gap:14px !important;
  align-items:start !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-consumption-assumptions{grid-column:1 !important; grid-row:1 !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-anlaegsoversigt,
.sdu-shell__panel[data-panel="financial"] .asb-card-consumption-overview{grid-column:2 !important; grid-row:1 !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-area-production{grid-column:1 !important; grid-row:2 !important; align-self:start !important;}
.sdu-shell__panel[data-panel="financial"] .asb-financial-profitability-wrap{grid-column:2 !important; grid-row:2 !important;}
.sdu-shell__panel[data-panel="financial"] .asb-financial-investment-wrap{grid-column:1 !important; grid-row:3 !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-sheet-summary{display:none !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-financial-overview{display:none !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-json-debug:not(.asb-json-debug-hidden){grid-column:1 / -1 !important; grid-row:90 !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-compact-production{min-height:0 !important; height:auto !important;}
.sdu-shell__panel[data-panel="financial"] .asb-side-card{align-self:start !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-profitability .asb-muted:empty{
  display:none !important;
}

/* Grafer cleanup */
.elitag-graphs-suggestions,
.elitag-graphs-meta{
  display:none !important;
}
.elitag-graphs-status:empty{
  display:none !important;
}
.elitag-graph-bar{
  position:relative !important;
}
.elitag-graph-value{
  position:absolute;
  left:50%;
  bottom:calc(100% + 2px);
  transform:translateX(-50%) rotate(-45deg);
  transform-origin:center bottom;
  font-size:9px;
  line-height:1;
  font-weight:700;
  color:#334155;
  white-space:nowrap;
  pointer-events:none;
}
.elitag-graph-plot{
  padding-top:26px !important;
}
.elitag-graph-card{
  overflow:visible !important;
}

@media(max-width:900px){
  .sdu-shell__panel[data-panel="financial"] .asb-side{
    grid-template-columns:1fr !important;
  }
  .sdu-shell__panel[data-panel="financial"] .asb-side > *{
    grid-column:1 !important;
    grid-row:auto !important;
  }
  .sdu-shell[data-active-tab="montage"] .sdu-shell__header,
  .elitag-tabs-shell[data-active-tab="montage"] .sdu-shell__header{
    grid-template-columns:1fr !important;
    grid-template-areas:
      "title"
      "project"
      "guide" !important;
  }
  .sdu-shell[data-active-tab="montage"] .elitag-shell-project-control,
  .elitag-tabs-shell[data-active-tab="montage"] .elitag-shell-project-control{
    justify-self:stretch !important;
    max-width:none !important;
    width:100% !important;
    margin-left:0 !important;
  }
}


/* v0.3.169 alignment + graph colors */

/* Make Montage header use the same simple top row behavior as other tabs.
   Project controls stay top-right, guide stays below title and no extra empty column is reserved in the content row. */
.sdu-shell__header{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) auto !important;
  grid-template-areas:
    "title project"
    "guide guide" !important;
  column-gap:14px !important;
  row-gap:8px !important;
  align-items:start !important;
}
.sdu-shell__title{grid-area:title !important;}
.sdu-shell__guide{grid-area:guide !important; width:100% !important; max-width:none !important; justify-self:stretch !important;}
.elitag-shell-project-control{
  grid-area:project !important;
  justify-self:end !important;
  align-self:start !important;
  width:auto !important;
  max-width:360px !important;
  margin-left:12px !important;
}
.elitag-shell-project-current{
  min-width:210px !important;
  max-width:250px !important;
}
.sdu-shell[data-active-tab="montage"] .sdu-shell__panel[data-panel="montage"],
.elitag-tabs-shell[data-active-tab="montage"] .sdu-shell__panel[data-panel="montage"]{
  width:100% !important;
}

/* Roof-type pictures full card width on Montage */
.mbr-roof-type-card img,
.mbr-roof-card img,
.mbr-card img,
[data-roof-type] img{
  width:100% !important;
  max-width:100% !important;
  object-fit:cover !important;
  display:block !important;
}

/* Financial tab: make left and right columns independent so expanding Rentabilitet does not push Investment down */
.sdu-shell__panel[data-panel="financial"] .asb-side{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
  grid-template-areas:
    "assumptions overview"
    "production profitability"
    "investment profitability"
    "json json" !important;
  gap:14px !important;
  align-items:start !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-consumption-assumptions{grid-area:assumptions !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-anlaegsoversigt,
.sdu-shell__panel[data-panel="financial"] .asb-card-consumption-overview{grid-area:overview !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-area-production{grid-area:production !important; align-self:start !important;}
.sdu-shell__panel[data-panel="financial"] .asb-financial-profitability-wrap{grid-area:profitability !important; align-self:start !important;}
.sdu-shell__panel[data-panel="financial"] .asb-financial-investment-wrap{grid-area:investment !important; align-self:start !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-sheet-summary,
.sdu-shell__panel[data-panel="financial"] .asb-card-financial-overview{display:none !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-json-debug:not(.asb-json-debug-hidden){grid-area:json !important;}
.sdu-shell__panel[data-panel="financial"] .asb-side > *{order:initial !important;}

/* Graphs: full-width graph cards */
.elitag-graphs-grid{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:16px !important;
}
.elitag-graph-card{
  width:100% !important;
}
.elitag-graph-plot{
  height:190px !important;
  padding-top:34px !important;
}
.elitag-graph-bars{
  height:154px !important;
}

/* Meaning colors: green good, yellow bad/cost/consumption, grey neutral */
.elitag-graph-bar{
  background:#94a3b8 !important;
  position:relative !important;
}
.elitag-graph-bar.is-good{
  background:#0f766e !important;
}
.elitag-graph-bar.is-bad{
  background:#f0b45b !important;
}
.elitag-graph-bar.is-neutral{
  background:#94a3b8 !important;
}
.elitag-graph-bar .elitag-graph-value{
  color:#64748b !important;
}
.elitag-graph-bar.is-good .elitag-graph-value{
  color:#0f766e !important;
}
.elitag-graph-bar.is-bad .elitag-graph-value{
  color:#b45309 !important;
}
.elitag-graph-value{
  font-size:10px !important;
  font-weight:800 !important;
}

/* Remove older nth-child graph colors */
.elitag-graph-bars .elitag-graph-bar:nth-child(2),
.elitag-graph-bars .elitag-graph-bar:nth-child(3),
.elitag-graph-bars .elitag-graph-bar:nth-child(4){
  background:inherit;
}

@media(max-width:900px){
  .sdu-shell__header{
    grid-template-columns:1fr !important;
    grid-template-areas:
      "title"
      "project"
      "guide" !important;
  }
  .elitag-shell-project-control{
    justify-self:stretch !important;
    width:100% !important;
    max-width:none !important;
    margin-left:0 !important;
  }
  .sdu-shell__panel[data-panel="financial"] .asb-side{
    grid-template-columns:1fr !important;
    grid-template-areas:
      "assumptions"
      "overview"
      "production"
      "profitability"
      "investment"
      "json" !important;
  }
}


/* v0.3.169 montage header + graph legend sizing */

/* Header: project control above guide, title left / project right */
.sdu-shell__header{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) auto !important;
  grid-template-areas:
    "title project"
    "guide guide" !important;
  align-items:start !important;
  column-gap:14px !important;
  row-gap:8px !important;
}
.sdu-shell__title{
  grid-area:title !important;
}
.elitag-shell-project-control{
  grid-area:project !important;
  justify-self:end !important;
  align-self:start !important;
  width:auto !important;
  max-width:380px !important;
  margin:0 !important;
  z-index:3 !important;
}
.sdu-shell__guide{
  grid-area:guide !important;
  width:100% !important;
  max-width:none !important;
  justify-self:stretch !important;
  margin-top:0 !important;
}
.elitag-shell-project-current{
  min-width:220px !important;
  max-width:260px !important;
}

/* Montage should not reserve an empty right column in the content */
.sdu-shell[data-active-tab="montage"] .sdu-shell__panel[data-panel="montage"],
.elitag-tabs-shell[data-active-tab="montage"] .sdu-shell__panel[data-panel="montage"]{
  width:100% !important;
  max-width:none !important;
}

/* Graph legends replace long note text */
.elitag-graph-card-note{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:8px !important;
  align-items:center !important;
  min-height:22px !important;
  margin-bottom:14px !important;
}
.elitag-graph-legend-item{
  display:inline-flex !important;
  align-items:center !important;
  gap:5px !important;
  font-size:13px !important;
  font-weight:800 !important;
  color:#64748b !important;
}
.elitag-graph-legend-item::before{
  content:"" !important;
  width:13px !important;
  height:13px !important;
  border-radius:4px !important;
  background:#94a3b8 !important;
  display:inline-block !important;
}
.elitag-graph-legend-item.is-good{
  color:#0f766e !important;
}
.elitag-graph-legend-item.is-good::before{
  background:#0f766e !important;
}
.elitag-graph-legend-item.is-bad{
  color:#b45309 !important;
}
.elitag-graph-legend-item.is-bad::before{
  background:#f0b45b !important;
}
.elitag-graph-legend-item.is-neutral{
  color:#64748b !important;
}
.elitag-graph-legend-item.is-neutral::before{
  background:#94a3b8 !important;
}

/* Larger graph bars and readable values */
.elitag-graph-plot{
  height:250px !important;
  padding-top:48px !important;
  gap:10px !important;
}
.elitag-graph-bars{
  height:200px !important;
  gap:5px !important;
}
.elitag-graph-bar{
  max-width:22px !important;
  min-width:8px !important;
  border-radius:6px 6px 0 0 !important;
}
.elitag-graph-value{
  font-size:12px !important;
  line-height:1 !important;
  font-weight:900 !important;
  bottom:calc(100% + 4px) !important;
}
.elitag-graph-col em{
  font-size:11px !important;
  font-weight:700 !important;
  margin-top:7px !important;
}

/* Full-width cards with more vertical room */
.elitag-graphs-grid{
  grid-template-columns:1fr !important;
}
.elitag-graph-card{
  padding:18px !important;
}

/* Preserve green/yellow meaning even if older nth-child rules exist */
.elitag-graph-bar.is-good{ background:#0f766e !important; }
.elitag-graph-bar.is-bad{ background:#f0b45b !important; }
.elitag-graph-bar.is-neutral{ background:#94a3b8 !important; }
.elitag-graph-bar.is-good .elitag-graph-value{ color:#0f766e !important; }
.elitag-graph-bar.is-bad .elitag-graph-value{ color:#b45309 !important; }
.elitag-graph-bar.is-neutral .elitag-graph-value{ color:#64748b !important; }

@media(max-width:900px){
  .sdu-shell__header{
    grid-template-columns:1fr !important;
    grid-template-areas:
      "title"
      "project"
      "guide" !important;
  }
  .elitag-shell-project-control{
    justify-self:stretch !important;
    width:100% !important;
    max-width:none !important;
  }
  .elitag-graph-plot{
    height:220px !important;
  }
  .elitag-graph-bars{
    height:170px !important;
  }
  .elitag-graph-value{
    font-size:10px !important;
  }
}


/* v0.3.169 clean layout lock */

/* Header is simple: title + guide only. Project controls live in the tab topbar, not in a phantom header column. */
.sdu-shell__header{
  display:block !important;
}
.sdu-shell__title{
  display:block !important;
  margin-bottom:8px !important;
}
.sdu-shell__guide{
  display:block !important;
  width:100% !important;
  max-width:none !important;
  margin:0 0 12px 0 !important;
}

/* Locked shared topbar */
.elitag-topbar{
  display:flex !important;
  justify-content:space-between !important;
  align-items:center !important;
  gap:16px !important;
  width:100% !important;
  margin:12px 0 16px 0 !important;
  clear:both !important;
}
.elitag-language,
.mbr-lang.elitag-language{
  display:flex !important;
  align-items:center !important;
  gap:8px !important;
  flex:0 0 auto !important;
  margin:0 !important;
}
.elitag-project{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:10px !important;
  margin-left:auto !important;
  flex:0 1 auto !important;
}
.elitag-project .mbr-project-compact,
.elitag-project .asb-project-compact{
  display:inline-flex !important;
  align-items:center !important;
  gap:10px !important;
  width:auto !important;
  max-width:none !important;
  margin:0 !important;
}
.elitag-project .mbr-project-compact-current,
.elitag-project .asb-project-compact-current{
  min-width:220px !important;
  max-width:280px !important;
}
.elitag-project .mbr-project-open-btn,
.elitag-project .asb-project-open-btn{
  white-space:nowrap !important;
}

/* Prevent older header/global project positioning from reappearing */
.sdu-shell__header > .elitag-shell-project-control,
.elitag-shell-project-control{
  position:static !important;
  grid-area:auto !important;
  justify-self:auto !important;
  width:auto !important;
  max-width:none !important;
  margin:0 !important;
}

/* Montage content is full width and does not reserve phantom right column */
.sdu-shell__panel[data-panel="montage"],
.elitag-tabs-shell .sdu-shell__panel[data-panel="montage"],
#mbr-root,
.mbr-root{
  width:100% !important;
  max-width:none !important;
}
.mbr-card-grid{
  width:100% !important;
}
.mbr-card img,
.mbr-roof-type-card img,
.mbr-roof-card img,
[data-roof-type] img{
  width:100% !important;
  max-width:100% !important;
  display:block !important;
  object-fit:cover !important;
}

/* Keep ASB standalone project topbar right-aligned without creating empty content columns */
.asb-topbar .asb-lang-spacer{
  min-width:0 !important;
}

/* Locked financial grid: independent columns and no PV-summary duplicate. */
.sdu-shell__panel[data-panel="financial"] .asb-side{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;
  grid-template-areas:
    "assumptions overview"
    "production profitability"
    "investment profitability"
    "json json" !important;
  gap:14px !important;
  align-items:start !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-card-consumption-assumptions{grid-area:assumptions !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-anlaegsoversigt,
.sdu-shell__panel[data-panel="financial"] .asb-card-consumption-overview{grid-area:overview !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-area-production{grid-area:production !important;}
.sdu-shell__panel[data-panel="financial"] .asb-financial-profitability-wrap{grid-area:profitability !important;}
.sdu-shell__panel[data-panel="financial"] .asb-financial-investment-wrap{grid-area:investment !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-sheet-summary,
.sdu-shell__panel[data-panel="financial"] .asb-card-financial-overview{display:none !important;}
.sdu-shell__panel[data-panel="financial"] .asb-card-json-debug:not(.asb-json-debug-hidden){grid-area:json !important;}

/* Graph system locked: full-width cards, legends, semantic colors */
.elitag-graphs-grid{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:18px !important;
}
.elitag-graph-card{
  width:100% !important;
  padding:18px !important;
}
.elitag-graph-card-note{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:10px !important;
  margin-bottom:14px !important;
}
.elitag-graph-legend-item{
  display:inline-flex !important;
  align-items:center !important;
  gap:6px !important;
  font-size:13px !important;
  font-weight:800 !important;
}
.elitag-graph-legend-item::before{
  content:"" !important;
  display:inline-block !important;
  width:13px !important;
  height:13px !important;
  border-radius:4px !important;
  background:#94a3b8 !important;
}
.elitag-graph-legend-item.is-good{color:#0f766e !important;}
.elitag-graph-legend-item.is-good::before{background:#0f766e !important;}
.elitag-graph-legend-item.is-bad{color:#b45309 !important;}
.elitag-graph-legend-item.is-bad::before{background:#f0b45b !important;}
.elitag-graph-legend-item.is-neutral{color:#64748b !important;}
.elitag-graph-legend-item.is-neutral::before{background:#94a3b8 !important;}

.elitag-graph-plot{
  height:250px !important;
  padding-top:48px !important;
}
.elitag-graph-bars{
  height:200px !important;
  gap:5px !important;
}
.elitag-graph-bar{
  max-width:22px !important;
  min-width:8px !important;
  border-radius:6px 6px 0 0 !important;
  position:relative !important;
}
.elitag-graph-bar.is-good{background:#0f766e !important;}
.elitag-graph-bar.is-bad{background:#f0b45b !important;}
.elitag-graph-bar.is-neutral{background:#94a3b8 !important;}
.elitag-graph-value{
  position:absolute !important;
  left:50% !important;
  bottom:calc(100% + 4px) !important;
  transform:translateX(-50%) rotate(-45deg) !important;
  font-size:12px !important;
  font-weight:900 !important;
  white-space:nowrap !important;
}
.elitag-graph-bar.is-good .elitag-graph-value{color:#0f766e !important;}
.elitag-graph-bar.is-bad .elitag-graph-value{color:#b45309 !important;}
.elitag-graph-bar.is-neutral .elitag-graph-value{color:#64748b !important;}
.elitag-graphs-suggestions,
.elitag-graphs-meta,
.elitag-graphs-status:empty{
  display:none !important;
}

@media(max-width:900px){
  .elitag-topbar{
    flex-direction:column !important;
    align-items:stretch !important;
  }
  .elitag-project{
    justify-content:stretch !important;
    margin-left:0 !important;
  }
  .elitag-project .mbr-project-compact,
  .elitag-project .asb-project-compact{
    width:100% !important;
  }
  .elitag-project .mbr-project-compact-current,
  .elitag-project .asb-project-compact-current{
    flex:1 1 auto !important;
    min-width:0 !important;
    max-width:none !important;
  }
  .sdu-shell__panel[data-panel="financial"] .asb-side{
    grid-template-columns:1fr !important;
    grid-template-areas:
      "assumptions"
      "overview"
      "production"
      "profitability"
      "investment"
      "json" !important;
  }
  .elitag-graph-plot{height:220px !important;}
  .elitag-graph-bars{height:170px !important;}
  .elitag-graph-value{font-size:10px !important;}
}


/* v0.3.170: desktop-only compact layout editor controls. Mobile CSS intentionally remains unchanged. */
@media (min-width: 769px){
  .asb-layout-editor-modal .asb-layout-editor-settings .asb-fields-5{
    grid-template-columns:repeat(5,minmax(0,1fr));
  }
  .asb-layout-editor-modal .asb-layout-editor-settings .asb-fields-4{
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
  .asb-layout-editor-modal .asb-layout-editor-settings label,
  .asb-layout-editor-modal .asb-layout-editor-settings .asb-label{
    font-size:11px;
    line-height:1.2;
  }
  .asb-layout-editor-modal .asb-layout-editor-settings input,
  .asb-layout-editor-modal .asb-layout-editor-settings select{
    font-size:13px;
    min-height:38px;
    padding:8px 9px;
  }
}


/* v0.3.186: Montage Tagområde cards as individual cards, no outer Tagområder box. */
.asb-area-card-info{margin-top:12px;padding:12px;border:1px solid #e2e8f0;border-radius:16px;background:#f8fafc;display:flex;flex-direction:column;gap:7px;}
.asb-area-card-info-line{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;font-size:13px;line-height:1.35;}
.asb-area-card-info-label{color:#475569;font-weight:600;white-space:nowrap;}
.asb-area-card-info-value{color:#0f172a;font-weight:800;min-width:0;overflow-wrap:anywhere;}
.asb-area-card-dimensions{margin-top:2px;color:#334155;font-weight:700;font-size:13px;line-height:1.35;}
.asb-open-design-box{align-items:flex-start;gap:7px;}
.asb-open-design-box .asb-open-design-mode-btn{margin-top:4px;align-self:flex-start;}

@media (min-width: 1100px){
  .sdu-shell__panel[data-panel="roof"] .asb-main{display:flex;flex-direction:column;gap:18px;align-items:stretch;}
  .sdu-shell__panel[data-panel="roof"] .asb-left{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:16px;align-items:start;}
  .sdu-shell__panel[data-panel="roof"] .asb-side{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:16px;align-items:start;}
  .sdu-shell__panel[data-panel="roof"] .asb-card-area-production,
  .sdu-shell__panel[data-panel="roof"] .asb-card-live-results,
  .sdu-shell__panel[data-panel="roof"] .asb-card-system-strategy,
  .sdu-shell__panel[data-panel="roof"] .asb-card-consumption-assumptions,
  .sdu-shell__panel[data-panel="roof"] .asb-card-bom-preview,
  .sdu-shell__panel[data-panel="roof"] .asb-card-anlaegsoversigt{min-width:0;}
}


/* v0.3.203 Tag-design numeric steppers: integrated inside the field like Montage inputs */
.asb-visible-stepper{
  display:grid;
  grid-template-columns:minmax(0,1fr) 28px;
  width:100%;
  min-width:0;
  min-height:42px;
  border:1px solid #cbd5e1;
  border-radius:12px;
  background:#fff;
  overflow:hidden;
  box-sizing:border-box;
}
.asb-visible-stepper .asb-visible-stepper-input{
  width:100%;
  min-width:0;
  height:40px;
  min-height:40px;
  padding:10px 12px!important;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
  box-sizing:border-box;
}
.asb-visible-stepper .asb-visible-stepper-input:focus{outline:none!important;box-shadow:none!important}
.asb-visible-stepper:focus-within{border-color:#0ea5a4;box-shadow:0 0 0 1px #0ea5a4}
.asb-visible-stepper-buttons{
  width:28px;
  display:flex;
  flex-direction:column;
  border-left:1px solid #d7e3ee;
  background:#f8fafc;
}
.asb-visible-stepper-btn{
  flex:1 1 0;
  min-height:0;
  border:0;
  border-bottom:1px solid #d7e3ee;
  background:transparent;
  color:#5b7188;
  font-size:9px;
  line-height:1;
  cursor:pointer;
  padding:0;
  margin:0;
  display:flex;
  align-items:center;
  justify-content:center;
}
.asb-visible-stepper-btn:last-child{border-bottom:0}
.asb-visible-stepper-btn:hover{background:#e8f0f7;color:#143348}
.asb-readonly-input{background:#f8fafc;color:#334155}

/* v0.4.5: transparent directional panel move controls in Tag-design modal */
.asb-roof-canvas .asb-panel-move-arrow{
  position:absolute;
  z-index:320;
  width:36px;
  height:36px;
  border:1px solid rgba(15,23,42,.10);
  border-radius:999px;
  background:rgba(255,255,255,.18);
  color:rgba(15,23,42,.34);
  font-size:18px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 4px 14px rgba(15,23,42,.08);
  backdrop-filter:blur(2px);
  transition:background .12s ease,color .12s ease,transform .12s ease;
}
.asb-roof-canvas .asb-panel-move-arrow:hover,
.asb-roof-canvas .asb-panel-move-arrow:focus-visible{
  background:rgba(255,255,255,.55);
  color:rgba(15,23,42,.72);
  transform:scale(1.04);
}
.asb-roof-canvas .asb-panel-move-arrow:active{transform:scale(.98);}
@media (max-width:760px){
  .asb-roof-canvas .asb-panel-move-arrow{width:34px;height:34px;font-size:16px;background:rgba(255,255,255,.32);}
}

/* ElOverblik integration */
.asb-eloverblik-inline{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:end;}
.asb-eloverblik-button{white-space:nowrap;min-height:34px;}
.asb-eloverblik-card{border-color:#b7d6d8;}
.asb-eloverblik-status{border:1px solid #b7d6d8;background:#f2fbfb;border-radius:10px;padding:10px 12px;margin:8px 0 12px;color:#1f6f73;font-weight:700;}
.asb-eloverblik-graph{display:grid;gap:7px;margin-top:10px;}
.asb-eloverblik-bar-row{display:grid;grid-template-columns:84px 1fr 96px;gap:10px;align-items:center;font-size:12px;}
.asb-eloverblik-bar-label{font-weight:700;color:#42536b;}
.asb-eloverblik-bar-track{height:12px;border-radius:999px;background:#eef4f7;overflow:hidden;border:1px solid #d5e3ea;}
.asb-eloverblik-bar-fill{height:100%;border-radius:999px;background:#6f9da4;}
.asb-eloverblik-bar-value{text-align:right;color:#42536b;font-variant-numeric:tabular-nums;}
@media (max-width: 760px){.asb-eloverblik-inline{grid-template-columns:1fr}.asb-eloverblik-bar-row{grid-template-columns:70px 1fr}.asb-eloverblik-bar-value{grid-column:2;text-align:left}}


/* v0.7.06: ElOverblik belongs only to Forbrug, never Tag-design/Financial. */
.sdu-shell__panel[data-panel="roof"] .asb-eloverblik-card,
.sdu-shell__panel[data-panel="financial"] .asb-eloverblik-card{
  display:none !important;
}
.sdu-shell__panel[data-panel="consumption"] .asb-eloverblik-card{
  display:block !important;
}


/* v0.7.06: Design-mode geometry isolation.
   The layout editor uses calculated pixel coordinates. These rules prevent
   Montage/card preview panel sizes from leaking into the modal and causing
   overlap when many panels are added. */
.asb-layout-editor-modal .asb-design-mode .asb-panel,
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel{
  min-width:0 !important;
  min-height:0 !important;
  box-sizing:border-box !important;
  overflow:hidden !important;
  flex:0 0 auto !important;
  margin:0 !important;
  padding:0 !important;
}
.asb-layout-editor-modal .asb-design-mode .asb-panel.portrait,
.asb-layout-editor-modal .asb-design-mode .asb-panel.landscape,
.asb-layout-editor-modal .asb-design-mode .asb-panel.is-large.portrait,
.asb-layout-editor-modal .asb-design-mode .asb-panel.is-large.landscape,
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel.portrait,
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel.landscape,
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel.is-large.portrait,
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel.is-large.landscape{
  min-width:0 !important;
  min-height:0 !important;
}
.asb-layout-editor-modal .asb-design-mode .asb-panel-index,
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel-index{
  font-size:clamp(0px, 45%, 10px) !important;
  line-height:1 !important;
  white-space:nowrap !important;
  overflow:hidden !important;
  max-width:100% !important;
  pointer-events:none !important;
}
.asb-layout-editor-modal .asb-design-mode .asb-panel[style*="width: 2px"] .asb-panel-index,
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel[style*="width: 2px"] .asb-panel-index{
  display:none !important;
}

/* v0.7.06: modals must not hide behind sticky plugin header/tabs in full-browser mode. */
body.elitag-solar-designer-active .asb-modal-backdrop{
  position:fixed !important;
  inset:0 !important;
  z-index:2147483400 !important;
  padding:12px !important;
  align-items:flex-start !important;
  justify-content:center !important;
  overflow:auto !important;
  box-sizing:border-box !important;
}
body.elitag-solar-designer-active .asb-modal{
  position:relative !important;
  z-index:2147483410 !important;
  max-height:calc(100dvh - 24px) !important;
  margin:0 auto !important;
}
body.elitag-solar-designer-active .asb-layout-editor-modal{
  width:min(98vw,1820px) !important;
  max-height:calc(100dvh - 24px) !important;
}
body.elitag-solar-designer-active .asb-layout-editor-modal .asb-modal-head{
  position:sticky !important;
  top:0 !important;
  z-index:2147483420 !important;
  background:#fff !important;
}
body.elitag-solar-designer-active .asb-consumption-modal{
  z-index:2147483410 !important;
  max-height:calc(100dvh - 24px) !important;
}
body.elitag-solar-designer-active .asb-modal-backdrop:has(.asb-consumption-modal){
  z-index:2147483450 !important;
}
body.elitag-solar-designer-active .asb-modal-backdrop:has(.asb-consumption-modal) .asb-consumption-modal{
  z-index:2147483460 !important;
}
/* Prevent sticky tabs/header hover/focus from visually dominating while any ASB modal is open. */
body.elitag-solar-designer-active:has(.asb-modal-backdrop) .elitag-tabs-shell > .sdu-shell__header,
body.elitag-solar-designer-active:has(.asb-modal-backdrop) .elitag-tabs-shell > .sdu-shell__tabs{
  z-index:2147481900 !important;
}


/* v0.7.06: Design-mode performance numbers.
   Panel numbers are hidden by default in the editor and shown only via the
   toggle. Hover keeps panel identity available without forcing text layout on
   hundreds of panel nodes. */
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel{
  transform:translate3d(0,0,0);
  will-change:transform;
}
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel:not(:has(.asb-panel-index)){
  font-size:0 !important;
}
.asb-design-panel-tooltip::after{
  content:attr(data-tooltip);
  position:absolute;
  left:50%;
  bottom:calc(100% + 6px);
  transform:translateX(-50%);
  background:rgba(15,23,42,.94);
  color:#fff;
  padding:5px 7px;
  border-radius:7px;
  font-size:11px;
  line-height:1.15;
  font-weight:700;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  z-index:2147483600;
  transition:opacity .08s ease;
}
.asb-design-panel-tooltip:hover::after,
.asb-design-panel-tooltip:focus-visible::after{
  opacity:1;
}
.asb-design-number-toggle{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 9px;
  border:1px solid #cbd5e1;
  border-radius:10px;
  background:#fff;
  font-size:12px;
  font-weight:700;
  color:#334155;
}
.asb-design-number-toggle input{margin:0;}


/* v0.7.06: keep native/custom design tooltips available without affecting panel geometry. */
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel.asb-design-panel-tooltip:hover{
  overflow:visible !important;
}
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel.asb-design-panel-tooltip:hover .asb-panel-index{
  pointer-events:none;
}


/* v0.7.06: Tag-design modal takes the available browser width and keeps
   design geometry separate from compact/basic previews. */
body.elitag-solar-designer-active .asb-layout-editor-modal,
.asb-layout-editor-modal{
  width:100vw !important;
  max-width:100vw !important;
  border-radius:0 !important;
}
body.elitag-solar-designer-active .asb-layout-editor-modal{
  max-height:100dvh !important;
}
.asb-layout-editor-modal .asb-modal-body.asb-layout-editor-body{
  width:100% !important;
  box-sizing:border-box !important;
}
.asb-layout-editor-modal .asb-layout-editor-grid,
.asb-layout-editor-modal .asb-area-grid-wrap.is-large{
  width:100% !important;
  max-width:100% !important;
  box-sizing:border-box !important;
}
.asb-layout-editor-modal .asb-roof-canvas{
  transform-origin:top center !important;
}
/* Keep basic Tag-design previews from inheriting large/design-mode sizing. */
.asb-area-grid-wrap:not(.is-large) .asb-panel.portrait,
.asb-area-grid-wrap:not(.is-large) .asb-panel.landscape{
  max-width:none !important;
  max-height:none !important;
  aspect-ratio:auto !important;
}
/* Make the Design-mode tooltip readable and useful without disabling clicks. */
.asb-layout-editor-modal .asb-design-panel-tooltip::after{
  min-width:max-content;
  max-width:260px;
  text-align:center;
  white-space:nowrap;
  z-index:2147483600 !important;
}
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel.asb-design-panel-tooltip:hover,
.asb-layout-editor-modal .asb-design-mode-canvas .asb-panel.asb-design-panel-tooltip:focus-visible{
  overflow:visible !important;
  z-index:2147483500 !important;
}
.asb-layout-editor-modal .asb-area-row-fit-label{
  white-space:nowrap;
  transform:translateX(0);
}


/* v0.7.06 Tag-design refinements */
.asb-layout-editor-modal .asb-area-row-fit-label{
  text-align:left !important;
  white-space:nowrap !important;
  pointer-events:none !important;
}
.asb-area-grid-wrap:not(.is-large) .asb-panel.portrait,
.asb-area-grid-wrap:not(.is-large) button.asb-panel.portrait,
.asb-area-grid-wrap:not(.is-large) .asb-panel.landscape,
.asb-area-grid-wrap:not(.is-large) button.asb-panel.landscape{
  aspect-ratio:auto !important;
}

/* v0.7.06: Forbrug tab compact assumptions layout */
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-grid{
  display:grid;
  grid-template-columns:minmax(280px, 1fr) minmax(240px, 1fr);
  gap:18px;
  align-items:start;
}
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-fields{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  width:100%;
  max-width:720px;
  justify-self:start;
}
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-actions{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:flex-start;
  justify-content:flex-start;
  padding-top:24px;
}
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-actions .button{
  min-width:230px;
  max-width:360px;
  width:auto;
}
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-actions .asb-muted{
  max-width:420px;
}
.sdu-shell__panel[data-panel="consumption"] .asb-eloverblik-card .button{
  display:none !important;
}
@media(max-width:900px){
  .sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-grid{
    grid-template-columns:1fr;
  }
  .sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-actions{
    padding-top:0;
  }
  .sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-actions .button{
    width:100%;
    max-width:none;
  }
}


/* v0.7.06: Forbrug action rows and financial cleanup */
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-grid{
  grid-template-columns:minmax(280px, 50%) minmax(280px, 1fr) !important;
  align-items:start !important;
}
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-fields{
  max-width:100% !important;
}
.sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-actions{
  display:flex !important;
  flex-direction:column !important;
  gap:14px !important;
  padding-top:34px !important;
  align-items:stretch !important;
}
.sdu-shell__panel[data-panel="consumption"] .asb-action-row{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:14px !important;
  width:100% !important;
}
.sdu-shell__panel[data-panel="consumption"] .asb-action-help{
  flex:1 1 auto !important;
  max-width:none !important;
  margin:0 !important;
}
.sdu-shell__panel[data-panel="consumption"] .asb-action-row .button{
  flex:0 0 auto !important;
  min-width:230px !important;
  max-width:320px !important;
  white-space:nowrap !important;
}
.sdu-shell__panel[data-panel="financial"] .asb-eloverblik-action-row,
.sdu-shell__panel[data-panel="financial"] .asb-eloverblik-card,
.sdu-shell__panel[data-panel="financial"] .asb-eloverblik-button{
  display:none !important;
}
@media(max-width:900px){
  .sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-grid{
    grid-template-columns:1fr !important;
  }
  .sdu-shell__panel[data-panel="consumption"] .asb-card-consumption-assumptions .asb-consumption-assumptions-actions{
    padding-top:0 !important;
  }
  .sdu-shell__panel[data-panel="consumption"] .asb-action-row{
    flex-direction:column !important;
    align-items:flex-start !important;
  }
  .sdu-shell__panel[data-panel="consumption"] .asb-action-row .button{
    width:100% !important;
    max-width:none !important;
  }
}

/* v0.7.06: Place ElOverblik status box directly under the Forbrug action buttons. */
.asb-consumption-assumptions-actions .asb-eloverblik-card{
  margin-top:12px;
  width:100%;
  box-sizing:border-box;
}
.asb-consumption-assumptions-actions .asb-eloverblik-card .asb-side-title{
  margin-bottom:8px;
}
.asb-consumption-assumptions-actions .asb-eloverblik-approved-button{
  margin:8px 0 10px;
  width:100%;
  max-width:360px;
}
.asb-consumption-assumptions-actions .asb-action-row{
  align-items:center;
}

/* v0.7.06: Tag-design selector polish. Keep panel/tilt selectors consistent with Montage-style fields. */
.asb-root .asb-preferred-select{
  width:100% !important;
  min-height:42px !important;
  height:42px !important;
  padding:8px 36px 8px 11px !important;
  border:1px solid #cbd5e1 !important;
  border-radius:12px !important;
  background-color:#fff !important;
  color:#0f172a !important;
  font-size:13px !important;
  font-weight:600 !important;
  line-height:1.2 !important;
  box-sizing:border-box !important;
  appearance:auto !important;
  -webkit-appearance:menulist !important;
  cursor:pointer;
}
.asb-root .asb-paneltype-select{
  min-width:0 !important;
}
.asb-root .asb-tilt-select{
  max-width:100% !important;
}
.asb-root .asb-preferred-select:focus{
  outline:2px solid rgba(34,113,177,.22) !important;
  border-color:#2271b1 !important;
  box-shadow:0 0 0 3px rgba(34,113,177,.10) !important;
}
@media (max-width:768px){
  .asb-root .asb-preferred-select,
  .asb-layout-editor-modal .asb-preferred-select{
    height:42px !important;
    min-height:42px !important;
    font-size:16px !important;
  }
}

/* v0.7.06: Stack ElOverblik authorization/fetch buttons in Forbrug right column. */
.asb-action-button-stack{display:flex;flex-direction:column;gap:8px;align-items:flex-start;}
.asb-action-button-stack .button{width:auto;max-width:100%;white-space:normal;text-align:left;}
@media (min-width: 900px){.asb-action-button-stack{align-items:flex-end}.asb-action-button-stack .button{text-align:center;}}


/* v0.7.06 ElOverblik approved button width */
.sdu-shell__panel[data-panel="consumption"] .asb-eloverblik-approved-button,
.asb-eloverblik-approved-button{
  min-width:360px!important;
  width:auto!important;
  max-width:none!important;
  padding-left:18px!important;
  padding-right:18px!important;
  white-space:nowrap!important;
}
.sdu-shell__panel[data-panel="consumption"] .asb-action-button-stack{
  align-items:flex-end!important;
}
@media(max-width:900px){
  .sdu-shell__panel[data-panel="consumption"] .asb-eloverblik-approved-button,
  .asb-eloverblik-approved-button{
    min-width:0!important;
    width:100%!important;
    white-space:normal!important;
  }
}


/* v0.7.06 ElOverblik no-metering message */
.asb-eloverblik-status{
  line-height:1.35;
}

/* v0.7.06 project bulk erase */
.mbr-project-modal-count{
  font-size:13px;
  color:#64748b;
  font-weight:700;
  margin-top:-4px;
}

/* v0.7.06 selective project deletion */
.mbr-project-delete-panel{
  margin-top:14px;
  padding:12px;
  border:1px solid #dbe5ee;
  border-radius:10px;
  background:#f8fafc;
}
.mbr-project-delete-title{
  font-weight:800;
  color:#15324a;
  margin-bottom:8px;
}
.mbr-project-delete-list{
  max-height:220px;
  overflow:auto;
  display:grid;
  gap:6px;
  margin-bottom:10px;
}
.mbr-project-delete-row{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:8px;
  align-items:center;
  padding:8px;
  border:1px solid #e2e8f0;
  border-radius:8px;
  background:#fff;
}
.mbr-project-delete-name{
  font-weight:700;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.mbr-project-delete-date{
  color:#64748b;
  font-size:12px;
}
.mbr-project-delete-empty{
  color:#64748b;
  padding:8px;
}

/* v0.7.06 annual consumption matrix */
.asb-radio-stack{display:grid;gap:8px;margin:8px 0 12px;}
.asb-radio-stack label{display:flex;align-items:center;gap:8px;font-weight:700;}
.asb-eloverblik-consumption-sum{display:grid;gap:6px;margin:12px 0;padding:12px;border:1px solid #dbe5ee;border-radius:10px;background:#f8fafc;}
.asb-eloverblik-consumption-sum>div{display:flex;justify-content:space-between;gap:12px;}
.asb-eloverblik-matrix-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;}
.asb-eloverblik-matrix-head>div:last-child{display:flex;gap:8px;flex-wrap:wrap;}
.asb-annual-matrix-wrap{margin-top:12px;}
.asb-annual-matrix-scroll{overflow:auto;max-width:100%;border:1px solid #dbe5ee;border-radius:10px;}
.asb-annual-matrix{border-collapse:collapse;width:max-content;min-width:100%;font-size:11px;}
.asb-annual-matrix th,.asb-annual-matrix td{padding:5px 6px;border:1px solid #e2e8f0;text-align:right;white-space:nowrap;}
.asb-annual-matrix th:first-child{text-align:left;position:sticky;left:0;background:#fff;z-index:1;}
.asb-annual-matrix thead th{position:sticky;top:0;background:#f8fafc;z-index:2;}
.asb-matrix-cell{background:rgba(0,107,112,calc(.05 + var(--p) * .22));}
.asb-matrix-total-row th{background:#f8fafc;font-weight:800;}
@media(max-width:900px){.asb-eloverblik-matrix-head{align-items:flex-start;flex-direction:column;}}

/* v0.7.06 focus/matrix warning */
.asb-eloverblik-warning{
  margin:10px 0;
  padding:10px 12px;
  border:1px solid #f59e0b;
  background:#fffbeb;
  color:#92400e;
  border-radius:10px;
  font-weight:800;
  line-height:1.35;
}
.asb-annual-matrix th,.asb-annual-matrix td{
  font-variant-numeric:tabular-nums;
}

/* v0.7.06 focus and ElOverblik total graph correction */
.asb-eloverblik-basis-card .asb-muted{line-height:1.35;}

/* v0.7.06 ElOverblik included/add modes and locked profiles */
.asb-eloverblik-submode{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:8px 0 12px;
  padding:10px 12px;
  border:1px solid #dbe5ee;
  border-radius:10px;
  background:#f8fafc;
  font-weight:700;
}
.asb-eloverblik-submode label{display:flex;align-items:center;gap:6px;}
.asb-slider-row input[disabled],
.asb-profile-bar select[disabled]{
  opacity:.65;
  cursor:not-allowed;
}




/* v0.7.06 Forbrug modal internal scroll fix */
.asb-modal-backdrop{
  position:fixed!important;
  inset:0!important;
  overflow:hidden!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:16px!important;
  box-sizing:border-box!important;
}
.asb-modal.asb-consumption-modal{
  width:min(1180px, calc(100vw - 32px))!important;
  max-width:1180px!important;
  height:min(92vh, 980px)!important;
  max-height:92vh!important;
  min-height:0!important;
  margin:0!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
}
.asb-consumption-modal .asb-modal-head{
  flex:0 0 auto!important;
  position:relative!important;
  top:auto!important;
  background:#fff!important;
  z-index:2!important;
  border-bottom:1px solid #dbe5ee!important;
}
.asb-consumption-modal .asb-modal-body{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  -webkit-overflow-scrolling:touch!important;
  padding-bottom:20px!important;
}
.asb-consumption-modal .asb-modal-actions{
  flex:0 0 auto!important;
  position:relative!important;
  bottom:auto!important;
  background:#fff!important;
  z-index:2!important;
  border-top:1px solid #dbe5ee!important;
}
body:has(.asb-consumption-modal){
  overflow:hidden!important;
}
@media(max-width:900px){
  .asb-modal-backdrop{
    align-items:stretch!important;
    padding:8px!important;
  }
  .asb-modal.asb-consumption-modal{
    width:calc(100vw - 16px)!important;
    height:calc(100vh - 16px)!important;
    max-height:calc(100vh - 16px)!important;
  }
}


/* v0.7.06 matrix moved outside Forbrug modal */
.asb-consumption-modal .asb-annual-matrix-card,
.asb-consumption-modal .asb-annual-matrix-wrap{
  display:none!important;
}
.asb-annual-matrix-card{
  overflow:hidden;
}



/* v0.7.06 basic matrix + modal focus stability */
.asb-annual-matrix-card{
  overflow:hidden;
}

.asb-consumption-modal input[data-no-autofocus="1"]{
  scroll-margin-top:0!important;
}
.asb-consumption-modal{
  overflow-anchor:none!important;
}
.asb-consumption-modal *{
  overflow-anchor:none!important;
}


/* v0.7.06 matrix full size by default */
.asb-annual-matrix-card{
  overflow:visible!important;
}
.asb-annual-matrix-card .asb-annual-matrix-scroll{
  max-height:none!important;
  height:auto!important;
  overflow-y:visible!important;
  overflow-x:auto!important;
}
.asb-annual-matrix-wrap{
  overflow:visible!important;
}
.asb-annual-matrix{
  width:max-content!important;
  min-width:100%!important;
}


/* v0.7.06 no focus / scroll-only Forbrug modal */
.asb-consumption-modal,
.asb-consumption-modal *,
.asb-modal-backdrop{
  overflow-anchor:none!important;
  scroll-behavior:auto!important;
}
.asb-consumption-modal input,
.asb-consumption-modal select,
.asb-consumption-modal textarea,
.asb-consumption-modal button{
  scroll-margin-top:0!important;
  scroll-margin-bottom:0!important;
}

.asb-consumption-modal .asb-modal-body{
  overflow-y:auto!important;
  overscroll-behavior:contain!important;
}


/* v0.7.06 dropdown fix: no programmatic focus trap, keep modal scroll stable */
.asb-consumption-modal,
.asb-consumption-modal *,
.asb-modal-backdrop{
  overflow-anchor:none!important;
  scroll-behavior:auto!important;
}
.asb-consumption-modal .asb-modal-body{
  overflow-y:auto!important;
  overscroll-behavior:contain!important;
}

/* v0.7.06 expected increase calculation rows */
.asb-eloverblik-consumption-sum .strong,
.asb-eloverblik-consumption-sum div:last-child{
  font-weight:800;
}

/* v0.7.06 project export/import buttons */
.mbr-project-modal-actions .button,
.asb-project-manager-modal .button{
  white-space:nowrap;
}

/* v0.7.06 ElOverblik warning outside modal */
.asb-eloverblik-warning-outside{
  margin:12px 0;
}
.asb-card-anlaegsoversigt .asb-eloverblik-warning-outside{
  margin-top:14px;
}

/* v0.7.06 compact warning under Moms */
.asb-consumption-assumptions .asb-eloverblik-warning-outside{
  margin-top:10px!important;
  margin-bottom:6px!important;
  width:100%!important;
  box-sizing:border-box;
}


/* v0.7.06 Android/mobile menu */
@media (max-width: 768px){
  html, body{
    max-width:100%;
    overflow-x:hidden!important;
  }
  .elitag-tabs-shell,
  .sdu-shell,
  .sdu-shell__panel,
  #mbr-root,
  #asb-root{
    max-width:100vw!important;
    overflow-x:hidden!important;
  }

  .sdu-shell__header{
    padding:10px 12px!important;
  }
  .sdu-shell__title{
    font-size:17px!important;
    line-height:1.15!important;
    margin:0!important;
  }
  .sdu-shell__version{
    font-size:10px!important;
  }

  .sdu-shell__tabs{
    position:sticky!important;
    top:0!important;
    z-index:40!important;
    display:flex!important;
    flex-wrap:nowrap!important;
    gap:4px!important;
    overflow-x:auto!important;
    overflow-y:hidden!important;
    -webkit-overflow-scrolling:touch!important;
    scroll-snap-type:x proximity!important;
    padding:4px 8px!important;
    min-height:58px!important;
    background:#fff!important;
    border-bottom:1px solid #dbe5ee!important;
    box-shadow:0 4px 14px rgba(15,23,42,.08)!important;
  }
  .sdu-shell__tabs::-webkit-scrollbar{display:none!important;}
  .sdu-shell__tab{
    flex:0 0 78px!important;
    min-width:78px!important;
    max-width:78px!important;
    height:52px!important;
    padding:6px 4px 5px!important;
    font-size:10px!important;
    line-height:1.05!important;
    border-radius:10px!important;
    scroll-snap-align:start!important;
    touch-action:manipulation!important;
  }
  .sdu-shell__tab::before{
    font-size:17px!important;
    margin-bottom:4px!important;
  }
  .sdu-shell__tab.is-active::after{
    left:8px!important;
    right:8px!important;
    height:3px!important;
  }

  .sdu-shell__site-link{
    display:none!important;
  }

  .elitag-topbar{
    display:flex!important;
    flex-direction:column!important;
    align-items:stretch!important;
    gap:8px!important;
    margin:8px 0 10px!important;
    padding:0 10px!important;
  }
  .elitag-language,
  .mbr-lang.elitag-language{
    justify-content:flex-start!important;
    gap:6px!important;
    width:100%!important;
  }
  .elitag-language .button,
  .mbr-lang.elitag-language .button{
    min-height:40px!important;
    padding:8px 14px!important;
  }

  .elitag-project{
    width:100%!important;
    margin:0!important;
    justify-content:stretch!important;
  }
  .elitag-project .mbr-project-compact,
  .elitag-project .asb-project-compact{
    display:grid!important;
    grid-template-columns:1fr auto!important;
    gap:8px!important;
    width:100%!important;
  }
  .elitag-project .mbr-project-compact-current,
  .elitag-project .asb-project-compact-current{
    min-width:0!important;
    max-width:none!important;
    width:100%!important;
    height:42px!important;
    padding:8px 10px!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    white-space:nowrap!important;
  }
  .elitag-project .mbr-project-open-btn,
  .elitag-project .asb-project-open-btn{
    min-height:42px!important;
    padding:8px 12px!important;
  }

  .mbr-card-grid,
  .asb-main,
  .asb-fields,
  .asb-fields-2,
  .asb-fields-3,
  .asb-fields-4{
    grid-template-columns:1fr!important;
  }
  .asb-main{
    display:block!important;
  }
  .asb-left,
  .asb-side{
    width:100%!important;
    max-width:100%!important;
  }
  .asb-side-card,
  .mbr-card,
  .mbr-tab-block{
    border-radius:12px!important;
    margin-left:8px!important;
    margin-right:8px!important;
  }

  .asb-modal,
  .mbr-project-manager-modal,
  .asb-project-manager-modal{
    width:calc(100vw - 16px)!important;
    max-width:calc(100vw - 16px)!important;
    max-height:calc(100vh - 16px)!important;
    border-radius:14px!important;
  }
  .asb-modal-body,
  .mbr-project-modal-body{
    max-height:calc(100vh - 150px)!important;
    overflow:auto!important;
    -webkit-overflow-scrolling:touch!important;
  }
  .mbr-project-modal-actions,
  .asb-project-manager-modal .mbr-project-modal-actions{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:8px!important;
  }
  .mbr-project-modal-actions .button,
  .asb-project-manager-modal .button{
    min-height:42px!important;
    white-space:normal!important;
  }

  .elitag-mobile-nav-toggle{
    display:flex!important;
    position:fixed!important;
    right:14px!important;
    bottom:calc(14px + env(safe-area-inset-bottom, 0px))!important;
    z-index:10000!important;
    align-items:center!important;
    justify-content:center!important;
    gap:7px!important;
    min-width:74px!important;
    height:48px!important;
    padding:0 14px!important;
    border:0!important;
    border-radius:999px!important;
    background:#006b70!important;
    color:#fff!important;
    font-weight:800!important;
    box-shadow:0 12px 28px rgba(0,0,0,.25)!important;
    touch-action:manipulation!important;
  }
  .elitag-mobile-nav-toggle-icon{
    font-size:18px!important;
    line-height:1!important;
  }
  .elitag-mobile-nav-toggle-text{
    font-size:13px!important;
  }
  .elitag-mobile-nav-panel{
    display:none!important;
    position:fixed!important;
    left:10px!important;
    right:10px!important;
    bottom:calc(72px + env(safe-area-inset-bottom, 0px))!important;
    z-index:9999!important;
    max-height:72vh!important;
    overflow:auto!important;
    -webkit-overflow-scrolling:touch!important;
    padding:12px!important;
    border:1px solid #dbe5ee!important;
    border-radius:18px!important;
    background:#fff!important;
    box-shadow:0 18px 45px rgba(15,23,42,.28)!important;
  }
  body.elitag-mobile-nav-open .elitag-mobile-nav-panel{
    display:block!important;
  }
  .elitag-mobile-nav-head{
    display:flex!important;
    align-items:center!important;
    justify-content:space-between!important;
    gap:10px!important;
    margin-bottom:10px!important;
    color:#15324a!important;
  }
  .elitag-mobile-nav-close{
    width:38px!important;
    height:38px!important;
    border:1px solid #dbe5ee!important;
    border-radius:999px!important;
    background:#fff!important;
    font-size:24px!important;
    line-height:1!important;
  }
  .elitag-mobile-project-slot{
    padding:9px 10px!important;
    margin-bottom:10px!important;
    border:1px solid #dbe5ee!important;
    border-radius:12px!important;
    background:#f8fafc!important;
    font-size:12px!important;
    color:#15324a!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    white-space:nowrap!important;
  }
  .elitag-mobile-nav-grid{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:8px!important;
  }
  .elitag-mobile-nav-grid button,
  .elitag-mobile-nav-actions button{
    min-height:48px!important;
    border:1px solid #dbe5ee!important;
    border-radius:12px!important;
    background:#fff!important;
    color:#15324a!important;
    font-weight:800!important;
    font-size:13px!important;
    touch-action:manipulation!important;
  }
  .elitag-mobile-nav-grid button{
    display:flex!important;
    align-items:center!important;
    justify-content:flex-start!important;
    gap:8px!important;
    padding:8px 10px!important;
  }
  .elitag-mobile-nav-grid button.is-active{
    background:#e9f7f7!important;
    border-color:#006b70!important;
    color:#006b70!important;
  }
  .elitag-mobile-nav-ico{
    width:22px!important;
    text-align:center!important;
    font-size:17px!important;
  }
  .elitag-mobile-nav-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:8px!important;
    margin-top:10px!important;
  }
  .elitag-mobile-nav-actions button{
    background:#006b70!important;
    color:#fff!important;
    border-color:#006b70!important;
  }
}

@media (min-width: 769px){
  .elitag-mobile-nav-toggle,
  .elitag-mobile-nav-panel{
    display:none!important;
  }
}


/* v0.7.06 production mobile Tag-design gestures/fullscreen */
@media (hover:none) and (pointer:coarse){
  body.asb-mobile-layout-active{
    overflow:hidden!important;
  }
  body.asb-mobile-layout-active .asb-modal-backdrop{
    position:fixed!important;
    inset:0!important;
    width:100vw!important;
    height:100dvh!important;
    z-index:2147483000!important;
    padding:0!important;
    margin:0!important;
    overflow:hidden!important;
    background:#fff!important;
  }
  body.asb-mobile-layout-active .asb-layout-editor-modal,
  body.asb-mobile-layout-active .asb-layout-editor-modal-mobile,
  body.asb-mobile-layout-active .asb-layout-editor-modal-landscape{
    position:fixed!important;
    inset:0!important;
    width:100vw!important;
    max-width:100vw!important;
    height:100dvh!important;
    max-height:100dvh!important;
    margin:0!important;
    border-radius:0!important;
    border:0!important;
    box-shadow:none!important;
    overflow:hidden!important;
    z-index:2147483001!important;
    display:flex!important;
    flex-direction:column!important;
    background:#fff!important;
  }
  body.asb-mobile-layout-active .asb-layout-editor-body{
    flex:1 1 auto!important;
    min-height:0!important;
    overflow:auto!important;
    -webkit-overflow-scrolling:touch!important;
    overscroll-behavior:contain!important;
    touch-action:pan-x pan-y!important;
    padding:8px!important;
    background:#fff!important;
  }
  body.asb-mobile-layout-active .asb-layout-editor-grid{
    display:inline-block!important;
    width:max-content!important;
    max-width:none!important;
    min-width:100%!important;
    margin:0 auto 14px!important;
    transform-origin:center top!important;
    touch-action:pan-x pan-y!important;
  }
  body.asb-mobile-layout-active .asb-layout-editor-grid.asb-layout-pinch-active{
    touch-action:none!important;
    transition:none!important;
  }
  body.asb-mobile-layout-active .asb-layout-editor-side{
    display:block!important;
    width:calc(100vw - 22px)!important;
    max-width:calc(100vw - 22px)!important;
    margin:10px auto!important;
    text-align:left!important;
  }
  body.asb-mobile-layout-active .asb-fields,
  body.asb-mobile-layout-active .asb-fields-2,
  body.asb-mobile-layout-active .asb-fields-3,
  body.asb-mobile-layout-active .asb-fields-4{
    grid-template-columns:1fr!important;
  }
  body.asb-mobile-layout-landscape .asb-layout-editor-modal,
  body.asb-mobile-layout-landscape .asb-layout-editor-modal-landscape{
    width:100vw!important;
    height:100dvh!important;
    max-height:100dvh!important;
  }
  body.asb-mobile-layout-landscape .asb-layout-editor-modal .asb-modal-head{
    max-height:42px!important;
    min-height:36px!important;
    overflow:hidden!important;
    padding:5px 8px!important;
  }
  body.asb-mobile-layout-landscape .asb-layout-editor-modal .asb-modal-head .asb-muted{
    display:none!important;
  }
  body.asb-mobile-layout-landscape .asb-layout-editor-modal .asb-modal-actions{
    max-height:40px!important;
    min-height:36px!important;
    padding:4px 8px!important;
  }
  body.asb-mobile-layout-landscape .asb-layout-editor-body{
    height:calc(100dvh - 78px)!important;
    max-height:calc(100dvh - 78px)!important;
    padding:4px!important;
  }
}

/* v0.7.06 financial customer PDF export */
.asb-card-pdf-export .button{margin-top:10px;}

/* v0.7.06 PDF fallback */
@media print{.no-print{display:none!important;}}
