@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=DM+Sans:wght@300;400;500;600&display=swap');
:root{--gold:#C9A84C;--gold-l:#E2C97E;--gold-bg:#FAF5E8;--gold-dim:rgba(201,168,76,.12);--gold-dim2:rgba(201,168,76,.22);--ch:#2A2727;--ch2:#3D3A3A;--surface:#F8F6F1;--surface2:#F0ECE4;--white:#fff;--border:#E0DBD3;--border-g:rgba(201,168,76,.3);--text:#2A2727;--muted:#7A7370;--muted2:#9A9390;--green:#3FA56C;--green-bg:#EAF7F0;--green-dim:rgba(42,154,90,.12);--red:#B8625C;--red-bg:#FBF1F0;--blue:#185FA5;--blue-bg:#E8F0FA;--r:8px;--r2:12px;--shadow:0 2px 12px rgba(42,39,39,.08);--shadow-md:0 4px 24px rgba(42,39,39,.12)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;background:var(--surface);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--surface2)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.hdr{background:var(--ch);height:64px;padding:0 22px;display:flex;align-items:center;justify-content:space-between;border-bottom:2.5px solid var(--gold);position:sticky;top:0;z-index:300;box-shadow:0 2px 20px rgba(0,0,0,.3)}
.hdr-logo{display:flex;align-items:center;gap:12px}
.logo-name{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:var(--gold);letter-spacing:.04em}
.logo-sub{font-size:8px;color:rgba(201,168,76,.5);letter-spacing:.14em;text-transform:uppercase;margin-top:2px}
.hdr-obj{font-size:16px;color:#fff;flex:1;text-align:left;padding:0 18px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;letter-spacing:.01em;display:flex;align-items:center;gap:14px;min-width:0}
.hdr-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}
.btn{display:inline-flex;align-items:center;gap:5px;padding:8px 13px;border-radius:var(--r);font-size:11.5px;font-weight:500;cursor:pointer;border:none;font-family:'DM Sans',sans-serif;transition:all .15s;white-space:nowrap}
.btn-gold{background:var(--gold);color:#fff}.btn-gold:hover{background:var(--gold-l);transform:translateY(-1px)}
.btn-ghost{background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.15)}.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-outline{background:var(--white);color:var(--muted);border:1px solid var(--border)}.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-sm{padding:5px 11px;font-size:11px}.btn-danger:hover{border-color:var(--red)!important;color:var(--red)!important}
.tabs{background:var(--white);border-bottom:1px solid var(--border);padding:0 22px;display:flex;overflow-x:auto;position:sticky;top:64px;z-index:200;scrollbar-width:none;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.tabs::-webkit-scrollbar{display:none}
.tab{padding:14px 14px;font-size:12px;color:var(--muted);cursor:pointer;border:none;border-bottom:2.5px solid transparent;background:none;white-space:nowrap;font-family:'DM Sans',sans-serif;transition:all .15s;display:flex;align-items:center;gap:5px}
.tab:hover{color:var(--ch)}.tab.active{color:var(--gold);border-bottom-color:var(--gold);font-weight:500}
.tab-num{width:17px;height:17px;border-radius:50%;background:var(--gold-dim);color:var(--gold);font-size:9px;font-weight:600;display:inline-flex;align-items:center;justify-content:center}
.tab.active .tab-num{background:var(--gold);color:#fff}
.body{padding:20px 22px 80px;max-width:1320px;margin:0 auto}
.sec{display:none}.sec.active{display:block;animation:fi .2s ease}
@keyframes fi{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.sec-title{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:600;color:var(--ch)}
.sec-desc{font-size:12px;color:var(--muted);margin-top:3px;margin-bottom:18px}
.col2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.col3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.s2{grid-column:1/-1}
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--r2);padding:20px;margin-bottom:16px;box-shadow:var(--shadow)}
.card-title{font-size:9.5px;font-weight:600;color:var(--gold);letter-spacing:.12em;text-transform:uppercase;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid var(--border-g);display:flex;align-items:center;gap:8px}
.card-title::before{content:'';display:block;width:3px;height:12px;background:var(--gold);border-radius:2px;flex-shrink:0}
.dvd{height:1px;background:var(--border);margin:14px 0;border:none}
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:4px}
.field label{font-size:11px;font-weight:500;color:var(--muted)}
.hint{font-size:10px;color:var(--muted2);font-style:italic}
.inp-wrap{position:relative}
input[type=text],input[type=number],input[type=date],input[type=password],input[type=email],select,textarea{height:38px;width:100%;padding:0 11px;border:1.5px solid var(--border);border-radius:var(--r);font-size:13px;color:var(--text);font-family:'DM Sans',sans-serif;background:var(--white);outline:none;transition:border .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,.12)}
textarea{height:72px;resize:vertical;padding:9px 11px;line-height:1.5}
select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237A7370' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:28px}
.tr{text-align:right;padding-right:28px}
.trl{text-align:right;padding-left:24px;padding-right:11px}
.pfx{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:11.5px;color:var(--muted);pointer-events:none;font-weight:500}
.sfx{position:absolute;right:11px;top:50%;transform:translateY(-50%);font-size:11.5px;color:var(--muted);pointer-events:none}
.cf{height:38px;padding:0 11px;border:1.5px solid var(--border-g);border-radius:var(--r);font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:600;color:var(--gold);background:var(--gold-dim);display:flex;align-items:center;justify-content:flex-end}
.total-bar{display:flex;justify-content:space-between;align-items:center;background:var(--ch);padding:14px 18px;border-radius:var(--r);margin-top:12px}
.total-bar>span:first-child{font-size:10px;color:rgba(255,255,255,.4);letter-spacing:.1em;text-transform:uppercase}
.total-val{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:600;color:var(--gold)}
.wert-puffer{display:flex;justify-content:space-between;align-items:center;background:var(--green-bg);border:1.5px solid rgba(42,154,90,.3);border-radius:var(--r);padding:10px 14px;margin-top:10px;font-size:12.5px}
.wp-val{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--green)}
.ass-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--surface2)}
.ass-row:last-child{border-bottom:none}
.ass-label{font-size:12.5px;color:var(--muted)}
.ass-inp{display:flex;align-items:center;gap:7px}
.ass-inp input,.ass-inp select{width:75px;height:32px;font-size:12px;text-align:right;padding-right:5px;border-width:1px}
.ass-inp select{width:90px}
.unit{font-size:11px;color:var(--muted)}
.badge{font-size:9px;padding:2px 8px;border-radius:99px;background:var(--gold-dim);color:var(--gold);font-weight:500;border:1px solid rgba(201,168,76,.25)}
.kv{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--surface2);font-size:12.5px}
.kv:last-child{border-bottom:none}
.kv span:first-child{color:var(--muted)}
.kv-val{font-weight:600;color:var(--text)}
.kv-val.gold{color:var(--gold);font-family:'Cormorant Garamond',serif;font-size:16px}
.kv-val.green{color:var(--green)}.kv-val.red{color:var(--red)}
.kv.hl{background:var(--gold-dim);padding:7px 8px;border-radius:var(--r);border-color:transparent}
.kv.hl-g{background:var(--green-bg);padding:7px 8px;border-radius:var(--r);border-color:transparent}
.kv.hl-d{background:var(--ch);padding:9px 10px;border-radius:var(--r);border-color:transparent;margin-top:4px}
.kv.hl-d span:first-child{color:rgba(255,255,255,.6)}
.kv.hl-d .kv-val{color:var(--gold);font-family:'Cormorant Garamond',serif;font-size:18px}
.ltv-labels{display:flex;justify-content:space-between;font-size:10.5px;color:var(--muted);margin:10px 0 5px}
.ltv-bg{height:10px;border-radius:5px;background:rgba(0,0,0,.06);overflow:hidden;border:1px solid var(--border)}
.ltv-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-l));border-radius:4px 0 0 4px;transition:width .5s}
.bank-item{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid var(--surface2)}
.bank-item:last-child{border-bottom:none}
.bank-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;margin-top:4px}
.bank-dot.green{background:var(--green)}.bank-dot.warn{background:var(--gold)}
.bank-title{font-size:12.5px;font-weight:500;margin-bottom:2px}
.bank-desc{font-size:11px;color:var(--muted);line-height:1.4}
.drop-zone{border:2px dashed var(--border-g);border-radius:var(--r);padding:28px 20px;text-align:center;cursor:pointer;background:var(--gold-dim);transition:all .2s;font-size:13px;color:var(--muted)}
.drop-zone:hover,.drop-zone.drag{border-color:var(--gold);background:var(--gold-dim2)}
.drop-icon{font-size:34px;margin-bottom:10px}
.drop-hint{font-size:10.5px;margin-top:5px;opacity:.7}
.img-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-top:12px}
.img-thumb{position:relative;border-radius:var(--r);overflow:hidden;border:1.5px solid var(--border);aspect-ratio:4/3}
.img-thumb img{width:100%;height:100%;object-fit:cover}
.img-del{position:absolute;top:5px;right:5px;background:rgba(0,0,0,.65);color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}
.img-del:hover{background:var(--red)}
.img-lbl{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff;font-size:9.5px;padding:8px 7px 4px}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px}
.kpi{background:linear-gradient(135deg,#1A1818 0%, #1F1D1D 100%);border-radius:12px;padding:20px;position:relative;overflow:hidden;border:1px solid rgba(201,168,76,0.20);transition:transform .15s ease,border-color .15s ease}
.kpi:hover{transform:translateY(-2px);border-color:rgba(201,168,76,0.45)}
.kpi::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--gold-l, #E2C97E))}
.kpi-label{font-size:10px;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:8px}
.kpi-val{font-family:'DM Sans',sans-serif;font-size:30px;font-weight:700;color:#fff;line-height:1.1;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.kpi-val.gn{color:#2FBE6E}.kpi-val.rd{color:#D55B5B}
.kpi-sub{font-size:11px;color:rgba(255,255,255,.45);margin-top:6px;letter-spacing:.02em}
.scen-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:16px}
.scen{border-radius:var(--r);padding:16px;border:1.5px solid var(--border);box-shadow:var(--shadow)}
.scen.today{background:var(--green-bg);border-color:rgba(42,154,90,.35)}
.scen.ezb{background:var(--gold-bg);border-color:var(--border-g)}
.scen.dark{background:var(--ch);border-color:transparent}
.scen-label{font-size:9px;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:6px}
.scen.today .scen-label{color:var(--green)}.scen.ezb .scen-label{color:var(--gold)}.scen.dark .scen-label{color:rgba(255,255,255,.45)}
.scen-val{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:600}
.scen.today .scen-val{color:var(--green)}.scen.ezb .scen-val{color:var(--ch)}.scen.dark .scen-val{color:var(--gold-l)}
.scen-sub{font-size:10.5px;color:var(--muted);margin-top:3px}
.scen.dark .scen-sub{color:rgba(255,255,255,.35)}
.chart-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r2);padding:18px;margin-bottom:16px;box-shadow:var(--shadow)}
.chart-title{font-size:9.5px;font-weight:600;color:var(--gold);letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
.chart-lbl{color:var(--muted2);font-weight:400;font-size:9px}
.table-wrap{overflow-x:auto;border-radius:var(--r)}
.cft{width:100%;border-collapse:collapse;font-size:11.5px}
.cft th{background:var(--ch);color:rgba(201,168,76,.8);padding:8px 9px;text-align:right;font-weight:500;font-size:9.5px;letter-spacing:.05em;white-space:nowrap}
.cft th.tal{text-align:left}
.cft td{padding:7px 9px;text-align:right;border-bottom:1px solid var(--surface2);white-space:nowrap}
.cft td.tal{text-align:left;font-weight:600}
.cft tr:hover td{background:var(--gold-dim)!important}
.cft tr.ezb td{background:var(--gold-bg);font-weight:500}
.pos{color:var(--green);font-weight:600}.neg{color:var(--red)}
.table-hint{font-size:10.5px;color:var(--muted);margin-top:10px;padding:8px 12px;background:var(--surface2);border-radius:var(--r)}
.ai-box{background:var(--ch);border-radius:var(--r2);padding:22px;margin-bottom:16px;border:1px solid rgba(201,168,76,.3);box-shadow:var(--shadow-md)}
.ai-hdr{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.ai-icon{font-size:22px;flex-shrink:0}
.ai-title{font-size:16px;font-weight:700;color:var(--gold)}
.ai-sub{font-size:11.5px;color:rgba(255,255,255,.55);letter-spacing:.02em;margin-top:2px}
.ai-body{font-size:13px;color:rgba(255,255,255,.85);line-height:1.75}
.ai-body a{color:var(--gold)}
.ai-icon{width:38px;height:38px;background:rgba(201,168,76,0.15);border:1.5px solid rgba(201,168,76,0.50);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;color:var(--gold)}
.ai-title{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:var(--gold)}
.ai-sub{font-size:10px;color:rgba(255,255,255,.45);margin-top:1px}
.ai-body{font-size:13px;color:rgba(255,255,255,.85);line-height:1.75}
.ai-body a{color:var(--gold-l, #E2C97E)}
.ai-section{margin-top:14px;padding-top:12px;border-top:1px solid rgba(255,255,255,.10)}
.ai-section-label{font-size:9.5px;text-transform:uppercase;letter-spacing:.12em;font-weight:600;margin-bottom:6px;color:rgba(255,255,255,.55)}
.ai-loading{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.55);font-size:12.5px}
.ai-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);animation:pulse 1.2s ease-in-out infinite}
.ai-dot:nth-child(2){animation-delay:.22s}.ai-dot:nth-child(3){animation-delay:.44s}
@keyframes pulse{0%,100%{opacity:.25}50%{opacity:1}}
.api-key-row{display:flex;gap:9px;align-items:center;margin-top:14px}
.api-key-row input{flex:1;height:38px;padding:0 13px;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.15);border-radius:var(--r);color:rgba(255,255,255,.85);font-family:monospace;font-size:12.5px;outline:none}
.api-key-row input:focus{border-color:var(--gold)}
.api-key-row button{padding:9px 16px;background:rgba(201,168,76,.18);color:var(--gold);border:1.5px solid rgba(201,168,76,.35);border-radius:var(--r);cursor:pointer;font-size:12px;font-family:'DM Sans',sans-serif;transition:all .15s}
.key-status{font-size:10.5px;color:rgba(255,255,255,.35);margin-top:5px}
.ai-btn{width:100%;padding:13px;background:rgba(201,168,76,0.08);color:#8C7430;border:1.8px solid var(--gold);border-radius:var(--r);font-family:'DM Sans',sans-serif;font-size:13.5px;font-weight:600;cursor:pointer;letter-spacing:.04em;transition:all .18s;margin-top:8px}
.ai-btn:hover{background:var(--gold);color:#fff;border-color:var(--gold)}.ai-btn:disabled{opacity:.55;cursor:not-allowed}
.empty-state{color:var(--muted);font-size:13px;text-align:center;padding:32px}
.save-item{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid var(--surface2)}
.save-item:last-child{border-bottom:none}
.save-name{font-size:13.5px;font-weight:500}
.save-date{font-size:11px;color:var(--muted);margin-top:2px}
.save-acts{display:flex;gap:6px}
.saved-btns{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.saved-btns .btn{flex:1;justify-content:center;padding:10px;min-width:150px}
#toast{position:fixed;bottom:28px;right:28px;background:var(--ch);color:var(--gold);padding:13px 22px;border-radius:var(--r);font-size:13.5px;font-weight:500;border:1.5px solid rgba(201,168,76,.35);z-index:9999;transition:all .3s;opacity:0;transform:translateY(10px);pointer-events:none;box-shadow:var(--shadow-md)}
#toast.show{opacity:1;transform:translateY(0)}
#pdf-overlay{position:fixed;inset:0;background:rgba(42,39,39,.85);z-index:9999;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
#pdf-overlay.show{display:flex}
.pdf-modal{background:var(--ch);border:1.5px solid var(--border-g);border-radius:var(--r2);padding:36px 44px;text-align:center;box-shadow:var(--shadow-md)}
.pdf-modal h3{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--gold);margin-bottom:6px}
.pdf-modal p{font-size:12.5px;color:rgba(255,255,255,.5);margin-bottom:24px}
.pdf-progress{width:280px;height:4px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden}
.pdf-progress-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-l));border-radius:2px;transition:width .4s}
.c-gold{color:var(--gold)}.c-green{color:var(--green)}.c-red{color:var(--red)}.c-muted{color:var(--muted)}.fw600{font-weight:600}.fs10{font-size:10px}.fs12{font-size:12px}.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}
@media(max-width:900px){.col2,.col3,.g2,.g3,.kpi-grid,.scen-grid{grid-template-columns:1fr}.s2{grid-column:1}.hdr-obj{display:none}}
@media print{.hdr,.tabs,.ai-btn,.btn,.save-acts,.saved-btns,#pdf-overlay{display:none!important}.sec{display:block!important}.body{padding:10px}.card{break-inside:avoid;box-shadow:none;border:1px solid #ccc}}

/* ── COMPAT ALIASES (kpi-l/v/s = kpi-label/val/sub) ─ */
.kpi-l{font-size:8.5px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.kpi-v{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:600;color:var(--gold);line-height:1.1}
.kpi-v.c-gn,.kpi-v.gn{color:#5ED99E}.kpi-v.c-gd{color:var(--gold-l)}.kpi-v.rd{color:#f08080}
.kpi-s{font-size:10px;color:rgba(255,255,255,.3);margin-top:4px}
/* Bank argument status colors */
.bank-item.ok .bank-dot{background:var(--green)}
.bank-item.warn .bank-dot{background:var(--gold)}
.bank-item.bad .bank-dot{background:var(--red)}
.bank-item.ok .bank-title{color:var(--green)}
.bank-item.warn .bank-title{color:var(--gold)}
.bank-item.bad .bank-title{color:var(--red)}
.bank-item{border-radius:var(--r);padding:10px 12px;margin-bottom:6px;transition:background .2s}
.bank-item.ok{background:rgba(42,154,90,.07);border:1px solid rgba(42,154,90,.2)}
.bank-item.warn{background:rgba(201,168,76,.07);border:1px solid rgba(201,168,76,.2)}
.bank-item.bad{background:rgba(201,76,76,.07);border:1px solid rgba(201,76,76,.2)}
/* DSCR display */
.dscr-badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:600}
.dscr-good{background:var(--green-bg);color:var(--green)}
.dscr-warn{background:rgba(201,168,76,.15);color:var(--gold)}
.dscr-bad{background:var(--red-bg);color:var(--red)}
/* Zaer auto-calc field */
.cf-auto{background:rgba(201,168,76,.08);border-color:rgba(201,168,76,.2);color:var(--muted)}

.ai-key-block {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r);
  padding: 14px;
  margin-top: 12px;
}
.ai-key-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 9px;
}
.ai-key-title {
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,.7);
}
.ai-key-link {
  font-size: 11px;
  color: var(--gold-l);
  text-decoration: none;
  padding: 3px 9px;
  border: 1px solid rgba(201,168,76,.3);
  border-radius: 99px;
  transition: all .15s;
}
.ai-key-link:hover { background: rgba(201,168,76,.15); }
.ai-model-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 9px;
}
.ai-model-label {
  font-size: 11.5px;
  color: rgba(255,255,255,.5);
  white-space: nowrap;
  flex-shrink: 0;
}
.ai-model-select {
  height: 34px;
  background: rgba(255,255,255,.08);
  border: 1.5px solid rgba(255,255,255,.15);
  border-radius: var(--r);
  color: rgba(255,255,255,.8);
  font-family: 'DM Sans', sans-serif;
  font-size: 12.5px;
  flex: 1;
  outline: none;
  padding: 0 10px;
  cursor: pointer;
}
.ai-model-select:focus { border-color: var(--gold); }
.ai-model-select option { background: var(--ch); color: var(--white); }
.ai-key-hint {
  font-size: 10.5px;
  color: rgba(255,255,255,.35);
  margin-top: 8px;
  line-height: 1.5;
}
.ai-key-hint.warn { color: rgba(201,168,76,.6); }

/* ═══════════════════════════════════════════════════
   SIDEBAR LAYOUT V5.3
═══════════════════════════════════════════════════ */
.app-wrap {
  display: grid;
  grid-template-columns: 380px 1fr;     /* V26: deutlich breiter (vorher 260px) für Mockup-Cards */
  min-height: 100vh;
  transition: grid-template-columns 0.25s ease;
}
.app-wrap.sb-collapsed {
  grid-template-columns: 50px 1fr;
}

.sidebar {
  background: var(--ch);
  border-right: 1.5px solid rgba(201,168,76,0.2);
  display: flex;
  flex-direction: column;
  height: 100vh;
  position: sticky;
  top: 0;
  overflow: hidden;
  z-index: 250;
}

.sb-header {
  padding: 0;
  border-bottom: 1px solid rgba(201,168,76,0.2);
  background: var(--ch);
  position: relative;
  overflow: hidden;
}
.sb-banner {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 3.98 / 1;
  object-fit: cover;
  background: var(--ch);
}
/* Toggle button - more compact, doesn't overlap with text */
.sb-toggle { right: 6px !important; top: 6px !important; width: 22px !important; height: 22px !important; font-size: 12px !important; }
.sb-toggle {
  position: absolute;
  right: 8px;
  top: 8px;
  background: rgba(0,0,0,0.4);
  border: 1px solid rgba(201,168,76,0.3);
  color: var(--gold);
  width: 26px; height: 26px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
  z-index: 5;
  backdrop-filter: blur(4px);
}
.sb-toggle:hover {
  background: var(--gold);
  color: var(--ch);
  border-color: var(--gold);
}
.app-wrap.sb-collapsed .sb-toggle { transform: rotate(180deg); }

.sb-actions {
  padding: 14px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.sb-section-title {
  padding: 14px 14px 8px;
  font-size: 9px;
  font-weight: 600;
  color: rgba(201,168,76,0.55);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.sb-list {
  flex: 1;
  overflow-y: auto;
  padding: 0 10px 10px;
}
.sb-empty {
  color: rgba(255,255,255,0.3);
  font-size: 11.5px;
  text-align: center;
  padding: 24px 12px;
  line-height: 1.5;
  font-style: italic;
}

.sb-item {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 7px;
  padding: 10px 11px;
  margin-bottom: 6px;
  cursor: pointer;
  transition: all 0.15s;
  position: relative;
}
.sb-item:hover {
  background: rgba(201,168,76,0.08);
  border-color: rgba(201,168,76,0.3);
}
.sb-item.active {
  background: rgba(201,168,76,0.12);
  border-color: var(--gold);
}
.sb-item-name {
  font-size: 12px;
  font-weight: 500;
  color: rgba(255,255,255,0.85);
  margin-bottom: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sb-item-meta {
  font-size: 9.5px;
  color: rgba(255,255,255,0.35);
  display: flex;
  justify-content: space-between;
}
.sb-item-actions {
  display: flex;
  gap: 4px;
  margin-top: 6px;
  opacity: 0;
  transition: opacity 0.15s;
}
.sb-item:hover .sb-item-actions { opacity: 1; }
.sb-item-btn {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.6);
  padding: 3px 8px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 10px;
  font-family: 'DM Sans', sans-serif;
  transition: all 0.12s;
}
.sb-item-btn:hover {
  border-color: var(--gold);
  color: var(--gold);
}
.sb-item-btn.del:hover {
  border-color: var(--red);
  color: var(--red);
}

.sb-footer {
  display: flex;
  gap: 6px;
  padding: 0;                                    /* V67: spacer nimmt keinen Platz mehr (war 12px) */
  border-top: 1px solid rgba(255,255,255,0.06);
}
.sb-fbtn {
  flex: 1;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.7);
  padding: 8px 6px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 10.5px;
  font-family: 'DM Sans', sans-serif;
  transition: all 0.15s;
}
.sb-fbtn:hover {
  border-color: var(--gold);
  color: var(--gold);
}

.main-col {
  min-width: 0;
  /* V41: clip statt hidden — bricht sticky nicht */
  overflow-x: clip;
}

/* Collapsed sidebar */
.app-wrap.sb-collapsed .sb-banner,
.app-wrap.sb-collapsed .sb-actions,
.app-wrap.sb-collapsed .sb-section-title,
.app-wrap.sb-collapsed .sb-list,
.app-wrap.sb-collapsed .sb-footer { display: none; }
.app-wrap.sb-collapsed .sb-header { padding: 10px; min-height: 50px; }
.app-wrap.sb-collapsed .sb-toggle {
  position: absolute;
  right: 50%;
  top: 50%;
  transform: translate(50%, -50%);
  background: var(--gold);
  color: var(--ch);
  border-color: var(--gold);
  z-index: 10;
}

/* Mobile: sidebar becomes off-canvas */
@media(max-width:900px){
  .app-wrap { grid-template-columns: 1fr; }
  .sidebar {
    position: fixed;
    left: -280px;
    width: 260px;
    transition: left 0.25s;
  }
  .sidebar.open { left: 0; box-shadow: 2px 0 20px rgba(0,0,0,0.4); }
  .app-wrap.sb-collapsed { grid-template-columns: 1fr; }
  .app-wrap.sb-collapsed .sidebar { display: none; }

  /* V124: Tablet-Fix — User-Box bleibt IMMER am unteren Sidebar-Rand sichtbar.
     Marcels Bug: auf dem Tablet schiebt langer Sidebar-Inhalt die User-Box unter
     den Viewport, Abmelden/Mein Plan nicht mehr erreichbar.
     Fix: Sidebar als ganzes ist scrollbar, User-Box klebt sticky am Boden,
     dann der Trigger drüber via sticky-Stack. */
  .sidebar {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  /* Header sticky oben — bleibt beim Scrollen sichtbar */
  .sidebar .sb-header {
    position: sticky;
    top: 0;
    z-index: 60;
  }
  /* User-Box sticky am Boden — wichtigstes UI-Element auf dem Tablet */
  #sb-user {
    position: sticky;
    bottom: 0;
    z-index: 56;
    background: var(--ch);
    border-top: 1px solid rgba(201,168,76,0.20);
    margin: 0 !important;
    border-radius: 0;
    padding-bottom: 6px;
    box-shadow: 0 -8px 20px rgba(20,18,18,0.55);
  }
  /* Aktionen-Trigger sticky knapp drüber */
  .sb-actions-trigger {
    position: sticky;
    bottom: 64px;            /* Höhe der User-Box (avatar + padding) */
    z-index: 55;
    margin-left: 8px;
    margin-right: 8px;
  }
  /* Liste/Portfolio NICHT mehr mit max-height begrenzen — Sidebar scrollt selbst */
  .sb-list-grow { flex: 0 1 auto; overflow-y: visible; min-height: 120px; }
  .sb-portfolio-collapsible { max-height: none; overflow-y: visible; }
}

/* ═══════════════════════════════════════════════════
   CF MODE SWITCHER
═══════════════════════════════════════════════════ */
.cf-switcher {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border-g);
}
.cf-mode-btns {
  display: flex;
  gap: 4px;
  background: var(--surface2);
  padding: 3px;
  border-radius: 7px;
}
.cf-mode-btn {
  padding: 6px 12px;
  border: none;
  background: transparent;
  color: var(--muted);
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  border-radius: 5px;
  font-family: 'DM Sans', sans-serif;
  transition: all 0.15s;
  white-space: nowrap;
}
.cf-mode-btn:hover { color: var(--ch); }
.cf-mode-btn.active {
  background: var(--ch);
  color: var(--gold);
  box-shadow: 0 1px 4px rgba(0,0,0,0.15);
}

/* ═══════════════════════════════════════════════════
   KI PDF TOGGLE (Custom Switch)
═══════════════════════════════════════════════════ */
.ai-pdf-toggle {
  margin-top: 14px;
  padding: 12px 14px;
  background: rgba(201,168,76,0.06);
  border: 1px solid rgba(201,168,76,0.20);
  border-radius: 8px;
}
.ji-switch {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  user-select: none;
}
.ji-switch input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0; height: 0;
}
.ji-slider {
  position: relative;
  width: 38px; height: 20px;
  background: rgba(42,39,39,0.20);
  border-radius: 99px;
  transition: background 0.2s;
  flex-shrink: 0;
}
.ji-slider::before {
  content: '';
  position: absolute;
  left: 2px; top: 2px;
  width: 16px; height: 16px;
  background: #fff;
  border-radius: 50%;
  transition: all 0.2s;
  box-shadow: 0 1px 2px rgba(0,0,0,0.15);
}
.ji-switch input:checked + .ji-slider { background: var(--gold); }
.ji-switch input:checked + .ji-slider::before { transform: translateX(18px); }
/* V63.98: Lesbarkeit auf hellem Hintergrund — vorher rgba(255,255,255,0.8) (= weiß auf weiß) */
.ji-switch-label {
  font-size: 12.5px;
  color: var(--ch);
  font-weight: 600;
}
.ai-pdf-hint {
  font-size: 11px;
  color: var(--muted);
  margin-top: 6px;
  margin-left: 48px;
  line-height: 1.4;
}

/* Print hide sidebar */
@media print {
  .sidebar { display: none !important; }
  .app-wrap { grid-template-columns: 1fr !important; }
}

/* ═══════════════════════════════════════════════════
   INFO BOXES (15%-Grenze, KfW, etc.)
═══════════════════════════════════════════════════ */
.info-box {
  border-radius: var(--r);
  padding: 12px 14px;
  margin-top: 10px;
  border: 1.5px solid;
  background: var(--surface2);
  border-color: var(--border);
}
.info-box.info-gold {
  background: var(--gold-dim);
  border-color: rgba(201,168,76,.35);
}
.info-box.info-blue {
  background: rgba(24,95,165,.08);
  border-color: rgba(24,95,165,.35);
}
.info-box.info-green {
  background: var(--green-bg);
  border-color: rgba(42,154,90,.35);
}
.info-box.info-red {
  background: var(--red-bg);
  border-color: rgba(201,76,76,.35);
}
.info-box.info-muted {
  background: var(--surface2);
  border-color: var(--border);
}
.info-box-title {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ch);
  margin-bottom: 7px;
}
.info-box.info-gold .info-box-title { color: var(--gold-d); }
.info-box.info-blue .info-box-title { color: var(--blue); }
.info-box.info-green .info-box-title { color: var(--green); }
.info-box.info-red .info-box-title { color: var(--red); }
.info-box-content { font-size: 11.5px; line-height: 1.5; color: var(--muted); }
.info-box-content .hint { font-size: 10.5px; }
.info-box-content .kv { padding: 5px 0; font-size: 12px; }

/* KfW Links list */
.kfw-links {
  list-style: none;
  padding: 0;
  margin: 8px 0 0 0;
}
.kfw-links li {
  padding: 5px 0;
  border-top: 1px solid rgba(0,0,0,.06);
}
.kfw-links li:first-child { border-top: none; }
.kfw-links a {
  color: var(--gold-d);
  text-decoration: none;
  font-size: 11.5px;
  font-weight: 500;
  transition: color .15s;
  display: block;
}
.kfw-links a:hover { color: var(--gold); }

/* ═══════════════════════════════════════════════════
   Card Title Row (Toggle inline with title)
═══════════════════════════════════════════════════ */
.ct-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border-g);
}

/* Slim toggle (like switch but smaller) */
.toggle-slim {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  cursor: pointer;
  font-size: 11.5px;
  color: var(--muted);
  user-select: none;
}
.toggle-slim input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 32px;
  height: 18px;
  background: var(--border);
  border-radius: 99px;
  position: relative;
  cursor: pointer;
  transition: background .2s;
  margin: 0;
}
.toggle-slim input[type="checkbox"]::before {
  content: '';
  position: absolute;
  left: 2px;
  top: 2px;
  width: 14px;
  height: 14px;
  background: #fff;
  border-radius: 50%;
  transition: transform .2s;
}
.toggle-slim input[type="checkbox"]:checked {
  background: var(--gold);
}
.toggle-slim input[type="checkbox"]:checked::before {
  transform: translateX(14px);
}
.toggle-slim input[type="checkbox"]:checked + span {
  color: var(--gold-d);
  font-weight: 500;
}

/* ═══════════════════════════════════════════════════
   BWK Mode Switcher
═══════════════════════════════════════════════════ */
.bwk-mode-btns {
  display: flex;
  gap: 4px;
  background: var(--surface2);
  padding: 3px;
  border-radius: 7px;
}
.mode-btn {
  padding: 7px 14px;
  border: none;
  background: transparent;
  color: var(--muted);
  font-size: 11.5px;
  font-weight: 500;
  cursor: pointer;
  border-radius: 5px;
  font-family: 'DM Sans', sans-serif;
  transition: all 0.15s;
  white-space: nowrap;
}
.mode-btn:hover { color: var(--ch); }
.mode-btn.active {
  background: var(--ch);
  color: var(--gold);
  box-shadow: 0 1px 4px rgba(0,0,0,0.15);
}


/* Badge utility classes for Sanierung 15%-Grenze status */
.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 99px;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .02em;
  line-height: 1.4;
  white-space: nowrap;
}
.badge-green { background: var(--green-bg); color: var(--green); border: 1px solid rgba(42,154,90,.3); }
.badge-red { background: var(--red-bg); color: var(--red); border: 1px solid rgba(201,76,76,.3); }
.badge-gold { background: rgba(201,168,76,.12); color: var(--gold-d); border: 1px solid rgba(201,168,76,.3); }
.badge-muted { background: var(--surface2); color: var(--muted); border: 1px solid var(--border); }

/* Small hint text (fine print) */
.hint {
  display: block;
  font-size: 10.5px;
  color: var(--muted);
  margin-top: 3px;
  line-height: 1.4;
}


/* Szenario - Orange variant for Anschluss */
.scen.scen-orange { background: linear-gradient(135deg, #f4a261 0%, #e76f51 100%); color: #fff; }
.scen.scen-orange .scen-label { color: rgba(255,255,255,.85); }
.scen.scen-orange .scen-val { color: #fff; }
.scen.scen-orange .scen-sub { color: rgba(255,255,255,.7); }

/* Wider scen layout - 4 cards */
.scens-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
@media (max-width: 1100px) { .scens-row { grid-template-columns: repeat(2, 1fr); } }

/* ═══════════════════════════════════════════════════
   AUTH MODAL
═══════════════════════════════════════════════════ */
.auth-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20, 18, 18, 0.92);
  backdrop-filter: blur(8px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: authFade 0.25s ease;
}
@keyframes authFade { from { opacity: 0; } to { opacity: 1; } }
.auth-modal {
  background: var(--white);
  border-radius: 14px;
  box-shadow: 0 25px 80px rgba(0,0,0,0.5), 0 0 0 1px rgba(201,168,76,0.2);
  width: 100%;
  max-width: 440px;
  overflow: hidden;
  animation: authSlide 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes authSlide { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.auth-header {
  background: var(--ch);
  padding: 28px 30px 24px;
  text-align: center;
  border-bottom: 2px solid var(--gold);
}
.auth-logo {
  width: 240px;
  max-width: 80%;
  height: auto;
  display: block;
  margin: 0 auto 14px;
  border-radius: 6px;
}
.auth-header h2 {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px;
  color: var(--gold);
  font-weight: 600;
  letter-spacing: 0.02em;
}
.auth-subtitle {
  margin-top: 4px;
  font-size: 11.5px;
  color: rgba(201,168,76,0.6);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.auth-form {
  padding: 26px 30px 24px;
}
.auth-field {
  margin-bottom: 14px;
}
.auth-field label {
  display: block;
  font-size: 11.5px;
  font-weight: 500;
  color: var(--muted);
  margin-bottom: 5px;
}
.auth-field input {
  width: 100%;
  height: 40px;
  padding: 0 12px;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  font-size: 14px;
  font-family: 'DM Sans', sans-serif;
  background: var(--surface);
  outline: none;
  transition: border-color 0.15s, background 0.15s;
}
.auth-field input:focus {
  border-color: var(--gold);
  background: #fff;
}
.auth-error {
  background: var(--red-bg);
  border-left: 3px solid var(--red);
  color: var(--red);
  padding: 10px 12px;
  border-radius: 6px;
  font-size: 12px;
  margin-bottom: 14px;
}
.auth-btn {
  width: 100%;
  height: 44px;
  background: var(--gold);
  color: var(--ch);
  border: none;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  font-family: 'DM Sans', sans-serif;
  cursor: pointer;
  letter-spacing: 0.02em;
  transition: all 0.15s;
}
.auth-btn:hover:not(:disabled) {
  background: var(--gold-d);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(201,168,76,0.4);
}
.auth-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.auth-switch {
  text-align: center;
  margin-top: 18px;
  font-size: 12.5px;
  color: var(--muted);
}
.auth-switch a {
  color: var(--gold-d);
  font-weight: 600;
  text-decoration: none;
}
.auth-switch a:hover { color: var(--gold); text-decoration: underline; }
.auth-footer {
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  text-align: center;
  color: var(--muted);
  font-size: 10.5px;
  line-height: 1.5;
}

/* User info in sidebar */
.sb-user-box {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-top: 1px solid rgba(255,255,255,0.06);
  background: rgba(0,0,0,0.2);
}
.sb-user-info { display: flex; align-items: center; gap: 9px; flex: 1; min-width: 0; }
.sb-user-avatar {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--gold);
  color: var(--ch);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
}
.sb-user-text { flex: 1; min-width: 0; overflow: hidden; }
.sb-user-name {
  font-size: 11.5px;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.sb-user-email {
  font-size: 9.5px;
  color: rgba(255,255,255,0.4);
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.sb-logout-btn {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.5);
  width: 28px; height: 28px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all 0.15s;
}
.sb-logout-btn:hover {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}

/* Mode badge in sidebar user box */
.sb-mode-badge {
  display: inline-block;
  font-size: 9px;
  margin-left: 4px;
  padding: 1px 5px;
  border-radius: 99px;
  background: rgba(255,255,255,0.08);
  vertical-align: middle;
}
.sb-mode-badge.api {
  background: rgba(42,154,90,0.2);
  color: #4dca8d;
  border: 1px solid rgba(42,154,90,0.4);
}
.sb-mode-badge.local {
  background: rgba(201,168,76,0.15);
  color: var(--gold);
}

/* ═══════════════════════════════════════════════════
   PRICING MODAL & SUBSCRIPTION UI
═══════════════════════════════════════════════════ */
.pricing-overlay {
  position: fixed; inset: 0;
  background: rgba(20, 18, 18, 0.94);
  backdrop-filter: blur(8px);
  z-index: 9990;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 40px 20px; overflow-y: auto;
  animation: authFade 0.25s ease;
}
.pricing-modal {
  background: var(--white);
  border-radius: 16px;
  box-shadow: 0 25px 80px rgba(0,0,0,0.5);
  width: 100%; max-width: 1100px;
  position: relative;
  padding: 28px;
}
.pricing-header {
  text-align: center; padding-bottom: 14px;
  position: relative;
}
.pricing-header h2 {
  margin: 0 0 14px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 30px; color: var(--ch);
}
.pricing-close {
  position: absolute; top: -6px; right: -6px;
  background: var(--surface2); border: 1px solid var(--border);
  width: 34px; height: 34px; border-radius: 50%;
  font-size: 22px; color: var(--muted); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.pricing-close:hover { background: var(--red); color: #fff; border-color: var(--red); }
.pricing-toggle {
  display: inline-flex; gap: 4px; padding: 4px;
  background: var(--surface2); border-radius: 9px;
  margin-bottom: 8px;
}
.pricing-toggle button {
  border: none; background: transparent;
  padding: 8px 18px; cursor: pointer;
  font-size: 13px; font-weight: 500;
  font-family: 'DM Sans', sans-serif;
  border-radius: 6px; color: var(--muted);
  transition: all .15s;
}
.pricing-toggle button.active { background: var(--ch); color: var(--gold); }
.save-badge {
  background: var(--green); color: #fff;
  padding: 1px 6px; border-radius: 99px;
  font-size: 9.5px; margin-left: 4px;
  font-weight: 600;
}
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px; margin-top: 22px;
}
@media (max-width: 1000px) {
  .pricing-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .pricing-grid { grid-template-columns: 1fr; }
}
.plan-card {
  border: 1.5px solid var(--border);
  border-radius: 12px;
  padding: 22px 18px;
  position: relative;
  display: flex; flex-direction: column;
  transition: all 0.2s;
}
.plan-card:hover { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(0,0,0,0.08); }
.plan-card.plan-highlight {
  border-color: var(--gold);
  background: linear-gradient(180deg, var(--gold-dim) 0%, #fff 60%);
  box-shadow: 0 8px 24px rgba(201, 168, 76, 0.18);
}
.plan-card.plan-current {
  border-color: var(--green);
  background: linear-gradient(180deg, var(--green-bg) 0%, #fff 60%);
}
.plan-ribbon {
  position: absolute; top: -10px; right: 14px;
  background: var(--gold); color: var(--ch);
  font-size: 10px; font-weight: 700; letter-spacing: .04em;
  padding: 4px 10px; border-radius: 99px;
  text-transform: uppercase;
}
.plan-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px; font-weight: 600; color: var(--ch);
  margin-bottom: 4px;
}
.plan-desc {
  font-size: 11.5px; color: var(--muted);
  margin-bottom: 12px; min-height: 20px;
}
.plan-price {
  font-size: 32px; font-weight: 700; color: var(--ch);
  margin: 8px 0;
}
.plan-price span {
  font-size: 13px; font-weight: 400; color: var(--muted);
  margin-left: 4px;
}
.plan-monthly {
  font-size: 11px; color: var(--muted);
  margin-bottom: 8px;
}
.plan-features {
  list-style: none; padding: 0; margin: 14px 0;
  font-size: 12.5px;
  flex: 1;
}
.plan-features li {
  padding: 5px 0 5px 20px;
  position: relative;
  color: var(--ch);
  border-top: 1px solid var(--border-g);
}
.plan-features li:first-child { border-top: none; }
.plan-features li::before {
  content: '✓'; position: absolute; left: 0;
  color: var(--green); font-weight: 700;
}
.plan-btn {
  width: 100%; height: 40px;
  border: 1.5px solid var(--gold);
  background: transparent; color: var(--gold-d);
  border-radius: 8px;
  font-size: 13px; font-weight: 600;
  font-family: 'DM Sans', sans-serif;
  cursor: pointer; margin-top: 8px;
  transition: all 0.15s;
}
.plan-btn.primary { background: var(--gold); color: var(--ch); }
.plan-btn.primary:hover:not(:disabled) {
  background: var(--gold-d);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(201,168,76,0.4);
}
.plan-btn.current { background: var(--green); color: #fff; border-color: var(--green); }
.plan-btn.free, .plan-btn.unavailable {
  background: var(--surface2); color: var(--muted); border-color: var(--border);
  cursor: not-allowed;
}
.plan-btn:disabled { cursor: not-allowed; }
.pricing-portal {
  text-align: center; margin-top: 22px;
  padding-top: 18px; border-top: 1px solid var(--border);
}
.pricing-portal a { color: var(--gold-d); font-size: 13px; }

/* Upgrade Toast */
.upgrade-toast {
  position: fixed; bottom: 22px; right: 22px;
  background: var(--ch); color: #fff;
  border: 1.5px solid var(--gold);
  border-radius: 12px;
  padding: 14px 18px;
  display: flex; align-items: center; gap: 14px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5);
  max-width: 460px;
  z-index: 9000;
  animation: slideIn 0.3s ease;
}
@keyframes slideIn { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.upgrade-icon {
  background: var(--gold); color: var(--ch);
  width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; font-weight: 700;
  flex-shrink: 0;
}
.upgrade-msg { flex: 1; font-size: 12.5px; }
.upgrade-msg strong { display: block; color: var(--gold); font-size: 13.5px; margin-bottom: 2px; }
.upgrade-cta {
  background: var(--gold); color: var(--ch);
  border: none; border-radius: 7px;
  padding: 8px 14px; font-weight: 600; font-size: 12px;
  cursor: pointer;
}
.upgrade-cta:hover { background: var(--gold-d); }
.upgrade-close {
  background: transparent; border: none;
  color: rgba(255,255,255,0.4); font-size: 22px;
  cursor: pointer; padding: 0 4px;
}
.upgrade-close:hover { color: #fff; }

/* Sidebar subscription badge */
.sb-sub-badge {
  display: flex; align-items: center;
  gap: 6px; padding: 7px 12px 9px;
  background: rgba(0,0,0,0.2);
  font-size: 10.5px;
  color: rgba(255,255,255,0.65);
}
.sb-sub-badge.plan-free .sb-sub-label {
  color: rgba(255,255,255,0.5);
}
.sb-sub-badge.plan-pro .sb-sub-label,
.sb-sub-badge.plan-business .sb-sub-label,
.sb-sub-badge.plan-enterprise .sb-sub-label {
  color: var(--gold); font-weight: 600;
}
.sb-sub-label { flex: 1; }
.sb-sub-upgrade, .sb-sub-manage {
  background: var(--gold); color: var(--ch);
  border: none; border-radius: 5px;
  padding: 3px 8px; font-size: 10px; font-weight: 600;
  cursor: pointer; line-height: 1.4;
  font-family: inherit;
}
.sb-sub-manage {
  background: rgba(255,255,255,0.08); color: var(--gold);
  padding: 3px 7px;
}
.sb-sub-upgrade:hover { background: var(--gold-d); }

/* ═══════════════════════════════════════════════════
   FESH (Fenster/Elektrik/Sanitär/Heizung)
═══════════════════════════════════════════════════ */
.fesh-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 12px;
}
@media (max-width: 1100px) {
  .fesh-grid { grid-template-columns: repeat(2, 1fr); }
}
.fesh-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 10px 8px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  background: var(--surface);
  transition: all 0.15s;
  text-align: center;
  position: relative;
}
.fesh-tile:hover { border-color: var(--gold); background: var(--gold-dim); }
.fesh-tile.active {
  border-color: var(--gold);
  background: var(--gold-dim);
  box-shadow: 0 0 0 2px rgba(201,168,76,0.18);
}
.fesh-tile input[type="checkbox"] {
  position: absolute;
  top: 6px; right: 6px;
  width: 14px; height: 14px;
  cursor: pointer;
}
.fesh-icon {
  font-size: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  width: 36px;
  height: 36px;
  margin: 0 auto 4px;
  color: var(--gold);
  background: linear-gradient(135deg, rgba(201,168,76,0.10), rgba(201,168,76,0.02));
  border-radius: 8px;
  border: 1px solid rgba(201,168,76,0.25);
  transition: all 0.15s;
}
.fesh-icon svg {
  width: 22px;
  height: 22px;
  display: block;
  stroke: currentColor;
  fill: none;
}
.fesh-tile.active .fesh-icon {
  background: linear-gradient(135deg, var(--gold), #9a7f33);
  color: #1a1414;
  border-color: var(--gold);
  box-shadow: 0 4px 10px rgba(201,168,76,0.35);
}
.fesh-name {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--ch);
}
.fesh-cost {
  display: flex;
  align-items: center;
  gap: 3px;
  font-size: 10.5px;
  color: var(--muted);
  margin-top: 2px;
}
.fesh-cost input {
  width: 56px;
  padding: 2px 4px;
  font-size: 10.5px;
  border: 1px solid var(--border);
  border-radius: 3px;
  text-align: right;
  background: var(--white);
  font-family: 'DM Sans', sans-serif;
}
.fesh-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px solid var(--border);
}
.fesh-summary .kv { flex: 1; padding: 0; }
.fesh-apply-btn {
  background: var(--gold);
  color: var(--ch);
  border: none;
  border-radius: 6px;
  padding: 8px 14px;
  font-weight: 600;
  font-size: 11.5px;
  cursor: pointer;
  transition: all 0.15s;
  font-family: 'DM Sans', sans-serif;
}
.fesh-apply-btn:hover { background: var(--gold-d); transform: translateY(-1px); }

/* KfW Recommendations */
.kfw-rec {
  padding: 9px 11px;
  background: rgba(255,255,255,0.5);
  border-left: 3px solid var(--blue);
  border-radius: 4px;
  margin-bottom: 7px;
}
.kfw-rec-head { font-size: 12.5px; color: var(--blue); margin-bottom: 4px; }
.kfw-rec-row { font-size: 11px; padding: 1px 0; color: var(--ch); }
.kfw-rec-row .kfw-label { color: var(--muted); display: inline-block; min-width: 65px; }
.kfw-rec-link {
  display: inline-block;
  margin-top: 5px;
  font-size: 10.5px;
  color: var(--blue);
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════
   BANK EXPORT TABLE
═══════════════════════════════════════════════════ */
.bank-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 10.5px;
  font-family: 'DM Sans', sans-serif;
  margin-top: 12px;
}
.bank-table thead th {
  background: linear-gradient(180deg, var(--ch) 0%, #3d3837 100%);
  color: var(--gold);
  font-weight: 600;
  padding: 7px 4px;
  text-align: left;
  border: 1px solid var(--ch);
  font-size: 9.5px;
  white-space: nowrap;
  vertical-align: top;
}
.bank-table tbody td {
  padding: 6px 4px;
  border: 1px solid var(--border);
  background: #FAF9F4;
  font-size: 10px;
  white-space: nowrap;
}
.bank-table tbody tr:nth-child(even) td {
  background: #F5F1E5;
}
.bank-table tbody tr:hover td {
  background: rgba(201,168,76,.1);
}
.bank-table .num { text-align: right; font-variant-numeric: tabular-nums; }
.bank-table .center { text-align: center; }
.bank-table .empty { color: var(--muted); font-style: italic; }

/* ═══════════════════════════════════════════════════
   PORTFOLIO SUMMARY (Sidebar)
═══════════════════════════════════════════════════ */
.sb-portfolio {
  border-top: 1px solid rgba(255,255,255,0.06);
  padding-top: 10px;
}
.sb-portfolio-content {
  background: rgba(0,0,0,0.18);
  border-radius: 8px;
  padding: 10px 11px;
  margin: 0 8px;
}
.port-row {
  display: flex;
  justify-content: space-between;
  font-size: 10.5px;
  color: rgba(255,255,255,0.55);
  padding: 4px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  gap: 6px;
}
.port-row:last-of-type { border-bottom: none; }
.port-v {
  color: rgba(255,255,255,0.85);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  font-size: 11px;
}
.port-v.port-cf.positive { color: #5fcc8a; }
.port-v.port-cf.negative { color: #e58787; }
.port-btn {
  width: 100%;
  margin-top: 9px;
  background: var(--gold);
  color: var(--ch);
  border: none;
  padding: 7px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.15s;
}
.port-btn:hover { background: var(--gold-d); }

/* Portfolio Detail Modal */
.portfolio-detail-overlay {
  position: fixed; inset: 0;
  background: rgba(20,18,18,0.94);
  backdrop-filter: blur(6px);
  z-index: 9990;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 30px 20px;
  overflow-y: auto;
  animation: authFade 0.25s ease;
}
.portfolio-modal {
  background: var(--white);
  border-radius: 14px;
  box-shadow: 0 25px 80px rgba(0,0,0,0.5);
  width: 100%;
  max-width: 1000px;
  padding: 26px;
  position: relative;
}
.portfolio-modal h2 {
  margin: 0 0 18px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px;
  color: var(--ch);
}
.portfolio-modal .pricing-close { top: 12px; right: 12px; }
.portfolio-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 20px;
}
.port-kpi {
  background: var(--surface2);
  border-left: 3px solid var(--gold);
  padding: 12px 13px;
  border-radius: 7px;
}
.port-kpi-label {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}
.port-kpi-val {
  font-size: 19px;
  font-weight: 700;
  color: var(--ch);
  font-variant-numeric: tabular-nums;
}
.port-kpi-val.green { color: var(--green); }
.port-kpi-val.red { color: var(--red); }
.portfolio-objs-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11.5px;
}
.portfolio-objs-table th,
.portfolio-objs-table td {
  padding: 7px 9px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.portfolio-objs-table th {
  background: var(--surface2);
  font-weight: 600;
  color: var(--ch);
}
.portfolio-objs-table td.num { text-align: right; font-variant-numeric: tabular-nums; }
.portfolio-objs-table tr:hover td { background: var(--gold-dim); }
@media (max-width: 700px) {
  .portfolio-summary-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ═══════════════════════════════════════════════════
   3-PHASE COMPARISON TABLE
═══════════════════════════════════════════════════ */
.phase-compare-card {
  margin-top: 16px;
  margin-bottom: 16px;
}
.phase-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
  margin-top: 8px;
}
.phase-table thead th {
  padding: 10px 12px;
  font-weight: 600;
  font-size: 11.5px;
  text-align: left;
  background: var(--surface2);
  border-bottom: 2px solid var(--border);
  color: var(--ch);
}
.phase-table thead th.num,
.phase-table tbody td.num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.phase-table thead th.phase-h-now { color: var(--green); }
.phase-table thead th.phase-h-ezb { color: var(--gold-d); }
.phase-table thead th.phase-h-an { color: #e76f51; }
.phase-table tbody td {
  padding: 7px 12px;
  border-bottom: 1px solid var(--border-g);
  color: var(--ch);
}
.phase-table tbody tr:hover td {
  background: var(--surface);
}
.phase-table tr.phase-row-hl td {
  background: var(--gold-dim);
  font-weight: 600;
}
.phase-table tr.phase-row-hl td.num {
  color: var(--gold-d);
}
.phase-table td.phase-divider {
  background: var(--ch);
  color: var(--gold);
  font-size: 10.5px;
  font-weight: 600;
  padding: 6px 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.phase-table td.phase-divider:hover {
  background: var(--ch);
}

/* ═══════════════════════════════════════════════════
   HEADER TAGLINE (replaces duplicate logo)
═══════════════════════════════════════════════════ */
.hdr-tagline {
  display: flex;
  align-items: center;
  flex: 1;
}
.tagline-text {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 16px;
  color: var(--gold-d);
  letter-spacing: 0.01em;
  line-height: 1.3;
}
@media (max-width: 1100px) {
  .tagline-text { font-size: 13px; }
}

/* ═══════════════════════════════════════════════════
   CF-PHASE BLOCKS (Heute / EZB / Anschluss)
═══════════════════════════════════════════════════ */
/* V34: Cashflow VOR/NACH Steuern im DealScore-Mockup-Stil */
.cf-phase-block {
  background: linear-gradient(135deg, #1A1818 0%, #1F1D1D 100%);
  border: 1.5px solid var(--gold);
  border-radius: 14px;
  padding: 22px 24px 20px;
  margin-bottom: 14px;
  box-shadow: 0 0 0 1px rgba(201,168,76,0.20), 0 12px 28px rgba(0,0,0,0.25);
  color: rgba(255,255,255,0.92);
}
.cf-phase-block-tax {
  /* nach Steuern: leichter grüner Akzent statt rein gold */
  border-color: rgba(63,165,108,0.65);
  box-shadow: 0 0 0 1px rgba(63,165,108,0.18), 0 12px 28px rgba(0,0,0,0.25);
}
.cf-phase-title {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.cf-phase-block-tax .cf-phase-title {
  color: #6FCB91;
}
.cf-phase-title::before {
  /* Akzent-Linie links neben dem Titel */
  content: '';
  width: 3px;
  height: 16px;
  background: var(--gold);
  border-radius: 2px;
  display: inline-block;
}
.cf-phase-block-tax .cf-phase-title::before { background: #6FCB91; }
.cf-phase-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.cf-phase-card {
  background: rgba(255,255,255,0.04);
  border-radius: 10px;
  padding: 16px 18px;
  border: 1px solid rgba(255,255,255,0.08);
  border-left: 3px solid var(--gold);
  transition: all 0.2s ease;
}
.cf-phase-card:hover {
  transform: translateY(-2px);
  background: rgba(255,255,255,0.06);
  border-left-color: var(--gold);
}
.cf-phase-card.cf-phase-now { border-left-color: #2FBE6E; }
.cf-phase-card.cf-phase-ezb { border-left-color: var(--gold); }
.cf-phase-card.cf-phase-an  { border-left-color: #E5BD53; }
.cf-phase-label {
  font-size: 10.5px;
  font-weight: 700;
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 8px;
}
.cf-phase-val {
  font-size: 28px;
  font-weight: 700;
  color: #fff;
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
  letter-spacing: -0.01em;
}
.cf-phase-val.positive { color: #2FBE6E; }
.cf-phase-val.negative { color: #D55B5B; }
.cf-phase-sub {
  font-size: 11px;
  color: rgba(255,255,255,0.45);
  margin-top: 4px;
  letter-spacing: 0.02em;
}
@media (max-width: 700px) {
  .cf-phase-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════
   SIDEBAR NAV (Bankexport, Track Record)
═══════════════════════════════════════════════════ */
.sb-nav {
  padding: 8px;
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  margin-top: 6px;
}
.sb-nav-btn {
  display: block;
  width: 100%;
  padding: 9px 11px;
  margin: 3px 0;
  background: transparent;
  border: 1px solid rgba(201,168,76,0.3);
  border-radius: 7px;
  color: var(--gold);
  font-size: 11.5px;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  transition: all 0.15s;
}
.sb-nav-btn:hover {
  background: rgba(201,168,76,0.12);
  border-color: var(--gold);
}

/* ═══════════════════════════════════════════════════
   GLOBAL BANKEXPORT VIEW (modal)
═══════════════════════════════════════════════════ */
.global-view-overlay {
  position: fixed; inset: 0;
  background: rgba(20, 18, 18, 0.94);
  backdrop-filter: blur(8px);
  z-index: 9990;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 30px 20px;
  overflow-y: auto;
  animation: authFade 0.25s ease;
}
.global-view-modal {
  background: var(--white);
  border-radius: 14px;
  box-shadow: 0 25px 80px rgba(0,0,0,0.5);
  width: 100%;
  max-width: 1400px;
  padding: 28px;
  position: relative;
}
.global-view-modal h2 {
  margin: 0 0 18px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px;
  color: var(--ch);
  display: flex;
  align-items: center;
  gap: 10px;
}
.global-view-modal .pricing-close {
  position: absolute;
  top: 12px; right: 12px;
}
.global-view-actions {
  display: flex;
  gap: 8px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.bank-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 18px;
}
.bank-sum-card {
  background: var(--surface2);
  border-left: 3px solid var(--gold);
  padding: 12px 14px;
  border-radius: 8px;
}
.bank-sum-label {
  font-size: 10.5px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 4px;
  font-weight: 600;
}
.bank-sum-val {
  font-size: 18px;
  font-weight: 700;
  color: var(--ch);
  font-variant-numeric: tabular-nums;
}
.bank-sum-val.green { color: var(--green); }
@media (max-width: 800px) {
  .bank-summary-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ═══════════════════════════════════════════════════
   TRACK RECORD GRID
═══════════════════════════════════════════════════ */
.trackrec-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
  margin-top: 10px;
}
.trackrec-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 9px;
  padding: 14px;
  transition: all 0.15s;
}
.trackrec-card:hover { border-color: var(--gold); box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
.trackrec-name {
  font-weight: 600;
  color: var(--ch);
  margin-bottom: 2px;
  font-size: 13px;
}
.trackrec-addr {
  font-size: 11.5px;
  color: var(--muted);
  margin-bottom: 6px;
}
.trackrec-meta {
  font-size: 11px;
  color: var(--muted);
  display: flex;
  gap: 6px;
  margin-bottom: 4px;
}
.btn-sm {
  padding: 5px 10px;
  font-size: 11px;
}

/* ═══════════════════════════════════════════════════
   STEUER-MODUL
═══════════════════════════════════════════════════ */
.tax-module-card {
  background: linear-gradient(180deg, #FAFCFD 0%, #FFFFFF 100%);
}
.tax-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
.tax-item {
  display: flex;
  justify-content: space-between;
  padding: 7px 12px;
  background: var(--surface2);
  border-radius: 6px;
  font-size: 12px;
  align-items: center;
}
.tax-item.tax-highlight {
  background: var(--gold-dim);
  border-left: 3px solid var(--gold);
  font-weight: 600;
}
.tax-item.tax-result {
  background: linear-gradient(90deg, #E8F2EC 0%, #F0F8F4 100%);
  border-left: 3px solid var(--green);
  font-weight: 700;
  grid-column: 1 / -1;
  padding: 12px 16px;
}
.tax-label { color: var(--muted); }
.tax-val { font-weight: 600; color: var(--ch); font-variant-numeric: tabular-nums; }
.tax-result .tax-label { font-weight: 700; font-size: 13px; color: var(--ch); }
@media (max-width: 700px) {
  .tax-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════
   STEUERVERLAUF (Timeline)
═══════════════════════════════════════════════════ */
.tax-tl-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(85px, 1fr));
  gap: 6px;
  margin-bottom: 14px;
}
.tax-tl-bar {
  border-left: 4px solid;
  padding: 9px 8px;
  border-radius: 5px;
  text-align: center;
  transition: transform 0.15s;
}
.tax-tl-bar:hover { transform: translateY(-2px); }
.tax-tl-year {
  font-size: 10.5px;
  font-weight: 600;
  color: var(--muted);
  margin-bottom: 3px;
}
.tax-tl-amount {
  font-size: 14px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.tax-tl-label {
  font-size: 9.5px;
  color: var(--muted);
  margin-top: 2px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.tax-tl-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  background: var(--surface2);
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ch);
  margin-top: 10px;
}

/* ═══════════════════════════════════════════════════
   YEARLY TAX FORM (Steuerformular pro Jahr)
═══════════════════════════════════════════════════ */
.ytf-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  flex-wrap: wrap;
  gap: 8px;
}
.ytf-mode-toggle {
  display: inline-flex;
  border: 1px solid var(--border);
  border-radius: 7px;
  overflow: hidden;
}
.ytf-mode-btn {
  padding: 7px 14px;
  background: var(--surface);
  border: none;
  font-size: 12px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  transition: all 0.15s;
}
.ytf-mode-btn.active {
  background: var(--gold);
  color: var(--ch);
}
.ytf-mode-btn:not(.active):hover {
  background: var(--surface2);
}

/* Quick mode table */
.ytf-quick-wrap { overflow-x: auto; }
.ytf-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11.5px;
  font-family: 'DM Sans', sans-serif;
}
.ytf-table thead th {
  background: var(--surface2);
  padding: 8px 6px;
  text-align: left;
  font-weight: 600;
  color: var(--ch);
  border-bottom: 2px solid var(--border);
  font-size: 10.5px;
  white-space: nowrap;
}
.ytf-table thead th.num { text-align: right; }
.ytf-table thead th.ytf-result { color: var(--gold-d); }
.ytf-table tbody td {
  padding: 4px 6px;
  border-bottom: 1px solid var(--border-g);
  vertical-align: middle;
}
.ytf-table td.num { text-align: right; font-variant-numeric: tabular-nums; }
.ytf-table td.ytf-year {
  font-weight: 700;
  color: var(--ch);
  background: var(--surface);
}
.ytf-table td.ytf-result {
  background: var(--surface);
}
.ytf-table td.ytf-computed {
  color: var(--muted);
  font-style: italic;
  background: var(--surface);
}

.ytf-input-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  justify-content: flex-end;
}
.ytf-input-wrap input {
  width: 90px;
  padding: 4px 6px;
  border: 1px solid var(--border);
  border-radius: 4px;
  font-size: 11px;
  text-align: right;
  background: var(--white);
  font-family: 'DM Sans', sans-serif;
  font-variant-numeric: tabular-nums;
}
.ytf-input-wrap input:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(201,168,76,0.2);
}
.ytf-cell.ytf-overridden .ytf-input-wrap input {
  background: rgba(201,168,76,0.12);
  border-color: var(--gold);
  font-weight: 600;
}
.ytf-reset {
  background: none;
  border: 1px solid var(--gold);
  border-radius: 50%;
  width: 18px;
  height: 18px;
  font-size: 11px;
  cursor: pointer;
  color: var(--gold-d);
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ytf-reset:hover { background: var(--gold); color: var(--ch); }
.ytf-auto-hint {
  color: var(--muted);
  font-size: 10px;
  cursor: help;
}

/* Detail mode */
.ytf-detail-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.ytf-year-selector {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--surface2);
  border-radius: 6px;
}
.ytf-year-selector label { font-weight: 600; color: var(--ch); font-size: 12.5px; }
.ytf-year-selector select {
  padding: 5px 10px;
  border: 1px solid var(--border);
  border-radius: 5px;
  background: var(--white);
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 600;
}
.ytf-section {
  background: var(--surface);
  padding: 10px 12px;
  border-radius: 7px;
  border: 1px solid var(--border);
}
.ytf-section-title {
  font-weight: 700;
  color: var(--gold-d);
  font-size: 12px;
  margin-bottom: 6px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--border);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.ytf-section-table { width: 100%; font-size: 11.5px; }
.ytf-section-table td {
  padding: 4px 0;
  vertical-align: middle;
}
.ytf-section-label { color: var(--ch); padding-right: 8px; }
.ytf-summary {
  grid-column: 1 / -1;
  background: linear-gradient(180deg, #FAF7EE 0%, #F5F1E5 100%);
  border: 1px solid var(--gold);
  border-radius: 7px;
  padding: 12px 14px;
}
.ytf-sum-row {
  display: flex;
  justify-content: space-between;
  padding: 4px 0;
  font-size: 12.5px;
  border-bottom: 1px solid rgba(201,168,76,0.2);
}
.ytf-sum-row:last-child { border-bottom: none; }
.ytf-sum-result {
  background: rgba(201,168,76,0.12);
  margin: 4px -8px;
  padding: 6px 8px;
  border-radius: 4px;
}
@media (max-width: 800px) {
  .ytf-detail-wrap { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════
   INFO-TAG (kleines blaues Info-Label im Label)
═══════════════════════════════════════════════════ */
.info-tag {
  display: inline-block;
  font-size: 9.5px;
  background: rgba(31, 122, 173, 0.12);
  color: #1f7aad;
  padding: 1px 6px;
  border-radius: 3px;
  margin-left: 6px;
  font-weight: 600;
  cursor: help;
  vertical-align: middle;
}

/* ═══════════════════════════════════════════════════
   CHECKBOX ROW (z.B. EK inkl. NK)
═══════════════════════════════════════════════════ */
.checkbox-row {
  background: rgba(201, 168, 76, 0.08);
  border-radius: 6px;
  padding: 8px 10px;
  margin: 6px 0 4px;
}
.cb-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 12px;
  color: var(--ch);
  font-weight: 500;
}
.cb-label input[type="checkbox"] {
  margin: 0;
  width: 16px; height: 16px;
  cursor: pointer;
  accent-color: var(--gold);
}

/* Gold outline button */
.btn-gold-outline {
  background: var(--gold);
  border: 1px solid var(--gold);
  color: var(--ch);
  font-weight: 700;
}
.btn-gold-outline:hover {
  background: var(--gold-d);
  color: white;
}
.btn-gold-outline:hover {
  background: var(--gold);
  color: #fff;
  border-color: var(--gold-d);
}

/* ═══════════════════════════════════════════════════
   CF DISPLAY - Klare Zwischenstufen (Punkt 13)
═══════════════════════════════════════════════════ */
.kv.kv-step {
  background: rgba(201, 168, 76, 0.06);
  border-left: 3px solid var(--gold);
  padding-left: 10px;
  font-weight: 600;
  margin: 4px 0;
}
.kv.kv-result {
  background: linear-gradient(90deg, rgba(201, 168, 76, 0.18) 0%, rgba(201, 168, 76, 0.10) 100%);
  border-left: 4px solid var(--gold-d);
  padding: 8px 12px;
  font-weight: 700;
  margin: 6px 0;
  border-radius: 4px;
  font-size: 13px;
}
.c-blue { color: #1f7aad; }

/* ═══════════════════════════════════════════════════
   PROGRESSION CHART LEGEND
═══════════════════════════════════════════════════ */
.prog-legend {
  display: flex;
  gap: 20px;
  justify-content: center;
  margin-top: 14px;
  font-size: 11.5px;
  color: var(--muted);
}
.prog-legend-item { display: flex; align-items: center; gap: 6px; }
.prog-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  display: inline-block;
}

/* ═══════════════════════════════════════════════════
   MARKTZINSEN (Punkt 3)
═══════════════════════════════════════════════════ */
.market-rates-card {
  background: linear-gradient(135deg, #FAF9F4 0%, #F5F1E5 100%);
  border: 1px solid var(--gold);
  margin-bottom: 12px;
}
.rates-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-top: 10px;
}
@media (max-width: 800px) { .rates-grid { grid-template-columns: repeat(2, 1fr); } }
.rate-tile {
  background: var(--white);
  border-radius: 8px;
  padding: 10px 12px;
  border-left: 3px solid var(--gold);
}
.rate-label {
  font-size: 10.5px;
  color: var(--muted);
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 3px;
}
.rate-val {
  font-size: 22px;
  font-weight: 700;
  color: var(--gold-d);
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
}
.rate-sub {
  font-size: 10px;
  color: var(--muted);
  margin-top: 2px;
}
.rates-trend {
  margin-top: 12px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.6);
  border-radius: 6px;
}
.rates-trend-title {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 6px;
}

/* ═════════════════════════════════════════
   V209: Markt-Zinsen-Modul (Multi-Line + Bar + Empfehlung)
   ═════════════════════════════════════════ */
.mr-v209-card { padding-bottom: 14px; }

/* Tiles mit Delta-Indikator unterhalb des Wertes */
.rate-delta {
  font-size: 10.5px;
  color: var(--muted);
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
  min-height: 14px;
}
.rate-delta.up   { color: #B8625C; }
.rate-delta.up::before   { content: '▲ '; font-size: 8px; }
.rate-delta.down { color: #3FA56C; }
.rate-delta.down::before { content: '▼ '; font-size: 8px; }
.rate-delta.flat { color: var(--muted); }
.rate-delta.flat::before { content: '— '; }

/* Chart-Controls + Toggles */
.mr-chart-controls {
  background: rgba(255,255,255,0.6);
  border-radius: 6px;
  padding: 12px 14px 10px;
}
.mr-chart-title {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.mr-chart-title-text {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.mr-chart-hint {
  font-size: 10.5px;
  color: var(--muted);
  font-style: italic;
}
.mr-chart-toggles {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.mr-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 11px;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 999px;
  background: var(--white);
  color: var(--ch2);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all 160ms;
  font-variant-numeric: tabular-nums;
}
.mr-toggle::before {
  content: '';
  display: inline-block;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--mr-color, var(--gold));
  flex-shrink: 0;
}
.mr-toggle:hover {
  border-color: var(--mr-color, var(--gold));
  transform: translateY(-1px);
}
.mr-toggle.active {
  border-color: var(--mr-color, var(--gold));
  background: color-mix(in srgb, var(--mr-color, var(--gold)) 8%, white);
  color: var(--ch);
}
.mr-toggle:not(.active) {
  opacity: 0.5;
}
.mr-toggle:not(.active)::before { opacity: 0.4; }

/* Bar-Section */
.mr-bar-section {
  margin-top: 14px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.6);
  border-radius: 6px;
}
.mr-bar-title {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.04em;
  margin-bottom: 8px;
}

/* Empfehlungs-Card */
.mr-recommendation {
  margin-top: 16px;
  padding: 14px 16px;
  background: linear-gradient(135deg, #FAF9F4 0%, #F5F1E5 100%);
  border: 1px solid rgba(201,168,76,0.35);
  border-radius: 8px;
  border-left: 3px solid var(--gold);
}
.mr-rec-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.mr-rec-icon {
  width: 24px; height: 24px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--gold);
  background: color-mix(in srgb, var(--gold) 12%, white);
  border-radius: 50%;
}
.mr-rec-label {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--ch);
  letter-spacing: 0.02em;
}
.mr-rec-tag {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 2px 6px;
  border-radius: 3px;
  background: rgba(201,168,76,0.18);
  color: var(--gold-d);
  text-transform: uppercase;
  margin-left: auto;
}
.mr-rec-body {
  font-size: 12.5px;
  color: var(--ch2);
  line-height: 1.6;
}
.mr-rec-empty {
  color: var(--muted);
  font-style: italic;
  font-size: 12px;
}
.mr-rec-headline {
  font-size: 15px;
  font-weight: 700;
  color: var(--ch);
  margin-bottom: 6px;
}
.mr-rec-headline strong { color: var(--gold-d); }
.mr-rec-reasoning {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed rgba(0,0,0,0.10);
  color: var(--ch2);
  font-size: 12px;
  line-height: 1.6;
}
.mr-rec-context-line {
  font-size: 11.5px;
  color: var(--muted);
  font-style: italic;
  margin-top: 4px;
}
.mr-rec-risk {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 999px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.02em;
  margin-right: 4px;
}
.mr-rec-risk.low    { background: rgba(63,165,108,0.15); color: #2F8A56; }
.mr-rec-risk.medium { background: rgba(201,168,76,0.18); color: var(--gold-d); }
.mr-rec-risk.high   { background: rgba(184,98,92,0.15); color: #9C453F; }

/* Disclaimer */
.mr-disclaimer {
  margin-top: 14px;
  padding: 10px 12px;
  background: rgba(0,0,0,0.025);
  border-radius: 6px;
  font-size: 11px;
  color: var(--muted);
  line-height: 1.55;
}
.mr-disclaimer strong { color: var(--ch2); }

/* ═════════════════════════════════════════
   END V209
   ═════════════════════════════════════════ */

/* ═════════════════════════════════════════
   V210: Pfandbrief-Konditionen-Card
   ═════════════════════════════════════════ */
.mr-pf-card {
  margin-top: 12px;
  background: linear-gradient(135deg, #FAF9F4 0%, #F5F1E5 100%);
  border: 1px solid rgba(201,168,76,0.4);
}
.mr-pf-intro {
  margin: 8px 0 14px;
  font-size: 12px;
  color: var(--ch2);
  line-height: 1.55;
}

/* Marge-Picker (3 große, klickbare Karten) */
.mr-pf-margin-picker {
  display: flex;
  gap: 8px;
  margin-bottom: 14px;
  flex-wrap: wrap;
  align-items: stretch;
}
.mr-pf-margin-label {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
  padding: 0 4px;
  align-self: center;
}
.mr-pf-margin-btn {
  flex: 1;
  min-width: 140px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  padding: 8px 12px;
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 8px;
  background: var(--white);
  color: var(--ch2);
  cursor: pointer;
  transition: all 150ms;
  text-align: left;
}
.mr-pf-margin-btn:hover {
  border-color: var(--gold);
  transform: translateY(-1px);
}
.mr-pf-margin-btn.active {
  border-color: var(--gold);
  background: color-mix(in srgb, var(--gold) 12%, white);
  color: var(--ch);
}
.mr-pf-margin-btn-title {
  font-size: 12px;
  font-weight: 700;
}
.mr-pf-margin-btn-hint {
  font-size: 10.5px;
  color: var(--muted);
}
.mr-pf-margin-btn.active .mr-pf-margin-btn-hint { color: var(--ch2); }

/* 4 Tiles für 5/10/15/20J */
.mr-pf-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 14px;
}
@media (max-width: 800px) { .mr-pf-grid { grid-template-columns: repeat(2, 1fr); } }
.mr-pf-tile {
  background: var(--white);
  border-radius: 8px;
  padding: 10px 12px;
  border-left: 3px solid var(--gold);
}
.mr-pf-tile-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 4px;
}
.mr-pf-tile-label {
  font-size: 10.5px;
  color: var(--muted);
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.mr-pf-tile-src {
  font-size: 9px;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 3px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.mr-pf-tile-src.live    { background: rgba(63,165,108,0.15);  color: #2F8A56; }
.mr-pf-tile-src.static  { background: rgba(201,168,76,0.15);  color: var(--gold-d); }
.mr-pf-tile-rate {
  font-size: 22px;
  font-weight: 700;
  color: var(--gold-d);
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
  margin: 2px 0;
}
.mr-pf-tile-detail {
  font-size: 10px;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}

/* Chart-Section */
.mr-pf-chart-section {
  padding: 12px 14px;
  background: rgba(255,255,255,0.6);
  border-radius: 6px;
  margin-bottom: 12px;
}
.mr-pf-chart-title {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.04em;
  margin-bottom: 8px;
}

/* Source-Box */
.mr-pf-source {
  font-size: 11.5px;
  color: var(--muted);
  margin-bottom: 8px;
  padding: 8px 12px;
  background: rgba(0,0,0,0.02);
  border-radius: 6px;
}
.mr-pf-source a { color: var(--gold-d); }
.mr-pf-source-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  padding: 2px 6px;
  border-radius: 3px;
  margin-right: 8px;
  text-transform: uppercase;
}
.mr-pf-source-badge.live    { background: rgba(63,165,108,0.15);  color: #2F8A56; }
.mr-pf-source-badge.static  { background: rgba(201,168,76,0.15);  color: var(--gold-d); }
.mr-pf-source-badge.mixed   { background: rgba(91,168,159,0.15);  color: #2F7A75; }
.mr-pf-source-badge.unavailable { background: rgba(184,98,92,0.15); color: #9C453F; }

/* ═════════════════════════════════════════
   END V210
   ═════════════════════════════════════════ */

/* ═════════════════════════════════════════
   V211: Markt-Kontext-Card (EZB + EURIBOR)
   ═════════════════════════════════════════ */
.mr-ctx-card {
  background: linear-gradient(135deg, #F0F5F4 0%, #E5EEED 100%);
  border: 1px solid rgba(91,168,159,0.35);
  margin-bottom: 12px;
}
.mr-ctx-intro {
  margin: 8px 0 14px;
  font-size: 12px;
  color: var(--ch2);
  line-height: 1.55;
}
.mr-ctx-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-bottom: 10px;
}
@media (max-width: 700px) { .mr-ctx-grid { grid-template-columns: 1fr; } }
.mr-ctx-tile {
  background: var(--white);
  border-radius: 8px;
  padding: 12px 14px;
  border-left: 3px solid #5BA89F;
}
.mr-ctx-tile-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 4px;
}
.mr-ctx-tile-label {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.mr-ctx-tile-src {
  font-size: 9px;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 3px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.mr-ctx-tile-src.live   { background: rgba(63,165,108,0.15);  color: #2F8A56; }
.mr-ctx-tile-src.static { background: rgba(201,168,76,0.15);  color: var(--gold-d); }
.mr-ctx-tile-rate {
  font-size: 28px;
  font-weight: 700;
  color: #2F7A75;
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
  margin: 4px 0;
}
.mr-ctx-tile-detail {
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 6px;
  font-variant-numeric: tabular-nums;
}
.mr-ctx-trend {
  display: inline-block;
  width: 14px;
  margin-right: 4px;
  font-weight: 700;
}
.mr-ctx-trend.up   { color: #B8625C; }
.mr-ctx-trend.down { color: #3FA56C; }
.mr-ctx-trend.flat { color: var(--muted); }
.mr-ctx-tile-explain {
  font-size: 10.5px;
  color: var(--muted);
  line-height: 1.5;
  padding-top: 6px;
  border-top: 1px solid rgba(0,0,0,0.05);
}
.mr-ctx-source {
  font-size: 11px;
  color: var(--muted);
  padding: 6px 10px;
  background: rgba(0,0,0,0.02);
  border-radius: 6px;
}
.mr-ctx-source a { color: #2F7A75; }
/* ═════════════════════════════════════════
   END V211
   ═════════════════════════════════════════ */

/* ═════════════════════════════════════════
   V212: Collapsible Market-Cards
   ═════════════════════════════════════════ */
.card[data-collapsible] {
  position: relative;
}
.card[data-collapsible] .v212-collapse-toggle {
  background: transparent;
  border: 1px solid rgba(0,0,0,0.15);
  border-radius: 6px;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform 180ms, background 120ms;
  color: var(--ch2);
  flex-shrink: 0;
  margin-left: 6px;
  padding: 0;
  line-height: 1;
}
.card[data-collapsible] .v212-collapse-toggle:hover {
  background: rgba(0,0,0,0.04);
}
.card[data-collapsible].v212-collapsed .v212-collapse-toggle {
  transform: rotate(-90deg);
}
.card[data-collapsible].v212-collapsed .v212-collapse-body {
  display: none;
}
/* Wenn eingeklappt: Card-Padding reduzieren */
.card[data-collapsible].v212-collapsed {
  padding-bottom: 12px;
}
/* Header bleibt immer sichtbar, Body verschwindet */
.card[data-collapsible] .ct-row {
  margin-bottom: 0;
}
.card[data-collapsible]:not(.v212-collapsed) .ct-row {
  margin-bottom: 10px;
}
/* Hint-Text wenn collapsed (kleiner Sublabel) */
.v212-collapse-hint {
  font-size: 11px;
  color: var(--muted);
  margin-left: 8px;
  font-weight: 400;
  font-style: italic;
}
.card[data-collapsible]:not(.v212-collapsed) .v212-collapse-hint {
  display: none;
}
/* ═════════════════════════════════════════
   END V212
   ═════════════════════════════════════════ */

/* ═════════════════════════════════════════
   V212: Card-Collapse-Verhalten
   ═════════════════════════════════════════ */
.card-collapse-btn {
  background: transparent;
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 6px;
  padding: 5px 7px;
  cursor: pointer;
  color: var(--ch2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 6px;
  transition: all 150ms;
}
.card-collapse-btn:hover {
  border-color: var(--gold);
  color: var(--gold-d);
}
.card-collapse-btn svg {
  transition: transform 200ms ease;
}
/* Aufgeklappt: Chevron nach oben drehen */
.card:not(.card-collapsed) .card-collapse-btn svg {
  transform: rotate(180deg);
}

/* Eingeklappt: Alles außer ct-row (Header) verstecken */
.card.card-collapsed > *:not(.ct-row):not(.ct) {
  display: none !important;
}
/* Spezialfall: direkter Text-Block oder p direkt nach ct ist ein Intro — auch verstecken */
.card.card-collapsed .mr-pf-intro,
.card.card-collapsed .mr-ctx-intro {
  display: none !important;
}
/* Card-Padding/Margin im eingeklappten Zustand etwas kompakter */
.card.card-collapsed {
  padding-bottom: 12px;
}
.card.card-collapsed .ct-row {
  margin-bottom: 0;
}
/* ═════════════════════════════════════════
   END V212
   ═════════════════════════════════════════ */

/* ═════════════════════════════════════════
   V213: Zinsannahme-Card (HAUPT) + Layout-Fixes
   ═════════════════════════════════════════ */

/* HAUPT-CARD: immer offen, prominent */
.v213-zins-card {
  background: linear-gradient(135deg, #FAF9F4 0%, #F5F1E5 100%);
  border: 1px solid rgba(201,168,76,0.5);
  border-left: 4px solid var(--gold, #C9A84C);
  padding: 18px 20px;
  margin-bottom: 16px;
}
.v213-zins-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(0,0,0,0.06);
  margin-bottom: 14px;
}
.v213-zins-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--ch, #2A2727);
  letter-spacing: 0.01em;
}
.v213-zins-badge {
  background: rgba(63,165,108,0.15);
  color: #2F8A56;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 4px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.v213-zins-badge.is-static {
  background: rgba(201,168,76,0.15);
  color: var(--gold-d, #8E7536);
}

/* Empfehlungs-Banner */
.v213-recommend {
  background: linear-gradient(135deg, rgba(201,168,76,0.10) 0%, rgba(201,168,76,0.04) 100%);
  border-left: 3px solid var(--gold, #C9A84C);
  padding: 12px 16px;
  border-radius: 0 6px 6px 0;
  margin-bottom: 16px;
}
.v213-recommend-label {
  font-size: 10.5px;
  font-weight: 700;
  color: #8E7536;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 4px;
}
.v213-recommend-text {
  font-size: 13.5px;
  color: var(--ch, #2A2727);
  line-height: 1.55;
}
.v213-recommend-text strong {
  font-weight: 600;
  color: var(--ch, #2A2727);
}

/* 4 Tiles — robustes Grid mit !important damit andere .card-Regeln nicht stören */
.v213-tiles {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 10px !important;
  margin-bottom: 14px !important;
}
@media (max-width: 800px) {
  .v213-tiles { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 480px) {
  .v213-tiles { grid-template-columns: 1fr !important; }
}
.v213-tile {
  background: #ffffff !important;
  border-radius: 8px !important;
  padding: 14px 16px !important;
  border-left: 3px solid #B0AEA7 !important;
  position: relative !important;
  display: block !important;
  min-width: 0 !important;
}
.v213-tile.is-recommended {
  border-left-color: var(--green, #3FA56C) !important;
  background: rgba(63,165,108,0.04) !important;
}
.v213-tile-tag {
  position: absolute !important;
  top: 8px !important;
  right: 10px !important;
  font-size: 9px !important;
  font-weight: 700 !important;
  padding: 2px 6px !important;
  border-radius: 3px !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  background: rgba(63,165,108,0.15) !important;
  color: #2F8A56 !important;
}
.v213-tile-label {
  font-size: 10.5px !important;
  color: var(--muted, #5F5E5A) !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  margin-bottom: 6px !important;
}
.v213-tile-rate {
  font-size: 26px !important;
  font-weight: 700 !important;
  color: var(--gold-d, #8E7536) !important;
  font-variant-numeric: tabular-nums !important;
  line-height: 1.05 !important;
  margin: 2px 0 6px !important;
}
.v213-tile.is-recommended .v213-tile-rate {
  color: #2F8A56 !important;
}
.v213-tile-detail {
  font-size: 11px !important;
  color: var(--muted, #5F5E5A) !important;
  font-variant-numeric: tabular-nums !important;
  line-height: 1.45 !important;
}

/* Marge-Picker als Footer */
.v213-margin-footer {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.5);
  border-radius: 6px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.v213-margin-label {
  font-size: 11px;
  color: var(--muted, #5F5E5A);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
}
.v213-margin-btns {
  display: flex;
  gap: 6px;
  flex: 1;
  flex-wrap: wrap;
}
.v213-margin-btn {
  background: white;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 6px;
  padding: 7px 12px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  color: var(--ch2, #444);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  transition: all 120ms;
  line-height: 1.2;
}
.v213-margin-btn:hover {
  border-color: var(--gold, #C9A84C);
}
.v213-margin-btn.active {
  border-color: var(--gold, #C9A84C);
  background: color-mix(in srgb, var(--gold, #C9A84C) 14%, white);
}
.v213-mb-hint {
  font-size: 9.5px;
  color: var(--muted, #5F5E5A);
  font-weight: 400;
}

.v213-source {
  font-size: 11px;
  color: var(--muted, #5F5E5A);
  padding: 4px 0 0;
}
.v213-source a { color: var(--gold-d, #8E7536); }

/* V214: Info-Button + aufklappbare Erklärung */
.v213-margin-info {
  background: white;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 50%;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--gold-d, #8E7536);
  transition: all 120ms;
  padding: 0;
  flex-shrink: 0;
}
.v213-margin-info:hover {
  background: rgba(201,168,76,0.15);
  border-color: var(--gold, #C9A84C);
}
.v213-margin-info.is-active {
  background: var(--gold, #C9A84C);
  color: white;
  border-color: var(--gold, #C9A84C);
}

.v213-margin-info-box {
  background: rgba(255,255,255,0.7);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 8px;
  padding: 14px 18px;
  margin: 0 0 12px;
  animation: v214FadeIn 200ms ease-out;
}
@keyframes v214FadeIn {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}
.v213-mib-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--ch, #2A2727);
  margin-bottom: 8px;
}
.v213-mib-text {
  font-size: 12px;
  color: var(--ch2, #444);
  line-height: 1.55;
  margin-bottom: 10px;
}
.v213-mib-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 10px;
}
.v213-mib-row {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 12px;
  align-items: start;
  padding: 8px 0;
  border-bottom: 1px dashed rgba(0,0,0,0.06);
}
.v213-mib-row:last-child {
  border-bottom: none;
}
@media (max-width: 700px) {
  .v213-mib-row { grid-template-columns: 1fr; gap: 4px; }
}
.v213-mib-tag {
  font-size: 11px;
  font-weight: 700;
  padding: 4px 8px;
  border-radius: 4px;
  text-align: center;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
.v213-mib-tag-prem {
  background: rgba(63,165,108,0.15);
  color: #2F8A56;
}
.v213-mib-tag-std {
  background: rgba(201,168,76,0.15);
  color: #8E7536;
}
.v213-mib-tag-risk {
  background: rgba(184,98,92,0.15);
  color: #B8625C;
}
.v213-mib-desc {
  font-size: 12px;
  color: var(--ch2, #444);
  line-height: 1.5;
}
.v213-mib-note {
  font-size: 11px;
  color: var(--muted, #5F5E5A);
  line-height: 1.5;
  padding: 10px 12px;
  background: rgba(0,0,0,0.03);
  border-radius: 6px;
}
.v213-mib-note strong { color: var(--ch, #2A2727); }

/* Variabel-Risiko: noch deutlicher */
.v213-tile-risk {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(184,98,92,0.10);
  color: #B8625C;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 3px;
  margin-top: 4px;
  letter-spacing: 0.03em;
}

/* ─── LAYOUT-FIX für die bestehenden Cards V210/V211 ─────────── */
/* Wegen ggf. überschreibenden .card-Regeln per !important sichern. */
.card .mr-ctx-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
}
@media (max-width: 700px) { .card .mr-ctx-grid { grid-template-columns: 1fr !important; } }

.card .mr-pf-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
}
@media (max-width: 800px) { .card .mr-pf-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; } }

.card .mr-pf-tile-head,
.card .mr-ctx-tile-head {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
}

.card .mr-pf-margin-picker {
  display: flex !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}

/* ─── Sublabel auf zugeklappten Cards ─────────────────────── */
.v213-card-sub {
  font-size: 11.5px;
  color: var(--muted, #5F5E5A);
  font-weight: 400;
  margin-left: 10px;
  font-style: italic;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.card[data-collapsible]:not(.v212-collapsed) .v213-card-sub {
  display: none;
}

/* V215: Action-Group rechts (Refresh + Chevron zusammen) */
.v215-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.v215-hint {
  font-size: 10.5px;
  color: var(--muted, #5F5E5A);
  font-style: italic;
  cursor: help;
  border-bottom: 1px dotted rgba(0,0,0,0.2);
}

/* ═════════════════════════════════════════
   END V213
   ═════════════════════════════════════════ */

/* ═════════════════════════════════════════
   V1.0: Kompakte Zinsannahme-Card + Modal-Overlay
   ═════════════════════════════════════════ */

/* Kompakt-Card — 2 Zeilen, flach, dezent */
.v10-zins-compact {
  background: #FAF9F4;
  border: 1px solid rgba(201,168,76,0.35);
  border-left: 3px solid var(--gold, #C9A84C);
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 14px;
}
.v10-zc-row1 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.v10-zc-recommend {
  flex: 1;
  min-width: 0;
}
.v10-zc-label {
  display: inline-block;
  background: rgba(63,165,108,0.15);
  color: #2F8A56;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 3px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-right: 8px;
  vertical-align: 2px;
}
.v10-zc-text {
  font-size: 13.5px;
  color: var(--ch, #2A2727);
  line-height: 1.5;
}
.v10-zc-text strong {
  font-weight: 600;
  color: var(--ch, #2A2727);
}
.v10-zc-btn {
  background: white;
  border: 1px solid rgba(201,168,76,0.5);
  color: var(--gold-d, #8E7536);
  padding: 7px 13px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
  transition: all 120ms;
}
.v10-zc-btn:hover {
  background: rgba(201,168,76,0.10);
  border-color: var(--gold, #C9A84C);
}
.v10-zc-row2 {
  display: flex;
  gap: 18px;
  font-size: 12px;
  color: var(--muted, #5F5E5A);
  font-variant-numeric: tabular-nums;
  flex-wrap: wrap;
  padding-top: 6px;
  border-top: 1px solid rgba(0,0,0,0.06);
}
.v10-zc-rate {
  white-space: nowrap;
}
.v10-zc-rate-label {
  font-size: 10.5px;
  color: var(--muted, #5F5E5A);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-right: 3px;
}
.v10-zc-rate.is-recommended .v10-zc-rate-label {
  color: #2F8A56;
}
.v10-zc-rate b {
  color: var(--gold-d, #8E7536);
  font-weight: 600;
  font-size: 13px;
}
.v10-zc-rate.is-recommended b {
  color: #2F8A56;
}
.v10-zc-stand {
  margin-left: auto;
  font-size: 11px;
  color: var(--muted, #5F5E5A);
  font-style: italic;
  white-space: nowrap;
}

/* Modal-Overlay */
.v10-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(42,39,39,0.55);
  z-index: 9999;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 40px 20px;
  overflow-y: auto;
  animation: v10FadeIn 180ms ease-out;
}
@keyframes v10FadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
.v10-modal-content {
  background: var(--surface, #F8F6F1);
  border-radius: 12px;
  max-width: 900px;
  width: 100%;
  margin: 0 auto;
  position: relative;
  padding: 24px 28px 28px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.18);
  animation: v10SlideIn 220ms ease-out;
}
@keyframes v10SlideIn {
  from { transform: translateY(-10px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
.v10-modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  background: transparent;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 8px;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--ch2, #444);
  transition: all 120ms;
}
.v10-modal-close:hover {
  background: rgba(0,0,0,0.06);
  border-color: rgba(0,0,0,0.25);
}
.v10-modal-header {
  margin-bottom: 18px;
  padding-right: 50px;
  border-bottom: 1px solid rgba(0,0,0,0.08);
  padding-bottom: 14px;
}
.v10-modal-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--ch, #2A2727);
  margin: 0 0 4px;
}
.v10-modal-sub {
  font-size: 12.5px;
  color: var(--muted, #5F5E5A);
  margin: 0;
}
.v10-modal-body .card {
  /* Cards im Modal: kein eigenes Margin oben weil Modal-Body Gap-System nutzt */
  margin-bottom: 12px;
}
.v10-modal-body .card:last-child {
  margin-bottom: 0;
}

/* Im Modal sind die Cards immer aufgeklappt — Collapsible-State ignorieren */
.v10-modal-body .card[data-collapsible].v212-collapsed {
  /* nichts — Modal nimmt seine eigene Logik */
}
.v10-modal-body .card[data-collapsible] .v212-collapse-toggle,
.v10-modal-body .card[data-collapsible] .v215-actions > .v212-collapse-toggle {
  display: none;
}

/* Auf Mobile: Modal Full-Screen */
@media (max-width: 700px) {
  .v10-modal-overlay { padding: 0; }
  .v10-modal-content { border-radius: 0; min-height: 100vh; padding: 20px 18px 24px; }
}

/* Hidden Source-Container — die 3 Cards leben hier wenn Modal zu ist */
.v10-cards-source { display: none; }

/* V1.0-Cleanup: alle alten Versions-Foot / Status-Foot Styles deaktiviert.
   Sicherheits-Net falls noch DOM-Reste rumstehen, werden sie unsichtbar. */
.v10-version-foot,
.v10-status-foot,
.v10-version-pill {
  display: none !important;
}

/* ═════════════════════════════════════════
   END V1.0
   ═════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════
   YTF Help-Tooltips, Readonly, Bemerkungen (Punkt 6, 8, 9, 10)
═══════════════════════════════════════════════════ */
.ytf-help {
  display: inline-block;
  margin-left: 4px;
  cursor: help;
  color: #1f7aad;
  background: rgba(31, 122, 173, 0.12);
  width: 14px; height: 14px;
  text-align: center;
  border-radius: 50%;
  font-size: 9.5px;
  font-weight: 700;
  line-height: 14px;
}
.ytf-help:hover {
  background: #1f7aad;
  color: white;
}
.ytf-readonly {
  background: var(--surface2);
  padding: 4px 8px;
  border-radius: 4px;
  color: var(--muted);
  font-style: italic;
  font-size: 11px;
  text-align: right;
  cursor: not-allowed;
}
.ytf-bemerkung-cell { padding-left: 8px; }
.ytf-bemerkung-input {
  width: 140px;
  padding: 3px 6px;
  border: 1px solid var(--border-g);
  border-radius: 3px;
  font-size: 10.5px;
  background: var(--surface);
  color: var(--ch);
  font-family: 'DM Sans', sans-serif;
}
.ytf-bemerkung-input:focus {
  outline: none;
  border-color: var(--gold);
  background: white;
}
.ytf-section-table th { padding-bottom: 4px; }

/* ═══════════════════════════════════════════════════
   CF-DISPLAY V2 (matches new design)
═══════════════════════════════════════════════════ */
.cf-hint {
  font-size: 10.5px;
  color: var(--muted);
  font-weight: 400;
  margin-left: 4px;
}

/* DSCR Box - prominent */
.dscr-box {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  margin-top: 12px;
  background: linear-gradient(90deg, rgba(201,168,76,0.08) 0%, rgba(201,168,76,0.03) 100%);
  border: 1.5px solid var(--gold);
  border-radius: 10px;
}
.dscr-icon {
  font-size: 28px;
  line-height: 1;
}
.dscr-content {
  flex: 1;
}
.dscr-title {
  font-weight: 700;
  font-size: 14px;
  color: var(--ch);
  margin-bottom: 2px;
}
.dscr-sub {
  font-size: 11.5px;
  color: var(--muted);
}
.dscr-result {
  text-align: right;
}
.dscr-formula {
  font-size: 11px;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
  margin-bottom: 2px;
}
.dscr-val {
  font-size: 22px;
  font-weight: 700;
  color: var(--green);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.dscr-val.warn { color: var(--gold-d); }
.dscr-val.bad { color: var(--red); }

/* ═══════════════════════════════════════════════════
   DEALPILOT BRANDING
═══════════════════════════════════════════════════ */
/* Sidebar brand block */
.sb-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 18px 16px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.sb-brand-mark {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.3);
  border-radius: 9px;
  flex-shrink: 0;
}
.sb-brand-text { line-height: 1.15; }
.sb-brand-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: 0.005em;
}
.sb-brand-by {
  font-size: 9.5px;
  color: rgba(255,255,255,0.45);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: 2px;
  font-weight: 600;
}

/* Header brand block */
.hdr-brand {
  display: flex;
  align-items: center;
  flex: 1;
}
.brand-logo {
  display: flex;
  align-items: center;
  gap: 11px;
}
.brand-mark {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px; height: 38px;
  background: var(--ch);
  color: var(--gold);
  border-radius: 8px;
  flex-shrink: 0;
}
.brand-text { line-height: 1.1; }
.brand-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--ch);
  letter-spacing: 0.01em;
  line-height: 1;
}
.brand-by {
  font-size: 9.5px;
  color: var(--muted);
  letter-spacing: 0.07em;
  text-transform: uppercase;
  font-weight: 600;
  margin-top: 3px;
}
@media (max-width: 900px) {
  .brand-name { font-size: 18px; }
  .brand-by { font-size: 8.5px; }
}

/* ═══════════════════════════════════════════════════
   DEALSCORE
═══════════════════════════════════════════════════ */
.dealscore-card {
  margin-bottom: 14px;
  background: linear-gradient(135deg, var(--white) 0%, var(--surface) 100%);
  border: 1px solid var(--border);
}
.ds-flex {
  display: flex;
  gap: 24px;
  align-items: flex-start;
}
.ds-ring {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ds-content {
  flex: 1;
}
.ds-label-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 4px;
}
.ds-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--ch);
}
.ds-pill {
  padding: 4px 12px;
  border-radius: 99px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.ds-pill-green { background: rgba(42,154,90,0.15); color: var(--green); }
.ds-pill-gold { background: rgba(201,168,76,0.18); color: var(--gold-d); }
.ds-pill-red { background: rgba(201,76,76,0.15); color: var(--red); }
.ds-pill-gray { background: rgba(100,100,100,0.12); color: var(--muted); }
.ds-interpretation {
  font-size: 12.5px;
  color: var(--muted);
  font-style: italic;
  margin-bottom: 14px;
  line-height: 1.4;
}
.ds-breakdown {
  margin-top: 10px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 16px;
}
@media (max-width: 800px) {
  .ds-breakdown { grid-template-columns: 1fr; }
  .ds-flex { flex-direction: column; align-items: center; text-align: center; }
}
.ds-row {
  font-size: 11px;
}
.ds-row-head {
  display: flex;
  justify-content: space-between;
  margin-bottom: 3px;
}
.ds-row-label { color: var(--ch); font-weight: 600; }
.ds-weight { color: var(--muted); font-weight: 400; font-size: 10px; }
.ds-row-score { color: var(--ch); font-weight: 700; font-variant-numeric: tabular-nums; }
.ds-bar {
  height: 6px;
  background: rgba(0,0,0,0.06);
  border-radius: 3px;
  overflow: hidden;
}
.ds-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.5s ease;
}
.ds-row-input {
  font-size: 10px;
  color: var(--muted);
  margin-top: 2px;
  font-style: italic;
}
.ds-settings-btn {
  margin-top: 14px;
  padding: 6px 12px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--muted);
  font-size: 11.5px;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
}
.ds-settings-btn:hover {
  border-color: var(--gold);
  color: var(--gold-d);
}

/* Dealscore settings modal */
.ds-settings-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 8px;
}
.ds-setting-row {
  display: grid;
  grid-template-columns: 130px 1fr;
  align-items: center;
  gap: 12px;
}
.ds-setting-row label { font-weight: 600; color: var(--ch); font-size: 12.5px; }
.ds-setting-input {
  display: flex;
  align-items: center;
  gap: 12px;
}
.ds-setting-input input[type="range"] {
  flex: 1;
  accent-color: var(--gold);
}
.ds-w-val {
  min-width: 44px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--ch);
  font-size: 13px;
  text-align: right;
}
.ds-sum-row {
  margin-top: 12px;
  padding: 10px 14px;
  background: var(--surface);
  border-radius: 6px;
  display: flex;
  justify-content: space-between;
  font-weight: 700;
  font-size: 14px;
}

/* ═══════════════════════════════════════════════════
   DEMO MODE BANNER
═══════════════════════════════════════════════════ */
.demo-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: linear-gradient(90deg, rgba(201,168,76,0.18) 0%, rgba(201,168,76,0.06) 100%);
  border: 1px solid var(--gold);
  border-radius: 10px;
  margin-bottom: 14px;
  position: relative;
}
.demo-banner-icon { font-size: 32px; }
.demo-banner-content { flex: 1; }
.demo-banner-title {
  font-weight: 700;
  font-size: 14px;
  color: var(--ch);
  margin-bottom: 2px;
}
.demo-banner-sub {
  font-size: 12px;
  color: var(--muted);
}
.demo-banner-close {
  position: absolute;
  top: 6px; right: 8px;
  background: none;
  border: none;
  font-size: 18px;
  color: var(--muted);
  cursor: pointer;
  padding: 0;
  width: 24px; height: 24px;
}
.demo-banner-close:hover { color: var(--ch); }

/* ═══════════════════════════════════════════════════
   PAYWALL USAGE BADGE
═══════════════════════════════════════════════════ */
.pw-badge {
  margin: 6px 8px 14px;
  background: rgba(201,168,76,0.06);
  border: 1px solid rgba(201,168,76,0.25);
  border-radius: 8px;
  padding: 10px 12px;
}
.pw-plan-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.pw-plan-label {
  font-size: 9.5px;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: 0.08em;
}
.pw-upgrade-btn {
  background: var(--gold);
  color: var(--ch);
  border: none;
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 9.5px;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: 0.04em;
}
.pw-upgrade-btn:hover { background: var(--gold-d); }
.pw-usage { display: flex; flex-direction: column; gap: 3px; }
.pw-row {
  display: flex;
  justify-content: space-between;
  font-size: 10.5px;
  color: rgba(255,255,255,0.55);
}
.pw-row span:last-child {
  color: rgba(255,255,255,0.85);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.pw-row span.pw-empty { color: #e58787; }
.pw-limit-msg {
  margin-top: 8px;
  padding: 6px 8px;
  background: rgba(201,76,76,0.18);
  color: #f0a3a3;
  font-size: 10px;
  text-align: center;
  border-radius: 4px;
  font-weight: 600;
}

/* Upgrade Modal */
.upgrade-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 14px;
}
.up-feat {
  padding: 10px 12px;
  background: var(--surface);
  border-left: 3px solid var(--gold);
  border-radius: 5px;
  font-size: 12.5px;
  color: var(--ch);
}
@media (max-width: 600px) { .upgrade-features { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════
   DEALPILOT BRANDING V2 - Größer, Original-Logo
═══════════════════════════════════════════════════ */
.hdr-brand {
  display: flex;
  align-items: center;
  padding-left: 4px;
}
.brand-dealpilot-logo {
  height: 46px;
  width: auto;
  display: block;
}
@media (max-width: 900px) {
  .brand-dealpilot-logo { height: 34px; }
}

/* Empty top spacer in sidebar (replaces removed brand block) */
.sb-empty-top {
  height: 12px;
}

/* ═══════════════════════════════════════════════════
   PAYWALL BADGE COMPACT (mit Hover-Popover)
═══════════════════════════════════════════════════ */
.pw-compact {
  display: flex;
  align-items: center;
  gap: 7px;
  margin: 4px 8px 8px;
  padding: 6px 10px;
  background: rgba(201,168,76,0.10);
  border: 1px solid rgba(201,168,76,0.25);
  border-radius: 6px;
  cursor: pointer;
  position: relative;
  transition: background 0.15s;
}
.pw-compact:hover {
  background: rgba(201,168,76,0.20);
}
.pw-compact-warn {
  background: rgba(201,76,76,0.14);
  border-color: rgba(201,76,76,0.30);
}
.pw-compact-label {
  font-size: 9px;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: 0.08em;
}
.pw-compact-warn .pw-compact-label {
  color: #f0a3a3;
}
.pw-compact-counter {
  flex: 1;
  font-size: 10px;
  color: rgba(255,255,255,0.7);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
.pw-compact-arrow {
  font-size: 11px;
  color: var(--gold);
  font-weight: 700;
}

/* Popover on hover */
.pw-popover {
  position: absolute;
  left: calc(100% + 6px);
  top: 0;
  background: var(--ch);
  border: 1px solid rgba(201,168,76,0.4);
  border-radius: 8px;
  padding: 12px 14px;
  min-width: 220px;
  z-index: 200;
  display: none;
  box-shadow: 0 6px 20px rgba(0,0,0,0.4);
}
.pw-compact:hover .pw-popover { display: block; }
.pw-pop-title {
  font-size: 9.5px;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: 0.08em;
  margin-bottom: 8px;
  text-transform: uppercase;
}
.pw-pop-cta {
  margin-top: 10px;
  font-size: 11px;
  color: var(--gold);
  text-align: center;
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-weight: 600;
}

.sec-hidden { display: none; }
.sec-hidden.active { display: block; }

/* Sidebar mini brand - just the Junker logo */
.sb-brand-mini {
  padding: 12px 14px 10px;
  display: flex;
  justify-content: center;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.sb-brand-logo {
  max-width: 130px;
  height: auto;
  background: white;
  padding: 6px 10px;
  border-radius: 6px;
  box-shadow: 0 0 0 1px rgba(201,168,76,0.3);
}

/* ═══════════════════════════════════════════════════
   V18: TABS MIT ICONS + SIDEBAR LOGO + AUTH LOGO
═══════════════════════════════════════════════════ */
.hdr-spacer { flex: 0 0 auto; min-width: 12px; }

/* Sidebar DealPilot logo */
.sb-header {
  padding: 22px 16px 18px !important;     /* V27: mehr Höhe für größeres Logo */
  display: flex !important;
  flex-direction: column !important;
  gap: 8px;
  align-items: center;
  position: relative;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.sb-dealpilot-logo {
  width: 100%;
  max-width: 320px;            /* V27: deutlich größer (vorher 200) */
  height: auto;
  display: block;
  margin: 0 auto;
}
.sb-toggle {
  position: absolute !important;
  top: 8px !important;
  right: 8px !important;
  background: rgba(255,255,255,0.08) !important;
  color: var(--gold) !important;
  border: none !important;
  width: 22px !important;
  height: 22px !important;
  border-radius: 4px !important;
  font-size: 13px !important;
  cursor: pointer !important;
  padding: 0 !important;
}

/* Tabs with icons */
.tab {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  padding: 7px 12px !important;
}
.tab-ico {
  font-size: 16px;
  line-height: 1;
}
.tab-lbl {
  font-size: 12px;
  font-weight: 600;
}

/* Auth dealpilot logo */
.auth-dealpilot-logo {
  width: 100%;
  max-width: 240px;
  height: auto;
  display: block;
  margin: 0 auto 14px;
}

/* Settings Modal */
.settings-modal { max-width: 720px; }
.settings-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
  overflow-x: auto;
}
.st-tab {
  padding: 9px 14px;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--muted);
  font-weight: 600;
  font-size: 12px;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  white-space: nowrap;
}
.st-tab.active {
  color: var(--gold-d);
  border-bottom-color: var(--gold);
}
.st-pane { padding: 4px 2px; }
.set-logo-row {
  display: flex; align-items: center; gap: 16px; margin-top: 8px;
}
.set-logo-preview {
  width: 200px; height: 70px;
  background: var(--surface);
  border: 1px dashed var(--border);
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.set-logo-preview img { max-width: 100%; max-height: 100%; }
.set-logo-empty { color: var(--muted); font-size: 11.5px; }
.set-api-status { margin: 8px 0; font-size: 12px; min-height: 18px; }
.settings-footer {
  display: flex; justify-content: flex-end; gap: 8px;
  margin-top: 16px; padding-top: 14px;
  border-top: 1px solid var(--border);
}

/* Disclaimer Box */
.disclaimer-box {
  background: rgba(31, 122, 173, 0.06);
  border-left: 3px solid #1f7aad;
  padding: 12px 16px;
  border-radius: 6px;
  font-size: 11.5px;
  color: var(--muted);
  margin-top: 12px;
  line-height: 1.5;
}
.disclaimer-box strong { color: var(--ch); }

/* LTV warning level (gold/yellow) */
.ltv-warn { color: var(--gold-d, #B89740); font-weight: 600; }

/* ═══════════════════════════════════════════════════
   V19: SIDEBAR LAYOUT - Bottom-Nav + Logo Update
═══════════════════════════════════════════════════ */
.sidebar {
  display: flex !important;
  flex-direction: column;
}
.sb-spacer { flex: 1 1 auto; min-height: 16px; }
.sb-nav-bottom {
  border-top: 1px solid rgba(255,255,255,0.06);
  padding-top: 8px;
  margin-bottom: 4px;
}
/* User box gets a top border to separate from nav */
.sb-user-box {
  border-top: 1px solid rgba(255,255,255,0.08);
  margin-top: 4px;
}

/* ═══════════════════════════════════════════════════
   V20: AUTH MODAL ZENTRIERT
═══════════════════════════════════════════════════ */
.auth-modal .auth-header { text-align: center !important; }
.auth-modal .auth-header h2 { text-align: center; }
.auth-modal .auth-subtitle { text-align: center; }

/* ═══════════════════════════════════════════════════
   V20: SIDEBAR Mehr Platz für Objekte + Submenu
   V29: Layout final — Header fix, Liste scrollt intern,
        Portfolio kann sich öffnen ohne Logo zu überdecken
═══════════════════════════════════════════════════ */
.sidebar {
  display: flex !important;
  flex-direction: column !important;
  height: 100vh !important;
  overflow: hidden;
}

/* V29: Header IMMER fix oben — schrumpft nicht, wird nicht verdrängt */
.sidebar > .sb-header {
  flex: 0 0 auto !important;
  position: sticky;
  top: 0;
  z-index: 5;
  background: var(--ch);
}

/* Free-Plan-Banner / Plan-Pill etc — fix oben */
#paywall-usage {
  flex: 0 0 auto;
}

/* Section-Title über der Objektliste — fix */
.sidebar > .sb-section-title {
  flex: 0 0 auto;
}

/* Objekt-Liste füllt verfügbaren Raum, scrollt intern */
.sb-list-grow {
  flex: 1 1 auto;
  min-height: 80px;
  overflow-y: auto;
  padding: 0 10px;          /* V29: für Mockup-Cards mehr Innen-Padding */
}

/* Portfolio-Block: NICHT mehr per max-height der Liste klauen,
   sondern eigene scrollbare Region innen */
.sb-portfolio-collapsible {
  border-top: 1px solid rgba(255,255,255,0.04);
  flex: 0 0 auto;          /* nimmt nur den Platz den der Inhalt braucht */
  max-height: 38vh;        /* V29: aber maximal 38% des Viewports */
  overflow-y: auto;        /* eigener Scroll falls Inhalt zu groß */
  background: var(--ch);
}

.sb-collapsible-header {
  width: 100%;
  background: transparent;
  border: none;
  color: var(--gold);
  font-size: 9.5px;
  letter-spacing: 0.08em;
  font-weight: 700;
  text-transform: uppercase;
  padding: 10px 14px 6px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  position: sticky;
  top: 0;
  background: var(--ch);
}
.sb-collapsible-header:hover { color: var(--gold-l, #E2C97E); }
.sb-toggle-arrow { font-size: 11px; }

.sb-portfolio-content { padding: 0 12px 8px; }

/* V29: Bottom-Bereiche fix unten, schrumpfen nicht */
.sb-nav-bottom,
.sb-footer,
#sb-user {
  flex: 0 0 auto !important;
}

/* Bottom Nav */
.sb-nav-bottom {
  border-top: 1px solid rgba(255,255,255,0.06);
  padding-top: 6px;
  flex: 0 0 auto;
}

/* User box clickable */
.sb-user-clickable .sb-user-main {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  padding: 8px 10px;
  border-radius: 6px;
  transition: background 0.15s;
}
.sb-user-clickable .sb-user-main:hover {
  background: rgba(255,255,255,0.04);
}
.sb-user-arrow {
  margin-left: auto;
  color: rgba(255,255,255,0.4);
  font-size: 11px;
}
.sb-user-submenu {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 4px 6px;
}
.sb-submenu-btn {
  display: block;
  width: 100%;
  text-align: left;
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.85);
  font-size: 11.5px;
  padding: 7px 10px;
  cursor: pointer;
  border-radius: 4px;
  font-family: 'DM Sans', sans-serif;
}
.sb-submenu-btn:hover {
  background: rgba(201,168,76,0.12);
  color: var(--gold);
}

/* ═══════════════════════════════════════════════════
   V20: PHASE-TABLE HEADER ALIGNMENT
═══════════════════════════════════════════════════ */
.phase-table th.phase-h-now,
.phase-table th.phase-h-ezb,
.phase-table th.phase-h-an {
  text-align: right !important;
  padding-right: 12px;
}
.phase-table td.num {
  text-align: right;
  padding-right: 12px;
  font-variant-numeric: tabular-nums;
}
.phase-table th:first-child {
  text-align: left;
}

/* ═══════════════════════════════════════════════════
   V21/V22: USER MENU NACH OBEN
   Wichtig: !important nötig, weil weiter oben in der Datei
   .sb-user-box{display:flex; align-items:center} steht und
   sonst das Submenü horizontal NEBEN dem User-Eintrag landet.
═══════════════════════════════════════════════════ */
.sb-user-box {
  position: relative;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  margin: 0 6px 6px;
  border-radius: 8px;
  background: rgba(255,255,255,0.02);
  padding: 0 !important;
  gap: 0 !important;
}
.sb-user-box.sb-user-open {
  background: rgba(255,255,255,0.04);
  box-shadow: 0 -4px 16px rgba(0,0,0,0.18);
}
.sb-user-main {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 9px 11px;
  cursor: pointer;
  border-radius: 8px;
  transition: background 0.12s ease;
  width: 100%;
  box-sizing: border-box;
}
.sb-user-main:hover { background: rgba(255,255,255,0.04); }
.sb-user-arrow {
  margin-left: auto;
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  transition: transform 0.15s ease;
}
.sb-user-open .sb-user-arrow { color: var(--gold); }
.sb-user-submenu {
  display: none;
  flex-direction: column;
  gap: 2px;
  padding: 5px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(180deg, rgba(0,0,0,0.18), rgba(0,0,0,0.05));
  border-radius: 8px 8px 0 0;
  animation: sb-fade-up 0.15s ease;
  width: 100%;
  box-sizing: border-box;
}
@keyframes sb-fade-up {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.sb-submenu-btn {
  display: flex;
  align-items: center;
  gap: 9px;
  width: 100%;
  text-align: left;
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.86);
  font-size: 12px;
  font-family: 'DM Sans', sans-serif;
  padding: 8px 10px;
  cursor: pointer;
  border-radius: 5px;
  transition: background 0.12s, color 0.12s;
}
.sb-submenu-btn:hover {
  background: rgba(201,168,76,0.14);
  color: var(--gold);
}
.sb-submenu-btn-danger:hover {
  background: rgba(184, 98, 92, 0.16);
  color: var(--red);
}
.sb-submenu-icon {
  width: 14px;
  text-align: center;
  font-size: 13px;
  opacity: 0.85;
}

/* ═══════════════════════════════════════════════════
   ALLE OBJEKTE VIEW
═══════════════════════════════════════════════════ */
.all-objects-modal { max-width: 1200px; }
.ao-toolbar {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.ao-search {
  flex: 1;
  padding: 9px 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  font-family: 'DM Sans', sans-serif;
  background: var(--white);
}
.ao-search:focus { outline: 2px solid var(--gold); outline-offset: -1px; border-color: var(--gold); }
.ao-stats { color: var(--muted); font-size: 11.5px; white-space: nowrap; }
.ao-empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--muted);
  font-size: 14px;
}
.ao-table-wrap { overflow-x: auto; max-height: 65vh; overflow-y: auto; }
.ao-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
  font-family: 'DM Sans', sans-serif;
}
.ao-table th {
  position: sticky;
  top: 0;
  background: var(--ch);
  color: var(--gold);
  text-align: left;
  padding: 10px 12px;
  font-weight: 600;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}
.ao-table th.num { text-align: right; }
.ao-table th:hover { color: var(--gold-l, #E2C97E); }
.ao-table th.ao-sorted { background: rgba(201,168,76,0.14); color: var(--gold-l, #E2C97E); }
.ao-th-act { width: 80px; text-align: center !important; }
.ao-row td {
  padding: 9px 12px;
  border-bottom: 1px solid var(--border);
}
.ao-row td.num { text-align: right; font-variant-numeric: tabular-nums; }
.ao-row:nth-child(even) td { background: var(--surface); }
.ao-row:hover td { background: rgba(201,168,76,0.06); }
.ao-kz { font-weight: 600; color: var(--ch); }
.ao-load-btn {
  padding: 4px 10px;
  border-radius: 4px;
  border: 1px solid var(--gold);
  background: transparent;
  color: var(--gold-d);
  font-size: 11px;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
}
.ao-load-btn:hover { background: var(--gold); color: var(--white); }
.c-warn { color: var(--gold-d, #B89740); font-weight: 600; }
.ao-footer-info { margin-top: 10px; }

/* Plan-Switcher in Settings */
.dev-badge {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 3px;
  background: var(--gold);
  color: var(--white);
  letter-spacing: 0.04em;
  margin-left: 4px;
}
.plan-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 8px;
}
.plan-card {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
  background: var(--white);
}
.plan-card.plan-current {
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold) inset;
}
.plan-card-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 8px;
}
.plan-card-head strong { font-size: 14px; }
.plan-price { color: var(--gold-d); font-weight: 600; font-size: 12px; }
.plan-features {
  list-style: none;
  padding: 0;
  margin: 0 0 10px 0;
  font-size: 11.5px;
  color: var(--ch2, var(--ch));
}
.plan-features li {
  padding: 3px 0;
  border-bottom: 1px dashed var(--border);
}
.plan-features li:last-child { border-bottom: none; }
@media (max-width: 700px) {
  .plan-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════
   V22: MIETENTWICKLUNG TOGGLE + DETAIL-TABELLE
═══════════════════════════════════════════════════ */
.me-mode-toggle {
  display: inline-flex;
  border: 1px solid rgba(201,168,76,0.35);
  border-radius: 6px;
  overflow: hidden;
  background: rgba(0,0,0,0.18);
}
.me-mode-btn {
  background: transparent;
  border: 0;
  color: var(--muted, rgba(255,255,255,0.55));
  padding: 4px 12px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  transition: background 0.12s, color 0.12s;
}
.me-mode-btn:hover { color: var(--gold); }
.me-mode-btn.active {
  background: var(--gold);
  color: var(--ch);
}
#me_table_wrap table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11.5px;
  font-variant-numeric: tabular-nums;
}
#me_table_wrap th,
#me_table_wrap td {
  padding: 5px 8px;
  text-align: right;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
#me_table_wrap th:first-child,
#me_table_wrap td:first-child { text-align: left; }
#me_table_wrap th {
  color: var(--gold);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 9.5px;
  border-bottom: 1px solid rgba(201,168,76,0.3);
}
#me_table_wrap tr.me-row-hike td {
  color: var(--gold);
  background: rgba(201,168,76,0.05);
}

/* ═══════════════════════════════════════════════════
   V23: NKM/zE Toggle in Mietentwicklung
═══════════════════════════════════════════════════ */
.me-incze-row {
  margin: 8px 0 12px;
  padding: 12px 14px;
  background: rgba(201,168,76,0.08);
  border-left: 3px solid var(--gold);
  border-radius: 0 5px 5px 0;
}
.me-incze-label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  color: var(--ch);                 /* charcoal — lesbar auf hellem Surface */
  cursor: pointer;
  user-select: none;
  line-height: 1.5;
}
.me-incze-label input[type="checkbox"] {
  margin-top: 3px;
  accent-color: var(--gold);
  cursor: pointer;
  flex-shrink: 0;
  width: 16px;
  height: 16px;
}
.me-incze-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}
.me-incze-text strong {
  font-weight: 600;
  color: var(--ch);
  font-size: 13px;
}
.me-incze-desc {
  font-size: 11.5px;
  color: rgba(42,39,39,0.65);
  line-height: 1.45;
  font-weight: 400;
}
/* Legacy-Selektor — falls irgendwo noch genutzt */
.me-incze-label .hint {
  color: rgba(42,39,39,0.55);
  font-size: 11px;
}

/* ═══════════════════════════════════════════════════
   V23: HEADER-OBJEKT-ANZEIGE (Nummer + Adresse linksbündig)
═══════════════════════════════════════════════════ */
.hdr-obj-num {
  background: var(--gold);
  color: var(--ch);
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 4px;
  font-size: 13px;
  letter-spacing: .05em;
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}
.hdr-obj-addr {
  color: #fff;
  font-weight: 500;
  font-size: 16px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.hdr-obj-placeholder {
  color: rgba(255,255,255,.45);
  font-size: 14px;
  font-weight: 400;
  font-style: italic;
}

/* ═══════════════════════════════════════════════════
   V23: SIDEBAR-OBJEKTNUMMER BADGE
═══════════════════════════════════════════════════ */
.sb-item-seq {
  display: inline-block;
  background: rgba(201,168,76,0.18);
  color: var(--gold);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .04em;
  padding: 1px 6px;
  border-radius: 3px;
  margin-right: 6px;
  font-variant-numeric: tabular-nums;
  vertical-align: 1px;
}

/* ═══════════════════════════════════════════════════
   V26: Sidebar-Cards — Mockup-Design (Foto + 3 Mini-Cards)
═══════════════════════════════════════════════════ */
.sb-card {
  display: flex;
  flex-direction: column;
  gap: 2px;                    /* V67: kein Spalt mehr zwischen top und mini-grid (war 6) */
  padding: 8px;                /* V27: kompakter (vorher 10) */
  background: rgba(0,0,0,0.18);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  margin-bottom: 7px;          /* V27: weniger Abstand (vorher 10) */
  cursor: pointer;
  position: relative;
  transition: background .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.sb-card:hover {
  background: rgba(0,0,0,0.28);
  border-color: rgba(201,168,76,0.30);
}
.sb-card.active {
  border-color: var(--gold);
  box-shadow: 0 0 0 1px var(--gold), 0 4px 16px rgba(201,168,76,0.12);
}

/* Top row: Photo + Title-Block */
.sbc-top {
  display: flex;
  gap: 10px;
  align-items: stretch;
}
.sbc-thumb {
  flex: 0 0 64px;              /* V67: größer (war 56px) */
  width: 64px;
  height: 64px;
  background-size: cover;
  background-position: center;
  background-color: rgba(255,255,255,0.04);
  border-radius: 7px;
  border: 1px solid rgba(255,255,255,0.06);
  position: relative;
  overflow: hidden;
}
.sbc-thumb-empty {
  background-color: rgba(255,255,255,0.03);
}
.sbc-thumb-icon {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 32px; height: 32px;   /* V67: passend zum größeren Thumb */
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  border: 1.5px solid var(--gold);
  background: rgba(0,0,0,0.45);
  color: var(--gold);
}
.sbc-thumb-icon svg { width: 18px; height: 18px; }
.sbc-top-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
  /* V67: KEIN space-between mehr — Inhalt rückt nach oben, kein vertikaler Stretch */
  justify-content: flex-start;
}
.sbc-top-line1 {
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  overflow: hidden;
}
.sbc-seq {
  background: var(--gold);
  color: var(--ch);
  font-weight: 700;
  font-size: 9.5px;            /* V27: kleiner */
  letter-spacing: .03em;
  padding: 2px 6px;
  border-radius: 3px;
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}
.sbc-street {
  font-size: 13.5px;           /* V27: kleiner (vorher 16) */
  font-weight: 700;
  color: #fff;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
}
.sbc-ai-badge {
  font-size: 11px;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  color: var(--gold);              /* V74: SVG erbt currentColor → gold */
  filter: drop-shadow(0 0 4px rgba(201,168,76,0.45));
}
.sbc-date {
  font-size: 10px;
  color: rgba(255,255,255,0.45);
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}
.sbc-arrow {
  color: rgba(255,255,255,0.35);
  font-size: 14px;
  font-weight: 300;
  flex-shrink: 0;
}
.sbc-line2 {
  font-size: 11px;             /* V27: kleiner */
  color: rgba(255,255,255,0.55);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sbc-kp {
  font-size: 16px;             /* V27: kleiner (vorher 22) */
  font-weight: 700;
  color: var(--gold);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
  margin-top: 1px;
}

/* Mini-Cards-Grid: DSCR / CF / BMR */
.sbc-mini-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}
.sbcm {
  padding: 6px 8px;            /* V27: kompakter */
  border-radius: 6px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.05);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.sbcm-good { background: rgba(63,165,108,0.10); border-color: rgba(63,165,108,0.20); color: #69C291; }
.sbcm-warn { background: rgba(201,168,76,0.10); border-color: rgba(201,168,76,0.22); color: #DBC179; }
.sbcm-bad  { background: rgba(184,98,92,0.10);  border-color: rgba(184,98,92,0.25);  color: #D58A85; }
.sbcm-info { background: rgba(74,144,201,0.10); border-color: rgba(74,144,201,0.22); color: #6EAFD9; }
.sbcm-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
}
.sbcm-label {
  font-size: 9px;              /* V27: kleiner */
  font-weight: 700;
  letter-spacing: .03em;
  color: rgba(255,255,255,0.7);
  text-transform: uppercase;
}
.sbcm-head .sbcm-info {
  font-size: 8.5px;
  color: rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.06);
  width: 12px; height: 12px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: help;
}
.sbcm-val-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
}
.sbcm-val {
  font-size: 14px;             /* V27: kleiner (vorher 19) */
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
  color: currentColor;
}
.sbcm-alert {
  font-size: 11px;
  color: currentColor;
}
.sbcm-track {
  position: relative;
  height: 3px;
  background: rgba(255,255,255,0.08);
  border-radius: 99px;
  margin-top: 6px;
}
.sbcm-track-fill {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  background: currentColor;
  opacity: 0.5;
  border-radius: 99px;
}
.sbcm-track-marker {
  position: absolute;
  top: 50%;
  width: 0; height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid currentColor;
  transform: translate(-50%, -110%);
}
.sbcm-scale {
  display: flex;
  justify-content: space-between;
  font-size: 8.5px;
  color: rgba(255,255,255,0.4);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}
.sbcm-spark {
  width: 100%;
  height: 22px;                /* V27: kompakter */
  margin-top: 2px;
}
.sbcm-bar {
  height: 3px;                 /* V27: dünner */
  background: rgba(255,255,255,0.08);
  border-radius: 99px;
  margin-top: 4px;
  overflow: hidden;
}
.sbcm-bar-fill {
  height: 100%;
  background: currentColor;
  border-radius: 99px;
  transition: width .3s ease;
}

/* Action-Buttons (Kopieren/Löschen) — on hover */
.sbc-actions {
  position: absolute;
  top: 6px;
  right: 6px;
  display: flex;
  gap: 3px;
  opacity: 0;
  transition: opacity .12s ease;
}
.sb-card:hover .sbc-actions { opacity: 1; }
.sbc-btn {
  width: 24px;
  height: 24px;
  background: rgba(0,0,0,0.65);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 5px;
  color: rgba(255,255,255,0.7);
  cursor: pointer;
  font-size: 13px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sbc-btn:hover { background: rgba(201,168,76,0.20); color: #fff; border-color: var(--gold); }
.sbc-btn.sbc-del:hover { background: rgba(184,98,92,0.40); border-color: #B8625C; }

/* "+ Neues Objekt hinzufügen" Button am Ende der Liste */
.sb-add-new {
  display: block;
  width: 100%;
  margin: 6px 0 14px;
  padding: 12px;
  background: transparent;
  border: 1px dashed rgba(201,168,76,0.30);
  border-radius: 10px;
  color: var(--gold);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-align: center;
  transition: all .15s ease;
}
.sb-add-new:hover {
  background: rgba(201,168,76,0.06);
  border-color: var(--gold);
  border-style: solid;
}

/* ═══════════════════════════════════════════════════
   V25: AI-Analyse Render (neue 7-Block-Struktur)
   V32: dunkles Theme — solidere Block-Cards mit weißen Texten
   V63.69: Basis-Klasse für unmarkierte Blöcke (Gesamtbewertung, Risikoanalyse etc.)
═══════════════════════════════════════════════════ */
.ai-block {
  border-left: 3px solid var(--gold);
  background: rgba(255,255,255,0.04);
  padding: 14px 18px;
  border-radius: 0 6px 6px 0;
  margin: 10px 0;
  color: rgba(255,255,255,0.92);
}
.ai-block h3 {
  color: var(--gold);
  margin: 0 0 10px;
  font-size: 15px;
  font-weight: 700;
}
.ai-block p {
  color: rgba(255,255,255,0.92);
  margin: 0 0 8px;
  line-height: 1.55;
}
.ai-block p:last-child { margin-bottom: 0; }
.ai-block ul {
  margin: 0;
  padding-left: 22px;
  color: rgba(255,255,255,0.92);
}
.ai-block li {
  margin-bottom: 6px;
  line-height: 1.5;
}
.ai-block .ai-sub {
  margin: 8px 0;
  padding: 8px 12px;
  background: rgba(255,255,255,0.04);
  border-radius: 4px;
  font-size: 13.5px;
  line-height: 1.5;
  color: rgba(255,255,255,0.88);
}
.ai-block .ai-sub strong { color: var(--gold-l, #E2C97E); }

.ai-block-green {
  border-left: 3px solid #3FA56C !important;
  background: rgba(63,165,108,0.12);
  padding: 14px 18px;
  border-radius: 0 6px 6px 0;
  margin: 10px 0;
  color: rgba(255,255,255,0.92);
}
.ai-block-green h3 { color: #69C291; margin: 0 0 8px; }
.ai-block-green ul, .ai-block-green li, .ai-block-green p { color: rgba(255,255,255,0.92); }

.ai-block-red {
  border-left: 3px solid #B8625C !important;
  background: rgba(184,98,92,0.14);
  padding: 14px 18px;
  border-radius: 0 6px 6px 0;
  margin: 10px 0;
  color: rgba(255,255,255,0.92);
}
.ai-block-red h3 { color: #D58A85; margin: 0 0 8px; }
.ai-block-red ul, .ai-block-red li, .ai-block-red p { color: rgba(255,255,255,0.92); }

.ai-block-empfehlung {
  border-left: 3px solid var(--gold) !important;
  background: rgba(201,168,76,0.14);
  text-align: center;
  padding: 16px 20px;
  border-radius: 0 6px 6px 0;
  margin: 10px 0;
  color: rgba(255,255,255,0.92);
}
.ai-block-empfehlung h3 { color: var(--gold); margin: 0 0 8px; }
.ai-block-empfehlung p { color: rgba(255,255,255,0.92); }
.ai-empfehlung-row {
  margin: 12px 0;
}
.ai-block-insight {
  border-left: 3px solid var(--gold) !important;
  background: rgba(201,168,76,0.16);
  padding: 14px 18px;
  border-radius: 0 6px 6px 0;
  margin: 10px 0;
  color: rgba(255,255,255,0.92);
}
.ai-block-insight h3 { color: var(--gold); margin: 0 0 8px; }
.ai-block-insight p { color: rgba(255,255,255,0.92); font-style: italic; }

.ai-block-research {
  border-left: 3px solid #4A90C9 !important;
  background: rgba(74,144,201,0.14);
  padding: 14px 18px;
  border-radius: 0 6px 6px 0;
  margin: 10px 0;
  color: rgba(255,255,255,0.92);
}
.ai-block-research h3 { color: #7FB6E2; margin: 0 0 8px; }
.ai-block-research .ai-sub { color: rgba(255,255,255,0.85); background: rgba(255,255,255,0.05); }
.ai-block-research strong { color: #fff; }

.ai-block-sources {
  font-size: 11.5px;
  opacity: 0.85;
  background: rgba(255,255,255,0.04);
  padding: 12px 16px;
  border-radius: 6px;
  margin: 10px 0;
}
.ai-block-sources h3 { color: var(--gold); margin: 0 0 8px; }
.ai-block-sources ul, .ai-block-sources li { color: rgba(255,255,255,0.75); }
.ai-block-sources a { color: var(--gold-l, #E2C97E); }
.ai-sub {
  margin: 8px 0;
  padding: 7px 10px;
  background: rgba(255,255,255,0.025);
  border-radius: 4px;
  font-size: 13px;
  line-height: 1.45;
}
.ai-sub strong { color: var(--gold); }
.ai-scenario-worst { border-left: 2px solid #B8625C; padding-left: 12px; }
.ai-scenario-best  { border-left: 2px solid #3FA56C; padding-left: 12px; }
.ai-fit-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 4px;
}
.ai-fit-row {
  display: grid;
  grid-template-columns: 200px 90px 1fr;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.55);
  border: 1px solid rgba(42,39,39,0.08);
  border-radius: 6px;
}
/* V29: Lesbar auf hellem Hintergrund */
.ai-fit-label { font-weight: 600; color: var(--ch); font-size: 13px; }
.ai-fit-reason { font-size: 12px; color: rgba(42,39,39,0.7); line-height: 1.4; }
@media (max-width: 700px) {
  .ai-fit-row {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "label badge"
      "reason reason";
    row-gap: 6px;
  }
  .ai-fit-row > .ai-fit-label  { grid-area: label; }
  .ai-fit-row > span:nth-child(2) { grid-area: badge; }
  .ai-fit-row > .ai-fit-reason { grid-area: reason; }
}

/* ═══════════════════════════════════════════════════
   V25: Marktzinsen-Quellen-Box
═══════════════════════════════════════════════════ */
.rates-source-box {
  margin-top: 10px;
  padding: 10px 14px;
  background: rgba(201,168,76,0.05);
  border-left: 2px solid var(--gold);
  border-radius: 0 4px 4px 0;
  font-size: 11.5px;
  color: rgba(42,39,39,0.75);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.rates-source-text {
  color: rgba(42,39,39,0.75);
}
.rates-source-text a {
  color: var(--gold-d, #8A7637);
  text-decoration: none;
  border-bottom: 1px dotted var(--gold);
  font-weight: 500;
}
.rates-source-text a:hover { color: var(--ch); border-bottom-color: var(--ch); }
.rates-fallback-warn {
  color: #8A7637;
  font-size: 10.5px;
  margin-left: 6px;
}
.rates-disclaimer {
  font-size: 10.5px;
  color: rgba(42,39,39,0.55);
  font-style: italic;
}

/* ═══════════════════════════════════════════════════
   V25: Mini-AI-Block in Tab Kennzahlen (s6)
═══════════════════════════════════════════════════ */
.ai-mini-card {
  background: linear-gradient(135deg, rgba(201,168,76,0.04) 0%, rgba(201,168,76,0.10) 100%);
  border: 1px solid rgba(201,168,76,0.30);
  margin-bottom: 18px;
}
.ai-mini-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  padding-bottom: 12px;
  margin-bottom: 14px;
  border-bottom: 1px solid rgba(201,168,76,0.20);
}
.ai-mini-title {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 14px;
  font-weight: 600;
  color: var(--ch);                     /* V27: dunkler Text auf hellem Card */
}
.ai-mini-icon { font-size: 18px; }
.ai-mini-tag {
  font-size: 10.5px;
  font-weight: 500;
  color: rgba(42,39,39,0.65);
  background: rgba(201,168,76,0.15);
  padding: 2px 8px;
  border-radius: 99px;
  letter-spacing: .02em;
}
.ai-mini-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}
.ai-mini-link {
  font-size: 11.5px;
  color: var(--gold);
  text-decoration: none;
  border: none;
  background: none;
  cursor: pointer;
  padding: 4px 8px;
  font-weight: 600;
}
.ai-mini-link:hover { text-decoration: underline; }
.ai-mini-empty {
  padding: 20px;
  text-align: center;
  color: rgba(42,39,39,0.65);
  font-size: 13px;
  line-height: 1.5;
}
.ai-mini-empty strong { color: var(--gold); }

.ai-mini-row.ai-mini-headline {
  display: flex;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 14px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.5);
  border: 1px solid rgba(42,39,39,0.08);
  border-radius: 6px;
}
.ai-mini-empf {
  display: inline-block;
  padding: 5px 14px;
  border-radius: 5px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  color: #fff;
  flex-shrink: 0;
}
.ai-mini-summary {
  font-size: 13px;
  color: var(--ch);
  line-height: 1.5;
  flex: 1;
  min-width: 240px;
}

.ai-mini-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 14px;
}
@media (max-width: 700px) {
  .ai-mini-grid { grid-template-columns: 1fr; }
}
.ai-mini-col {
  padding: 10px 12px;
  border-radius: 5px;
  background: rgba(255,255,255,0.55);
  border: 1px solid rgba(42,39,39,0.06);
  border-left: 3px solid;
}
.ai-mini-col-good { border-left-color: #3FA56C; }
.ai-mini-col-bad  { border-left-color: #B8625C; }
.ai-mini-col-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .03em;
  color: var(--ch);
  margin-bottom: 6px;
  text-transform: uppercase;
}
.ai-mini-col ul {
  margin: 0;
  padding-left: 18px;
  font-size: 12.5px;
  line-height: 1.55;
  color: rgba(42,39,39,0.85);
}
.ai-mini-col ul li { margin-bottom: 4px; }
.ai-mini-col ul li:last-child { margin-bottom: 0; }

.ai-mini-insight {
  margin: 14px 0;
  padding: 12px 14px;
  background: rgba(201,168,76,0.10);
  border-left: 3px solid var(--gold);
  border-radius: 0 5px 5px 0;
}
.ai-mini-insight-label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .05em;
  color: var(--gold);
  margin-bottom: 4px;
  text-transform: uppercase;
}
.ai-mini-insight p {
  margin: 0;
  font-size: 13px;
  font-style: italic;
  color: var(--ch);
  line-height: 1.55;
}

.ai-mini-fit-row {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  padding: 10px 14px;
  background: rgba(255,255,255,0.45);
  border: 1px solid rgba(42,39,39,0.06);
  border-radius: 5px;
  margin-top: 10px;
  font-size: 12px;
}
.ai-mini-fit-label {
  font-weight: 600;
  color: rgba(42,39,39,0.65);
  margin-right: 4px;
}
.ai-mini-fit-dot {
  font-size: 14px;
  margin-right: 2px;
}
.ai-mini-fit-dot.good { color: #3FA56C; }
.ai-mini-fit-dot.bad  { color: #B8625C; }
.ai-mini-fit-dot.warn { color: #C9A84C; }
.ai-mini-fit-name {
  color: var(--ch);
  font-weight: 500;
  margin-right: 10px;
}

.btn-link {
  background: none;
  border: none;
  color: var(--gold);
  cursor: pointer;
}
.btn-link:hover { text-decoration: underline; }

/* ═══════════════════════════════════════════════════
   V26: Settings-Updates (dirty-hint, data-actions, etc.)
═══════════════════════════════════════════════════ */
.settings-footer {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
  padding: 14px 0 0;
  margin-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.settings-dirty-hint {
  margin-right: auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11.5px;
  color: var(--gold);
  font-style: italic;
}

/* Data-Tab: Import/Export Karten */
.data-actions-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 12px;
}
@media (max-width: 720px) {
  .data-actions-grid { grid-template-columns: 1fr; }
}
.data-action-card {
  padding: 18px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  text-align: center;
}
.data-action-icon {
  font-size: 32px;
  margin-bottom: 8px;
}
.data-action-card h4 {
  margin: 0 0 6px;
  font-size: 14px;
  color: var(--ch);
}
.data-action-card .hint {
  font-size: 11.5px;
  color: rgba(42,39,39,0.6);
  margin-bottom: 12px;
  display: block;
  line-height: 1.45;
}

/* V26: Marktzinsen Loading-State */
.rates-loading {
  display: inline-block;
  color: var(--gold);
  opacity: 0.5;
  letter-spacing: 0.1em;
  animation: rates-pulse 1.4s ease-in-out infinite;
}
@keyframes rates-pulse {
  0%, 100% { opacity: 0.3; }
  50%      { opacity: 0.8; }
}

/* ═══════════════════════════════════════════════════
   V26: View-Switcher Header (Single ↔ Alle Objekte)
═══════════════════════════════════════════════════ */
.hdr-view-switch {
  display: inline-flex;
  background: rgba(255,255,255,0.06);              /* V27: heller Container für dunklen Header */
  border: 1px solid rgba(201,168,76,0.20);
  border-radius: 8px;
  padding: 3px;
  margin-right: 14px;
  flex-shrink: 0;
}
.vw-btn {
  padding: 7px 14px;
  background: transparent;
  border: none;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,0.65);                   /* V27: hell für dunklen Header */
  cursor: pointer;
  transition: all .15s ease;
  white-space: nowrap;
}
.vw-btn:hover {
  color: #fff;
  background: rgba(255,255,255,0.05);
}
.vw-btn.active {
  background: var(--gold);
  color: var(--ch);
  box-shadow: 0 2px 6px rgba(201,168,76,0.35);
  font-weight: 700;
}

/* All-Objects-Hauptview */
.ao-main {
  /* V32: padding-top reduziert (vorher 22px) — Suche rückt nach oben */
  /* V33: noch enger — Toolbar klebt direkt unter Header */
  /* V34: komplett 0 oben — der Toolbar-Wrapper ist jetzt sticky */
  padding: 0 26px 22px;
  background: var(--surface);
  min-height: calc(100vh - 64px);
}
.ao-main .ao-toolbar {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0 0 12px;
  background: #fff;
  padding: 10px 14px;
  border-radius: 0 0 8px 8px;
  border: 1px solid rgba(42,39,39,0.08);
  border-top: none;
  /* V34: Toolbar klebt direkt unter dem Header */
  position: sticky;
  top: 64px;
  z-index: 100;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.ao-main .ao-search {
  flex: 1;
  padding: 9px 12px;
  border: 1px solid rgba(42,39,39,0.15);
  border-radius: 6px;
  font-size: 14px;
  background: #fff;
}
.ao-main .ao-search:focus {
  outline: none;
  border-color: var(--gold);
}
.ao-main .ao-stats {
  font-size: 12.5px;
  color: rgba(42,39,39,0.6);
  white-space: nowrap;
}
.ao-main .ao-table-wrap {
  background: #fff;
  border-radius: 8px;
  overflow: auto;
  border: 1px solid rgba(42,39,39,0.08);
}
.ao-main .ao-empty {
  text-align: center;
  padding: 60px 20px;
  color: rgba(42,39,39,0.5);
  font-size: 15px;
  background: #fff;
  border-radius: 8px;
  border: 1px solid rgba(42,39,39,0.08);
}

/* ═══════════════════════════════════════════════════
   V27: Plan-Pill in User-Box (statt Footer-Badge)
═══════════════════════════════════════════════════ */
.sb-user-plan-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 4px;
  padding: 3px 10px;
  border-radius: 99px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  cursor: pointer;
  user-select: none;
  transition: all .15s ease;
}
.sb-user-plan-pill.plan-free {
  background: rgba(160,160,160,0.16);
  color: #B0AAA0;
  border: 0.5px solid rgba(160,160,160,0.30);
}
.sb-user-plan-pill.plan-starter {
  background: rgba(94,217,158,0.18);
  color: #6FCB91;
  border: 0.5px solid rgba(94,217,158,0.30);
}
.sb-user-plan-pill.plan-investor {
  background: linear-gradient(135deg, rgba(201,168,76,0.30), rgba(201,168,76,0.18));
  color: #fff;
  border: 0.5px solid var(--gold);
  box-shadow: 0 1px 6px rgba(201,168,76,0.30);
}
.sb-user-plan-pill.plan-investor::before {
  content: '★';
  color: var(--gold);
  font-size: 10px;
}
.sb-user-plan-pill.plan-pro {
  background: linear-gradient(135deg, #C9A84C, #d8b85e);
  color: #1A1818;
  border: 0.5px solid #d8b85e;
  box-shadow: 0 2px 8px rgba(201,168,76,0.45);
}
.sb-user-plan-pill.plan-pro::before {
  content: '★';
  font-size: 10px;
}
/* Legacy: business / enterprise mappen zu pro-Stil */
.sb-user-plan-pill.plan-business,
.sb-user-plan-pill.plan-enterprise {
  background: rgba(201,168,76,0.18);
  color: var(--gold);
}
.sb-user-plan-pill:hover {
  transform: translateY(-1px);
  filter: brightness(1.1);
}

/* ═══════════════════════════════════════════════════
   V27: Portfolio-Header in All-Objects-View
═══════════════════════════════════════════════════ */
.ao-portfolio-header {
  background: linear-gradient(135deg, rgba(201,168,76,0.06) 0%, rgba(201,168,76,0.12) 100%);
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 10px;
  padding: 18px 22px;
  margin-bottom: 18px;
}
.ao-portfolio-header h3 {
  margin: 0 0 14px;
  font-size: 14px;
  font-weight: 700;
  color: var(--ch);
  letter-spacing: .02em;
}
.ao-portfolio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 14px;
}
.ao-port-kpi {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ao-port-label {
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: rgba(42,39,39,0.55);
}
.ao-port-val {
  font-size: 18px;
  font-weight: 700;
  color: var(--ch);
  font-variant-numeric: tabular-nums;
}
.ao-port-val.pos { color: #2A9A5A; }
.ao-port-val.neg { color: #B8625C; }

/* ═══════════════════════════════════════════════════
   V28: Marktzinsen-Quellen-Status-Badges
═══════════════════════════════════════════════════ */
.rates-source-line {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}
.rates-src-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 9px;
  border-radius: 99px;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .02em;
}
.rates-src-live {
  background: rgba(63,165,108,0.15);
  color: #2A9A5A;
}
.rates-src-mixed {
  background: rgba(201,168,76,0.15);
  color: #8A7637;
}
.rates-src-static {
  background: rgba(184,98,92,0.15);
  color: #B8625C;
}

/* ═══════════════════════════════════════════════════
   V28: Lokale Kennzahlen-Bewertung (Tab Kennzahlen)
═══════════════════════════════════════════════════ */
.kpi-eval-card {
  background: #fff;
  border: 1px solid rgba(42,39,39,0.08);
  margin-bottom: 18px;
}
.kpi-eval-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 12px;
  margin-bottom: 14px;
  border-bottom: 1px solid rgba(42,39,39,0.08);
}
.kpi-eval-title {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 14px;
  font-weight: 600;
  color: var(--ch);
}
.kpi-eval-icon { font-size: 18px; }
.kpi-eval-tag {
  font-size: 10.5px;
  font-weight: 500;
  color: rgba(42,39,39,0.5);
  background: rgba(42,39,39,0.05);
  padding: 2px 8px;
  border-radius: 99px;
  letter-spacing: .02em;
}
.kpi-eval-empty {
  padding: 18px 8px;
  text-align: center;
  color: rgba(42,39,39,0.5);
  font-size: 13px;
}

.kpi-eval-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13px;
}
.kpi-eval-table thead th {
  text-align: left;
  font-weight: 600;
  font-size: 10.5px;
  letter-spacing: .03em;
  text-transform: uppercase;
  color: rgba(42,39,39,0.5);
  padding: 6px 10px 8px;
  border-bottom: 1.5px solid rgba(201,168,76,0.20);
}
.kpi-eval-table tbody td {
  padding: 10px;
  border-bottom: 1px solid rgba(42,39,39,0.06);
  vertical-align: middle;
}
.kpi-eval-table tbody tr:last-child td { border-bottom: none; }

.kpi-eval-name {
  font-weight: 600;
  color: var(--ch);
}
.kpi-eval-val {
  font-weight: 700;
  color: var(--ch);
  font-variant-numeric: tabular-nums;
  font-size: 14px;
  white-space: nowrap;          /* V63.63: '6,27 %' nicht in zwei Zeilen brechen */
  min-width: 80px;              /* genug Platz für '+1.234 €' und '12,34 %' */
  text-align: right;
  padding-right: 18px !important;
}
.kpi-eval-comment {
  font-size: 12px;
  color: rgba(42,39,39,0.65);
  line-height: 1.4;
}

.kpi-eval-light {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 99px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: uppercase;
  white-space: nowrap;
}
.kpi-eval-green {
  background: rgba(63,165,108,0.15);
  color: #2A9A5A;
}
.kpi-eval-gold {
  background: rgba(201,168,76,0.18);
  color: #8A7637;
}
.kpi-eval-red {
  background: rgba(184,98,92,0.15);
  color: #B8625C;
}
.kpi-eval-gray {
  background: rgba(42,39,39,0.06);
  color: rgba(42,39,39,0.55);
}

.kpi-eval-footer-hint {
  margin-top: 12px;
  padding-top: 10px;
  font-size: 11px;
  color: rgba(42,39,39,0.55);
  border-top: 1px dashed rgba(42,39,39,0.10);
  line-height: 1.5;
}

/* ═══════════════════════════════════════════════════
   V29: KI-Analyse-Reiter — Block-Farben für die 6 alten Sektionen
   V30: Explizite Text-Farben — ai-body erbt sonst weißen Text
        vom dunklen ai-box-Container = unleserlich auf hellen Cards.
═══════════════════════════════════════════════════ */
.ai-block-investmentbewertung {
  background: #EBF1F8;
  border-left: 4px solid #3C6694;
  color: var(--ch);
  padding: 14px 18px;
  border-radius: 0 6px 6px 0;
  margin: 12px 0;
}
.ai-block-investmentbewertung h3 { color: #3C6694; margin: 0 0 8px; }
.ai-block-investmentbewertung p { color: var(--ch); margin: 0; line-height: 1.55; }

.ai-block-verhandlung {
  background: #FAF4E6;
  border-left: 4px solid var(--gold);
  color: var(--ch);
  padding: 14px 18px;
  border-radius: 0 6px 6px 0;
  margin: 12px 0;
}
.ai-block-verhandlung h3 { color: #8A7637; margin: 0 0 8px; }
.ai-block-verhandlung p { color: var(--ch); margin: 0; line-height: 1.55; }

.ai-block-offerte {
  background: #F0E8FF;
  border-left: 4px solid #7A5AB5;
  color: var(--ch);
  padding: 14px 18px;
  border-radius: 0 6px 6px 0;
  margin: 12px 0;
}
.ai-block-offerte h3 { color: #5A3FA0; margin: 0 0 8px; }
.ai-block-offerte p { color: var(--ch); margin: 0 0 10px; line-height: 1.55; }
.ai-block-offerte .ai-sub { color: #5A3FA0; font-weight: 600; margin-top: 8px; }
.ai-block-offerte ul { margin: 6px 0 0; padding-left: 22px; }
.ai-block-offerte ul li { color: var(--ch); margin-bottom: 4px; line-height: 1.5; }
.ai-offerte-price {
  font-size: 28px;
  font-weight: 700;
  color: #5A3FA0;
  margin: 6px 0 12px;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.01em;
}

.ai-block-bank {
  background: #E8F4EA;
  border-left: 4px solid #2A9A5A;
  color: var(--ch);
  padding: 14px 18px;
  border-radius: 0 6px 6px 0;
  margin: 12px 0;
}
.ai-block-bank h3 { color: #2A9A5A; margin: 0 0 8px; }
.ai-block-bank ul { margin: 6px 0 0; padding-left: 22px; }
.ai-block-bank li { color: var(--ch); margin-bottom: 6px; line-height: 1.5; }



/* ═══════════════════════════════════════════════════
   V30: SPLIT-SCREEN AUTH — Werbebild links, Login-Card rechts
═══════════════════════════════════════════════════ */
.auth-overlay.auth-split {
  position: fixed;
  inset: 0;
  z-index: 9999;
  overflow: auto;
  display: block;
  padding: 0;
  /* V31: Werbebild als Vollbild-Background über die GANZE Seite */
  background: #1A1818 url('../assets/login_hero.png') center / cover no-repeat;
}
.auth-split-wrap {
  display: grid;
  /* V31: Linke Spalte gibt nur Platz für die Headline-Sicht des Bildes,
     rechte Spalte enthält die schwebende Card */
  grid-template-columns: 1fr 1fr;
  min-height: 100vh;
  width: 100%;
  /* Auf großen Screens das Bild nicht "wachsen" lassen — Card-Bereich rechts hat fixe max-Breite */
}
@media (max-width: 980px) {
  .auth-split-wrap {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr auto;
  }
}

/* ── HERO LINKS: Platzhalter, Bild kommt aus dem Body-Background ── */
.auth-hero {
  /* V31: Wir lassen die linke Hälfte komplett leer —
     der Body-Background zeigt das Werbebild durchgehend. */
  min-height: 100vh;
}
.auth-hero-img {
  /* V31: Das Werbebild ist jetzt als CSS-Background gesetzt.
     Das <img>-Element wird nicht mehr gerendert (display:none),
     bleibt aber im DOM für Accessibility (Screen-Reader). */
  display: none;
}

/* ── PANE RECHTS: Transparent, Card schwebt über dem Bild ── */
.auth-pane {
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px 36px;
  min-height: 100vh;
}
@media (max-width: 980px) {
  .auth-pane {
    padding: 28px 16px 36px;
    min-height: auto;
  }
}

/* V32: Card kompakter + Glas-Look — der COMING-SOON-Stempel
   und das Mockup im Werbebild bleiben durch Transparenz sichtbar */
.auth-pane-card {
  width: 100%;
  max-width: 360px;                          /* V32: schmaler (vorher 420) */
  background: rgba(255,255,255,0.96);        /* leicht transparent — Glas-Look */
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border: 1.5px solid rgba(201,168,76,0.40); /* V32: goldene Umrahmung statt grau */
  border-radius: 12px;
  padding: 24px 28px 22px;                   /* V32: kompakter (vorher 36px) */
  box-shadow: 0 16px 50px rgba(0,0,0,0.50), 0 4px 14px rgba(0,0,0,0.18);
}
@media (max-width: 980px) {
  .auth-pane-card { padding: 22px 20px 20px; max-width: 100%; }
}

/* V32: Logo kleiner, kompakter Abstand */
.auth-pane-logo {
  margin-bottom: 16px;                       /* V32: kompakter */
  text-align: center;
}
.auth-pane-logo img {
  max-width: 160px;                          /* V32: kleiner (vorher 200) */
  width: 100%;
  height: auto;
  display: inline-block;
}

.auth-pane h2 {
  margin: 0 0 4px;
  font-size: 20px;                           /* V32: kleiner (vorher 26) */
  font-weight: 700;
  color: var(--ch);
  text-align: center;
  letter-spacing: -0.01em;
}
.auth-pane .auth-subtitle {
  font-size: 11px;                           /* V32: kleiner */
  font-weight: 600;
  color: rgba(42,39,39,0.55);
  text-align: center;
  margin-bottom: 18px;                       /* V32: kompakter */
  line-height: 1.4;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.auth-pane .auth-form {
  display: flex;
  flex-direction: column;
  gap: 10px;                                 /* V32: kompakter (vorher 14) */
}
.auth-pane .auth-field {
  display: flex;
  flex-direction: column;
  gap: 4px;                                  /* V32: kompakter */
}
.auth-pane .auth-field label {
  font-size: 12px;
  font-weight: 600;
  color: rgba(42,39,39,0.7);
  letter-spacing: 0.02em;
}
.auth-pane .auth-field input {
  padding: 11px 14px;
  border: 1.5px solid rgba(42,39,39,0.15);
  border-radius: 7px;
  font-size: 14px;
  font-family: inherit;
  background: #fff;
  color: var(--ch);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.auth-pane .auth-field input:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,0.18);
}
.auth-pane .auth-error {
  padding: 10px 12px;
  background: rgba(184,98,92,0.10);
  border: 1px solid rgba(184,98,92,0.30);
  border-radius: 6px;
  color: #B8625C;
  font-size: 13px;
  font-weight: 500;
}
.auth-pane .auth-btn {
  padding: 13px 20px;
  background: var(--gold);
  color: var(--ch);
  border: none;
  border-radius: 7px;
  font-size: 14.5px;
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.05s ease;
  margin-top: 4px;
}
.auth-pane .auth-btn:hover:not(:disabled) {
  background: #D4B25A;
}
.auth-pane .auth-btn:active:not(:disabled) {
  transform: scale(0.99);
}
.auth-pane .auth-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.auth-pane .auth-switch {
  font-size: 13px;
  color: rgba(42,39,39,0.65);
  text-align: center;
  margin-top: 8px;
}
.auth-pane .auth-switch a {
  color: var(--gold);
  text-decoration: none;
  font-weight: 600;
}
.auth-pane .auth-switch a:hover { text-decoration: underline; }
.auth-pane .auth-footer {
  text-align: center;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px dashed rgba(42,39,39,0.10);
  font-size: 11.5px;
  color: rgba(42,39,39,0.5);
}


/* ═══════════════════════════════════════════════════
   V29: Steuer-Empty-State
═══════════════════════════════════════════════════ */
.tax-empty-state {
  padding: 36px 24px;
  text-align: center;
  background: rgba(201,168,76,0.04);
  border: 1px dashed rgba(201,168,76,0.30);
  border-radius: 8px;
}
.tax-empty-icon { font-size: 36px; margin-bottom: 10px; }
.tax-empty-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--ch);
  margin-bottom: 6px;
}
.tax-empty-text {
  font-size: 13px;
  color: rgba(42,39,39,0.65);
  line-height: 1.5;
  max-width: 480px;
  margin: 0 auto;
}

/* V30: Compare-Links Zeile in Marktzinsen */
.rates-compare-line {
  margin-top: 10px;
  font-size: 11.5px;
  color: rgba(42,39,39,0.55);
  font-style: italic;
}
.rates-compare-line a {
  color: var(--gold-d, #8A7637);
  text-decoration: none;
  font-style: normal;
  font-weight: 500;
}
.rates-compare-line a:hover { text-decoration: underline; }

/* ═══════════════════════════════════════════════════
   V31: Titelbild auswählbar
═══════════════════════════════════════════════════ */
.img-thumb-title {
  border-color: var(--gold);
  border-width: 2.5px;
  box-shadow: 0 0 0 2px rgba(201,168,76,0.20);
}
.img-lbl-title {
  background: linear-gradient(transparent, rgba(201,168,76,0.85));
  font-weight: 700;
  letter-spacing: 0.02em;
}
.img-set-title {
  background: rgba(0,0,0,0.55);
  color: #fff;
  border: 1px solid rgba(201,168,76,0.50);
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 9.5px;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.02em;
  transition: all 0.15s ease;
  display: inline-block;
}
.img-set-title:hover {
  background: var(--gold);
  color: var(--ch);
  border-color: var(--gold);
}

/* ═══════════════════════════════════════════════════
   V32: Marktzinsen-Trend-Chart kompakter
   - feste Höhe, damit Chart.js beim Re-Render nicht wächst
═══════════════════════════════════════════════════ */
.rates-chart-wrap {
  position: relative;
  width: 100%;
  height: 110px;
  margin-top: 4px;
}
.rates-chart-wrap canvas {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
}

/* ═══════════════════════════════════════════════════
   V32: Sanierung/Möbel — Steuerliche Verteilung Optionen
═══════════════════════════════════════════════════ */
.san-tax-options {
  margin-top: 10px;
  padding: 10px 12px;
  background: rgba(201,168,76,0.06);
  border: 1px solid rgba(201,168,76,0.20);
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.san-tax-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ch);
  cursor: pointer;
}
.san-tax-checkbox input {
  width: 16px;
  height: 16px;
  margin: 0;
  cursor: pointer;
  accent-color: var(--gold);
}
.san-tax-years {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: rgba(42,39,39,0.7);
}
.san-tax-years label {
  margin: 0;
  font-weight: 500;
  flex-shrink: 0;
}
.san-tax-years select {
  flex: 1;
  padding: 5px 8px;
  font-size: 12px;
  border: 1px solid rgba(42,39,39,0.20);
  border-radius: 4px;
  background: #fff;
  color: var(--ch);
  cursor: pointer;
}
.san-tax-years select:focus {
  outline: none;
  border-color: var(--gold);
}

/* ═══════════════════════════════════════════════════
   V33: DealScore Mockup-Design
   Dunkles Theme · großer Donut · Top-Deal-Card · Metrik-Grid
═══════════════════════════════════════════════════ */
.ds-mockup {
  background: linear-gradient(135deg, #1A1818 0%, #1F1D1D 100%);
  border: 1.5px solid var(--gold);
  border-radius: 14px;
  padding: 28px;
  color: rgba(255,255,255,0.92);
  position: relative;
  box-shadow: 0 0 0 1px rgba(201,168,76,0.20), 0 18px 40px rgba(0,0,0,0.30);
  font-family: 'DM Sans', sans-serif;
}

/* ── Top-Bar: Brand links + Top-Deal rechts ── */
.ds-top {
  display: grid;
  grid-template-columns: minmax(280px, auto) 1fr;
  gap: 24px;
  align-items: start;
  margin-bottom: 26px;
}
@media (max-width: 720px) {
  .ds-top { grid-template-columns: 1fr; gap: 14px; }
}
.ds-brand {
  background: rgba(255,255,255,0.04);
  border: 1.5px solid rgba(201,168,76,0.45);
  border-radius: 10px;
  padding: 18px 28px;
  display: flex;
  align-items: center;
}
.ds-brand-name {
  font-size: 34px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.02em;
  line-height: 1;
}
.ds-brand-accent {
  color: var(--gold);
}

.ds-top-deal {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 10px;
  padding: 14px 18px;
  min-height: 64px;
}
.ds-top-deal-icon {
  width: 38px;
  height: 38px;
  flex-shrink: 0;
}
.ds-top-deal-icon svg {
  width: 100%;
  height: 100%;
  color: var(--gold);
}
.ds-badge-top .ds-top-deal-icon svg { color: var(--gold); }
.ds-badge-green .ds-top-deal-icon svg { color: #2FBE6E; }
.ds-badge-gold  .ds-top-deal-icon svg { color: var(--gold); }
.ds-badge-red   .ds-top-deal-icon svg { color: #D55B5B; }

.ds-top-deal-text { flex: 1; min-width: 0; }
.ds-top-deal-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.10em;
  color: var(--gold);
  margin-bottom: 4px;
}
.ds-badge-green .ds-top-deal-label { color: #2FBE6E; }
.ds-badge-red   .ds-top-deal-label { color: #D55B5B; }

.ds-top-deal-desc {
  font-size: 13px;
  color: rgba(255,255,255,0.80);
  line-height: 1.45;
}

/* ── Mittlerer Bereich: Donut + Metriken ── */
.ds-middle {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 36px;
  align-items: center;
  padding: 12px 0;
}
@media (max-width: 720px) {
  .ds-middle { grid-template-columns: 1fr; gap: 20px; }
}

/* Donut-Wrap */
.ds-donut-wrap {
  position: relative;
  width: 240px;
  height: 240px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ds-donut {
  width: 100%;
  height: 100%;
  filter: drop-shadow(0 0 24px rgba(47,190,110,0.20));
}
.ds-donut-text {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}
.ds-donut-score {
  font-size: 64px;
  font-weight: 700;
  color: #fff;
  line-height: 1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.ds-donut-max {
  font-size: 14px;
  color: rgba(255,255,255,0.50);
  margin-top: 4px;
  letter-spacing: 0.04em;
}
.ds-donut-pill {
  position: absolute;
  bottom: -6px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  background: rgba(0,0,0,0.50);
  border: 1.5px solid;
  white-space: nowrap;
}
.ds-donut-pill .ds-pill-icon {
  width: 14px;
  height: 14px;
  display: inline-flex;
}
.ds-donut-pill .ds-pill-icon svg { width: 100%; height: 100%; }
.ds-donut-pill-green { color: #2FBE6E; border-color: #2FBE6E; }
.ds-donut-pill-gold  { color: #E5BD53; border-color: #E5BD53; }
.ds-donut-pill-red   { color: #D55B5B; border-color: #D55B5B; }

/* Metriken-Grid */
.ds-metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px 36px;
  align-content: center;
}
@media (max-width: 980px) {
  .ds-metrics { grid-template-columns: 1fr; gap: 16px; }
}

.ds-metric {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 14px;
  align-items: start;
}
.ds-metric-icon {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: rgba(255,255,255,0.03);
  border: 1.5px solid rgba(255,255,255,0.10);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 9px;
  flex-shrink: 0;
}
.ds-metric-icon svg {
  width: 100%;
  height: 100%;
}
.ds-metric-body {
  min-width: 0;
}
.ds-metric-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 6px;
  gap: 12px;
}
.ds-metric-label {
  font-size: 14px;
  font-weight: 600;
  color: rgba(255,255,255,0.90);
}
.ds-metric-weight {
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  font-weight: 400;
}
.ds-metric-score {
  font-size: 14px;
  font-weight: 700;
  color: rgba(255,255,255,0.95);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.ds-metric-bar {
  height: 6px;
  background: rgba(255,255,255,0.08);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 6px;
}
.ds-metric-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.6s cubic-bezier(0.4,0,0.2,1);
}
.ds-metric-input {
  font-size: 11.5px;
  color: rgba(255,255,255,0.50);
  font-variant-numeric: tabular-nums;
}

/* ── Footer-Button ── */
.ds-mockup .ds-settings-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  margin-top: 22px;
  padding: 13px 20px;
  background: rgba(255,255,255,0.04);
  border: 1.5px solid rgba(201,168,76,0.40);
  border-radius: 10px;
  color: var(--gold);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: all 0.15s ease;
  font-family: inherit;
}
.ds-mockup .ds-settings-btn:hover {
  background: rgba(201,168,76,0.10);
  border-color: var(--gold);
}
.ds-mockup .ds-settings-icon {
  width: 18px;
  height: 18px;
  display: inline-flex;
}
.ds-mockup .ds-settings-icon svg { width: 100%; height: 100%; }

/* ═══════════════════════════════════════════════════
   V34: Saubere KI-Fehler-Box (kein hässlicher JSON-Dump mehr)
   V63.90: Schrift dunkel — die ai-box ist seit V63.85/87 hell (#fff),
   die alten weißen Texte waren auf hellrosa Hintergrund unleserlich
   ("KI-Analyse fehlgeschlagen" Bug aus Marcels Bild 3).
═══════════════════════════════════════════════════ */
.ai-error {
  padding: 18px 22px;
  background: rgba(184,98,92,0.08);
  border-left: 3px solid #B8625C;
  border-radius: 0 8px 8px 0;
  color: var(--ch);
}
.ai-error-title {
  font-size: 14px;
  font-weight: 700;
  color: #8E3F3A;
  margin-bottom: 6px;
}
.ai-error-msg {
  font-size: 13px;
  line-height: 1.55;
  color: var(--ch);
  max-width: 640px;
}
.ai-error-details {
  margin-top: 12px;
  font-size: 11px;
  color: var(--muted);
}
.ai-error-details summary {
  cursor: pointer;
  user-select: none;
  padding: 4px 0;
  color: var(--ch);
}
.ai-error-details pre {
  background: rgba(0,0,0,0.04);
  border: 1px solid var(--border);
  padding: 12px;
  border-radius: 6px;
  font-size: 10.5px;
  line-height: 1.4;
  max-height: 280px;
  overflow: auto;
  white-space: pre-wrap;
  margin-top: 8px;
  color: var(--ch);
}

/* ═══════════════════════════════════════════════════
   V35: BMF-AfA-Rechner Modal
═══════════════════════════════════════════════════ */
.bmf-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20,18,18,0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.bmf-modal {
  background: var(--ch);
  border: 1.5px solid var(--gold);
  border-radius: 14px;
  width: 100%;
  max-width: 920px;
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,0.50);
  color: rgba(255,255,255,0.92);
  font-family: 'DM Sans', sans-serif;
}
.bmf-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 18px 24px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.bmf-header h3 {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  color: var(--gold);
}
.bmf-sub {
  font-size: 11.5px;
  color: rgba(255,255,255,0.55);
  margin-top: 2px;
  letter-spacing: 0.02em;
}
.bmf-close {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.7);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  flex-shrink: 0;
}
.bmf-close:hover {
  background: rgba(255,255,255,0.08);
  color: #fff;
}
.bmf-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  padding: 20px 24px;
  overflow-y: auto;
  flex: 1;
}
@media (max-width: 760px) {
  .bmf-body { grid-template-columns: 1fr; padding: 16px; gap: 18px; }
  .bmf-modal { max-height: 96vh; }
}
.bmf-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.bmf-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.bmf-row label {
  font-size: 11px;
  font-weight: 600;
  color: rgba(255,255,255,0.65);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.bmf-row input,
.bmf-row select {
  width: 100%;
  padding: 9px 11px;
  font-size: 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 6px;
  color: #fff;
  font-family: inherit;
}
.bmf-row input:focus,
.bmf-row select:focus {
  outline: none;
  border-color: var(--gold);
  background: rgba(255,255,255,0.07);
}
.bmf-grid2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.bmf-hint {
  font-size: 10.5px;
  color: rgba(255,255,255,0.45);
  margin-top: 2px;
}
.bmf-modern {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  padding: 10px 14px;
}
.bmf-modern summary {
  cursor: pointer;
  font-size: 12.5px;
  font-weight: 600;
  color: rgba(255,255,255,0.78);
  user-select: none;
  padding: 4px 0;
}
.bmf-modern[open] summary { margin-bottom: 10px; }
.bmf-modern-grid {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.bmf-mod-row {
  display: grid;
  grid-template-columns: 1fr 110px;
  gap: 10px;
  align-items: center;
  font-size: 12px;
  color: rgba(255,255,255,0.78);
}
.bmf-mod-row select {
  width: 100%;
  padding: 5px 8px;
  font-size: 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 4px;
  color: #fff;
}
.bmf-mod-sum {
  margin-top: 10px;
  padding: 6px 10px;
  background: rgba(201,168,76,0.10);
  border-left: 2px solid var(--gold);
  border-radius: 0 4px 4px 0;
  font-size: 11.5px;
  color: var(--gold);
  font-weight: 600;
}
.bmf-result {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  font-size: 13px;
}
.bmf-empty {
  color: rgba(255,255,255,0.50);
  font-size: 13px;
  text-align: center;
  padding: 30px 20px;
  font-style: italic;
}
.bmf-err {
  color: #DDA29E;
  font-size: 13px;
  text-align: center;
  padding: 30px 20px;
}
.bmf-result-section h4 {
  margin: 0 0 8px;
  font-size: 12px;
  font-weight: 700;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.bmf-fbj {
  background: rgba(201,168,76,0.10);
  border-left: 2px solid var(--gold);
  border-radius: 0 4px 4px 0;
  padding: 6px 10px;
  font-size: 11.5px;
  color: rgba(255,255,255,0.85);
  margin-bottom: 8px;
}
.bmf-fbj strong { color: var(--gold); }
.bmf-kv {
  display: flex;
  justify-content: space-between;
  padding: 5px 0;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  font-size: 13px;
  color: rgba(255,255,255,0.78);
}
.bmf-kv:last-child { border-bottom: none; }
.bmf-kv .kv-v { color: #fff; font-weight: 600; font-variant-numeric: tabular-nums; }
.bmf-kv-strong {
  font-weight: 600;
  color: #fff;
}
.bmf-kv-highlight {
  background: rgba(201,168,76,0.10);
  margin: 0 -8px;
  padding: 8px 8px;
  border-radius: 4px;
  border-bottom: none !important;
}
.bmf-kv-highlight .kv-v { color: var(--gold); font-size: 14px; }
.bmf-note {
  margin-top: 6px;
  font-size: 11px;
  color: rgba(255,255,255,0.55);
  font-style: italic;
}
.bmf-zwischen {
  margin-top: 10px;
  font-size: 11.5px;
  color: rgba(255,255,255,0.65);
}
.bmf-zwischen summary {
  cursor: pointer;
  font-weight: 600;
  color: rgba(255,255,255,0.55);
  padding: 6px 0;
}
.bmf-zwischen[open] summary { margin-bottom: 6px; }
.bmf-zwischen .bmf-kv { font-size: 11.5px; padding: 3px 0; }
.bmf-footer {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 14px 24px 18px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
@media (max-width: 760px) {
  .bmf-footer { flex-direction: column-reverse; padding: 12px 16px 16px; }
  .bmf-footer .btn { width: 100%; }
}

/* ═══════════════════════════════════════════════════
   V35: Mobile + Tablet Responsiveness
═══════════════════════════════════════════════════ */

/* Hamburger-Button — Default versteckt, nur auf Mobile sichtbar */
.hdr-mobile-menu {
  display: none;
  background: transparent;
  border: 1px solid rgba(201,168,76,0.40);
  border-radius: 6px;
  width: 38px;
  height: 38px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4px;
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
  margin-right: 10px;
}
.hdr-mobile-menu span {
  display: block;
  width: 18px;
  height: 2px;
  background: var(--gold);
  border-radius: 2px;
  transition: all 0.22s ease;
}
.hdr-mobile-menu.active span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.hdr-mobile-menu.active span:nth-child(2) { opacity: 0; }
.hdr-mobile-menu.active span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.sb-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(20,18,18,0.65);
  backdrop-filter: blur(2px);
  z-index: 240;
}

/* ─── TABLET (≤1024px): Sidebar als Off-Canvas ─── */
@media (max-width: 1024px) {
  .app-wrap {
    grid-template-columns: 1fr;   /* Single-column */
  }
  .app-wrap.sb-collapsed {
    grid-template-columns: 1fr;
  }
  .sidebar {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: 320px;
    max-width: 85vw;
    height: 100vh;
    transform: translateX(-100%);
    transition: transform 0.28s cubic-bezier(0.4,0,0.2,1);
    z-index: 260;
    box-shadow: 4px 0 30px rgba(0,0,0,0.35);
  }
  .app-wrap.sb-mobile-open .sidebar {
    transform: translateX(0);
  }
  .hdr-mobile-menu {
    display: flex;
  }
  /* Sidebar-Toggle (Desktop-Pfeil) auf Mobile ausblenden */
  .sb-toggle {
    display: none !important;
  }
  /* Header kompakter auf Tablet */
  .hdr {
    padding: 0 14px;
    gap: 10px;
  }
  .hdr-view-switch .vw-btn {
    padding: 6px 12px;
    font-size: 12.5px;
  }
  .hdr-obj {
    font-size: 14px;
    padding: 0 8px;
  }
  /* Tabs scrollbar mit Touch */
  .tabs {
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x proximity;
    padding: 0 12px;
  }
  .tab {
    scroll-snap-align: start;
    flex-shrink: 0;
    min-height: 44px;       /* Touch-Target */
    padding: 0 14px !important;
  }
  /* Body padding kleiner */
  .body {
    padding: 14px 14px 80px;
  }
  /* col2-Layout aufbrechen */
  .col2 {
    grid-template-columns: 1fr !important;
  }
  /* g2 (2-Spalten-Forms) bleibt 2-Spaltig auf Tablet, nur auf Phone 1 */
  /* DealScore stapelt */
  .ds-top {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .ds-middle {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .ds-metrics {
    grid-template-columns: 1fr !important;
  }
  .ds-donut-wrap {
    width: 200px;
    height: 200px;
  }
  .ds-donut-score {
    font-size: 52px;
  }
  /* KPI-Grid auf Tablet 2 Spalten statt 4 */
  .kpi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  /* Cashflow-Phase-Cards stapeln */
  .cf-phase-grid {
    grid-template-columns: 1fr !important;
  }
  /* Ao-toolbar nicht mehr sticky an 64px */
  .ao-main .ao-toolbar {
    top: 56px;
  }
}

/* ─── PHONE (≤640px): noch kompakter ─── */
@media (max-width: 640px) {
  /* Header: PDF/CSV-Buttons als Icons-only oder ausgeblendet */
  .hdr {
    height: 56px;
    padding: 0 10px;
    gap: 6px;
  }
  .hdr-view-switch {
    display: none;     /* Auf Phone weg, da im Sidebar-Menü */
  }
  .hdr-obj {
    font-size: 13px;
    padding: 0 4px;
  }
  .hdr-actions .btn {
    padding: 8px 10px;
    font-size: 12px;
  }
  /* CSV-Button ausblenden auf Phone — wenig Platz */
  .hdr-actions .btn:nth-child(2) {
    display: none;
  }
  .hdr-actions .btn:nth-child(3) {
    /* PDF Export: Text kürzen */
    font-size: 0;
  }
  .hdr-actions .btn:nth-child(3)::before {
    content: 'PDF';
    font-size: 12px;
    font-weight: 600;
  }
  .hdr-actions .btn:nth-child(4) {
    /* Speichern-Btn: nur "💾" */
    font-size: 13px;
    min-width: 44px;
  }
  /* Body padding noch kleiner */
  .body {
    padding: 10px 10px 80px;
  }
  /* Card padding kompakt */
  .card {
    padding: 14px 14px;
  }
  /* g2 Forms auf Phone 1-spaltig */
  .g2 {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  /* KPI-Grid 1 Spalte */
  .kpi-grid {
    grid-template-columns: 1fr;
  }
  /* Inputs: font-size:16px verhindert iOS-Zoom-on-focus */
  input[type="number"],
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="date"],
  input[type="search"],
  select,
  textarea {
    font-size: 16px !important;
  }
  /* Tab-Buttons: Touch-Targets ≥44px */
  .tab {
    min-height: 48px;
    font-size: 13px;
  }
  /* DealScore: noch kompakter */
  .ds-mockup {
    padding: 18px;
  }
  .ds-brand {
    padding: 12px 18px;
  }
  .ds-brand-name {
    font-size: 26px;
  }
  .ds-donut-wrap {
    width: 180px;
    height: 180px;
  }
  .ds-donut-score {
    font-size: 46px;
  }
  /* KI-Box kompakter */
  .ai-box {
    padding: 16px 14px;
  }
  /* Modal-Buttons: full-width auf Phone */
  .ao-toolbar {
    flex-wrap: wrap;
  }
  .ao-search {
    min-width: 0;
    flex: 1;
  }
  /* Auth-Pane Login-Card auf Phone */
  .auth-pane {
    padding: 20px 12px 24px !important;
  }
  /* Sidebar Off-Canvas: volle Breite */
  .sidebar {
    width: 88vw;
    max-width: 320px;
  }
}

/* ─── Sehr kleine Phones (≤380px) ─── */
@media (max-width: 380px) {
  .ds-donut-wrap {
    width: 160px;
    height: 160px;
  }
  .ds-donut-score {
    font-size: 40px;
  }
  .hdr-obj {
    display: none;     /* Adresse-Header ausblenden bei sehr wenig Platz */
  }
}

/* ─── Touch-Friendly Buttons app-weit ─── */
@media (hover: none) and (pointer: coarse) {
  .btn,
  .vw-btn,
  .tab,
  .sb-nav-btn,
  .ds-settings-btn,
  .cf-mode-btn {
    min-height: 44px;
  }
  .saved-btns button,
  .img-del,
  .delete-btn {
    min-width: 32px;
    min-height: 32px;
  }
}

/* ═══════════════════════════════════════════════════
   V36: DealScore 2.0
═══════════════════════════════════════════════════ */
.ds2-card { margin-top: 16px; }
.ds2-mockup .ds-brand-name { font-size: 30px; }
.ds2-explanation .ds-top-deal-desc {
  font-size: 12.5px;
  font-style: italic;
}

.ds2-pn-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  padding: 18px 0 14px;
  margin-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.10);
}
@media (max-width: 720px) { .ds2-pn-grid { grid-template-columns: 1fr; gap: 14px; } }
.ds2-pn-col h5 {
  margin: 0 0 10px;
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  font-weight: 700;
}
.ds2-pn-pos h5 { color: #2FBE6E; }
.ds2-pn-neg h5 { color: #D55B5B; }
.ds2-pn-col ul {
  list-style: none;
  margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 6px;
}
.ds2-pn-col li {
  font-size: 12.5px;
  color: rgba(255,255,255,0.85);
  padding: 6px 10px;
  background: rgba(255,255,255,0.04);
  border-radius: 5px;
  border-left: 2px solid;
}
.ds2-pn-pos li { border-left-color: #2FBE6E; }
.ds2-pn-neg li { border-left-color: #D55B5B; }
.ds2-pn-col li.ds2-empty-li {
  border-left: none;
  background: transparent;
  color: rgba(255,255,255,0.45);
  font-style: italic;
  padding-left: 0;
}

/* Eingabe-Karte für DS2-Zusatzangaben */
.ds2-inputs-card { margin-top: 16px; }
.ds2-input-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px 16px;
}
@media (max-width: 760px) { .ds2-input-grid { grid-template-columns: 1fr; } }

/* Settings-Modal */
.ds2-settings-modal {
  background: var(--ch);
  border: 1.5px solid var(--gold);
  border-radius: 14px;
  width: 100%;
  max-width: 720px;
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,0.50);
  color: rgba(255,255,255,0.92);
  font-family: 'DM Sans', sans-serif;
}
.ds2-settings-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 18px 24px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.ds2-settings-header h3 {
  margin: 0;
  font-size: 19px;
  font-weight: 700;
  color: var(--gold);
}
.ds2-settings-sub {
  font-size: 11.5px;
  color: rgba(255,255,255,0.55);
  margin-top: 2px;
}
.ds2-settings-body {
  padding: 18px 24px;
  overflow-y: auto;
  flex: 1;
}
.ds2-set-section {
  margin-bottom: 24px;
}
.ds2-set-section h4 {
  margin: 0 0 12px;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--gold);
}
.ds2-set-hint {
  font-size: 11.5px;
  color: rgba(255,255,255,0.55);
  margin: 0 0 10px;
}
.ds2-set-hint code {
  background: rgba(0,0,0,0.30);
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 11px;
}
.ds2-set-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px 18px;
}
.ds2-set-grid-wide {
  grid-template-columns: 1fr;
}
.ds2-set-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
}
.ds2-set-row-wide {
  flex-direction: column;
  align-items: stretch;
  gap: 4px;
}
.ds2-set-row label {
  flex: 1;
  color: rgba(255,255,255,0.78);
}
.ds2-set-row input {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 5px;
  color: #fff;
  padding: 6px 9px;
  font-size: 12.5px;
}
.ds2-set-row input:focus {
  outline: none;
  border-color: var(--gold);
}
.ds2-set-row-wide input { width: 100%; }
.ds2-set-unit {
  color: rgba(255,255,255,0.55);
  font-size: 11px;
  width: 14px;
}
.ds2-settings-footer {
  display: flex;
  gap: 10px;
  padding: 14px 24px 18px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
@media (max-width: 760px) {
  .ds2-settings-footer { flex-wrap: wrap; }
  .ds2-settings-footer .btn { flex: 1; }
}

/* ═══════════════════════════════════════════════════
   V36 Fix: BMF-Modal Selects — Optionen lesbar machen
   Browser zeigt <option> im OS-Native-Stil — wir erzwingen
   dunklen Hintergrund + helle Schrift in den Optionen.
═══════════════════════════════════════════════════ */
.bmf-modal select option,
.ds2-settings-modal select option {
  background: #1F1D1D;
  color: #fff;
}
.bmf-modal select:focus option:checked,
.bmf-modal select option:hover,
.ds2-settings-modal select option:hover,
.ds2-settings-modal select option:checked {
  background: var(--gold);
  color: var(--ch);
}
/* Dropdown-Pfeil sichtbar machen */
.bmf-modal select,
.ds2-settings-modal select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23C9A84C' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
}

/* ═══════════════════════════════════════════════════
   V36: KI-Lage-Bewertung (kompaktes Gimmick)
═══════════════════════════════════════════════════ */
.ki-lage-box {
  margin-top: 14px;
  padding: 14px 16px;
  background: rgba(201,168,76,0.06);
  border: 1px solid rgba(201,168,76,0.25);
  border-radius: 10px;
}
.ki-lage-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.ki-lage-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--ch);
}
.ki-lage-icon {
  display: inline-flex;
  color: var(--gold);
}
.ki-lage-tag {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  background: rgba(201,168,76,0.18);
  color: var(--gold-d, #8A7637);
  border-radius: 4px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.ki-lage-empty {
  font-size: 12.5px;
  color: rgba(42,39,39,0.6);
  font-style: italic;
}
.ki-lage-loading {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
  color: var(--gold-d, #8A7637);
}
.ki-lage-spinner {
  width: 16px; height: 16px;
  border: 2px solid rgba(201,168,76,0.25);
  border-top-color: var(--gold);
  border-radius: 50%;
  animation: ki-spin 0.7s linear infinite;
}
@keyframes ki-spin { to { transform: rotate(360deg); } }
.ki-lage-err {
  font-size: 12.5px;
  color: #B8625C;
  padding: 8px 0;
}
.ki-lage-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 720px) { .ki-lage-grid { grid-template-columns: 1fr; } }
.ki-lage-card {
  background: #fff;
  border: 1px solid rgba(42,39,39,0.10);
  border-radius: 8px;
  padding: 12px 14px;
}
.ki-lage-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
}
.ki-lage-card-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(42,39,39,0.55);
}
.ki-lage-score {
  font-size: 18px;
  font-weight: 700;
  border: 1.5px solid;
  border-radius: 999px;
  padding: 1px 11px;
  font-variant-numeric: tabular-nums;
}
.ki-lage-score span {
  font-size: 10px;
  font-weight: 500;
  opacity: 0.6;
  margin-left: 1px;
}
.ki-lage-card-label {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}
.ki-lage-card-text {
  font-size: 12.5px;
  color: var(--ch);
  line-height: 1.55;
  margin-bottom: 6px;
}
.ki-lage-factors {
  list-style: none;
  margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 4px 6px;
}
.ki-lage-factors li {
  font-size: 11px;
  background: rgba(201,168,76,0.08);
  color: var(--gold-d, #8A7637);
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(201,168,76,0.20);
}

/* ═══════════════════════════════════════════════════
   V36: Quadratmeterpreise im Investition-Tab
═══════════════════════════════════════════════════ */
.qm-prices {
  margin-top: 8px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 14px;
  padding: 8px 14px;
  background: rgba(201,168,76,0.05);
  border: 1px solid rgba(201,168,76,0.18);
  border-radius: 6px;
  font-size: 12.5px;
}
@media (max-width: 640px) { .qm-prices { grid-template-columns: 1fr; } }
.qm-price-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: rgba(42,39,39,0.65);
}
.qm-price-val {
  font-weight: 700;
  color: var(--ch);
  font-variant-numeric: tabular-nums;
}

/* ═══════════════════════════════════════════════════
   V36: Header Kennzahlen-Badges
═══════════════════════════════════════════════════ */
.hdr-badges {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.hdr-badge {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  padding: 3px 9px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 999px;
  font-size: 11px;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.hdr-badge-l {
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
}
.hdr-badge-v {
  font-weight: 700;
  color: #fff;
}
.hdr-badge.b-green { border-color: rgba(63,165,108,0.55); background: rgba(63,165,108,0.15); }
.hdr-badge.b-green .hdr-badge-v { color: #6FCB91; }
.hdr-badge.b-gold  { border-color: rgba(201,168,76,0.55); background: rgba(201,168,76,0.18); }
.hdr-badge.b-gold .hdr-badge-v { color: var(--gold); }
.hdr-badge.b-red   { border-color: rgba(184,98,92,0.55); background: rgba(184,98,92,0.18); }
.hdr-badge.b-red .hdr-badge-v { color: #DDA29E; }

/* Auf Tablet/Phone: nur die wichtigsten Badges, Schriftgröße kleiner */
@media (max-width: 1024px) {
  .hdr-badges { gap: 4px; }
  .hdr-badge { padding: 2px 7px; font-size: 10px; }
  .hdr-badge-l { font-size: 9px; }
}
@media (max-width: 640px) {
  .hdr-badges { display: none; }       /* Auf Phone: Platz sparen */
}

/* ═══════════════════════════════════════════════════
   V36: Header-Objektnummer klickbar
═══════════════════════════════════════════════════ */
.hdr-obj-num-edit {
  background: rgba(201,168,76,0.15);
  border: 1px solid rgba(201,168,76,0.45);
  color: var(--gold);
  font-weight: 700;
  padding: 3px 11px;
  border-radius: 6px;
  font-size: 13px;
  cursor: pointer;
  font-variant-numeric: tabular-nums;
  font-family: inherit;
  transition: all 0.15s ease;
  margin-right: 10px;
}
.hdr-obj-num-edit:hover {
  background: rgba(201,168,76,0.30);
  border-color: var(--gold);
}

/* ═══════════════════════════════════════════════════
   V37: Login — Beta-Tester-Button (durchgestrichen + Stempel)
═══════════════════════════════════════════════════ */
.auth-beta-wrap {
  margin-top: 14px;
  text-align: center;
}
.auth-beta-btn {
  position: relative;
  display: inline-block;
  width: 100%;
  padding: 11px 16px;
  background: rgba(201,168,76,0.06);
  border: 1.5px dashed rgba(201,168,76,0.45);
  border-radius: 8px;
  color: var(--ch);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  letter-spacing: 0.01em;
  overflow: hidden;
  transition: all 0.15s ease;
}
.auth-beta-btn:hover {
  background: rgba(201,168,76,0.14);
  border-color: var(--gold);
}
.auth-beta-text {
  text-decoration: line-through;
  text-decoration-thickness: 1.5px;
  text-decoration-color: rgba(184,98,92,0.65);
  color: rgba(42,39,39,0.55);
}
/* Schräger "In Vorbereitung"-Stempel über dem Text */
.auth-beta-stamp {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-8deg);
  background: rgba(184,98,92,0.92);
  color: #fff;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: 4px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.20);
  pointer-events: none;
  white-space: nowrap;
}

/* ═══════════════════════════════════════════════════
   V37: Beta-Signup-Modal
═══════════════════════════════════════════════════ */
.beta-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20,18,18,0.78);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: beta-fade 0.2s ease;
}
@keyframes beta-fade { from { opacity: 0; } to { opacity: 1; } }
.beta-modal {
  background: linear-gradient(135deg, #1A1818 0%, #1F1D1D 100%);
  border: 1.5px solid var(--gold);
  border-radius: 14px;
  width: 100%;
  max-width: 480px;
  padding: 28px;
  position: relative;
  box-shadow: 0 0 0 1px rgba(201,168,76,0.20), 0 24px 60px rgba(0,0,0,0.55);
  color: rgba(255,255,255,0.92);
  font-family: 'DM Sans', sans-serif;
  animation: beta-slide 0.25s cubic-bezier(0.4,0,0.2,1);
}
@keyframes beta-slide { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

.beta-close {
  position: absolute;
  top: 12px; right: 12px;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.7);
  width: 30px; height: 30px;
  border-radius: 50%;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}
.beta-close:hover { background: rgba(255,255,255,0.08); color: #fff; }

.beta-header {
  text-align: center;
  margin-bottom: 22px;
}
.beta-icon {
  width: 56px; height: 56px;
  margin: 0 auto 12px;
  background: rgba(201,168,76,0.15);
  border: 1.5px solid var(--gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
}
.beta-header h3 {
  margin: 0 0 6px;
  font-size: 22px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.01em;
}
.beta-sub {
  font-size: 12.5px;
  color: rgba(255,255,255,0.65);
  line-height: 1.5;
}

.beta-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.beta-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.beta-field label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.65);
}
.beta-optional {
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  color: rgba(255,255,255,0.40);
  font-size: 10px;
}
.beta-field input,
.beta-field textarea {
  width: 100%;
  padding: 10px 12px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 6px;
  color: #fff;
  font-family: inherit;
  font-size: 14px;
  resize: vertical;
}
.beta-field input:focus,
.beta-field textarea:focus {
  outline: none;
  border-color: var(--gold);
  background: rgba(255,255,255,0.08);
}

/* Honeypot — visuell für User unsichtbar */
.beta-hp {
  position: absolute;
  left: -9999px;
  top: -9999px;
  width: 1px; height: 1px;
  opacity: 0;
  pointer-events: none;
}

.beta-error {
  font-size: 12.5px;
  color: #DDA29E;
  background: rgba(184,98,92,0.14);
  padding: 8px 12px;
  border-radius: 5px;
  border-left: 2px solid #B8625C;
}
.beta-success {
  font-size: 13px;
  color: #6FCB91;
  background: rgba(63,165,108,0.14);
  padding: 12px 14px;
  border-radius: 6px;
  border-left: 2px solid #3FA56C;
  font-weight: 500;
  line-height: 1.5;
}
.beta-actions {
  display: flex;
  gap: 10px;
  margin-top: 6px;
}
.beta-actions .btn { flex: 1; }
.beta-note {
  font-size: 11px;
  color: rgba(255,255,255,0.40);
  font-style: italic;
  text-align: center;
  margin-top: 4px;
  line-height: 1.4;
}
@media (max-width: 480px) {
  .beta-modal { padding: 20px; }
  .beta-actions { flex-direction: column-reverse; }
}

/* ═══════════════════════════════════════════════════
   V37: Demo-Hinweis im Login
═══════════════════════════════════════════════════ */
.auth-demo-hint {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  padding: 8px 10px;
  background: rgba(63,165,108,0.06);
  border: 1px solid rgba(63,165,108,0.20);
  border-radius: 6px;
  font-size: 11.5px;
}
.auth-demo-l {
  color: rgba(42,39,39,0.65);
  font-weight: 500;
}
.auth-demo-btn {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--green);
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  text-align: right;
  padding: 0;
  text-decoration: underline;
  font-family: inherit;
}
.auth-demo-btn:hover { color: #2A7E54; }

/* ═══════════════════════════════════════════════════
   V37: Qualität & Zustand — 5-Sterne-Bewertung
═══════════════════════════════════════════════════ */
.qz-card {
  margin-top: 14px;
  padding: 18px 20px;
  background: #fff;
  border: 1px solid rgba(42,39,39,0.08);
  border-radius: 8px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.03);
}
.qz-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--ch);
  margin-bottom: 14px;
  letter-spacing: -0.01em;
}
.qz-rows {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.qz-row {
  display: grid;
  grid-template-columns: 150px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 6px 0;
}
.qz-row-name {
  display: flex;
  align-items: center;
  gap: 9px;
  font-weight: 600;
  font-size: 13px;
  color: var(--ch);
}
.qz-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--ch);
  width: 22px;
  height: 22px;
}
.qz-stars {
  display: flex;
  gap: 4px;
  align-items: center;
}
.qz-star {
  background: transparent;
  border: none;
  padding: 8px;                     /* V40: deutlich größerer Hitbereich (war 2-3px) */
  margin: -4px;                     /* visuell aber nicht mehr Platz */
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  transition: transform 0.10s ease, background 0.12s ease;
  user-select: none;
  -webkit-tap-highlight-color: rgba(201,168,76,0.20);
  position: relative;
  z-index: 1;                       /* damit nichts den Klick blockiert */
}
.qz-star:hover {
  transform: scale(1.12);
  background: rgba(201,168,76,0.10);
}
.qz-star:active { transform: scale(0.95); }
.qz-star:focus { outline: 2px solid rgba(201,168,76,0.50); outline-offset: 1px; }
.qz-star svg { display: block; pointer-events: none; }   /* SVG nicht klickbar — nur der Container */
.qz-label {
  font-size: 12.5px;
  color: var(--ch);
  font-weight: 500;
  min-width: 180px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.qz-label-empty {
  color: rgba(42,39,39,0.40);
  font-style: italic;
  font-weight: 400;
}
.qz-footer {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px dashed rgba(42,39,39,0.10);
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
}
.qz-footer-l {
  font-weight: 600;
  color: rgba(42,39,39,0.65);
  letter-spacing: 0.02em;
}
.qz-footer-stars {
  display: inline-flex;
  gap: 1px;
  align-items: center;
}
.qz-avg-empty {
  color: rgba(42,39,39,0.30);
  letter-spacing: 4px;
  font-size: 11px;
}
.qz-footer-v {
  font-weight: 600;
  color: var(--ch);
}

/* Mobile: weniger Spalten */
@media (max-width: 720px) {
  .qz-row {
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .qz-stars {
    justify-content: flex-start;
  }
  .qz-label {
    min-width: 0;
    text-align: left;
    padding-left: 32px;
  }
}

/* V37: DealScore 2.0 — Sterne-Banner wenn Q&Z-Bewertung aktiv ist */
.ds2-stern-banner {
  margin: 4px 0 12px;
  padding: 10px 14px;
  background: rgba(201,168,76,0.12);
  border-left: 2px solid var(--gold);
  border-radius: 0 6px 6px 0;
  font-size: 12px;
  color: rgba(255,255,255,0.85);
  display: flex;
  align-items: center;
  gap: 10px;
  line-height: 1.5;
}
.ds2-stern-icon {
  font-size: 18px;
  color: #FFC83D;
  flex-shrink: 0;
}
.ds2-stern-banner strong { color: var(--gold); }

/* ═══════════════════════════════════════════════════
   V38: Passwort-vergessen-Button (deaktiviert)
═══════════════════════════════════════════════════ */
.auth-forgot-wrap {
  margin-top: 8px;
  text-align: center;
}
.auth-forgot-btn {
  background: transparent;
  border: 1px solid rgba(42,39,39,0.10);
  color: rgba(42,39,39,0.45);
  font-size: 12px;
  font-weight: 500;
  padding: 7px 14px;
  border-radius: 6px;
  cursor: not-allowed;
  font-family: inherit;
  letter-spacing: 0.01em;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.auth-forgot-btn[disabled] { opacity: 0.85; }
.auth-forgot-btn:hover[disabled] {
  background: rgba(184,98,92,0.04);
  border-color: rgba(184,98,92,0.18);
}
.auth-forgot-tag {
  background: rgba(184,98,92,0.14);
  color: #B8625C;
  font-size: 9.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 2px 6px;
  border-radius: 3px;
}

/* ═══════════════════════════════════════════════════
   V38: DS2-Tag Pille (z.B. „DS2" neben Labels)
═══════════════════════════════════════════════════ */
.ds2-tag {
  display: inline-block;
  background: rgba(201,168,76,0.14);
  color: var(--gold);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 2px 6px;
  border-radius: 3px;
  margin-left: 6px;
  vertical-align: middle;
  text-transform: uppercase;
}

/* ═══════════════════════════════════════════════════
   V38: KI-Vorschlags-Button neben Label (✨)
═══════════════════════════════════════════════════ */
.ds2-ai-mini {
  background: rgba(201,168,76,0.10);
  border: 1px solid rgba(201,168,76,0.30);
  color: var(--gold);
  font-size: 11px;
  width: 22px;
  height: 22px;
  padding: 0;
  border-radius: 4px;
  cursor: pointer;
  margin-left: 6px;
  vertical-align: middle;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.12s ease;
}
.ds2-ai-mini:hover {
  background: rgba(201,168,76,0.25);
  transform: scale(1.08);
}
.ds2-ai-mini:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
}

/* Loading-Indikator auf einem Feld */
.ds2-loading {
  background: linear-gradient(90deg, rgba(201,168,76,0.10), rgba(201,168,76,0.20), rgba(201,168,76,0.10));
  background-size: 200% 100%;
  animation: ds2-shimmer 1.2s linear infinite;
}
@keyframes ds2-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ═══════════════════════════════════════════════════
   V38: Inline-Suggest-Box (nach Einzelfeld-KI-Vorschlag)
═══════════════════════════════════════════════════ */
.ds2-sugg-box {
  margin-top: 8px;
  padding: 12px 14px;
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.30);
  border-left: 3px solid var(--gold);
  border-radius: 6px;
  font-size: 12.5px;
  animation: ds2-sugg-in 0.2s ease;
}
@keyframes ds2-sugg-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
.ds2-sugg-head {
  display: flex;
  align-items: center;
  gap: 8px;
}
.ds2-sugg-icon { font-size: 16px; flex-shrink: 0; }
.ds2-sugg-label { flex: 1; line-height: 1.4; }
.ds2-sugg-label strong { color: var(--gold); font-weight: 700; }
.ds2-sugg-close {
  background: transparent;
  border: none;
  font-size: 18px;
  color: rgba(42,39,39,0.45);
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
}
.ds2-sugg-close:hover { color: rgba(42,39,39,0.75); }
.ds2-sugg-reason {
  margin-top: 6px;
  padding-left: 24px;
  font-size: 11.5px;
  color: rgba(42,39,39,0.65);
  font-style: italic;
  line-height: 1.45;
}
.ds2-sugg-actions {
  margin-top: 10px;
  padding-left: 24px;
  display: flex;
  gap: 8px;
}

/* ═══════════════════════════════════════════════════
   V38: Bulk-KI-Modal („Alle ausfüllen")
═══════════════════════════════════════════════════ */
.ds2-bulk-overlay {
  position: fixed; inset: 0;
  background: rgba(20,18,18,0.78);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 10100;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.ds2-bulk-modal {
  background: #fff;
  border-radius: 10px;
  width: 100%;
  max-width: 720px;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,0.45);
}
.ds2-bulk-header {
  padding: 16px 22px;
  border-bottom: 1px solid rgba(42,39,39,0.08);
  display: flex;
  align-items: center;
  gap: 12px;
}
.ds2-bulk-header h3 {
  flex: 1;
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.ds2-bulk-body {
  padding: 16px 22px;
  overflow-y: auto;
  flex: 1;
}
.ds2-bulk-warn {
  padding: 10px 14px;
  background: rgba(184,98,92,0.10);
  border-left: 3px solid #B8625C;
  border-radius: 4px;
  font-size: 12.5px;
  margin-bottom: 12px;
}
.ds2-bulk-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
}
.ds2-bulk-table th {
  text-align: left;
  padding: 8px 10px;
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(42,39,39,0.55);
  border-bottom: 1px solid rgba(42,39,39,0.08);
}
.ds2-bulk-table td {
  padding: 10px;
  border-bottom: 1px solid rgba(42,39,39,0.05);
  vertical-align: top;
}
.ds2-bulk-row-empty td { color: rgba(42,39,39,0.40); }
.ds2-bulk-cell {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  cursor: pointer;
}
.ds2-bulk-cb { margin-top: 3px; cursor: pointer; }
.ds2-bulk-new {
  font-weight: 600;
  color: var(--gold);
  display: block;
}
.ds2-bulk-reason {
  display: block;
  margin-top: 3px;
  font-size: 11px;
  color: rgba(42,39,39,0.55);
  font-style: italic;
}
.ds2-bulk-current {
  color: rgba(42,39,39,0.65);
}
.muted { color: rgba(42,39,39,0.40); }
.ds2-bulk-footer {
  padding: 12px 22px;
  border-top: 1px solid rgba(42,39,39,0.08);
  display: flex;
  align-items: center;
  gap: 10px;
}
@media (max-width: 720px) {
  .ds2-bulk-table th:nth-child(2), .ds2-bulk-table td:nth-child(2) { display: none; }
}

/* ═══════════════════════════════════════════════════
   V38: ds2-readonly-Card (Tab Kennzahlen)
═══════════════════════════════════════════════════ */
.ds2-readonly-card { /* wie .card */ }
.ds2-readonly-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}
.ds2-readonly-grid {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: 6px;
}
.ds2-ro-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 7px 10px;
  background: rgba(42,39,39,0.025);
  border-radius: 5px;
  font-size: 12.5px;
}
.ds2-ro-row.ds2-ro-empty { background: transparent; }
.ds2-ro-label {
  font-weight: 500;
  color: var(--ch);
}
.ds2-ro-value {
  font-weight: 600;
  color: var(--ch);
  text-align: right;
}
.ds2-ro-row.ds2-ro-empty .ds2-ro-value {
  color: rgba(42,39,39,0.35);
  font-style: italic;
  font-weight: 400;
}
.ds2-ro-jump {
  background: transparent;
  border: 1px solid rgba(42,39,39,0.15);
  color: rgba(42,39,39,0.65);
  font-size: 10.5px;
  font-weight: 500;
  padding: 3px 8px;
  border-radius: 4px;
  cursor: pointer;
  font-family: inherit;
}
.ds2-ro-jump:hover {
  border-color: var(--gold);
  color: var(--gold);
  background: rgba(201,168,76,0.06);
}
@media (max-width: 720px) {
  .ds2-ro-row {
    grid-template-columns: 1fr auto;
    gap: 4px;
  }
  .ds2-ro-value { grid-column: 1 / -1; text-align: left; }
}

/* ═══════════════════════════════════════════════════
   V38: Quick Check Modal
═══════════════════════════════════════════════════ */
.btn-quickcheck {
  background: linear-gradient(135deg, #C9A84C, #B89638);
  color: #fff;
  border: 1px solid #B89638;
  font-weight: 600;
  letter-spacing: 0.01em;
}
.btn-quickcheck:hover {
  background: linear-gradient(135deg, #D4B458, #C2A340);
  border-color: #C9A84C;
}

.qc-overlay {
  position: fixed; inset: 0;
  background: rgba(20,18,18,0.78);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 10000;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  animation: qc-fade 0.2s ease;
}
@keyframes qc-fade { from { opacity: 0; } to { opacity: 1; } }

.qc-modal {
  background: #fff;
  border-radius: 12px;
  width: 100%;
  /* V49: breiter — vorher 920px */
  max-width: 1100px;
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,0.45);
  animation: qc-slide 0.25s cubic-bezier(0.4,0,0.2,1);
}
@keyframes qc-slide { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

.qc-header {
  padding: 18px 22px;
  border-bottom: 1px solid rgba(42,39,39,0.08);
  display: flex;
  align-items: center;
  gap: 14px;
}
.qc-icon {
  width: 44px; height: 44px;
  background: linear-gradient(135deg, rgba(201,168,76,0.20), rgba(201,168,76,0.08));
  border: 1.5px solid var(--gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  color: var(--gold);
  flex-shrink: 0;
}
.qc-title-block { flex: 1; }
.qc-title-block h3 {
  margin: 0 0 3px;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.qc-sub {
  font-size: 12px;
  color: rgba(42,39,39,0.55);
  line-height: 1.4;
}

.qc-body {
  /* V49: Stack-Layout — Donut/Score oben volle Breite, Form darunter.
     Vorher: grid-template-columns: 1fr 320px (zu schmal, Werte unleserlich) */
  display: flex;
  flex-direction: column;
  gap: 0;
  flex: 1;
  overflow-y: auto;
}

/* Linke Spalte: Form */
.qc-form {
  /* V49: order: 2 → kommt unter dem Score-Bereich */
  order: 2;
  padding: 18px 22px;
  overflow-y: visible;
  border-right: none;
  border-top: 1px solid rgba(42,39,39,0.08);
}
.qc-section {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px dashed rgba(42,39,39,0.10);
}
.qc-section:first-child { margin-top: 0; padding-top: 0; border-top: none; }
.qc-section-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gold);
  margin-bottom: 8px;
}
.qc-row { display: grid; gap: 12px; }
.qc-row-2 { grid-template-columns: 1fr 1fr; }
.qc-row-3 { grid-template-columns: 1fr 1fr 1fr; }
.qc-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 10px;
}
.qc-field label {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--ch);
}
.qc-field input {
  padding: 8px 10px;
  font-size: 14px;
  border: 1px solid rgba(42,39,39,0.15);
  border-radius: 5px;
  font-family: inherit;
  font-variant-numeric: tabular-nums;
}
.qc-field input:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,0.12);
}
.qc-hint {
  font-size: 10.5px;
  color: rgba(42,39,39,0.50);
  font-style: italic;
}

/* Rechte Spalte: Score */
.qc-result {
  /* V49: order: 1 → oben, volle Breite */
  order: 1;
  padding: 22px 22px 18px;
  overflow-y: visible;
  background: linear-gradient(180deg, rgba(201,168,76,0.04), rgba(201,168,76,0.01));
}
.qc-score-card {
  text-align: center;
  padding: 14px 0 18px;
}
.qc-score-label {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: rgba(42,39,39,0.50);
  margin-bottom: 10px;
}
.qc-score-circle {
  width: 130px; height: 130px;
  margin: 0 auto 10px;
  border-radius: 50%;
  background: rgba(42,39,39,0.05);
  border: 4px solid rgba(42,39,39,0.10);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}
.qc-score-value {
  font-size: 38px;
  font-weight: 800;
  color: var(--ch);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.qc-score-max {
  font-size: 11px;
  color: rgba(42,39,39,0.40);
  margin-top: 2px;
}
.qc-score-tag {
  font-size: 13px;
  font-weight: 700;
  color: rgba(42,39,39,0.65);
}
.qc-score-circle.qc-score-green-strong {
  background: rgba(63,165,108,0.10);
  border-color: #2A7E54;
}
.qc-score-circle.qc-score-green-strong .qc-score-value { color: #2A7E54; }
.qc-score-circle.qc-score-green {
  background: rgba(63,165,108,0.08);
  border-color: #3FA56C;
}
.qc-score-circle.qc-score-green .qc-score-value { color: #3FA56C; }
.qc-score-circle.qc-score-gold {
  background: rgba(201,168,76,0.10);
  border-color: var(--gold);
}
.qc-score-circle.qc-score-gold .qc-score-value { color: var(--gold); }
.qc-score-circle.qc-score-red {
  background: rgba(184,98,92,0.10);
  border-color: #B8625C;
}
.qc-score-circle.qc-score-red .qc-score-value { color: #B8625C; }

.qc-kpis {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  margin-bottom: 12px;
}
.qc-kpi {
  padding: 8px 10px;
  background: #fff;
  border: 1px solid rgba(42,39,39,0.10);
  border-radius: 5px;
  text-align: center;
}
.qc-kpi-l {
  font-size: 9.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: rgba(42,39,39,0.50);
}
.qc-kpi-v {
  font-size: 14px;
  font-weight: 700;
  color: var(--ch);
  margin-top: 2px;
  font-variant-numeric: tabular-nums;
}
.qc-kpi.qc-kpi-green { border-color: rgba(63,165,108,0.45); background: rgba(63,165,108,0.05); }
.qc-kpi.qc-kpi-green .qc-kpi-v { color: #2A7E54; }
.qc-kpi.qc-kpi-gold { border-color: rgba(201,168,76,0.45); background: rgba(201,168,76,0.05); }
.qc-kpi.qc-kpi-gold .qc-kpi-v { color: var(--gold); }
.qc-kpi.qc-kpi-red { border-color: rgba(184,98,92,0.45); background: rgba(184,98,92,0.05); }
.qc-kpi.qc-kpi-red .qc-kpi-v { color: #B8625C; }

.qc-eval {
  background: rgba(255,255,255,0.6);
  border: 1px solid rgba(42,39,39,0.06);
  border-radius: 5px;
  padding: 10px 12px;
  font-size: 11.5px;
  line-height: 1.5;
  color: var(--ch);
}
.qc-eval-empty { color: rgba(42,39,39,0.45); font-style: italic; }
.qc-eval-line { margin-bottom: 4px; }
.qc-eval-line:last-child { margin-bottom: 0; }

.qc-footer {
  padding: 14px 22px;
  border-top: 1px solid rgba(42,39,39,0.08);
  display: flex;
  gap: 10px;
  align-items: center;
}

@media (max-width: 800px) {
  .qc-body { grid-template-columns: 1fr; }
  .qc-form { border-right: none; border-bottom: 1px solid rgba(42,39,39,0.08); }
  .qc-row-3 { grid-template-columns: 1fr 1fr; }
  .qc-result { padding-bottom: 30px; }
}

/* ═══════════════════════════════════════════════════
   V38: PDF-Import Modal
═══════════════════════════════════════════════════ */
.pdfi-overlay {
  position: fixed; inset: 0;
  background: rgba(20,18,18,0.78);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 10100;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.pdfi-modal {
  background: #fff;
  border-radius: 12px;
  width: 100%;
  max-width: 600px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,0.45);
}
.pdfi-header {
  padding: 18px 22px;
  border-bottom: 1px solid rgba(42,39,39,0.08);
  display: flex;
  align-items: center;
  gap: 14px;
}
.pdfi-icon {
  font-size: 32px;
  flex-shrink: 0;
}
.pdfi-title-block { flex: 1; }
.pdfi-title-block h3 {
  margin: 0 0 3px;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.pdfi-sub {
  font-size: 11.5px;
  color: rgba(42,39,39,0.55);
  line-height: 1.4;
}
.pdfi-body {
  padding: 22px;
  overflow-y: auto;
  flex: 1;
  min-height: 280px;
}

.pdfi-drop {
  border: 2px dashed rgba(201,168,76,0.35);
  border-radius: 10px;
  padding: 36px 20px;
  text-align: center;
  background: rgba(201,168,76,0.04);
  transition: all 0.15s ease;
}
.pdfi-drop.pdfi-drag {
  border-color: var(--gold);
  background: rgba(201,168,76,0.10);
}
.pdfi-drop-icon {
  font-size: 40px;
  margin-bottom: 10px;
}
.pdfi-drop-title {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 4px;
}
.pdfi-drop-sub {
  font-size: 11.5px;
  color: rgba(42,39,39,0.55);
  margin-bottom: 16px;
}

.pdfi-loading {
  text-align: center;
  padding: 40px 20px;
}
.pdfi-spinner {
  width: 48px; height: 48px;
  margin: 0 auto 14px;
  border: 4px solid rgba(201,168,76,0.18);
  border-top-color: var(--gold);
  border-radius: 50%;
  animation: pdfi-spin 0.8s linear infinite;
}
@keyframes pdfi-spin { to { transform: rotate(360deg); } }
.pdfi-loading-msg {
  font-size: 13px;
  color: rgba(42,39,39,0.65);
  font-weight: 500;
}

.pdfi-error {
  text-align: center;
  padding: 30px 20px;
}
.pdfi-error-icon {
  font-size: 36px;
  color: #B8625C;
  margin-bottom: 10px;
}
.pdfi-error-msg {
  font-size: 13px;
  color: #8B4744;
  margin-bottom: 14px;
  line-height: 1.5;
  background: rgba(184,98,92,0.08);
  padding: 10px 14px;
  border-radius: 6px;
  text-align: left;
}

.pdfi-result-head {
  display: flex;
  gap: 14px;
  align-items: center;
  margin-bottom: 14px;
}
.pdfi-result-icon {
  width: 36px; height: 36px;
  background: #3FA56C;
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 800;
  flex-shrink: 0;
}
.pdfi-result-head h4 {
  margin: 0 0 2px;
  font-size: 15px;
  font-weight: 700;
}
.pdfi-result-sub {
  font-size: 11.5px;
  color: rgba(42,39,39,0.55);
}
.pdfi-result-warn {
  background: rgba(184,98,92,0.10);
  border-left: 3px solid #B8625C;
  padding: 10px 14px;
  border-radius: 4px;
  font-size: 12px;
  margin-bottom: 12px;
}
.pdfi-result-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
}
.pdfi-result-table td {
  padding: 8px 10px;
  border-bottom: 1px solid rgba(42,39,39,0.05);
}
.pdfi-result-cb { width: 30px; text-align: center; }
.pdfi-result-label { font-weight: 600; width: 35%; }
.pdfi-result-value { color: var(--ch); font-variant-numeric: tabular-nums; }
.pdfi-result-empty .pdfi-result-value { color: rgba(42,39,39,0.40); font-style: italic; }
.pdfi-result-actions {
  margin-top: 16px;
  display: flex;
  justify-content: flex-end;
}
.pdfi-footer {
  padding: 12px 22px;
  border-top: 1px solid rgba(42,39,39,0.08);
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

/* ═══════════════════════════════════════════════════
   V39: Premium-Login nach Mockup
═══════════════════════════════════════════════════ */
.auth-overlay-v39 {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background:
    /* Goldener radialer Glow oben drüber — nach rechts verschoben */
    radial-gradient(circle at 75% 50%, rgba(201,168,76,0.20) 0%, rgba(10,8,8,0.55) 35%, rgba(10,8,8,0.85) 70%),
    /* Werbebild Vollbild im Hintergrund */
    url('../assets/login_hero.png') center center / cover no-repeat,
    #0A0808;
  display: flex;
  align-items: center;
  /* V41: Card ~25% von rechts statt mittig */
  justify-content: flex-end;
  padding: 24px 25vw 24px 24px;
  overflow: auto;
  font-family: 'DM Sans', -apple-system, sans-serif;
}

/* Hintergrund-Layer: nur noch der "COMING SOON"-Sticker */
.auth-bg-v39 {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}
.auth-bg-glow {
  /* V40: nicht mehr nötig — Glow ist im Overlay-Background */
  display: none;
}
/* V41: COMING SOON Sticker entfernt */
.auth-bg-coming {
  display: none;
}

/* Card */
.auth-card-v39 {
  position: relative;
  z-index: 2;
  width: 100%;
  /* V41: kleiner — 360px statt 420 */
  max-width: 360px;
  padding: 28px 28px 22px;
  background: linear-gradient(180deg, #1F1B1B 0%, #181515 100%);
  border: 1.5px solid rgba(201,168,76,0.55);
  border-radius: 18px;
  box-shadow:
    0 0 0 1px rgba(201,168,76,0.10),
    0 0 50px rgba(201,168,76,0.22),
    0 20px 60px rgba(0,0,0,0.65);
  color: #fff;
  animation: auth-in-v39 0.45s cubic-bezier(0.4,0,0.2,1);
}
@keyframes auth-in-v39 {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Logo-Block */
.auth-logo-v39 {
  position: relative;
  text-align: center;
  margin-bottom: 28px;
  padding: 14px 24px 16px;
  background: linear-gradient(180deg, #1A1818 0%, #141212 100%);
  border: 1.5px solid rgba(201,168,76,0.45);
  border-radius: 14px;
  overflow: hidden;
}
.auth-logo-wave {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.auth-logo-wave svg {
  width: 100%;
  height: 100%;
  display: block;
}
.auth-logo-text {
  position: relative;
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1;
}
.auth-logo-deal { color: #fff; }
.auth-logo-pilot { color: #C9A84C; }
.auth-logo-by {
  position: relative;
  margin-top: 6px;
  font-size: 11.5px;
  color: #C9A84C;
  font-weight: 500;
  letter-spacing: 0.02em;
}

/* Titel + Sub */
.auth-title-v39 {
  text-align: center;
  font-size: 26px;
  font-weight: 700;
  margin: 0 0 8px;
  color: #fff;
  letter-spacing: -0.01em;
}
.auth-sub-v39 {
  text-align: center;
  margin: 0 0 24px;
  font-size: 13.5px;
  color: rgba(255,255,255,0.55);
  line-height: 1.5;
}

/* Form */
.auth-form-v39 {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.auth-field-v39 {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.auth-field-v39 label {
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.01em;
}

/* Input mit Icon */
.auth-input-wrap {
  position: relative;
}
.auth-input-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: #C9A84C;
  pointer-events: none;
}
.auth-input-wrap input {
  width: 100%;
  padding: 13px 14px 13px 42px;
  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 10px;
  color: #fff;
  font-size: 14px;
  font-family: inherit;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.auth-input-wrap input::placeholder { color: rgba(255,255,255,0.30); }
.auth-input-wrap input:focus {
  outline: none;
  border-color: rgba(201,168,76,0.55);
  background: rgba(0,0,0,0.50);
}
.auth-input-wrap input:-webkit-autofill {
  -webkit-text-fill-color: #fff;
  -webkit-box-shadow: 0 0 0 30px rgba(20,18,18,0.95) inset;
  caret-color: #fff;
}

/* Eye-Toggle */
.auth-eye-btn {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.45);
  padding: 6px;
  cursor: pointer;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.auth-eye-btn:hover { color: #C9A84C; }
.auth-eye-btn.auth-eye-active { color: #C9A84C; }

/* Anmelde-Button */
.auth-btn-v39 {
  margin-top: 6px;
  width: 100%;
  padding: 15px 20px;
  background: linear-gradient(180deg, #E0BB5C 0%, #C9A84C 100%);
  border: none;
  border-radius: 12px;
  color: #1A1818;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.01em;
  cursor: pointer;
  font-family: inherit;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.10) inset,
    0 6px 24px rgba(201,168,76,0.45);
  transition: transform 0.10s ease, box-shadow 0.15s ease;
}
.auth-btn-v39:hover {
  transform: translateY(-1px);
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.15) inset,
    0 10px 30px rgba(201,168,76,0.55);
}
.auth-btn-v39:active { transform: translateY(0); }
.auth-btn-v39:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}
.auth-btn-arrow { font-size: 17px; transition: transform 0.15s ease; }
.auth-btn-v39:hover .auth-btn-arrow { transform: translateX(3px); }

/* Error-Box */
.auth-error-v39 {
  background: rgba(184,98,92,0.16);
  border: 1px solid rgba(184,98,92,0.40);
  border-radius: 8px;
  color: #DDA29E;
  font-size: 12.5px;
  padding: 9px 12px;
  margin-top: 2px;
}

/* Forgot-Password (deaktiviert) */
.auth-forgot-v39 {
  text-align: center;
  margin-top: -2px;
}
.auth-link-disabled {
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.35);
  font-size: 12px;
  font-family: inherit;
  cursor: not-allowed;
  padding: 4px 8px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.auth-link-tag {
  background: rgba(184,98,92,0.20);
  color: #DDA29E;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  padding: 2px 6px;
  border-radius: 3px;
}

/* Divider */
.auth-divider-v39 {
  position: relative;
  text-align: center;
  margin: 14px 0 4px;
  font-size: 11px;
  color: rgba(255,255,255,0.30);
  text-transform: uppercase;
  letter-spacing: 0.18em;
}
.auth-divider-v39::before,
.auth-divider-v39::after {
  content: '';
  position: absolute;
  top: 50%;
  width: calc(50% - 28px);
  height: 1px;
  background: rgba(255,255,255,0.10);
}
.auth-divider-v39::before { left: 0; }
.auth-divider-v39::after { right: 0; }
.auth-divider-v39 span {
  background: linear-gradient(180deg, #1F1B1B 0%, #181515 100%);
  padding: 0 12px;
}

/* Beta-Tester-Button (prominent gold-outline) */
.auth-beta-v39 {
  width: 100%;
  padding: 12px 16px;
  background: rgba(201,168,76,0.08);
  border: 1.5px solid rgba(201,168,76,0.55);
  border-radius: 10px;
  color: #C9A84C;
  font-size: 13.5px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all 0.15s ease;
}
.auth-beta-v39:hover {
  background: rgba(201,168,76,0.18);
  border-color: #C9A84C;
}
.auth-beta-icon { font-size: 14px; }

/* Registrieren-Button (deaktiviert) */
.auth-register-v39 {
  width: 100%;
  padding: 11px 16px;
  background: transparent;
  border: 1px dashed rgba(255,255,255,0.18);
  border-radius: 10px;
  color: rgba(255,255,255,0.40);
  font-size: 12.5px;
  font-weight: 500;
  cursor: not-allowed;
  font-family: inherit;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.auth-register-v39[disabled] { opacity: 0.85; }

/* Footer DSGVO */
.auth-footer-v39 {
  margin-top: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 11.5px;
  color: rgba(201,168,76,0.65);
  font-weight: 500;
}
.auth-footer-v39 svg { color: #C9A84C; flex-shrink: 0; }

/* Mobile */
@media (max-width: 768px) {
  /* V41: Auf Phone wieder zentriert (kein Padding-rechts) */
  .auth-overlay-v39 { justify-content: center; padding: 24px; }
}
@media (max-width: 480px) {
  .auth-card-v39 { padding: 22px 20px 18px; max-width: 100%; }
  .auth-logo-text { font-size: 26px; }
  .auth-title-v39 { font-size: 22px; }
}

/* ═══════════════════════════════════════════════════
   V39: Header-Kennzahlen-Pills (größer + prominenter)
═══════════════════════════════════════════════════ */
.hdr-badges-v39 {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.hdr-badges-v39 .hdr-badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 7px 14px 7px 11px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 10px;
  font-size: 13px;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  transition: transform 0.15s ease;
}
.hdr-badges-v39 .hdr-badge:hover {
  transform: translateY(-1px);
  background: rgba(255,255,255,0.10);
}
.hdr-badges-v39 .hdr-badge-l {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
}
.hdr-badges-v39 .hdr-badge-v {
  font-weight: 800;
  font-size: 14.5px;
  color: #fff;
  letter-spacing: -0.01em;
}
.hdr-badges-v39 .hdr-badge.b-green {
  border-color: rgba(63,165,108,0.55);
  background: rgba(63,165,108,0.18);
  box-shadow: 0 0 0 1px rgba(63,165,108,0.18) inset;
}
.hdr-badges-v39 .hdr-badge.b-green .hdr-badge-v { color: #6FCB91; }
.hdr-badges-v39 .hdr-badge.b-gold {
  border-color: rgba(201,168,76,0.60);
  background: rgba(201,168,76,0.22);
  box-shadow: 0 0 0 1px rgba(201,168,76,0.20) inset;
}
.hdr-badges-v39 .hdr-badge.b-gold .hdr-badge-v { color: var(--gold); }
.hdr-badges-v39 .hdr-badge.b-red {
  border-color: rgba(184,98,92,0.60);
  background: rgba(184,98,92,0.22);
  box-shadow: 0 0 0 1px rgba(184,98,92,0.20) inset;
}
.hdr-badges-v39 .hdr-badge.b-red .hdr-badge-v { color: #DDA29E; }

@media (max-width: 1280px) {
  .hdr-badges-v39 .hdr-badge { padding: 6px 11px 6px 9px; }
  .hdr-badges-v39 .hdr-badge-l { font-size: 9px; }
  .hdr-badges-v39 .hdr-badge-v { font-size: 13px; }
}
@media (max-width: 1024px) {
  .hdr-badges-v39 { display: none; }     /* auf Tablet/Phone: Platz für Mehr-Menü */
}

/* ═══════════════════════════════════════════════════
   V39: Header "Mehr"-Dropdown
═══════════════════════════════════════════════════ */
.hdr-more-wrap {
  position: relative;
  display: inline-block;
}
.hdr-more-btn {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  padding: 7px 12px !important;
}
.hdr-more-btn > span:first-child {
  font-size: 18px;
  line-height: 1;
}
.hdr-more-label {
  font-size: 13px;
  font-weight: 600;
}
@media (max-width: 720px) {
  .hdr-more-label { display: none; }
}

.hdr-more-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 240px;
  background: linear-gradient(180deg, #2A2727 0%, #1F1D1D 100%);
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 10px;
  padding: 8px;
  box-shadow: 0 12px 36px rgba(0,0,0,0.55), 0 0 0 1px rgba(201,168,76,0.10);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity 0.15s ease, transform 0.15s ease;
  z-index: 9000;
}
.hdr-more-menu.hdr-more-open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.hdr-more-section {
  padding: 4px 0;
}
.hdr-more-sec-l {
  font-size: 9.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: rgba(255,255,255,0.40);
  padding: 4px 12px 6px;
}
.hdr-more-sep {
  height: 1px;
  background: rgba(255,255,255,0.08);
  margin: 4px 0;
}
.hdr-more-item {
  display: flex;
  align-items: center;
  gap: 11px;
  width: 100%;
  padding: 9px 12px;
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.85);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  border-radius: 6px;
  text-align: left;
  font-family: inherit;
  transition: background 0.10s ease, color 0.10s ease;
}
.hdr-more-item:hover {
  background: rgba(201,168,76,0.12);
  color: #fff;
}
.hdr-more-icon {
  width: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  color: var(--gold);
  flex-shrink: 0;
}
.hdr-more-text {
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex: 1;
}
.hdr-more-text small {
  font-size: 10.5px;
  color: rgba(255,255,255,0.45);
  font-weight: 400;
}
.hdr-more-item-accent {
  background: linear-gradient(90deg, rgba(201,168,76,0.10), transparent);
}
.hdr-more-item-accent:hover {
  background: linear-gradient(90deg, rgba(201,168,76,0.22), rgba(201,168,76,0.04));
}

/* ═══════════════════════════════════════════════════
   V39: Quick Check Erweiterungen
═══════════════════════════════════════════════════ */
.qc-section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.qc-ai-mini {
  background: rgba(201,168,76,0.10);
  border: 1px solid rgba(201,168,76,0.35);
  color: var(--gold);
  font-size: 11px;
  width: 24px;
  height: 24px;
  padding: 0;
  border-radius: 5px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.12s ease;
  font-family: inherit;
}
.qc-ai-mini:hover {
  background: rgba(201,168,76,0.25);
  transform: scale(1.08);
}
.qc-ai-mini:disabled {
  opacity: 0.5;
  cursor: wait;
}

/* Bewirtschaftung Toggle */
.qc-bewirt-toggle {
  display: inline-flex;
  background: rgba(42,39,39,0.05);
  border: 1px solid rgba(42,39,39,0.10);
  border-radius: 6px;
  padding: 2px;
  margin-bottom: 10px;
  margin-top: 4px;
}
.qc-bewirt-btn {
  background: transparent;
  border: none;
  padding: 6px 12px;
  font-size: 11.5px;
  font-weight: 500;
  color: rgba(42,39,39,0.65);
  cursor: pointer;
  border-radius: 4px;
  font-family: inherit;
  transition: all 0.10s ease;
}
.qc-bewirt-btn.active {
  background: var(--gold);
  color: #fff;
  font-weight: 600;
}

/* LTV Quick-Selects */
.qc-ltv-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.qc-ltv-l {
  font-size: 11px;
  font-weight: 600;
  color: rgba(42,39,39,0.65);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-right: 4px;
}
.qc-ltv-btn {
  background: rgba(42,39,39,0.04);
  border: 1px solid rgba(42,39,39,0.15);
  padding: 6px 12px;
  font-size: 12px;
  font-weight: 600;
  color: rgba(42,39,39,0.70);
  border-radius: 6px;
  cursor: pointer;
  font-family: inherit;
  font-variant-numeric: tabular-nums;
  transition: all 0.12s ease;
}
.qc-ltv-btn:hover {
  border-color: var(--gold);
  color: var(--gold);
}
.qc-ltv-btn.active {
  background: var(--gold);
  color: #fff;
  border-color: var(--gold);
  box-shadow: 0 2px 8px rgba(201,168,76,0.30);
}

/* KI-Source Annotation */
.qc-ai-src {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  margin-top: 5px;
  padding: 6px 9px;
  background: rgba(201,168,76,0.08);
  border-left: 2px solid var(--gold);
  border-radius: 0 4px 4px 0;
  font-size: 10.5px;
  line-height: 1.4;
  color: rgba(42,39,39,0.75);
  animation: qc-ai-src-in 0.25s ease;
}
@keyframes qc-ai-src-in { from { opacity: 0; transform: translateY(-3px); } to { opacity: 1; transform: translateY(0); } }
.qc-ai-src-icon { color: var(--gold); flex-shrink: 0; }
.qc-ai-src-text strong { color: var(--gold); font-weight: 700; }

/* ═══════════════════════════════════════════════════
   V39: KI-Quellen-Anzeige (persistent unter Feldern)
═══════════════════════════════════════════════════ */
.ds2-field-source {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
  padding: 5px 8px;
  background: linear-gradient(90deg, rgba(201,168,76,0.10), rgba(201,168,76,0.04));
  border-left: 2px solid var(--gold);
  border-radius: 0 4px 4px 0;
  font-size: 10.5px;
  color: rgba(42,39,39,0.75);
  line-height: 1.4;
  animation: ds2-field-source-in 0.25s ease;
}
@keyframes ds2-field-source-in { from { opacity: 0; transform: translateY(-3px); } to { opacity: 1; transform: translateY(0); } }
.ds2-field-source-icon {
  flex-shrink: 0;
  font-size: 11px;
}
.ds2-field-source-text {
  flex: 1;
}
.ds2-field-source-text strong {
  color: var(--gold);
  font-weight: 700;
}
.ds2-field-source-x {
  background: transparent;
  border: none;
  color: rgba(42,39,39,0.40);
  cursor: pointer;
  padding: 0 4px;
  font-size: 14px;
  line-height: 1;
  font-family: inherit;
}
.ds2-field-source-x:hover { color: rgba(42,39,39,0.75); }

/* In Bulk-Modal Source-Display */
.ds2-bulk-source {
  display: block;
  margin-top: 3px;
  font-size: 10.5px;
  color: var(--gold);
  font-weight: 600;
}

/* Inline-Suggestion Source */
.ds2-sugg-source {
  margin-top: 4px;
  padding-left: 24px;
  font-size: 10.5px;
  color: var(--gold);
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════
   V39: DealScore 2.0 — Icons/Parameter größer
═══════════════════════════════════════════════════ */
.ds-card.ds2-card .ds-cat-name,
.ds2-metrics .ds-metric-name {
  font-size: 13.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.005em;
}
.ds2-metrics .ds-metric-pct,
.ds-card.ds2-card .ds-cat-pct {
  font-size: 14px !important;
  font-weight: 700 !important;
}
.ds2-card .ds-score-num {
  font-size: 64px !important;
  font-weight: 800 !important;
}
.ds2-card .ds-score-max {
  font-size: 16px !important;
}
.ds2-card .ds-pn-col h5 {
  font-size: 13px !important;
  letter-spacing: 0.04em;
}
.ds2-card .ds-pn-col li {
  font-size: 13px !important;
  padding: 4px 0;
}
.ds2-card .ds-cat-name::before {
  /* Icon-Container vor dem Namen — nutzt Emoji aus Datenattribut */
  content: '';
}

/* Bullet-Pfeile vor Top-Faktoren statt nur "•" — größer und farbig */
.ds2-pn-pos li::marker { color: #6FCB91; }
.ds2-pn-neg li::marker { color: #DDA29E; }

/* DealScore 2.0 — Header mit Icon-Pills */
.ds-card.ds2-card {
  padding: 22px 24px !important;
}

/* ═══════════════════════════════════════════════════
   V39: Sterne-Bewertung — größer und prominenter
═══════════════════════════════════════════════════ */
.qz-card {
  padding: 22px 24px !important;
}
.qz-title {
  font-size: 17px !important;
  margin-bottom: 18px !important;
}
.qz-row {
  grid-template-columns: 170px 1fr auto !important;
  padding: 8px 0 !important;
}
.qz-row-name {
  gap: 10px !important;
  font-size: 14px !important;
}
.qz-icon {
  width: 24px !important;
  height: 24px !important;
}
.qz-stars {
  gap: 6px !important;
}
.qz-star {
  padding: 8px !important;
  margin: -4px !important;
}
.qz-label {
  font-size: 13px !important;
  min-width: 200px !important;
}
.qz-footer {
  padding-top: 14px !important;
  margin-top: 16px !important;
  font-size: 13px !important;
}

/* ═══════════════════════════════════════════════════
   V40: KI-Lage-Box inline in der Bewertung-&-Lage-Card
═══════════════════════════════════════════════════ */
.ki-lage-box-inline {
  margin-top: 14px;
  padding: 12px 14px !important;
  border-top: 1px dashed rgba(42,39,39,0.10);
  background: linear-gradient(180deg, rgba(201,168,76,0.04), transparent);
  border-radius: 0 0 6px 6px;
}
.ki-lage-box-inline .ki-lage-title {
  font-size: 13px;
}
.ki-lage-box-inline .ki-lage-tag {
  font-size: 9.5px !important;
}

/* ═══════════════════════════════════════════════════
   V40: Source-Link (klickbar mit Pfeil)
═══════════════════════════════════════════════════ */
.ds2-source-link {
  color: var(--gold);
  text-decoration: none;
  font-weight: 700;
}
.ds2-source-link:hover {
  text-decoration: underline;
}
.ds2-source-link strong {
  color: inherit;
}

/* ═══════════════════════════════════════════════════
   V40: Header zeigt DealScore 2.0 + 5 Bereiche
═══════════════════════════════════════════════════ */
.hdr-badges-v39 {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.hdr-ds2-score {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 64px;
  padding: 4px 12px;
  background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(255,255,255,0.18);
  border-radius: 10px;
}
.hdr-ds2-num {
  font-size: 20px;
  font-weight: 800;
  line-height: 1;
  color: #fff;
  font-variant-numeric: tabular-nums;
}
.hdr-ds2-l {
  font-size: 8.5px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  margin-top: 2px;
}
.hdr-ds2-score.b-green-strong {
  border-color: #2A7E54;
  background: rgba(63,165,108,0.25);
}
.hdr-ds2-score.b-green-strong .hdr-ds2-num { color: #6FCB91; }
.hdr-ds2-score.b-green {
  border-color: rgba(63,165,108,0.55);
  background: rgba(63,165,108,0.18);
}
.hdr-ds2-score.b-green .hdr-ds2-num { color: #6FCB91; }
.hdr-ds2-score.b-gold {
  border-color: rgba(201,168,76,0.60);
  background: rgba(201,168,76,0.22);
}
.hdr-ds2-score.b-gold .hdr-ds2-num { color: var(--gold); }
.hdr-ds2-score.b-red {
  border-color: rgba(184,98,92,0.60);
  background: rgba(184,98,92,0.22);
}
.hdr-ds2-score.b-red .hdr-ds2-num { color: #DDA29E; }

.hdr-ds2-cats {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
  gap: 6px;
}
.hdr-ds2-cat {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 9.5px;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  min-width: 0;
}
.hdr-ds2-cat-l {
  color: rgba(255,255,255,0.55);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  width: 42px;
  text-align: right;
}
.hdr-ds2-cat-bar {
  flex: 1;
  height: 5px;
  background: rgba(255,255,255,0.10);
  border-radius: 3px;
  overflow: hidden;
  min-width: 36px;
}
.hdr-ds2-cat-fill {
  display: block;
  height: 100%;
  border-radius: 3px;
  transition: width 0.4s ease;
}
.hdr-ds2-cat.b-green .hdr-ds2-cat-fill { background: linear-gradient(90deg, #3FA56C, #6FCB91); }
.hdr-ds2-cat.b-gold .hdr-ds2-cat-fill  { background: linear-gradient(90deg, #B89638, #C9A84C); }
.hdr-ds2-cat.b-red .hdr-ds2-cat-fill   { background: linear-gradient(90deg, #B8625C, #DDA29E); }
.hdr-ds2-cat-v {
  color: #fff;
  font-weight: 700;
  width: 18px;
  text-align: right;
  font-size: 10px;
}

@media (max-width: 1280px) {
  .hdr-ds2-num { font-size: 17px; }
  .hdr-ds2-cats { grid-template-columns: 1fr 1fr 1fr; }
  .hdr-ds2-cat:nth-child(n+4) { display: none; }
}
@media (max-width: 1024px) {
  .hdr-badges-v39 { display: none; }
}

/* ═══════════════════════════════════════════════════
   V40: DealScore 2.0 — 5 Bereiche deutlich größer
═══════════════════════════════════════════════════ */
.ds2-card .ds2-metrics .ds-metric {
  padding: 14px 16px !important;        /* war ~10px */
  font-size: 14px;
}
.ds2-card .ds2-metrics .ds-metric-name {
  font-size: 14.5px !important;
  font-weight: 600 !important;
}
.ds2-card .ds2-metrics .ds-metric-icon {
  width: 26px !important;
  height: 26px !important;
  font-size: 18px !important;
}
.ds2-card .ds2-metrics .ds-metric-pct {
  font-size: 16px !important;
  font-weight: 800 !important;
}
.ds2-card .ds2-metrics .ds-metric-bar {
  height: 8px !important;
  border-radius: 4px !important;
}

/* KPI-Übersicht-Modal */
.ds2-actions-row {
  display: flex;
  gap: 8px;
  margin-top: 14px;
  flex-wrap: wrap;
}
.ds2-actions-row .btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.ds2-kpi-overlay {
  position: fixed; inset: 0;
  background: rgba(20,18,18,0.78);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 10100;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.ds2-kpi-modal {
  background: #fff;
  border-radius: 12px;
  width: 100%;
  max-width: 720px;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,0.45);
}
.ds2-kpi-header {
  padding: 18px 22px;
  border-bottom: 1px solid rgba(42,39,39,0.08);
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.ds2-kpi-header h3 {
  margin: 0 0 4px;
  font-size: 17px;
  font-weight: 700;
}
.ds2-kpi-summary {
  font-size: 12px;
  color: rgba(42,39,39,0.65);
}
.ds2-kpi-summary strong { color: var(--ch); }
.ds2-kpi-body {
  padding: 18px 22px;
  overflow-y: auto;
  flex: 1;
}
.ds2-kpi-section {
  margin-bottom: 16px;
  border: 1px solid rgba(42,39,39,0.08);
  border-radius: 8px;
  overflow: hidden;
}
.ds2-kpi-section-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: rgba(42,39,39,0.03);
  border-bottom: 1px solid rgba(42,39,39,0.05);
}
.ds2-kpi-section-icon {
  font-size: 18px;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  color: var(--gold, #C9A84C);
}
.ds2-kpi-section-icon svg {
  width: 18px;
  height: 18px;
  display: block;
}
.ds2-kpi-section-name {
  flex: 1;
  font-size: 14px;
  font-weight: 700;
  color: var(--ch);
}
.ds2-kpi-section-stats {
  font-size: 11px;
  color: rgba(42,39,39,0.55);
  font-weight: 500;
}
.ds2-kpi-section-score {
  font-size: 12px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 4px;
  background: rgba(42,39,39,0.05);
  font-variant-numeric: tabular-nums;
}
.ds2-kpi-section-score.ds2-kpi-green { background: rgba(63,165,108,0.15); color: #2A7E54; }
.ds2-kpi-section-score.ds2-kpi-gold  { background: rgba(201,168,76,0.18); color: var(--gold); }
.ds2-kpi-section-score.ds2-kpi-red   { background: rgba(184,98,92,0.18); color: #B8625C; }

.ds2-kpi-group-l {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(42,39,39,0.50);
  padding: 8px 14px 4px;
}
.ds2-kpi-group-avail .ds2-kpi-group-l { color: #2A7E54; }
.ds2-kpi-group-miss .ds2-kpi-group-l { color: rgba(42,39,39,0.40); }

.ds2-kpi-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 80px 50px;
  align-items: center;
  gap: 10px;
  padding: 6px 14px;
  font-size: 12.5px;
  border-bottom: 1px solid rgba(42,39,39,0.04);
}
.ds2-kpi-row:last-child { border-bottom: none; }
.ds2-kpi-row-applied { background: #fff; }
.ds2-kpi-row-missing {
  background: rgba(42,39,39,0.02);
  color: rgba(42,39,39,0.55);
}
.ds2-kpi-label { font-weight: 500; }
.ds2-kpi-value { font-variant-numeric: tabular-nums; color: var(--ch); }
.ds2-kpi-empty { color: rgba(42,39,39,0.40); font-style: italic; font-size: 11.5px; }
.ds2-kpi-points {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  text-align: center;
  padding: 2px 6px;
  border-radius: 3px;
  font-size: 11.5px;
}
.ds2-kpi-points.ds2-kpi-green { background: rgba(63,165,108,0.15); color: #2A7E54; }
.ds2-kpi-points.ds2-kpi-gold  { background: rgba(201,168,76,0.18); color: var(--gold); }
.ds2-kpi-points.ds2-kpi-red   { background: rgba(184,98,92,0.18); color: #B8625C; }
.ds2-kpi-weight {
  font-size: 10.5px;
  color: rgba(42,39,39,0.50);
  text-align: right;
}
.ds2-kpi-footer {
  padding: 12px 22px;
  border-top: 1px solid rgba(42,39,39,0.08);
  display: flex;
  justify-content: flex-end;
}

@media (max-width: 600px) {
  .ds2-kpi-row { grid-template-columns: 1fr 60px 40px; }
  .ds2-kpi-value { display: none; }
}

/* DS2-Settings-CTA in Einstellungen */
.ds2-settings-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 10px;
}

/* ═══════════════════════════════════════════════════
   V40: Sidebar Icon-Nav (ersetzt Header-Dropdown)
═══════════════════════════════════════════════════ */
.sb-iconnav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 8px;
  border-top: 1px solid rgba(255,255,255,0.06);
  margin-top: 8px;
}
.sb-iconnav-btn {
  display: flex;
  align-items: center;
  gap: 11px;
  width: 100%;
  padding: 9px 10px;
  background: transparent;
  border: 1px solid transparent;
  color: rgba(255,255,255,0.75);
  font-size: 12.5px;
  font-weight: 500;
  cursor: pointer;
  border-radius: 6px;
  text-align: left;
  font-family: inherit;
  transition: all 0.10s ease;
}
.sb-iconnav-btn:hover {
  background: rgba(201,168,76,0.10);
  color: #fff;
  border-color: rgba(201,168,76,0.20);
}
.sb-iconnav-active {
  background: rgba(201,168,76,0.18) !important;
  color: #fff !important;
  border-color: rgba(201,168,76,0.45) !important;
  font-weight: 600;
}
.sb-iconnav-accent {
  background: linear-gradient(90deg, rgba(201,168,76,0.10), transparent);
  border-color: rgba(201,168,76,0.20);
  color: var(--gold);
  font-weight: 600;
}
.sb-iconnav-accent:hover {
  background: linear-gradient(90deg, rgba(201,168,76,0.25), rgba(201,168,76,0.05));
}
.sb-iconnav-ico {
  width: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
}
.sb-iconnav-l {
  flex: 1;
}

/* ═══════════════════════════════════════════════════
   V40: Track Record — Karten-Grid mit Thumbnail
═══════════════════════════════════════════════════ */
.trackrec-summary {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
  margin-bottom: 14px;
}
.trackrec-sum-tile {
  padding: 12px 14px;
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.20);
  border-radius: 8px;
  text-align: center;
}
.trackrec-sum-l {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.65);
  margin-bottom: 4px;
}
.trackrec-sum-v {
  font-size: 18px;
  font-weight: 800;
  color: var(--gold);
  font-variant-numeric: tabular-nums;
}

.trackrec-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}
.trackrec-card-v40 {
  background: linear-gradient(180deg, #2A2727 0%, #1F1D1D 100%);
  border: 1px solid rgba(201,168,76,0.18);
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  transition: all 0.15s ease;
}
.trackrec-card-v40:hover {
  border-color: var(--gold);
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.40);
}
.trackrec-card-img {
  width: 100%;
  aspect-ratio: 16/9;
  background: #1A1818 center center / cover no-repeat;
}
.trackrec-card-img-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.30);
  font-size: 32px;
  gap: 4px;
}
.trackrec-card-img-empty small { font-size: 11px; }
.trackrec-card-body {
  padding: 14px 14px 12px;
}
.trackrec-card-head {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 4px;
}
.trackrec-card-name {
  flex: 1;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  line-height: 1.3;
}
.trackrec-card-score {
  position: relative;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.trackrec-card-score.tr-score-green-strong { color: #6FCB91; }
.trackrec-card-score.tr-score-green { color: #6FCB91; }
.trackrec-card-score.tr-score-gold { color: var(--gold); }
.trackrec-card-score.tr-score-red { color: #DDA29E; }
.trackrec-card-score-num {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11.5px;
  font-weight: 800;
  color: inherit;
  font-variant-numeric: tabular-nums;
}
.trackrec-card-addr {
  font-size: 11.5px;
  color: rgba(255,255,255,0.55);
  margin-bottom: 10px;
}
.trackrec-card-kpis {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
  margin-bottom: 10px;
}
.trackrec-card-kpi {
  text-align: left;
}
.trackrec-card-kpi-l {
  font-size: 9.5px;
  font-weight: 600;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
  letter-spacing: 0.05em;
}
.trackrec-card-kpi-v {
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}
.trackrec-card-pdf {
  width: 100%;
}

@media (max-width: 600px) {
  .trackrec-cards-grid { grid-template-columns: 1fr; }
  .trackrec-summary { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════
   V40: Mini-DS2-Score in Sidebar-Karten neben Kaufpreis
═══════════════════════════════════════════════════ */
.sbc-kp-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.sbc-mini-score {
  position: relative;
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.sbc-mini-score.sbc-score-green-strong { color: #6FCB91; }
.sbc-mini-score.sbc-score-green { color: #6FCB91; }
.sbc-mini-score.sbc-score-gold { color: var(--gold); }
.sbc-mini-score.sbc-score-red { color: #DDA29E; }
.sbc-mini-score-num {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 800;
  color: inherit;
  font-variant-numeric: tabular-nums;
}

/* ═══════════════════════════════════════════════════
   V41: Login-Card kompakter
═══════════════════════════════════════════════════ */
.auth-card-v39 .auth-title-v39 {
  font-size: 22px !important;
  margin-bottom: 6px !important;
}
.auth-card-v39 .auth-sub-v39 {
  font-size: 12.5px !important;
  margin-bottom: 18px !important;
}
.auth-card-v39 .auth-form-v39 {
  gap: 11px !important;
}
.auth-card-v39 .auth-input-wrap input {
  padding: 11px 12px 11px 38px !important;
  font-size: 13.5px !important;
}
.auth-card-v39 .auth-btn-v39 {
  padding: 12px 18px !important;
  font-size: 14px !important;
}
.auth-card-v39 .auth-logo-v39 {
  margin-bottom: 22px !important;
  padding: 12px 22px 14px !important;
}
.auth-card-v39 .auth-logo-text {
  font-size: 28px !important;
}
.auth-card-v39 .auth-divider-v39 {
  margin: 10px 0 2px !important;
}
.auth-card-v39 .auth-beta-v39,
.auth-card-v39 .auth-register-v39 {
  padding: 10px 14px !important;
  font-size: 13px !important;
}

/* ═══════════════════════════════════════════════════
   V41: Header beim Scrollen sticky (verstärkt)
═══════════════════════════════════════════════════ */
.hdr {
  position: sticky !important;
  top: 0 !important;
  z-index: 300;
}
/* Tabs darunter auch sticky bleiben */
.tabs {
  position: sticky !important;
  top: 64px !important;
  z-index: 200;
}

/* ═══════════════════════════════════════════════════
   V41: Sidebar Toggle-Button + minimierter Modus
═══════════════════════════════════════════════════ */
/* Toggle-Button oben links in Sidebar (über Logo) */
.sb-toggle-v41 {
  position: absolute;
  top: 12px;
  left: 12px;
  width: 32px;
  height: 32px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 6px;
  color: var(--gold);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  font-family: inherit;
  transition: all 0.12s ease;
}
.sb-toggle-v41:hover {
  background: rgba(201,168,76,0.18);
  border-color: var(--gold);
}

/* App-Wrap Breite anpassen — minimiert ist nun 64px (statt 50) für die größeren Icons */
.app-wrap.sb-collapsed {
  grid-template-columns: 64px 1fr;
}

/* Minimierter Modus: Logo, Liste, Banner, Footer ausblenden */
.app-wrap.sb-collapsed .sb-banner,
.app-wrap.sb-collapsed .sb-actions,
.app-wrap.sb-collapsed .sb-section-title,
.app-wrap.sb-collapsed .sb-list,
.app-wrap.sb-collapsed .sb-portfolio,
.app-wrap.sb-collapsed .sb-footer,
.app-wrap.sb-collapsed .sb-dealpilot-logo {
  display: none !important;
}

/* sb-header im minimiert: kleiner */
.app-wrap.sb-collapsed .sb-header {
  padding: 0;
  min-height: 56px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

/* Toggle-Button im minimiert: zentrieren */
.app-wrap.sb-collapsed .sb-toggle-v41 {
  left: 50%;
  transform: translateX(-50%);
  top: 12px;
}

/* Icon-Nav im minimiert: nur Icons, keine Labels */
.app-wrap.sb-collapsed .sb-iconnav {
  padding: 8px 6px;
  gap: 4px;
}
.app-wrap.sb-collapsed .sb-iconnav-btn {
  padding: 10px 0;
  justify-content: center;
  position: relative;
}
.app-wrap.sb-collapsed .sb-iconnav-btn .sb-iconnav-l {
  display: none;
}
.app-wrap.sb-collapsed .sb-iconnav-btn .sb-iconnav-ico {
  width: auto;
  font-size: 18px;
}

/* Hover-Tooltip im minimiert — zeigt den Label-Text rechts neben dem Icon */
.app-wrap.sb-collapsed .sb-iconnav-btn::after {
  content: attr(title);
  position: absolute;
  left: calc(100% + 10px);
  top: 50%;
  transform: translateY(-50%);
  background: rgba(20, 18, 18, 0.95);
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  padding: 6px 10px;
  border-radius: 5px;
  border: 1px solid rgba(201,168,76,0.30);
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  z-index: 9999;
  transition: opacity 0.15s ease;
  box-shadow: 0 4px 14px rgba(0,0,0,0.35);
}
.app-wrap.sb-collapsed .sb-iconnav-btn:hover::after {
  opacity: 1;
}

/* Mobile: Sidebar überlagert */
@media (max-width: 1024px) {
  .app-wrap.sb-collapsed {
    grid-template-columns: 0 1fr;
  }
  .app-wrap.sb-collapsed .sidebar {
    width: 0;
    overflow: hidden;
  }
}

/* ═══════════════════════════════════════════════════
   V41: Auto-Save-Indikator im Header
═══════════════════════════════════════════════════ */
.hdr-save-indicator {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 12.5px;
  font-weight: 500;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.10);
  color: rgba(255,255,255,0.65);
  transition: all 0.20s ease;
}
.hdr-save-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,0.30);
  flex-shrink: 0;
}
.hdr-save-indicator.save-idle .hdr-save-dot {
  background: rgba(255,255,255,0.30);
}
.hdr-save-indicator.save-pending .hdr-save-dot {
  background: var(--gold);
  animation: hdr-save-pulse 1s ease infinite;
}
.hdr-save-indicator.save-saving .hdr-save-dot {
  background: var(--gold);
  animation: hdr-save-pulse 0.7s ease infinite;
}
.hdr-save-indicator.save-saved {
  background: rgba(63,165,108,0.18);
  border-color: rgba(63,165,108,0.45);
  color: #6FCB91;
}
.hdr-save-indicator.save-saved .hdr-save-dot {
  background: #6FCB91;
}
.hdr-save-indicator.save-error {
  background: rgba(184,98,92,0.18);
  border-color: rgba(184,98,92,0.45);
  color: #DDA29E;
}
.hdr-save-indicator.save-error .hdr-save-dot {
  background: #DDA29E;
}
@keyframes hdr-save-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.85); }
}

@media (max-width: 720px) {
  .hdr-save-indicator .hdr-save-text { display: none; }
  .hdr-save-indicator { padding: 6px 8px; }
}

/* ═══════════════════════════════════════════════════
   V41: Header DealScore-Bar Icons
═══════════════════════════════════════════════════ */
.hdr-ds2-cat {
  grid-template-columns: auto auto 1fr auto;     /* mit icon */
}
.hdr-ds2-cat-ico {
  font-size: 13px;
  flex-shrink: 0;
  width: 16px;
  text-align: center;
}

/* ═══════════════════════════════════════════════════
   V41: Bewertungs-Label neben Score in Sidebar-Karteien
═══════════════════════════════════════════════════ */
.sbc-score-wrap {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.sbc-score-label {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.02em;
  padding: 2px 7px;
  border-radius: 4px;
  white-space: nowrap;
}
.sbc-score-label.sbc-score-green-strong {
  background: rgba(63,165,108,0.18);
  color: #6FCB91;
}
.sbc-score-label.sbc-score-green {
  background: rgba(63,165,108,0.14);
  color: #6FCB91;
}
.sbc-score-label.sbc-score-gold {
  background: rgba(201,168,76,0.18);
  color: var(--gold);
}
.sbc-score-label.sbc-score-red {
  background: rgba(184,98,92,0.18);
  color: #DDA29E;
}

/* ═══════════════════════════════════════════════════
   V41: Quick Check — neues Design
═══════════════════════════════════════════════════ */
.qc-top-actions {
  display: flex;
  gap: 10px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.qc-top-actions .btn { flex: 1; min-width: 200px; }
.qc-ai-fill-all {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.qc-bewirt-tip {
  background: rgba(201,168,76,0.08);
  border-left: 3px solid var(--gold);
  padding: 8px 12px;
  margin-top: 10px;
  font-size: 11.5px;
  border-radius: 0 6px 6px 0;
  line-height: 1.5;
}

/* Photos */
.qc-photos-drop {
  border: 2px dashed rgba(255,255,255,0.20);
  border-radius: 8px;
  padding: 18px;
  text-align: center;
  cursor: pointer;
  background: rgba(255,255,255,0.02);
  transition: all 0.12s ease;
}
.qc-photos-drop:hover {
  border-color: var(--gold);
  background: rgba(201,168,76,0.08);
}
.qc-photos-drop-l {
  font-size: 13px;
  color: rgba(255,255,255,0.65);
}
.qc-photos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
  gap: 8px;
  margin-top: 10px;
}
.qc-photo-thumb {
  position: relative;
  aspect-ratio: 4/3;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.10);
}
.qc-photo-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.qc-photo-del {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 22px;
  height: 22px;
  background: rgba(0,0,0,0.70);
  color: #fff;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* V41: Quick-Score wie DS2 */
.qc-score-card-v41 {
  background: linear-gradient(180deg, #2A2727 0%, #1F1D1D 100%);
  border: 1px solid rgba(201,168,76,0.20);
  border-radius: 14px;
  padding: 22px 18px;
  text-align: center;
  margin-bottom: 16px;
}
.qc-score-label-v41 {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  margin-bottom: 12px;
}
.qc-score-circle-v41 {
  position: relative;
  width: 140px;
  height: 140px;
  margin: 0 auto;
  color: rgba(255,255,255,0.20);
  transition: color 0.25s ease;
}
.qc-score-circle-v41 svg { display: block; }
.qc-score-circle-v41.qc-score-green-strong { color: #6FCB91; }
.qc-score-circle-v41.qc-score-green { color: #6FCB91; }
.qc-score-circle-v41.qc-score-gold { color: var(--gold); }
.qc-score-circle-v41.qc-score-red { color: #DDA29E; }
.qc-score-inner {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.qc-score-value-v41 {
  font-size: 42px;
  font-weight: 800;
  line-height: 1;
  color: inherit;
  font-variant-numeric: tabular-nums;
}
.qc-score-max-v41 {
  font-size: 11px;
  color: rgba(255,255,255,0.45);
  margin-top: 4px;
  letter-spacing: 0.05em;
}
.qc-score-tag-v41 {
  margin-top: 12px;
  font-size: 13px;
  font-weight: 700;
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.02em;
}

/* 5 Mini-Bars */
.qc-cats-grid {
  display: flex;
  flex-direction: column;
  gap: 7px;
  background: rgba(0,0,0,0.20);
  padding: 14px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.05);
  margin-bottom: 16px;
}
.qc-cat-bar {
  display: grid;
  grid-template-columns: 22px 90px 1fr 36px;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: rgba(255,255,255,0.80);
}
.qc-cat-ico {
  font-size: 14px;
  text-align: center;
}
.qc-cat-l {
  font-weight: 600;
}
.qc-cat-bar-bg {
  height: 6px;
  background: rgba(255,255,255,0.08);
  border-radius: 3px;
  overflow: hidden;
}
.qc-cat-bar-fill {
  display: block;
  height: 100%;
  background: rgba(255,255,255,0.30);
  border-radius: 3px;
  transition: width 0.30s ease, background 0.20s ease;
}
.qc-cat-v {
  font-weight: 700;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.qc-cat-bar.qc-cat-green .qc-cat-bar-fill { background: #6FCB91; }
.qc-cat-bar.qc-cat-green .qc-cat-v { color: #6FCB91; }
.qc-cat-bar.qc-cat-gold .qc-cat-bar-fill { background: var(--gold); }
.qc-cat-bar.qc-cat-gold .qc-cat-v { color: var(--gold); }
.qc-cat-bar.qc-cat-red .qc-cat-bar-fill { background: #DDA29E; }
.qc-cat-bar.qc-cat-red .qc-cat-v { color: #DDA29E; }

/* ═══════════════════════════════════════════════════
   V42: Sidebar-Toggle als schwebender Button am rechten Sidebar-Rand
   (verschoben aus dem Logo-Bereich)
═══════════════════════════════════════════════════ */
.sb-toggle-v41 { display: none !important; }   /* alter V41-Button raus */

.sb-toggle-v42 {
  position: absolute;
  top: 80px;
  right: -14px;
  z-index: 260;
  width: 28px;
  height: 28px;
  background: var(--ch);
  border: 1.5px solid rgba(201,168,76,0.45);
  border-radius: 50%;
  color: var(--gold);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: inherit;
  box-shadow: 0 2px 10px rgba(0,0,0,0.30);
  transition: all 0.15s ease;
}
.sb-toggle-v42:hover {
  background: rgba(201,168,76,0.18);
  border-color: var(--gold);
  transform: scale(1.10);
}
/* Icon-Switch je nach State */
.sb-toggle-v42 .sb-toggle-icon-collapsed { display: inline-block; }
.sb-toggle-v42 .sb-toggle-icon-expanded { display: none; }
.app-wrap:not(.sb-collapsed) .sb-toggle-v42 .sb-toggle-icon-collapsed { display: none; }
.app-wrap:not(.sb-collapsed) .sb-toggle-v42 .sb-toggle-icon-expanded { display: inline-block; }

/* Im collapsed-Modus den Button mittig auf der Sidebar-Kante zeigen */
.app-wrap.sb-collapsed .sb-toggle-v42 {
  right: -14px;
  top: 80px;
  left: auto;
  transform: none;
}
.app-wrap.sb-collapsed .sb-toggle-v42:hover {
  transform: scale(1.10);
}

/* Logo-Bereich: das alte Toggle ist weg, also Padding wieder hinzufügen */
.app-wrap.sb-collapsed .sb-header { padding: 16px 0; }

/* Mobile: Toggle bleibt sichtbar als floating button */
@media (max-width: 1024px) {
  .sb-toggle-v42 {
    position: fixed;
    top: 14px;
    left: 14px;
    right: auto;
    z-index: 9999;
  }
  .app-wrap.sb-collapsed .sb-toggle-v42 {
    left: 14px;
    right: auto;
  }
}

/* ═══════════════════════════════════════════════════
   V42: Login-Anpassungen
   - Goldenes Wellen-Design entfernt
   - Card nochmal ~1cm kleiner (340px statt 360px)
   - Card 30vw von rechts (war 25vw)
   - Logo-Box ohne Border/Background
═══════════════════════════════════════════════════ */
.auth-logo-wave { display: none !important; }   /* Wellen-Design weg */

.auth-card-v39 .auth-logo-v39 {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 4px 0 6px !important;
  margin-bottom: 14px !important;
}

/* Card kompakter — ~1cm = ~38px weniger Höhe + schmaler */
.auth-card-v39 {
  max-width: 340px !important;
  padding: 22px 24px 18px !important;
}

/* Card 30vw von rechts (war 25vw) */
.auth-overlay-v39 {
  padding: 24px 30vw 24px 24px !important;
}
.auth-overlay-v39 {
  background:
    radial-gradient(circle at 70% 50%, rgba(201,168,76,0.20) 0%, rgba(10,8,8,0.55) 35%, rgba(10,8,8,0.85) 70%),
    url('../assets/login_hero.png') center center / cover no-repeat,
    #0A0808 !important;
}

@media (max-width: 1024px) {
  .auth-overlay-v39 { padding: 24px 24px 24px 24px !important; justify-content: center !important; }
}

/* ═══════════════════════════════════════════════════
   V42: Header-Pills mit SVG-Icons + KI-Icon konsistent
═══════════════════════════════════════════════════ */
.hdr-ds2-cat-ico svg {
  width: 13px;
  height: 13px;
  display: block;
}
.hdr-ds2-cat-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: currentColor;
}
.hdr-ds2-cat.b-green .hdr-ds2-cat-ico { color: #6FCB91; }
.hdr-ds2-cat.b-gold  .hdr-ds2-cat-ico { color: var(--gold); }
.hdr-ds2-cat.b-red   .hdr-ds2-cat-ico { color: #DDA29E; }

/* KI-Icon (Sparkles) konsistent — überall wo "✨" stand wird Icons.sparkles verwendet,
   und falls dennoch Emoji erscheint, einheitliche Größe */
.ds2-ai-trigger, .qc-ai-fill-all, .ds2-bulk-trigger, .qc-ai-src-icon {
  font-size: 14px;
}
.ds2-ai-trigger svg, .qc-ai-fill-all svg, .qc-ai-src-icon svg {
  width: 14px;
  height: 14px;
}

/* ═══════════════════════════════════════════════════
   V42: Pricing-CSS — Coming-Soon-Tag gold gestyled
═══════════════════════════════════════════════════ */
.auth-link-tag {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 8px;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: rgba(201,168,76,0.18);
  color: var(--gold);
  border-radius: 3px;
  border: 1px solid rgba(201,168,76,0.40);
}
.auth-link {
  background: transparent;
  border: none;
  color: var(--gold);
  font-size: 12px;
  cursor: pointer;
  text-decoration: underline;
  font-family: inherit;
  padding: 0;
}
.auth-link:hover { color: #E0BD5C; }


/* ═══════════════════════════════════════════════════
   V42: Header-DS2 als Mini-Donut + größere Bars
   (visuell konsistent mit DS2-Card in Kennzahlen)
═══════════════════════════════════════════════════ */
.hdr-ds2-score {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-direction: row !important;
  width: 56px;
  height: 56px;
  min-width: 56px !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  border-radius: 50% !important;
  color: rgba(255,255,255,0.30);
}
.hdr-ds2-donut {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.hdr-ds2-inner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 1;
}
.hdr-ds2-num {
  font-size: 18px !important;
  line-height: 1;
}
.hdr-ds2-l {
  font-size: 7.5px !important;
  margin-top: 1px !important;
}
.hdr-ds2-score.b-green-strong { color: #6FCB91; }
.hdr-ds2-score.b-green        { color: #6FCB91; }
.hdr-ds2-score.b-gold         { color: var(--gold); }
.hdr-ds2-score.b-red          { color: #DDA29E; }

/* Bars größer (10.5px statt 9.5px) */
.hdr-ds2-cat { font-size: 10.5px !important; }
.hdr-ds2-cat-l { width: 50px !important; font-size: 9.5px; }
.hdr-ds2-cat-bar { height: 6px !important; }
.hdr-ds2-cat-v { font-size: 11px !important; width: 22px !important; }

/* Header insgesamt etwas mehr Platz für DS2 */
.hdr-badges-v39 {
  gap: 14px !important;
  padding: 0 12px;
}

/* ═══════════════════════════════════════════════════
   V42: Q&Z-Card optisch identisch zu Objektdaten
═══════════════════════════════════════════════════ */
.qz-card.card {
  /* erbt jetzt das card-Layout */
  margin-bottom: 22px !important;            /* mehr Abstand zu Objektfotos */
}
.qz-card.card .qz-rows {
  margin-top: 4px;
}
.qz-card.card .qz-row {
  font-size: 13px;
  padding: 6px 0;
}
.qz-card.card .qz-row-name {
  font-weight: 500;
  font-size: 13px;
}
.qz-card.card .qz-name {
  font-family: inherit;
}

/* ═══════════════════════════════════════════════════
   V42: PDF-Import Bilder-Vorschau
═══════════════════════════════════════════════════ */
.pdfi-photos-section {
  margin-top: 14px;
  padding: 12px;
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.25);
  border-radius: 8px;
}
.pdfi-photos-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  font-size: 13px;
}
.pdfi-photos-head input { width: 16px; height: 16px; cursor: pointer; }
.pdfi-photos-head label { cursor: pointer; user-select: none; }
.pdfi-photos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 8px;
}
.pdfi-photo-thumb {
  aspect-ratio: 4/3;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.10);
  background: #1A1818;
}
.pdfi-photo-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ═══════════════════════════════════════════════════════════════
   V43: Bottom-Sheet — Hybrid-Sidebar-Konzept
   - Sidebar links bleibt schmal (nur Objekte + Logo)
   - Aktionen wandern in Bottom-Sheet das von unten hochkommt
═══════════════════════════════════════════════════════════════ */

/* Floating Burger-Button unten rechts */
.bsheet-burger {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--gold);
  color: #1A1818;
  border: none;
  box-shadow: 0 8px 24px rgba(0,0,0,0.35), 0 4px 8px rgba(201,168,76,0.25);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 9000;
  transition: all 0.18s ease;
  font-family: inherit;
}
.bsheet-burger:hover {
  transform: scale(1.06);
  box-shadow: 0 12px 32px rgba(0,0,0,0.40), 0 6px 12px rgba(201,168,76,0.35);
}
.bsheet-burger:active {
  transform: scale(0.96);
}

/* Overlay (dunkler Hintergrund) */
.bsheet-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 8, 8, 0);
  backdrop-filter: blur(0);
  -webkit-backdrop-filter: blur(0);
  z-index: 9999;
  pointer-events: none;
  transition: background 0.25s ease, backdrop-filter 0.25s ease;
}
.bsheet-overlay.bsheet-open {
  background: rgba(10, 8, 8, 0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  pointer-events: auto;
}

/* Panel das von unten hochkommt */
.bsheet-panel {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  max-height: 80vh;
  background: linear-gradient(180deg, #2A2727 0%, #1F1D1D 100%);
  border-top-left-radius: 18px;
  border-top-right-radius: 18px;
  border-top: 1.5px solid rgba(201,168,76,0.35);
  padding: 8px 22px 28px;
  box-shadow: 0 -10px 40px rgba(0,0,0,0.45);
  transform: translateY(100%);
  transition: transform 0.30s cubic-bezier(0.4, 0, 0.2, 1);
  overflow-y: auto;
}
.bsheet-overlay.bsheet-open .bsheet-panel {
  transform: translateY(0);
}

/* Drag-Handle oben */
.bsheet-handle {
  width: 44px;
  height: 4px;
  background: rgba(255,255,255,0.18);
  border-radius: 2px;
  margin: 6px auto 14px;
}

.bsheet-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.bsheet-head h3 {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.02em;
}
.bsheet-close {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  color: rgba(255,255,255,0.70);
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: inherit;
  transition: all 0.15s ease;
}
.bsheet-close:hover {
  background: rgba(255,255,255,0.14);
  color: #fff;
}

/* Grid mit Aktion-Tiles */
.bsheet-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.bsheet-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 18px 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  color: rgba(255,255,255,0.80);
  cursor: pointer;
  transition: all 0.15s ease;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  text-align: center;
}
.bsheet-tile:hover {
  background: rgba(201,168,76,0.10);
  border-color: rgba(201,168,76,0.30);
  color: #fff;
  transform: translateY(-2px);
}
.bsheet-tile-active {
  background: rgba(201,168,76,0.18) !important;
  border-color: rgba(201,168,76,0.50) !important;
  color: #fff !important;
  font-weight: 600;
}
.bsheet-tile-accent {
  background: linear-gradient(135deg, rgba(201,168,76,0.18), rgba(201,168,76,0.08));
  border-color: rgba(201,168,76,0.40);
  color: var(--gold);
  font-weight: 600;
}
.bsheet-tile-ico {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
}
.bsheet-tile-ico svg { width: 22px; height: 22px; display: block; }
.bsheet-tile-l {
  font-size: 12px;
  line-height: 1.2;
}

/* Body lock wenn Sheet offen */
body.bsheet-body-locked { overflow: hidden; }

/* Burger nur sichtbar wenn nicht in Modal */
.global-view-overlay .bsheet-burger,
.qc-overlay ~ .bsheet-burger {
  display: none;
}

/* Mobile-Optimierung */
@media (max-width: 600px) {
  .bsheet-grid { grid-template-columns: repeat(2, 1fr); }
  .bsheet-burger {
    bottom: 16px;
    right: 16px;
    width: 52px;
    height: 52px;
  }
  .bsheet-panel { padding: 8px 16px 24px; max-height: 85vh; }
}

/* ═══════════════════════════════════════════════════
   V43: DealScore Collapse-Header
═══════════════════════════════════════════════════ */
.ds2-collapse-toggle {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 14px 18px;
  background: linear-gradient(180deg, rgba(201,168,76,0.06), rgba(201,168,76,0.02));
  border: none;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  color: var(--ch);
  font-family: inherit;
  font-size: 14px;
  cursor: pointer;
  text-align: left;
  border-radius: 10px 10px 0 0;
}
.ds2-collapse-toggle:hover {
  background: linear-gradient(180deg, rgba(201,168,76,0.10), rgba(201,168,76,0.04));
}
.ds2-collapse-l {
  font-weight: 700;
  font-size: 14px;
}
.ds2-collapse-summary {
  flex: 1;
  font-size: 13px;
  color: rgba(42,39,39,0.55);
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.ds2-collapse-summary.ds2-coll-green-strong { color: #2A7E54; }
.ds2-collapse-summary.ds2-coll-green        { color: #2A7E54; }
.ds2-collapse-summary.ds2-coll-gold         { color: var(--gold); }
.ds2-collapse-summary.ds2-coll-red          { color: #B8625C; }
.ds2-collapse-summary strong {
  font-size: 15px;
  font-weight: 800;
}
.ds2-collapse-arrow {
  font-size: 11px;
  color: rgba(42,39,39,0.45);
  transition: transform 0.20s ease;
}

/* Collapsed: Body verstecken, Pfeil drehen */
.ds2-card-collapsed #dealscore2-box {
  display: none;
}
.ds2-card-collapsed .ds2-collapse-toggle {
  border-bottom: none;
  border-radius: 10px;
}
.ds2-card-collapsed .ds2-collapse-arrow {
  transform: rotate(-90deg);
}

/* ═══════════════════════════════════════════════════
   V43: KI-Bulk-Modal Robustheit (Punkt 6)
═══════════════════════════════════════════════════ */
/* Override + force korrektes Modal-Layout */
.ds2-bulk-overlay {
  position: fixed !important;
  inset: 0 !important;
  z-index: 10100 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;
}
.ds2-bulk-overlay .ds2-bulk-modal {
  background: #fff !important;
  border-radius: 12px !important;
  width: 100% !important;
  max-width: 720px !important;
  max-height: 88vh !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  box-shadow: 0 24px 60px rgba(0,0,0,0.45) !important;
  /* Defensive Reset gegen vererbte Styles */
  font-family: 'DM Sans', -apple-system, sans-serif;
  color: var(--ch);
  text-align: left;
}
.ds2-bulk-overlay .ds2-bulk-header {
  padding: 16px 22px !important;
  flex-shrink: 0 !important;
}
.ds2-bulk-overlay .ds2-bulk-body {
  padding: 16px 22px !important;
  overflow-y: auto !important;
  flex: 1 1 auto !important;
  min-height: 0 !important;
}
.ds2-bulk-overlay .ds2-bulk-footer {
  flex-shrink: 0 !important;
}

/* Tabelle robuster — nicht auseinanderbrechen */
.ds2-bulk-overlay .ds2-bulk-table {
  table-layout: fixed !important;
  width: 100% !important;
}
.ds2-bulk-overlay .ds2-bulk-table th:nth-child(1) { width: 38% !important; }
.ds2-bulk-overlay .ds2-bulk-table th:nth-child(2) { width: 22% !important; }
.ds2-bulk-overlay .ds2-bulk-table th:nth-child(3) { width: 40% !important; }
.ds2-bulk-overlay .ds2-bulk-table td {
  word-wrap: break-word !important;
  word-break: break-word !important;
  overflow-wrap: anywhere;
}

@media (max-width: 720px) {
  .ds2-bulk-overlay .ds2-bulk-table { table-layout: auto !important; }
  .ds2-bulk-overlay .ds2-bulk-table th:nth-child(2),
  .ds2-bulk-overlay .ds2-bulk-table td:nth-child(2) { display: none !important; }
}

/* ═══════════════════════════════════════════════════
   V43: Quick-Check — AI-gesetzte Felder visuell markieren
═══════════════════════════════════════════════════ */
.qc-form input[data-ai-set="1"] {
  background: rgba(201,168,76,0.10) !important;
  border-color: rgba(201,168,76,0.45) !important;
  color: var(--gold) !important;
  font-weight: 600;
}
.qc-form input[data-ai-set="1"]:focus {
  background: rgba(201,168,76,0.15) !important;
  border-color: var(--gold) !important;
}

.qc-ai-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px;
  background: linear-gradient(135deg, rgba(201,168,76,0.12), rgba(201,168,76,0.04));
  border: 1px solid rgba(201,168,76,0.28);
  border-radius: 8px;
  margin: 16px 0 12px;
}
.qc-ai-row .qc-ai-fill-all {
  flex-shrink: 0;
}
.qc-ai-hint {
  flex: 1;
  font-size: 11.5px;
  color: rgba(255,255,255,0.65);
  line-height: 1.45;
}

/* Quick-Check Source-Box mit klickbarem Link */
.qc-ai-src {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  margin-top: 4px;
  padding: 6px 8px;
  background: rgba(201,168,76,0.08);
  border-left: 2px solid var(--gold);
  border-radius: 0 4px 4px 0;
  font-size: 10.5px;
  line-height: 1.4;
}
.qc-ai-src-icon {
  flex-shrink: 0;
  color: var(--gold);
}
.qc-ai-src-text {
  color: rgba(255,255,255,0.75);
}
.qc-ai-src-text a {
  color: var(--gold);
  text-decoration: underline;
  font-weight: 600;
}
.qc-ai-src-text a:hover {
  color: #E0BD5C;
}

/* ═══════════════════════════════════════════════════
   V43: Login — 5cm nach rechts (~190px), 1cm nach unten (~38px)
═══════════════════════════════════════════════════ */
.auth-overlay-v39 {
  /* Override V42 — größere padding-right + unten Padding */
  padding-right: 190px !important;
  padding-bottom: 38px !important;
  padding-top: calc(24px - 38px / 2) !important;
  align-items: center !important;
}

/* Auf <1366px Bildschirmen wieder zurück damit Card sichtbar bleibt */
@media (max-width: 1366px) {
  .auth-overlay-v39 {
    padding-right: 24px !important;
    padding-bottom: 24px !important;
    padding-top: 24px !important;
    justify-content: center !important;
  }
}

/* ═══════════════════════════════════════════════════
   V43: Q&Z-Card final identisch zu Objektdaten
═══════════════════════════════════════════════════ */
/* V43 final: Q&Z = Objektdaten optisch — kein Override mehr, nur Margin */
.qz-card.card {
  margin-bottom: 28px !important;          /* deutlich mehr Abstand zu Objektfotos */
}
.qz-card.card .qz-row {
  display: grid !important;
  grid-template-columns: 1fr auto auto !important;
  gap: 12px !important;
  align-items: center !important;
  padding: 6px 0 !important;
  border-bottom: 1px solid rgba(255,255,255,0.04) !important;
}
.qz-card.card .qz-row:last-child {
  border-bottom: none !important;
}
.qz-card.card .qz-row-name {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,0.85) !important;
}
.qz-card.card .qz-name {
  font-family: inherit !important;
}
.qz-card.card .qz-icon {
  width: 18px !important;
  height: 18px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--gold) !important;
  opacity: 0.75 !important;
}
.qz-card.card .qz-stars {
  display: inline-flex !important;
  gap: 2px !important;
}
.qz-card.card .qz-label {
  font-size: 11px !important;
  color: rgba(255,255,255,0.55) !important;
  min-width: 90px;
  text-align: right;
}

/* ═══════════════════════════════════════════════════
   V43: KI-Bulk-Modal verzerrt-Bug fixen
   - Sicherstellen dass Modal nie über Viewport ragt
   - Tabellen-Layout robust auch bei langen Texten
═══════════════════════════════════════════════════ */
.ds2-bulk-overlay {
  /* Mehr Padding auf kleinen Screens */
  padding: 16px !important;
}
.ds2-bulk-modal {
  /* Robustes Sizing — nie breiter als Viewport, nie höher als 90vh */
  width: 100% !important;
  max-width: min(720px, calc(100vw - 32px)) !important;
  max-height: min(85vh, 720px) !important;
  /* Wichtig: overflow-hidden wirkt nur wenn flex-children korrekt schrumpfen */
  min-height: 0;
}
.ds2-bulk-body {
  /* Force scrollable area */
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
}
.ds2-bulk-table {
  /* Cell-overflow verhindern — lange KI-Reasoning Texte wrappen */
  table-layout: fixed;
}
.ds2-bulk-table th:nth-child(1),
.ds2-bulk-table td:nth-child(1) { width: 30%; }
.ds2-bulk-table th:nth-child(2),
.ds2-bulk-table td:nth-child(2) { width: 25%; }
.ds2-bulk-table th:nth-child(3),
.ds2-bulk-table td:nth-child(3) { width: 45%; }
.ds2-bulk-table td {
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
}
.ds2-bulk-cell { flex-wrap: wrap; }
.ds2-bulk-new {
  word-break: break-word;
  white-space: normal;
}
.ds2-bulk-reason {
  word-break: break-word;
  line-height: 1.4;
}
.ds2-bulk-current {
  word-break: break-word;
  font-size: 11.5px;
}

/* Footer immer unten sichtbar */
.ds2-bulk-footer {
  flex-shrink: 0;
  position: sticky;
  bottom: 0;
  background: #fff;
  z-index: 2;
}

/* ═══════════════════════════════════════════════════
   V45: Login zurück zu V42-Stand (30vw position, vertikal zentriert)
   PLUS 1,5cm nach links (57px) → padding-right: calc(30vw - 57px)
   Marcel: "alles war zu weit nach rechts gewandert"
═══════════════════════════════════════════════════ */
.auth-overlay-v39 {
  padding: 24px calc(30vw - 57px) 24px 24px !important;
  justify-content: flex-end !important;
  align-items: center !important;            /* zurück zur vertikalen Mitte (war flex-start) */
}

@media (max-width: 1366px) {
  .auth-overlay-v39 {
    padding: 24px 24px 24px 24px !important;
    justify-content: center !important;
    align-items: center !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   V44: Aktionen-Trigger in der Sidebar unten
   - Alter Floating-Burger unten rechts → versteckt
   - Neuer breiter Button unten in der Sidebar
═══════════════════════════════════════════════════════════════ */
.bsheet-burger { display: none !important; }   /* alter Floating-Button raus */

.sb-actions-trigger {
  display: flex;
  align-items: center;
  gap: 10px;
  width: calc(100% - 20px);
  margin: 8px 10px 14px;
  padding: 12px 14px;
  background: linear-gradient(180deg, rgba(201,168,76,0.18), rgba(201,168,76,0.08));
  border: 1.5px solid rgba(201,168,76,0.50);
  border-radius: 10px;
  color: var(--gold);
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-align: left;
  transition: all 0.15s ease;
}
/* V92: Alter Aktionen-Trigger Hover deaktiviert — Stil kommt aus Investment-PDF-Block.
.sb-actions-trigger:hover {
  background: linear-gradient(180deg, rgba(201,168,76,0.28), rgba(201,168,76,0.14));
  border-color: var(--gold);
  transform: translateY(-1px);
}
.sb-actions-trigger:active {
  transform: translateY(0);
}
*/
.sb-actions-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.sb-actions-l {
  flex: 1;
}
.sb-actions-arrow {
  font-size: 10px;
  opacity: 0.65;
}

/* Wenn Bottom-Sheet offen ist, zeigt der Pfeil ▼ statt ▲ */
body.bsheet-body-locked .sb-actions-arrow::before {
  content: '▼';
}
body.bsheet-body-locked .sb-actions-arrow {
  font-size: 0;
}
body.bsheet-body-locked .sb-actions-arrow::before { font-size: 10px; }

/* Im Mobile-Mode (Sidebar collapsed/Drawer): Trigger trotzdem sichtbar */
@media (max-width: 1024px) {
  .sb-actions-trigger { width: calc(100% - 24px); margin: 8px 12px 16px; }
}

/* ═══════════════════════════════════════════════════════════════
   V47: Quick Check Score-Mockup → DUNKEL wie Investor Deal Score (Bild 2)
   V44 hatte hellen Override — wird hier komplett zurückgenommen,
   damit die normalen .ds-mockup / .ds2-mockup Styles greifen.
═══════════════════════════════════════════════════════════════ */
.qc-ds-mockup {
  /* Keine eigenen Background-/Border-Overrides mehr — übernimmt ds2-mockup-Look */
  margin-bottom: 14px;
}
/* QC-Result-Bereich (rechts im Modal) bekommt dunklen Hintergrund-Container,
   Body bleibt hell weil der Score-Bereich self-contained ist */
#qc-result {
  background: transparent;
}
/* ds-top-deal innerhalb QC: identisch zum DS-Mockup (transparenter goldener Tint) */
.qc-ds-mockup .ds-top-deal-label {
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: 0.10em;
}

/* QC-KI-Detail-Box bleibt hell (passt zum hellen Modal-Body) */
.qc-ki-detail {
  margin-top: 8px;
  margin-bottom: 18px;
  padding: 16px 18px;
  background: linear-gradient(180deg, rgba(201,168,76,0.06) 0%, rgba(201,168,76,0.02) 100%);
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 12px;
}
.qc-ki-detail-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--ch);
}
.qc-ki-detail-icon {
  color: var(--gold);
  font-size: 15px;
}
.qc-ki-detail-title {
  flex: 1;
}
.qc-ki-detail-tag {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: rgba(201,168,76,0.15);
  color: var(--gold);
  padding: 2px 8px;
  border-radius: 10px;
}
.qc-ki-detail-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.qc-ki-detail-row {
  display: grid;
  grid-template-columns: 200px 140px 1fr;
  gap: 12px;
  align-items: baseline;
  padding: 8px 0;
  border-bottom: 1px solid rgba(42,39,39,0.05);
  font-size: 12.5px;
}
.qc-ki-detail-row:last-child { border-bottom: none; }
.qc-ki-detail-label {
  font-weight: 600;
  color: var(--ch);
}
.qc-ki-detail-value {
  font-weight: 700;
  color: var(--gold);
  font-variant-numeric: tabular-nums;
}
.qc-ki-detail-src {
  font-size: 11.5px;
  color: rgba(42,39,39,0.65);
  line-height: 1.4;
}
.qc-ki-detail-reason {
  font-style: italic;
}
@media (max-width: 720px) {
  .qc-ki-detail-row {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 10px 0;
  }
}

/* ═══════════════════════════════════════════════════
   V46: DealScore-Collapse (alter DS oben, jetzt mit Toggle)
═══════════════════════════════════════════════════ */
.ds-collapse-toggle {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 14px 18px;
  background: linear-gradient(180deg, rgba(201,168,76,0.06), rgba(201,168,76,0.02));
  border: none;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  color: var(--ch);
  font-family: inherit;
  font-size: 14px;
  cursor: pointer;
  text-align: left;
  border-radius: 10px 10px 0 0;
}
.ds-collapse-toggle:hover {
  background: linear-gradient(180deg, rgba(201,168,76,0.10), rgba(201,168,76,0.04));
}
.ds-collapse-l { font-weight: 700; font-size: 14px; }
.ds-collapse-summary {
  flex: 1;
  font-size: 13px;
  color: rgba(42,39,39,0.55);
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.ds-collapse-summary.ds-coll-green { color: #2A7E54; }
.ds-collapse-summary.ds-coll-gold  { color: var(--gold); }
.ds-collapse-summary.ds-coll-red   { color: #B8625C; }
.ds-collapse-summary strong { font-size: 15px; font-weight: 800; }
.ds-collapse-arrow {
  font-size: 11px;
  color: rgba(42,39,39,0.45);
  transition: transform 0.20s ease;
}

/* Collapsed: Body verstecken, Pfeil drehen */
.dealscore-card-v46-collapsed #dealscore-box { display: none; }
.dealscore-card-v46-collapsed .ds-collapse-toggle {
  border-bottom: none;
  border-radius: 10px;
}
.dealscore-card-v46-collapsed .ds-collapse-arrow { transform: rotate(-90deg); }

/* ═══════════════════════════════════════════════════════════════
   V46: Aktionen-Akkordeon — klappt NACH OBEN in der Sidebar (kein Overlay)
═══════════════════════════════════════════════════════════════ */
/* Bottom-Sheet aus V43 verstecken — wird in V46 nicht mehr genutzt */
.bsheet-overlay { display: none !important; }

/* V48: Akkordeon klappt komplett auf bis ganz nach oben, ÜBERLAGERT die Objekt-Karten.
   Position: absolute innerhalb der Sidebar. Bottom-Anker am Trigger.
   Maximale Höhe: bis fast ganz nach oben in der Sidebar (alle Items sichtbar). */
.sb-actions-accordion {
  position: absolute;
  bottom: 56px;                /* Höhe des Trigger-Buttons + 4px Abstand */
  left: 10px;
  right: 10px;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.30s ease-out, opacity 0.20s ease-out;
  opacity: 0;
  z-index: 50;
  pointer-events: none;
}
.sb-actions-accordion.sb-actions-open {
  /* V48: bis ganz nach oben in der Sidebar — Karten werden überlagert.
     calc(100vh - 200px) lässt knapp Platz für Trigger + Bottom-Spacer. */
  max-height: calc(100vh - 200px);
  opacity: 1;
  pointer-events: auto;
  /* V48: Schatten + leicht opaker Hintergrund damit es deutlich über den Karten "schwebt" */
  box-shadow: 0 -8px 28px rgba(0,0,0,0.45);
}
/* Custom Scrollbar — falls 9 Items doch nicht passen */
.sb-actions-accordion-inner::-webkit-scrollbar { width: 6px; }
.sb-actions-accordion-inner::-webkit-scrollbar-track { background: transparent; }
.sb-actions-accordion-inner::-webkit-scrollbar-thumb {
  background: rgba(201,168,76,0.30);
  border-radius: 3px;
}
.sb-actions-accordion-inner::-webkit-scrollbar-thumb:hover {
  background: rgba(201,168,76,0.50);
}

.sb-actions-accordion-inner {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 6px;
  /* V48: kräftigerer Background damit es deutlich über Karten steht */
  background: linear-gradient(180deg, rgba(28,26,26,0.97) 0%, rgba(20,18,18,0.97) 100%);
  border: 1px solid rgba(201,168,76,0.40);
  border-radius: 10px;
  max-height: calc(100vh - 200px);
  overflow-y: auto;
  backdrop-filter: blur(8px);
}

/* Sidebar muss position:relative sein damit absolute kindern andocken kann */
aside, .sidebar { position: relative; }

.sb-act-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 7px;
  color: rgba(255,255,255,0.78);
  cursor: pointer;
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 500;
  text-align: left;
  transition: all 0.12s ease;
}
.sb-act-item:hover {
  background: rgba(201,168,76,0.10);
  border-color: rgba(201,168,76,0.30);
  color: #fff;
}
.sb-act-active {
  background: rgba(201,168,76,0.15) !important;
  border-color: rgba(201,168,76,0.40) !important;
  color: #fff !important;
  font-weight: 600;
}
.sb-act-accent {
  color: var(--gold);
  font-weight: 600;
}
.sb-act-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  color: var(--gold);
  flex-shrink: 0;
}
.sb-act-ico svg { width: 18px; height: 18px; display: block; }
.sb-act-l { flex: 1; }

/* Trigger-Pfeil dreht sich wenn Akkordeon offen */
.sb-actions-trigger[aria-expanded="true"] .sb-actions-arrow {
  transform: rotate(180deg);
}
.sb-actions-arrow {
  transition: transform 0.20s ease;
  display: inline-block;
}

/* V46: Read-only-Block — berechnete KPIs visuell abgesetzt */
.ds2-ro-derived {
  background: rgba(201,168,76,0.04);
  border-left: 3px solid rgba(201,168,76,0.40) !important;
  padding-left: 10px !important;
}
.ds2-ro-derived .ds2-ro-label::before {
  content: '∑ ';
  color: var(--gold);
  font-weight: 700;
}

/* ═══════════════════════════════════════════════════════════════
   V47: Floating Save-Button
   Position: oben links über dem Tab-Inhalt, fix beim Scrollen.
   Sichtbar in JEDEM Register, immer da.
═══════════════════════════════════════════════════════════════ */
.dp-floating-save {
  position: fixed;
  top: 110px;            /* V48: unter Header (64px) + Tab-Leiste (~46px) */
  right: 28px;           /* V48: rechts oben am Rand des Tab-Bereichs */
  z-index: 950;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 16px 9px 13px;
  border-radius: 22px;
  border: 1.5px solid rgba(201,168,76,0.45);
  background: linear-gradient(180deg, #FFFFFF 0%, #FAF6EC 100%);
  color: var(--ch);
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.01em;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(20,18,18,0.10), 0 1px 3px rgba(20,18,18,0.06);
  transition: all 0.15s ease;
}
.dp-floating-save:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(20,18,18,0.14), 0 1px 3px rgba(20,18,18,0.08);
}
.dp-floating-save:active { transform: translateY(0); }
.fs-icon {
  font-size: 15px;
  line-height: 1;
}

/* States */
.dp-floating-save.fs-idle {
  background: linear-gradient(180deg, #FFFFFF 0%, #F5F5F2 100%);
  border-color: rgba(42,39,39,0.18);
  color: rgba(42,39,39,0.55);
}
.dp-floating-save.fs-dirty {
  background: linear-gradient(180deg, #FFF5D9 0%, #F2D98A 100%);
  border-color: var(--gold);
  color: var(--ch);
  animation: fs-pulse-dirty 1.6s ease-in-out infinite;
}
@keyframes fs-pulse-dirty {
  0%, 100% { box-shadow: 0 4px 14px rgba(201,168,76,0.18), 0 1px 3px rgba(20,18,18,0.06); }
  50%      { box-shadow: 0 4px 22px rgba(201,168,76,0.55), 0 1px 3px rgba(20,18,18,0.08); }
}
.dp-floating-save.fs-saving {
  background: linear-gradient(180deg, #FFFFFF 0%, #FAF6EC 100%);
  border-color: var(--gold);
  color: var(--gold);
}
.dp-floating-save.fs-saved {
  background: linear-gradient(180deg, #E6F5EB 0%, #C8E6D2 100%);
  border-color: #2FBE6E;
  color: #1F7F4D;
}
.dp-floating-save.fs-error {
  background: linear-gradient(180deg, #FBE3E3 0%, #F2C0BD 100%);
  border-color: #D55B5B;
  color: #B22B2B;
}

/* Wenn Login/Register Overlay offen ist: Save-Button verstecken */
.auth-overlay-v39:not([style*="display: none"]) ~ .dp-floating-save,
body.dp-auth-active .dp-floating-save { display: none; }

/* Mobile: Button etwas kleiner und näher am Rand */
@media (max-width: 1024px) {
  .dp-floating-save {
    top: 12px;
    right: 12px;            /* V48: rechts statt links */
    left: auto;
    padding: 8px 12px 8px 10px;
    font-size: 12px;
  }
  .fs-label { display: none; }   /* nur Icon im Mobile */
}

/* ═══════════════════════════════════════════════════════════════
   V50: Sidebar fix — minimal-invasiver Ansatz
   Statt position: fixed (zerstörte Grid-Layout in V49):
   - Sidebar bleibt im Grid (380px Spalte) — alles original
   - Body scrollt nicht — der Scroll-Container ist .main-col
   - Sidebar scrollt intern selbst falls die Liste lang ist
═══════════════════════════════════════════════════════════════ */
html, body {
  height: 100vh;
  overflow: hidden;
  margin: 0;
}

/* app-wrap füllt full viewport, eigenes scroll an die Spalten weiterreichen */
.app-wrap {
  height: 100vh;
}

/* Sidebar: scrollt intern — Liste, Portfolio, Aktionen können größer als 100vh sein */
aside.sidebar, #sidebar {
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
}

/* Main-Section rechts der Sidebar: eigener Scroll-Container.
   Tab-Inhalt kann beliebig lang sein, scrollt darin. Sidebar bleibt fix sichtbar. */
.main-col {
  height: 100vh;
  overflow-y: auto;
}

/* ═══════════════════════════════════════════════════════════════
   V49: Beispielwerte als Placeholder (gold-getönt) bei neuen Objekten
═══════════════════════════════════════════════════════════════ */
.dp-example-placeholder::placeholder {
  color: rgba(201,168,76,0.55);
  font-style: italic;
}
.dp-example-placeholder:focus {
  /* Beim Fokus normaler Placeholder-Farbe (signalisiert: jetzt ist's aktiv) */
}
.dp-example-placeholder:focus::placeholder {
  color: rgba(42,39,39,0.30);
  font-style: normal;
}

/* ═══════════════════════════════════════════════════════════════
   V49: Quick Check — Score-Bereich nutzt jetzt volle Modal-Breite
   Donut links, 5 Kategorie-Bars rechts daneben (wie Investor Deal Score)
═══════════════════════════════════════════════════════════════ */
.qc-result .ds-middle {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 24px;
  align-items: center;
  margin-top: 18px;
}
.qc-result .ds-donut-wrap {
  width: 240px;
  position: relative;
}
.qc-result .ds-metrics {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
/* Auf schmalen Bildschirmen: Donut wieder zentral oben + Bars darunter */
@media (max-width: 720px) {
  .qc-result .ds-middle {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .qc-result .ds-donut-wrap { margin: 0 auto; }
}

/* QC-Modal auf großen Screens noch breiter, damit Score+Bars nebeneinander voll passen */
@media (min-width: 1280px) {
  .qc-modal { max-width: 1180px; }
}

/* ═══════════════════════════════════════════════════════════════
   V51 — ADDITIONS (Quick-Check Tab, Settings KI/Info, KPI-Jumps)
   ═══════════════════════════════════════════════════════════════ */

/* V51: .ct/.f/.iw als Shorthand-Aliase (V50 nutzt sie ohne CSS-Definition;
        wir machen sie explizit damit's konsistent ist und nicht nur über
        Element-Default-Styling funktioniert) */
.ct {
  font-size: 9.5px;
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 15px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border-g);
  display: flex;
  align-items: center;
  gap: 8px;
}
.ct::before {
  content: '';
  display: block;
  width: 3px;
  height: 12px;
  background: var(--gold);
  border-radius: 2px;
  flex-shrink: 0;
}
.f {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-bottom: 4px;
}
.f label {
  font-size: 11px;
  font-weight: 500;
  color: var(--muted);
}
.f.s2 { grid-column: 1 / -1; }
.iw {
  position: relative;
}

/* V51: Tab-Label sichtbar lassen, Mobile compact */
.tab-lbl {
  display: inline-flex;
  align-items: center;
  margin-left: 5px;
}
@media (max-width: 720px) {
  .tab-lbl { display: none; }
  .tab { padding: 14px 10px; }
}

/* V51: Quick-Check Haupt-Tab */
.qc-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
}
.qc-input-card,
.qc-result-card {
  display: flex;
  flex-direction: column;
}
.qc-input-card .g2 { margin-bottom: 14px; }
.qc-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid var(--surface2);
  flex-wrap: wrap;
}
.qc-result-card {
  background: linear-gradient(180deg, var(--ch) 0%, #232020 100%);
  color: rgba(255,255,255,0.92);
  border-color: transparent;
}
.qc-result-card .ct {
  color: var(--gold);
  border-bottom-color: rgba(201,168,76,0.3);
}
.qc-verdict-box {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--r);
  margin-bottom: 14px;
}
.qc-verdict-icon {
  font-size: 36px;
  line-height: 1;
  flex-shrink: 0;
}
.qc-verdict-text { flex: 1 1 auto; min-width: 0; }
.qc-verdict-label {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 600;
  color: var(--gold);
  line-height: 1.15;
  margin-bottom: 3px;
}
.qc-verdict-sub {
  font-size: 11.5px;
  color: rgba(255,255,255,0.65);
  line-height: 1.45;
}
.qc-kpis {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 14px;
  margin-bottom: 12px;
}
.qc-kpi {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 7px 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  font-size: 12.5px;
}
.qc-kpi:last-child { border-bottom: none; }
.qc-kpi-l { color: rgba(255,255,255,0.55); }
.qc-kpi-v {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 600;
  font-size: 16px;
  color: var(--gold);
}
.qc-kpi-v.gn { color: #5ED99E; }
.qc-kpi-v.rd { color: #f08080; }
.qc-hint {
  margin-top: 6px;
  padding-top: 8px;
  border-top: 1px dashed rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.45) !important;
  font-size: 11px;
  line-height: 1.5;
}

@media (max-width: 800px) {
  .qc-grid { grid-template-columns: 1fr; }
}

/* V51: Settings — KI-Tab Section-Titel + Slider-Wert */
.set-section-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 18px 0 10px 0;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border-g);
}
.set-section-title:first-child { margin-top: 4px; }
.ai-val {
  font-size: 12px;
  font-weight: 600;
  color: #B08C30;
  font-variant-numeric: tabular-nums;
  margin-left: 6px;
}

/* V51: Settings — Info-Tab */
.info-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-bottom: 18px;
}
.info-card {
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 11px 13px;
  background: var(--white);
}
.info-label {
  font-size: 10px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 4px;
}
.info-val {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--ch);
  line-height: 1.2;
}
.info-sub {
  font-size: 11px;
  color: var(--muted);
  margin-top: 2px;
}
.info-section {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.info-section-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 8px;
}
.info-textarea {
  width: 100%;
  min-height: 140px;
  font-family: 'SFMono-Regular', Menlo, monospace;
  font-size: 11px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: var(--r);
  background: var(--surface);
  color: var(--ch);
  resize: vertical;
  line-height: 1.5;
}
.info-actions {
  display: flex;
  gap: 8px;
  margin-top: 8px;
  flex-wrap: wrap;
}
.info-links {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 12px;
}
.info-links a {
  color: #B08C30;
  text-decoration: none;
}
.info-links a:hover { text-decoration: underline; }
.info-license {
  font-size: 11px;
  color: var(--muted);
  line-height: 1.5;
  background: var(--surface);
  padding: 10px 12px;
  border-radius: var(--r);
  border: 1px dashed var(--border);
}

@media (max-width: 600px) {
  .info-grid { grid-template-columns: 1fr; }
}

/* V51: KPI-Modal Tab-Jump-Pfeile */
.ds2-kpi-jump-btn {
  background: var(--gold-dim);
  border: 1px solid var(--border-g);
  color: #B08C30;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s;
  margin-left: 6px;
}
.ds2-kpi-jump-btn:hover {
  background: var(--gold);
  color: #fff;
}
.ds2-kpi-row {
  cursor: pointer;
  transition: background 0.12s;
}
.ds2-kpi-row:hover {
  background: rgba(201,168,76,0.06);
}

/* ═══════════════════════════════════════════════════════════════
   V53 — Tab-Bar mit Action-Buttons (Speichern + PDF) rechts
   ═══════════════════════════════════════════════════════════════ */
.tabs {
  display: flex;
  align-items: stretch;
  padding: 0 14px 0 22px;
}
.tabs-spacer {
  flex: 1 1 auto;
}
.tabs-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0 8px 14px;
  border-left: 1px solid var(--border);
  flex-shrink: 0;
}
.tab-action-btn {
  height: 36px;
  padding: 0 14px;
  font-size: 12px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
}
.tab-action-btn .tab-ico {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.tab-action-btn .tab-lbl {
  display: inline-flex;
  align-items: center;
}

/* Tabs selbst — SVG-Icon-Style aufpolieren */
.tab .tab-ico {
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 6px;
  vertical-align: middle;
  color: var(--muted);
  transition: color 0.15s;
}
.tab.active .tab-ico {
  color: var(--gold);
}
.tab:hover .tab-ico {
  color: var(--ch);
}
.tab.active:hover .tab-ico {
  color: var(--gold);
}

/* Mobile: Aktion-Buttons kompakter, Labels weg */
@media (max-width: 900px) {
  .tab-action-btn .tab-lbl { display: none; }
  .tab-action-btn { padding: 0 10px; }
  .tabs-actions { padding-left: 8px; gap: 5px; }
}
@media (max-width: 720px) {
  .tab .tab-lbl { display: none; }
  .tab { padding: 14px 9px; }
  .tabs { padding: 0 8px 0 12px; }
}

/* SVG-Icons in der Save-Indikator-Reihe (oben rechts) — anders als Tabs */
.hdr-save-indicator { /* bleibt wie vorher */ }

/* ═══════════════════════════════════════════════════════════════
   V53 — Tab Objekt: Q&Z bündig zu Objektdaten, Lage&Markt unten
   ═══════════════════════════════════════════════════════════════ */
.col2-stretch {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items: stretch;
}
.col2-stretch > .card-stretch {
  display: flex;
  flex-direction: column;
  height: auto;
}
.col2-stretch > .card-stretch > .g2 {
  flex: 1 1 auto;
  align-content: start;
}

/* CRITICAL FIX: Selects in allen Cards — schwarze Schrift erzwingen */
.card select,
.f select,
select {
  color: var(--text) !important;
  background-color: var(--white);
}
.card select option,
.f select option,
select option {
  color: var(--text) !important;
  background-color: var(--white);
}
/* Ausnahme: Selects auf dunklem Background (z.B. qc-result-card) */
.qc-result-card select {
  color: var(--white) !important;
  background-color: rgba(255,255,255,0.05);
}

/* Trenner zwischen Selects und Sterne in Q&Z */
.qz-divider {
  height: 1px;
  background: var(--border);
  margin: 14px 0;
  position: relative;
}
.qz-divider::after {
  content: '★ Sterne-Bewertung';
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--white);
  padding: 0 12px;
  font-size: 9.5px;
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* Lage- & Markt-Indikatoren-Card */
.lage-markt-card {
  border-color: rgba(201,168,76,0.25);
  margin-top: 14px;
}

/* KI-Lage-Box "bottom"-Variante (innerhalb Lage&Markt-Card, am Ende) */
.ki-lage-box-bottom {
  margin-top: 18px;
  padding: 14px 16px;
  background: var(--gold-dim);
  border: 1px solid var(--border-g);
  border-radius: var(--r);
}
.ki-lage-box-bottom .ki-lage-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.ki-lage-box-bottom .ki-lage-title {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ch);
}
.ki-lage-box-bottom .ki-lage-icon {
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
}
.ki-lage-box-bottom .ki-lage-tag {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 2px 6px;
  border-radius: 3px;
  background: var(--gold);
  color: #fff;
  text-transform: uppercase;
}
.ki-lage-box-bottom .ki-lage-body {
  margin-top: 12px;
  font-size: 12.5px;
  color: var(--ch2);
  line-height: 1.55;
}
.ki-lage-box-bottom .ki-lage-empty {
  color: var(--muted);
  font-style: italic;
  font-size: 12px;
}

/* Drop-Zone Icon (statt 📷-Emoji) */
.drop-zone .dz-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  margin: 0 auto 8px;
  color: var(--gold);
  background: var(--gold-dim);
  border-radius: 50%;
}
.drop-zone .dz-sub {
  font-size: 10.5px;
  margin-top: 4px;
  opacity: 0.7;
  line-height: 1.4;
}

/* Q&Z-Card Layout-Verfeinerung */
.qz-card {
  display: flex;
  flex-direction: column;
}
.qz-card .qz-rows {
  flex: 1 1 auto;
}

/* ═══════════════════════════════════════════════════════════════
   V53 — Quick-Check als Tab (statt Modal)
   ═══════════════════════════════════════════════════════════════ */
#qc-tab-host {
  display: block;
  width: 100%;
}

/* Im Tab-Modus: kein Overlay, kein Modal-Padding */
.qc-body-tab {
  /* überschreibt .qc-body falls da was max-height/overflow ist */
  max-height: none !important;
  overflow: visible !important;
  padding: 0 !important;
}

/* Tab-Header für Quick-Check */
.qc-tab-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.qc-tab-icon {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--gold-dim);
  color: var(--gold);
  border-radius: var(--r);
  flex-shrink: 0;
}
.qc-tab-title-block {
  flex: 1 1 auto;
  min-width: 0;
}
.qc-tab-title-block .sec-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px;
  line-height: 1.1;
}
.qc-tab-title-block .qc-sub {
  font-size: 12.5px;
  color: var(--muted);
  margin-top: 4px;
  line-height: 1.5;
}
.qc-tab-footer {
  display: flex;
  gap: 10px;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  align-items: center;
}

/* ═══════════════════════════════════════════════════════════════
   V54 — Quick-Check: Pflichtfelder, optionale Sektion, Empfehlung
   ═══════════════════════════════════════════════════════════════ */

/* Pflichtfeld-Marker (Stern statt Sternchen im Label-Text) */
.qc-required::after {
  content: ' *';
  color: var(--red);
  font-weight: 700;
}

/* Optionaler Block (collapsible) */
.qc-optional-block {
  margin: 12px 0 8px;
  padding: 12px 14px;
  background: var(--surface);
  border: 1px dashed var(--border);
  border-radius: var(--r);
}
.qc-optional-block summary {
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  color: var(--gold-d, var(--ch));
  user-select: none;
  margin-bottom: 0;
  padding: 2px 0;
  list-style: none;
}
.qc-optional-block summary::-webkit-details-marker { display: none; }
.qc-optional-block summary::before {
  content: '▸ ';
  display: inline-block;
  margin-right: 4px;
  transition: transform 0.15s;
}
.qc-optional-block[open] summary::before {
  transform: rotate(90deg);
}
.qc-optional-block[open] summary {
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}

/* qc-row 3 Spalten */
.qc-row-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
}

/* V54 — KPIs/Score-Werte größer und dominanter */
.ds2-metric-score {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: var(--gold) !important;
  letter-spacing: -0.01em;
}
.ds2-metric-label {
  font-size: 12px !important;
  font-weight: 600;
}

/* V54 — Kauf-Empfehlungs-Box */
.qc-recommendation {
  margin-top: 14px;
  padding: 18px 20px;
  background: linear-gradient(135deg, #2A2727, #3a3433);
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: var(--r);
  color: rgba(255,255,255,0.92);
}
.qc-rec-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(201,168,76,0.25);
}
.qc-rec-icon {
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
}
.qc-rec-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.02em;
}
.qc-rec-verdict {
  display: inline-block;
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin-bottom: 8px;
  padding: 4px 14px;
  border-radius: var(--r);
}
.qc-rec-green { color: #5ED99E; background: rgba(94,217,158,0.12); }
.qc-rec-gold  { color: var(--gold); background: rgba(201,168,76,0.18); }
.qc-rec-red   { color: #f08080; background: rgba(240,128,128,0.12); }

.qc-rec-text {
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255,255,255,0.85);
}
.qc-rec-text strong {
  color: var(--gold);
  font-weight: 700;
}

/* V54 — Bewirt-HG-Modus Container */
.qc-bewirt-hg .qc-bewirt-tip {
  margin-top: 8px;
  background: rgba(201,168,76,0.06);
  border-left: 3px solid var(--gold);
}

/* V54 — Score-Werte (KPI-Werte im Card-Score-Block) — auch im qc-result */
.qc-result .ds-donut-score {
  font-size: 56px !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-weight: 700 !important;
}
.qc-result .ds-top-deal-label {
  font-size: 11px !important;
  letter-spacing: 0.15em !important;
  font-weight: 700 !important;
}

/* ═══════════════════════════════════════════════════════════════
   V54 — Score-Werte: große Zahl gold, "/100" klein und gedämpft
   ═══════════════════════════════════════════════════════════════ */
.qc-cat-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}
.qc-cat-bar.qc-cat-green .qc-cat-num { color: #6FCB91; }
.qc-cat-bar.qc-cat-gold  .qc-cat-num { color: var(--gold); }
.qc-cat-bar.qc-cat-red   .qc-cat-num { color: #DDA29E; }

.qc-cat-max {
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.4);
  margin-left: 3px;
  vertical-align: 4px;
  letter-spacing: 0.02em;
}

/* Score-Wert in den ds2-metrics als rechtsbündig + groß */
.ds2-metric-score {
  display: flex !important;
  align-items: baseline;
  gap: 1px;
  justify-content: flex-end;
  font-size: inherit !important;     /* überschreibt die V54-Riesenwerte für die Mini-Layout */
  font-weight: 600 !important;
}
.ds2-metric .ds2-metric-score .qc-cat-num {
  font-size: 22px;
  line-height: 1;
}
.ds2-metric .ds2-metric-score .qc-cat-max {
  font-size: 10px;
  color: rgba(255,255,255,0.42);
}

/* ds2-metric-label muss lesbar sein — nicht weiß, sondern hell gold */
.qc-result .ds2-metric-label {
  color: rgba(255, 255, 255, 0.92) !important;
  font-weight: 600;
}

/* V54: Score-Block — Kategorien-Grid in 2 Spalten umsortieren
   (3 oben + 2 unten = visuell ausgeglichener als 5 untereinander) */
.qc-cats-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px 14px !important;
  flex-direction: unset !important;
}
.ds2-metric.qc-cat-bar {
  display: grid !important;
  grid-template-columns: 32px 1fr auto !important;
  gap: 8px;
  align-items: center;
}
.ds2-metric .ds2-metric-icon {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  border: 1px solid;
}
.ds2-metric .ds2-metric-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.ds2-metric .ds2-metric-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
}
.ds2-metric .ds2-metric-bar {
  height: 4px;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
  overflow: hidden;
}
.ds2-metric .ds2-metric-bar-fill {
  display: block;
  height: 100%;
  background: rgba(255,255,255,0.30);
  border-radius: 2px;
  transition: width 0.30s ease, background 0.20s ease;
}

/* Bei schmaleren Layouts (Mobile) zurück auf 1 Spalte */
@media (max-width: 720px) {
  .qc-cats-grid { grid-template-columns: 1fr !important; }
}

/* V54 — Score-Block: Hint-Box mit konkreten Werten unter dem Donut */
.qc-score-explainer {
  margin-top: 10px;
  padding: 8px 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 6px;
  font-size: 11.5px;
  color: rgba(255,255,255,0.7);
  line-height: 1.5;
}
.qc-score-explainer strong {
  color: var(--gold);
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════════
   V54 Fixes — qc-form auf hellem Tab-Hintergrund (war Modal-Dark)
   ═══════════════════════════════════════════════════════════════ */

/* qc-ai-hint: weiß auf weiß → dunkler */
.qc-ai-hint {
  color: var(--ch2, #5a5350) !important;
}

/* qc-ai-src auf hellem Background */
.qc-ai-src-text {
  color: var(--ch2, #5a5350) !important;
}

/* Photo-Drop-Zone im QC-Tab: helle Variante */
.qc-photos-drop {
  border-color: rgba(42,39,39,0.20) !important;
  background: rgba(201,168,76,0.04) !important;
}
.qc-photos-drop-l {
  color: var(--ch2, #5a5350) !important;
}

/* qc-section-title: gold (war OK) — aber falls untergegangen */
.qc-section-title {
  color: var(--gold) !important;
}

/* Bewirt-Toggle-Buttons: lesbar auf hellem Hintergrund */
.qc-bewirt-btn {
  background: rgba(42,39,39,0.04);
  color: var(--ch);
  border: 1px solid rgba(42,39,39,0.10);
}
.qc-bewirt-btn:hover {
  background: rgba(201,168,76,0.10);
}
.qc-bewirt-btn.active {
  background: var(--gold) !important;
  color: #fff !important;
  border-color: var(--gold);
}

/* qc-eval (kleine Bewertungs-Liste) — auf hellem Background */
.qc-eval-line {
  color: var(--ch2, #5a5350);
}
.qc-eval-empty {
  color: rgba(42,39,39,0.45);
  font-style: italic;
}

/* Pflichtfeld-Stern muss sichtbar bleiben (var(--red) Fallback) */
.qc-required::after {
  color: #d55b5b !important;
}

/* qc-tab-header: hgr Subline lesbar */
.qc-tab-title-block .qc-sub {
  color: var(--ch2, #5a5350) !important;
}

/* Eingabe-Felder in qc-form — explizit hellgrund + dunkle Schrift erzwingen
   (gegen Browser-Autofill-Tönung) */
.qc-form input[type="text"],
.qc-form input[type="number"],
.qc-form select,
.qc-form textarea {
  background: #fff;
  color: var(--text, #1a1a1a) !important;
}
.qc-form input::placeholder,
.qc-form textarea::placeholder {
  color: rgba(42,39,39,0.30);
}

/* ═══════════════════════════════════════════════════════════════
   V55 — Versions-Badge in Tab-Leiste (damit man auf einen Blick
   sieht welche Version aktuell läuft)
   ═══════════════════════════════════════════════════════════════ */
.tabs-version-badge {
  display: inline-flex;
  align-items: center;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--gold);
  background: var(--gold-dim, rgba(201,168,76,0.10));
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 4px;
  padding: 3px 8px;
  margin: 0 10px 0 0;
  align-self: center;
  user-select: none;
}
@media (max-width: 720px) {
  .tabs-version-badge { display: none; }
}

/* ═══════════════════════════════════════════════════════════════
   V56 — Q&Z-Card: schwarze Schrift erzwingen
   ═══════════════════════════════════════════════════════════════ */
.qz-card select,
.qz-card option,
.qz-card label,
.qz-card .f label,
.qz-card .qz-name,
.qz-card .qz-label,
.qz-card .qz-footer-l,
.qz-card .qz-footer-v {
  color: var(--text, #1a1a1a) !important;
}
.qz-card select {
  background: #fff !important;
}
/* qz-divider Schriftzug "STERNE-BEWERTUNG" — auf hellem Background */
.qz-divider::after {
  background: var(--white, #fff) !important;
  color: var(--gold) !important;
}
/* Sterne selbst — deutlicher */
.qz-stars .qz-star {
  color: rgba(42,39,39,0.20);
  cursor: pointer;
}
.qz-stars .qz-star.active,
.qz-stars .qz-star:hover ~ .qz-star,
.qz-stars .qz-star:hover {
  color: var(--gold);
}

/* ═══════════════════════════════════════════════════════════════
   V56 — Quick-Check Score: 7 KPI-Karten als Visualisierung
   ═══════════════════════════════════════════════════════════════ */
.qc-score-kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-top: 14px;
}
.qc-score-kpi {
  padding: 10px 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: all 0.18s ease;
}
.qc-score-kpi:hover {
  background: rgba(255,255,255,0.06);
  transform: translateY(-1px);
}
.qc-score-kpi-l {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.qc-score-kpi-v {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 700;
  color: rgba(255,255,255,0.95);
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
}
.qc-score-kpi-h {
  font-size: 9.5px;
  color: rgba(255,255,255,0.40);
  font-style: italic;
}
/* Farb-Coding nach Performance */
.qc-score-kpi.qc-kpi-good {
  background: rgba(94,217,158,0.10);
  border-color: rgba(94,217,158,0.30);
}
.qc-score-kpi.qc-kpi-good .qc-score-kpi-v { color: #5ED99E; }
.qc-score-kpi.qc-kpi-mid {
  background: rgba(201,168,76,0.10);
  border-color: rgba(201,168,76,0.30);
}
.qc-score-kpi.qc-kpi-mid .qc-score-kpi-v { color: var(--gold); }
.qc-score-kpi.qc-kpi-bad {
  background: rgba(240,128,128,0.10);
  border-color: rgba(240,128,128,0.30);
}
.qc-score-kpi.qc-kpi-bad .qc-score-kpi-v { color: #f08080; }

/* Mobile: 2 Spalten */
@media (max-width: 900px) {
  .qc-score-kpis { grid-template-columns: repeat(2, 1fr); }
}

/* ═══════════════════════════════════════════════════════════════
   V56 — Workflow-Progress-Bar oberhalb der Tabs
   ═══════════════════════════════════════════════════════════════ */
.workflow-progress-wrap {
  background: var(--surface, #F8F6F1);
  border-bottom: 1px solid rgba(42,39,39,0.08);
}
.workflow-progress-inner {
  max-width: 1500px;
  margin: 0 auto;
  padding: 10px 22px;
  display: flex;
  align-items: center;
  gap: 16px;
}
.wf-wizard-start {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11.5px;
}

#workflow-progress {
  flex: 1;
  min-width: 0;
}
.wf-progress-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 6px;
}
.wf-progress-bar {
  flex: 1;
  height: 6px;
  background: rgba(42,39,39,0.08);
  border-radius: 3px;
  overflow: hidden;
}
.wf-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold) 0%, var(--gold-l, #d8b85e) 100%);
  border-radius: 3px;
  transition: width 0.4s ease;
}
.wf-progress-text {
  font-size: 11px;
  font-weight: 600;
  color: var(--ch2, #5a5350);
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.wf-progress-steps {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.wf-step {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  font-size: 10.5px;
  font-weight: 600;
  border-radius: 4px;
  border: 1px solid transparent;
  background: rgba(42,39,39,0.04);
  color: var(--ch2, #5a5350);
  cursor: pointer;
  transition: all 0.15s ease;
}
.wf-step:hover {
  background: rgba(201,168,76,0.12);
  border-color: rgba(201,168,76,0.30);
}
.wf-step-num {
  font-size: 9.5px;
  font-weight: 700;
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(42,39,39,0.10);
  color: var(--ch);
}
.wf-step-name { font-size: 11px; }
.wf-step-check { color: #5ED99E; font-weight: 700; }
.wf-step-done {
  background: rgba(94,217,158,0.10);
  border-color: rgba(94,217,158,0.30);
  color: #4caf6f;
}
.wf-step-done .wf-step-num {
  background: #5ED99E;
  color: #fff;
}
.wf-step-current {
  background: rgba(201,168,76,0.15);
  border-color: var(--gold);
  color: var(--ch);
}
.wf-step-current .wf-step-num {
  background: var(--gold);
  color: #fff;
}

/* ═══════════════════════════════════════════════════════════════
   V56 — Wizard (Vollbild-Stepper)
   ═══════════════════════════════════════════════════════════════ */
.wizard-overlay {
  position: fixed;
  inset: 0;
  background: rgba(42,39,39,0.55);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  backdrop-filter: blur(4px);
}
.wizard-modal {
  width: 100%;
  max-width: 600px;
  max-height: 90vh;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.wizard-header {
  padding: 16px 22px;
  border-bottom: 1px solid rgba(42,39,39,0.08);
  display: flex;
  align-items: center;
  gap: 16px;
}
.wizard-progress {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.wizard-progress-bar {
  height: 5px;
  background: rgba(42,39,39,0.08);
  border-radius: 3px;
  overflow: hidden;
}
.wizard-progress-fill {
  height: 100%;
  background: var(--gold);
  border-radius: 3px;
  transition: width 0.4s ease;
}
.wizard-progress-text {
  font-size: 10.5px;
  font-weight: 600;
  color: var(--ch2, #5a5350);
  letter-spacing: 0.05em;
}
.wizard-close {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: transparent;
  border: 1px solid rgba(42,39,39,0.10);
  color: var(--ch);
  font-size: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.wizard-close:hover {
  background: rgba(42,39,39,0.05);
}
.wizard-body {
  padding: 24px 28px;
  flex: 1;
  overflow-y: auto;
}
.wizard-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px;
  font-weight: 600;
  color: var(--ch);
  margin: 0 0 8px;
  line-height: 1.15;
}
.wizard-sub {
  font-size: 13px;
  color: var(--ch2, #5a5350);
  margin-bottom: 22px;
  line-height: 1.5;
}
.wf-fields {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.wf-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.wf-field label {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--ch);
  display: flex;
  align-items: center;
  gap: 6px;
}
.wf-req {
  color: #d55b5b;
  font-weight: 700;
}
.wf-input {
  padding: 10px 12px;
  font-size: 14px;
  border: 1px solid rgba(42,39,39,0.15);
  border-radius: 6px;
  font-family: inherit;
  color: var(--text, #1a1a1a);
  background: #fff;
}
.wf-input:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,0.12);
}
.wizard-footer {
  padding: 14px 22px;
  border-top: 1px solid rgba(42,39,39,0.08);
  display: flex;
  align-items: center;
  gap: 10px;
}

@media (max-width: 720px) {
  .workflow-progress-inner { flex-wrap: wrap; padding: 8px 12px; }
  .wf-progress-steps { display: none; } /* Mobile: nur Bar zeigen */
  .wizard-modal { max-width: 100%; max-height: 100vh; border-radius: 0; }
}

/* ═══════════════════════════════════════════════════════════════
   V57 — Header mit Workflow-Bar (sticky, beim Scrollen immer sichtbar)
   ═══════════════════════════════════════════════════════════════ */

/* Header insgesamt: Sticky-Position */
.hdr {
  position: sticky !important;
  top: 0;
  z-index: 100;
  display: flex;
  flex-direction: column;
  /* etwas tiefer für 2 Reihen */
  height: auto !important;
  min-height: auto !important;
  padding: 0 !important;
}

/* Erste Reihe: Mobile-Menu, Obj-Name, Badges */
.hdr-row {
  display: flex;
  align-items: center;
  width: 100%;
}
.hdr-row-top {
  padding: 12px 22px;
  min-height: 56px;
  background: var(--ch, #2A2727);
  border-bottom: 1px solid rgba(201,168,76,0.15);
}
/* Workflow-Reihe: dunkler, mit Gold-Akzent */
.hdr-row-workflow {
  padding: 8px 22px;
  background: #1f1d1d;
  min-height: 44px;
}

/* Workflow-Inner V57: dunkles Theme */
.workflow-progress-inner-v57 {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.workflow-progress-inner-v57 .wf-progress-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0;
}
.workflow-progress-inner-v57 .wf-progress-bar {
  flex: 1;
  height: 4px;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
  overflow: hidden;
}
.workflow-progress-inner-v57 .wf-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold) 0%, var(--gold-l, #d8b85e) 100%);
  border-radius: 2px;
  transition: width 0.4s ease;
}
.workflow-progress-inner-v57 .wf-progress-text {
  font-size: 10.5px;
  font-weight: 600;
  color: rgba(255,255,255,0.65);
  letter-spacing: 0.04em;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.workflow-progress-inner-v57 .wf-progress-steps {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.workflow-progress-inner-v57 .wf-step {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 9px;
  font-size: 10px;
  font-weight: 600;
  border-radius: 3px;
  border: 1px solid transparent;
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.7);
  cursor: pointer;
  transition: all 0.15s ease;
}
.workflow-progress-inner-v57 .wf-step:hover {
  background: rgba(201,168,76,0.18);
  border-color: rgba(201,168,76,0.40);
  color: #fff;
}
.workflow-progress-inner-v57 .wf-step-num {
  font-size: 8.5px;
  font-weight: 700;
  width: 14px;
  height: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,0.10);
  color: rgba(255,255,255,0.85);
}
.workflow-progress-inner-v57 .wf-step-name { font-size: 10.5px; }
.workflow-progress-inner-v57 .wf-step-check { color: #5ED99E; font-weight: 700; font-size: 10px; }
.workflow-progress-inner-v57 .wf-step-done {
  background: rgba(94,217,158,0.12);
  border-color: rgba(94,217,158,0.30);
  color: #6FCB91;
}
.workflow-progress-inner-v57 .wf-step-done .wf-step-num {
  background: #5ED99E;
  color: var(--ch);
}
.workflow-progress-inner-v57 .wf-step-current {
  background: rgba(201,168,76,0.15);
  border-color: rgba(201,168,76,0.55);
  color: var(--gold);
}
.workflow-progress-inner-v57 .wf-step-current .wf-step-num {
  background: var(--gold);
  color: var(--ch);
}

/* Tabs auch sticky lassen, direkt unter Header */
.tabs {
  position: sticky;
  top: 100px; /* unter dem 2-Reihen-Header */
  z-index: 99;
  background: var(--surface, #F8F6F1);
}

/* Alte Workflow-Wrap Klasse nicht mehr genutzt — verstecken falls noch da */
.workflow-progress-wrap { display: none; }

@media (max-width: 720px) {
  .hdr-row-top { padding: 10px 14px; min-height: 50px; }
  .hdr-row-workflow { padding: 6px 14px; }
  .workflow-progress-inner-v57 .wf-progress-steps { display: none; }
  .tabs { top: 85px; }
}

/* V57 — alle 7 Score-KPIs in einer Reihe (vorher 4+3) */
.qc-score-kpis {
  grid-template-columns: repeat(7, 1fr) !important;
  gap: 6px !important;
}
.qc-score-kpi {
  padding: 8px 9px !important;
}
.qc-score-kpi-l {
  font-size: 9px !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.qc-score-kpi-v {
  font-size: 18px !important;
}
.qc-score-kpi-h {
  font-size: 8.5px !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Mobile: 2 Spalten, dann wieder 1 */
@media (max-width: 1100px) {
  .qc-score-kpis { grid-template-columns: repeat(4, 1fr) !important; }
}
@media (max-width: 720px) {
  .qc-score-kpis { grid-template-columns: repeat(2, 1fr) !important; }
}

/* ═══════════════════════════════════════════════════════════════
   V59 — Header-Hint "Daten unvollständig" (statt Phantom-Score)
   ═══════════════════════════════════════════════════════════════ */
.hdr-incomplete-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  background: rgba(201,168,76,0.10);
  border: 1px solid rgba(201,168,76,0.35);
  border-radius: 18px;
  font-size: 11.5px;
  color: rgba(255,255,255,0.85);
  font-weight: 500;
  letter-spacing: 0.01em;
}
.hdr-incomplete-icon {
  font-size: 14px;
  opacity: 0.85;
}
.hdr-incomplete-text {
  white-space: nowrap;
}
@media (max-width: 720px) {
  .hdr-incomplete-text { display: none; }
}

/* V60 — Completeness-Threshold Slider in Settings */
.ds-completeness-row {
  display: grid;
  grid-template-columns: 200px 1fr 60px;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  margin-top: 8px;
}
.ds-completeness-row label {
  font-size: 12px;
  font-weight: 600;
  color: var(--ch);
}
.ds-completeness-row input[type="range"] {
  width: 100%;
  accent-color: var(--gold);
}
.ds-completeness-row span {
  color: var(--gold);
  font-variant-numeric: tabular-nums;
}

/* V60 — User-Submenü mit Divider zwischen normalen Aktionen und Abmelden */
.sb-submenu-divider {
  height: 1px;
  background: rgba(255,255,255,0.10);
  margin: 4px 0;
}

/* ═══════════════════════════════════════════════════════════════
   V61 — Neuer Header (Charcoal + Score + 5 KPI-Pills)
   ═══════════════════════════════════════════════════════════════ */
.hdr {
  position: sticky !important;
  top: 0;
  z-index: 100;
  display: flex !important;
  flex-direction: column !important;
  height: auto !important;
  min-height: auto !important;
  padding: 0 !important;
  background: #2A2727;
  border-bottom: none;
}

/* Reihe 1: Adresse + Buttons */
.hdr-v61-row1 {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 22px;
  background: #2A2727;
  min-height: 56px;
}
.hdr-v61-row1 .hdr-mobile-menu {
  display: none;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 6px;
  width: 32px;
  height: 32px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 3px;
  cursor: pointer;
  margin-right: 6px;
}
.hdr-v61-row1 .hdr-mobile-menu span {
  width: 16px;
  height: 1.5px;
  background: rgba(255,255,255,0.7);
  display: block;
}
@media (max-width: 1024px) {
  .hdr-v61-row1 .hdr-mobile-menu { display: inline-flex; }
}
.hdr-obj-num {
  font-size: 10.5px;
  font-weight: 700;
  color: #C9A84C;
  background: rgba(201,168,76,0.12);
  border: 0.5px solid rgba(201,168,76,0.40);
  padding: 4px 10px;
  border-radius: 4px;
  letter-spacing: 0.05em;
  flex-shrink: 0;
}
.hdr-sep {
  color: rgba(255,255,255,0.30);
  font-size: 13px;
  flex-shrink: 0;
}
.hdr-obj-name {
  font-size: 14.5px;
  font-weight: 500;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
  font-family: 'DM Sans', sans-serif;
}
.hdr-autosave {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: #6FCB91;
  flex-shrink: 0;
  padding-left: 12px;
  border-left: 0.5px solid rgba(255,255,255,0.10);
  margin-left: 4px;
}
.hdr-autosave-dot {
  width: 6px;
  height: 6px;
  background: #6FCB91;
  border-radius: 50%;
}
.hdr-spacer { flex: 1; min-width: 0; }
.hdr-actions-v61 {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.hdr-icon-btn {
  width: 32px;
  height: 32px;
  background: transparent;
  border: 0.5px solid rgba(255,255,255,0.15);
  border-radius: 6px;
  color: rgba(255,255,255,0.75);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
}
.hdr-icon-btn:hover {
  background: rgba(255,255,255,0.06);
  color: #fff;
  border-color: rgba(255,255,255,0.25);
}
.hdr-pdf-btn {
  height: 34px;
  padding: 0 14px;
  background: transparent;
  border: 0.5px solid rgba(201,168,76,0.55);
  border-radius: 6px;
  color: #C9A84C;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  font-weight: 500;
  margin-left: 4px;
  transition: all 0.15s;
}
.hdr-pdf-btn:hover {
  background: rgba(201,168,76,0.10);
  border-color: var(--gold);
}
.hdr-save-btn {
  height: 34px;
  padding: 0 16px;
  background: var(--gold);
  border: 0.5px solid var(--gold);
  border-radius: 6px;
  color: #2A2727;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  font-weight: 600;
  transition: all 0.15s;
}
.hdr-save-btn:hover {
  background: #d8b85e;
  border-color: #d8b85e;
}

/* Reihe 2: Score-Donut + 5 KPI-Pills — wird von updHeaderBadges() befüllt */
.hdr-v61-row2 {
  display: grid;
  grid-template-columns: 230px repeat(5, 1fr);
  gap: 10px;
  padding: 14px 22px;
  background: #2A2727;
  border-bottom: 0.5px solid rgba(255,255,255,0.06);
}
.hdr-v61-row2:empty {
  display: none;
}

/* Score-Donut-Karte (links) */
.hdr-score-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 4px 8px;
  border-radius: 8px;
  border: 0.5px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
}
.hdr-score-card.tier-green {
  background: rgba(94,217,158,0.08);
  border-color: rgba(94,217,158,0.30);
}
.hdr-score-card.tier-gold {
  background: rgba(201,168,76,0.08);
  border-color: rgba(201,168,76,0.30);
}
.hdr-score-card.tier-red {
  background: rgba(240,128,128,0.08);
  border-color: rgba(240,128,128,0.30);
}
.hdr-score-donut { flex-shrink: 0; }
.hdr-score-info { min-width: 0; }
.hdr-score-tier {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}
.hdr-score-tier-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
}
.hdr-score-card.tier-green .hdr-score-tier { color: #6FCB91; }
.hdr-score-card.tier-green .hdr-score-tier-dot { background: #6FCB91; }
.hdr-score-card.tier-gold .hdr-score-tier { color: var(--gold); }
.hdr-score-card.tier-gold .hdr-score-tier-dot { background: var(--gold); }
.hdr-score-card.tier-red .hdr-score-tier { color: #f08080; }
.hdr-score-card.tier-red .hdr-score-tier-dot { background: #f08080; }
.hdr-score-headline {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  font-weight: 600;
  color: #fff;
  line-height: 1.1;
  margin-top: 2px;
}
.hdr-score-sub {
  font-size: 10.5px;
  color: rgba(255,255,255,0.55);
  margin-top: 3px;
  line-height: 1.35;
}
.hdr-score-rec {
  font-size: 10.5px;
  color: rgba(255,255,255,0.65);
  margin-top: 2px;
}
.hdr-score-rec strong {
  color: var(--gold);
  font-weight: 600;
}

/* KPI-Pill */
.hdr-kpi-pill {
  background: rgba(255,255,255,0.04);
  border: 0.5px solid rgba(255,255,255,0.10);
  border-radius: 8px;
  padding: 9px 12px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 78px;
}
.hdr-kpi-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  margin-bottom: 5px;
}
.hdr-kpi-l {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.10em;
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
}
.hdr-kpi-icon {
  color: rgba(255,255,255,0.55);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.hdr-kpi-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 6px;
}
.hdr-kpi-v {
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px;
  font-weight: 700;
  color: #fff;
  line-height: 1;
}
.hdr-kpi-pill.tier-gold .hdr-kpi-v { color: var(--gold); }
.hdr-kpi-pill.tier-red .hdr-kpi-v { color: #f08080; }
.hdr-kpi-trend {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-size: 9.5px;
  font-weight: 600;
  padding: 2px 5px;
  border-radius: 3px;
}
.hdr-kpi-trend.up {
  color: #6FCB91;
  background: rgba(94,217,158,0.15);
}
.hdr-kpi-trend.down {
  color: #f08080;
  background: rgba(240,128,128,0.15);
}
.hdr-kpi-bar {
  height: 3px;
  background: rgba(255,255,255,0.06);
  border-radius: 2px;
  margin-top: 8px;
  overflow: hidden;
}
.hdr-kpi-bar-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.4s ease;
}
.hdr-kpi-pill.tier-green .hdr-kpi-bar-fill { background: #5ED99E; }
.hdr-kpi-pill.tier-gold .hdr-kpi-bar-fill  { background: var(--gold); }
.hdr-kpi-pill.tier-red .hdr-kpi-bar-fill   { background: #f08080; }

/* Workflow-Bar V57 ist nicht mehr im Header — versteckt */
.hdr-row-workflow { display: none; }
.workflow-progress-wrap { display: none; }

/* Tabs-Leiste hell unter dem dunklen Header */
.tabs {
  position: sticky;
  top: 154px;
  z-index: 99;
  background: var(--surface, #F8F6F1);
  border-bottom: 0.5px solid rgba(42,39,39,0.10);
}

/* Mobile-Anpassungen */
@media (max-width: 1100px) {
  .hdr-v61-row2 {
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .hdr-pdf-btn span,
  .hdr-save-btn span { display: inline; }
}
@media (max-width: 720px) {
  .hdr-v61-row1 { padding: 10px 14px; gap: 8px; }
  .hdr-v61-row2 { padding: 10px 14px; }
  .hdr-pdf-btn span,
  .hdr-save-btn span { display: none; }
  .hdr-pdf-btn { padding: 0 10px; }
  .hdr-save-btn { padding: 0 12px; }
  .hdr-autosave { display: none !important; }
  .tabs { top: 130px; }
}

/* ═══════════════════════════════════════════════════════════════
   V61 — Sidebar-Logo deutlich größer + Toggle-Button entfernt
   ═══════════════════════════════════════════════════════════════ */
.sb-dealpilot-logo {
  width: 100% !important;
  max-width: 380px !important;     /* V60 hatte 320 */
  margin-top: 8px !important;
  margin-bottom: 6px !important;
}
/* Alten Toggle-Button für alle Fälle wegmachen falls noch wo da */
.sb-toggle-v42 { display: none !important; }

/* Sidebar-Collapse-Logik komplett deaktivieren */
.app-wrap.sb-collapsed .sb-dealpilot-logo,
.app-wrap.sb-collapsed .sb-footer {
  display: block !important;
}
.app-wrap.sb-collapsed {
  /* Sidebar bleibt in voller Breite */
}

/* ═══════════════════════════════════════════════════════════════
   V62 — Tab-Bar Sticky-Top auf neuen Header anpassen + KPI größer
   ═══════════════════════════════════════════════════════════════ */

/* Tab-Bar muss UNTER dem 2-Reihen-Header sticky bleiben (Header ~154px) */
nav.tabs,
.tabs {
  position: sticky !important;
  top: 154px !important;
  z-index: 99 !important;
  background: var(--surface, #F8F6F1) !important;
  border-bottom: 0.5px solid rgba(42,39,39,0.10) !important;
}

/* V62: Header-KPI-Pills GRÖSSER — passend zur Vorlage (Bild 2) */
.hdr-v61-row2 {
  padding: 18px 22px !important;
  gap: 12px !important;
  grid-template-columns: 280px repeat(5, 1fr) !important;
}
.hdr-score-card {
  padding: 12px 14px !important;
  gap: 14px !important;
}
.hdr-score-donut {
  width: 72px !important;
  height: 72px !important;
}
.hdr-score-headline {
  font-size: 21px !important;
}
.hdr-score-sub {
  font-size: 11.5px !important;
}
.hdr-score-rec {
  font-size: 11.5px !important;
}
.hdr-kpi-pill {
  padding: 12px 14px !important;
  min-height: 96px !important;
}
.hdr-kpi-l {
  font-size: 10px !important;
}
.hdr-kpi-v {
  font-size: 32px !important;
}
.hdr-kpi-bar {
  height: 4px !important;
  margin-top: 12px !important;
}

/* V62: Versions-Badge wieder rechts in den Tabs ohne Action-Buttons daneben */
.tabs-version-badge {
  margin-left: auto;
  margin-right: 0;
}

/* V62: Header-Action-Buttons Optimierung */
.hdr-icon-btn {
  width: 34px;
  height: 34px;
}
.hdr-pdf-btn,
.hdr-save-btn {
  height: 36px !important;
  font-size: 13px !important;
}

/* V62: Workflow-Progress-Bar wieder einblenden — als Tab-Sub-Header in hellem Bereich */
.tabs-workflow-bar {
  background: var(--surface, #F8F6F1);
  padding: 12px 22px;
  display: flex;
  align-items: center;
  gap: 16px;
  border-bottom: 0.5px solid rgba(42,39,39,0.06);
  position: sticky;
  top: 200px;     /* unter Header (154px) + Tabs (~46px) */
  z-index: 98;
}
.tabs-workflow-bar .wf-tab-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px;
  font-weight: 600;
  color: var(--ch);
  line-height: 1;
}
.tabs-workflow-bar .wf-tab-sub {
  font-size: 12px;
  color: rgba(42,39,39,0.55);
  flex: 1;
}
.tabs-workflow-bar .wf-tab-progress {
  display: flex;
  align-items: center;
  gap: 10px;
}
.tabs-workflow-bar .wf-tab-progress-text {
  font-size: 11.5px;
  color: rgba(42,39,39,0.55);
  font-variant-numeric: tabular-nums;
}
.tabs-workflow-bar .wf-tab-progress-bar {
  width: 160px;
  height: 5px;
  background: rgba(42,39,39,0.08);
  border-radius: 3px;
  overflow: hidden;
}
.tabs-workflow-bar .wf-tab-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold), #d8b85e);
  border-radius: 3px;
  transition: width 0.4s ease;
}

@media (max-width: 1100px) {
  .hdr-v61-row2 {
    grid-template-columns: 1fr 1fr 1fr !important;
    gap: 8px !important;
  }
  .hdr-score-card { grid-column: 1 / -1; }
  nav.tabs, .tabs { top: 120px !important; }
}
@media (max-width: 720px) {
  .hdr-kpi-v { font-size: 24px !important; }
  .tabs-workflow-bar { padding: 8px 14px; flex-wrap: wrap; }
  .tabs-workflow-bar .wf-tab-title { font-size: 20px; }
}

/* ═══════════════════════════════════════════════════════════════
   V62.2 — Header-Layout-Fixes (gegen alte CSS-Konflikte)
   ═══════════════════════════════════════════════════════════════ */

/* Override alte hdr{height:64px} — neuer 2-Reihen-Header braucht auto-Höhe */
header.hdr,
.hdr {
  height: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  background: #2A2727 !important;
  display: block !important;
  border-bottom: 0.5px solid rgba(201,168,76,0.20) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.25) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 300 !important;
}

/* Reihen müssen wirklich Charcoal-Hintergrund haben (gegen transparente Stelle) */
.hdr-v61-row1,
.hdr-v61-row2 {
  background: #2A2727 !important;
}
.hdr-v61-row2 {
  width: 100%;
  box-sizing: border-box;
}

/* Tab-Bar fest unter Header — sticky (gegen "verschwindet beim Scrollen").
   V63.45: Default-top via --tabs-top, JS misst Header-Höhe & setzt sie neu. */
nav.tabs,
.tabs {
  position: sticky !important;
  top: var(--tabs-top, 156px) !important;
  z-index: 250 !important;
  background: var(--surface, #F8F6F1) !important;
  border-bottom: 0.5px solid rgba(42,39,39,0.10) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04) !important;
  transition: top 0.18s ease;
}

/* Workflow-Bar darunter — auch sticky.
   V63.45: Default-top via CSS-Variable --wf-top, die JS bei Header-Höhen-Änderung
   neu berechnet. Wenn Header collapsed ist, sinkt der Wert automatisch. */
.tabs-workflow-bar {
  position: sticky !important;
  top: var(--wf-top, 200px) !important;
  z-index: 240 !important;
  background: var(--surface, #F8F6F1) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.04);
  transition: top 0.18s ease;
}

@media (max-width: 1100px) {
  nav.tabs, .tabs { top: 140px !important; }
  .tabs-workflow-bar { top: var(--wf-top, 102px) !important; }
}
@media (max-width: 720px) {
  nav.tabs, .tabs { top: 110px !important; }
  .tabs-workflow-bar { top: var(--wf-top, 102px) !important; }
}

/* V62.2: Adresse im Header — flex:1 von alter .hdr-obj-Klasse override */
.hdr-v61-row1 .hdr-obj-name {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  text-align: left !important;
  padding: 0 !important;
  font-size: 14.5px !important;
  color: #fff !important;
  font-weight: 500 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* V62.2: Auto-saved-Indikator im Header — sichtbar machen */
.hdr-autosave[style*="inline-flex"] {
  display: inline-flex !important;
}

/* V62.2: Tab-Workflow-Bar — vermeide doppelte Sub mit alter Logik */
.tabs-workflow-bar .wf-tab-title {
  flex-shrink: 0;
}

/* V62.2: Score-Karte: bei zu schmalem Container nicht abschneiden */
.hdr-score-card {
  overflow: hidden;
}
.hdr-score-info {
  flex: 1 1 auto;
  min-width: 0;
}
.hdr-score-headline {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* V62.2: Tab-Workflow-Bar Steps (kleine klickbare Indikatoren) */
.wf-tab-steps {
  display: flex;
  gap: 4px;
  flex-wrap: nowrap;
  overflow-x: auto;
  scrollbar-width: none;
  flex-shrink: 1;
  min-width: 0;
}
.wf-tab-steps::-webkit-scrollbar { display: none; }
.wf-tstep {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  font-size: 10.5px;
  font-weight: 600;
  border-radius: 4px;
  border: 0.5px solid rgba(42,39,39,0.10);
  background: rgba(42,39,39,0.03);
  color: var(--ch2, #5a5350);
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.15s;
}
.wf-tstep:hover {
  background: rgba(201,168,76,0.10);
  border-color: rgba(201,168,76,0.40);
  color: var(--ch);
}
.wf-tstep-num {
  font-size: 9.5px;
  font-weight: 700;
  width: 14px;
  height: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(42,39,39,0.10);
  color: var(--ch);
}
.wf-tstep-done {
  background: rgba(94,217,158,0.10);
  border-color: rgba(94,217,158,0.40);
  color: #4caf6f;
}
.wf-tstep-done .wf-tstep-num {
  background: #5ED99E;
  color: #fff;
}
.wf-tstep-check {
  color: #5ED99E;
  font-size: 10px;
  font-weight: 700;
}
@media (max-width: 1200px) {
  .wf-tab-steps .wf-tstep-name { display: none; }
  .wf-tstep { padding: 3px 4px; }
}
@media (max-width: 720px) {
  .wf-tab-steps { display: none; }
}

/* ═══════════════════════════════════════════════════════════════
   V62.3 — Header schmaler + Sticky-Lücke fixen
   ═══════════════════════════════════════════════════════════════ */

/* Header schmaler — Reihe 1 weniger Padding, Reihe 2 kompakter */
.hdr-v61-row1 {
  padding: 8px 22px !important;
  min-height: 48px !important;
}
.hdr-v61-row2 {
  padding: 10px 22px !important;
  gap: 8px !important;
}
/* Score-Karte deutlich kompakter */
.hdr-score-card {
  padding: 6px 10px !important;
  gap: 10px !important;
}
.hdr-score-donut {
  width: 56px !important;
  height: 56px !important;
}
.hdr-score-headline {
  font-size: 16px !important;
}
.hdr-score-sub {
  font-size: 10.5px !important;
  -webkit-line-clamp: 1;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.hdr-score-rec {
  font-size: 10.5px !important;
}
/* KPI-Pills kompakter */
.hdr-kpi-pill {
  padding: 8px 10px !important;
  min-height: 70px !important;
}
.hdr-kpi-v {
  font-size: 22px !important;
}
.hdr-kpi-bar {
  margin-top: 6px !important;
}

/* V62.3: Buttons in Reihe 1 kleiner */
.hdr-icon-btn {
  width: 30px !important;
  height: 30px !important;
}
.hdr-pdf-btn,
.hdr-save-btn {
  height: 32px !important;
  font-size: 12px !important;
  padding: 0 12px !important;
}

/* ═══════════════════════════════════════════════════════════════
   V62.3 — Sticky-Top dynamisch (kein Workspace zwischen Header und Tabs)
   ═══════════════════════════════════════════════════════════════ */

/* Default: Header hat 2 Reihen (mit Score) → Tabs auf 134px */
nav.tabs,
.tabs {
  top: 134px !important;     /* 48px Reihe1 + 86px Reihe2 */
}
.tabs-workflow-bar {
  top: 178px !important;     /* + ~44px Tabs */
}

/* Wenn Reihe 2 leer/versteckt ist → Tabs direkt unter Reihe 1 */
.hdr:has(.hdr-v61-row2:empty) ~ nav.tabs,
.hdr:has(.hdr-v61-row2:empty) ~ .tabs,
header.hdr:has(.hdr-v61-row2:empty) ~ nav.tabs {
  top: 48px !important;
}
header.hdr:has(.hdr-v61-row2:empty) ~ .tabs-workflow-bar { top: var(--wf-top, 102px) !important; }

/* Fallback für Browser ohne :has()-Support — JavaScript-Klasse setzen */
body.hdr-no-score nav.tabs,
body.hdr-no-score .tabs {
  top: 48px !important;
}
body.hdr-no-score .tabs-workflow-bar { top: var(--wf-top, 102px) !important; }

@media (max-width: 1100px) {
  nav.tabs, .tabs { top: 130px !important; }
  .tabs-workflow-bar { top: var(--wf-top, 102px) !important; }
  body.hdr-no-score nav.tabs,
  body.hdr-no-score .tabs { top: 48px !important; }
  body.hdr-no-score .tabs-workflow-bar { top: var(--wf-top, 102px) !important; }
}
@media (max-width: 720px) {
  nav.tabs, .tabs { top: 100px !important; }
  .tabs-workflow-bar { top: var(--wf-top, 102px) !important; }
  body.hdr-no-score nav.tabs,
  body.hdr-no-score .tabs { top: 44px !important; }
  body.hdr-no-score .tabs-workflow-bar { top: var(--wf-top, 102px) !important; }
}

/* ═══════════════════════════════════════════════════════════════
   V63 — KPI-Vollständigkeit + 70%-Threshold-Banner
   ═══════════════════════════════════════════════════════════════ */

/* Globale Vollständigkeit-Anzeige in Header Reihe 1 */
.hdr-completeness {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 10px;
  border-radius: 4px;
  background: rgba(255,255,255,0.04);
  border: 0.5px solid rgba(255,255,255,0.10);
  flex-shrink: 0;
  margin-left: 8px;
  font-size: 11px;
  color: rgba(255,255,255,0.70);
}
.hdr-completeness.good {
  background: rgba(94,217,158,0.10);
  border-color: rgba(94,217,158,0.30);
  color: #6FCB91;
}
.hdr-completeness.warn {
  background: rgba(201,168,76,0.10);
  border-color: rgba(201,168,76,0.30);
  color: #C9A84C;
}
.hdr-completeness.low {
  background: rgba(240,128,128,0.08);
  border-color: rgba(240,128,128,0.30);
  color: #f08080;
}
.hdr-comp-text {
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.hdr-comp-bar {
  width: 60px;
  height: 4px;
  background: rgba(255,255,255,0.10);
  border-radius: 2px;
  overflow: hidden;
  display: inline-block;
}
.hdr-comp-fill {
  height: 100%;
  background: currentColor;
  transition: width 0.4s ease;
  display: block;
}

/* KPI-Pill-Vollständigkeit (kleine Zeile mit "X/Y KPIs") */
.hdr-kpi-comp {
  font-size: 9.5px;
  color: rgba(255,255,255,0.50);
  margin-bottom: 4px;
  font-variant-numeric: tabular-nums;
}

/* 70%-Threshold-Banner */
.hdr-incomplete-banner {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: rgba(201,168,76,0.10);
  border: 0.5px solid rgba(201,168,76,0.40);
  border-radius: 8px;
  color: rgba(255,255,255,0.85);
  font-size: 13px;
  line-height: 1.4;
}
.hdr-incomplete-banner .hdr-incomplete-icon {
  font-size: 22px;
  flex-shrink: 0;
}
.hdr-incomplete-banner strong {
  color: var(--gold);
  font-weight: 600;
}

@media (max-width: 1100px) {
  .hdr-completeness { display: none; }
}

/* V63: Threshold-Banner für DealPilot Score (Tab Kennzahlen) */
.ds-threshold-banner {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 24px 28px;
  background: linear-gradient(135deg, rgba(201,168,76,0.08), rgba(201,168,76,0.03));
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 12px;
  color: var(--ch);
}
.ds-threshold-icon {
  font-size: 36px;
  flex-shrink: 0;
}
.ds-threshold-body {
  flex: 1;
}
.ds-threshold-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 600;
  color: var(--ch);
  margin-bottom: 4px;
}
.ds-threshold-sub {
  font-size: 13px;
  color: rgba(42,39,39,0.70);
  margin-bottom: 12px;
}
.ds-threshold-sub strong {
  color: var(--gold);
  font-weight: 700;
}
.ds-threshold-bar {
  height: 6px;
  background: rgba(42,39,39,0.10);
  border-radius: 3px;
  overflow: hidden;
}
.ds-threshold-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold), #d8b85e);
  border-radius: 3px;
  transition: width 0.4s ease;
}

/* V63: DSGVO-Checkbox im Beta-Signup */
.beta-dsgvo {
  margin-top: 8px;
  padding: 12px;
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 6px;
}
.beta-dsgvo-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  /* V63.3: kein uppercase und kein letter-spacing, damit Text lesbar bleibt */
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-weight: 400 !important;
}
.beta-dsgvo-row input[type="checkbox"] {
  flex-shrink: 0;
  margin-top: 3px;
  width: 18px;
  height: 18px;
  accent-color: var(--gold);
}
.beta-dsgvo-text {
  font-size: 13px;
  line-height: 1.5;
  /* V63.3: Helle Schrift für dunklen Modal-Hintergrund */
  color: rgba(255,255,255,0.92) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-weight: 400 !important;
}
.beta-dsgvo-text a {
  color: var(--gold);
  text-decoration: underline;
  font-weight: 600;
}
.beta-dsgvo-text a:hover {
  color: #d8b85e;
}
.btn[disabled] {
  opacity: 0.55;
  cursor: not-allowed;
}

/* ═══════════════════════════════════════════════════════════════
   V63 — Layout-Bug-Fix: kein Background zwischen Header und Tabs
   ═══════════════════════════════════════════════════════════════ */

/* main-col bekommt durchgehenden Background damit nichts mehr durchblitzt */
.main-col {
  background: var(--surface, #F8F6F1);
  min-height: 100vh;
}

/* Sidebar bekommt eigenen Background damit nichts durchscheint */
.app-wrap {
  background: var(--surface, #F8F6F1);
}

/* Body selbst hat festen Background */
body {
  background: var(--surface, #F8F6F1);
  overflow-x: hidden;
}

/* Wenn der hdr-no-score-Modus aktiv ist, soll die Tab-Bar bündig anschließen */
body.hdr-no-score nav.tabs,
body.hdr-no-score .tabs {
  margin-top: 0;
}

/* Sticky-Container immer mit voller Hintergrund-Deckung */
header.hdr {
  width: 100%;
  box-sizing: border-box;
}

/* Workspace-Container (.body) durchgehender Hintergrund */
.body {
  background: var(--surface, #F8F6F1);
  position: relative;
}

/* Beim Rendern des Quick-Check-Tab-Hosts: sicherstellen dass kein transparenter Bereich entsteht */
#qc-tab-host,
.sec.active {
  background: var(--surface, #F8F6F1);
}

/* ═══════════════════════════════════════════════════════════════
   V63.1 — Plan-Pane in Settings (4 Pläne + Toggle + Credit-Pakete)
   ═══════════════════════════════════════════════════════════════ */

.plan-billing-toggle {
  display: inline-flex;
  background: rgba(42,39,39,0.06);
  padding: 4px;
  border-radius: 8px;
  margin: 12px 0 8px;
  gap: 4px;
}
.plan-toggle-btn {
  padding: 8px 16px;
  border: none;
  background: transparent;
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  color: var(--ch);
  transition: all 0.2s;
}
.plan-toggle-btn.active {
  background: var(--gold);
  color: #fff;
  box-shadow: 0 2px 6px rgba(201,168,76,0.30);
}
.plan-toggle-bonus {
  font-size: 10.5px;
  font-weight: 500;
  color: inherit;
  opacity: 0.85;
}

.plan-yearly-bonus-banner {
  margin: 10px 0 16px;
  padding: 12px 14px;
  background: linear-gradient(135deg, rgba(94,217,158,0.12), rgba(94,217,158,0.04));
  border: 1px solid rgba(94,217,158,0.30);
  border-radius: 8px;
  font-size: 13px;
  color: #4caf6f;
}

.plan-grid-v63 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin: 18px 0;
}
@media (max-width: 1100px) {
  .plan-grid-v63 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .plan-grid-v63 { grid-template-columns: 1fr; }
}
.plan-grid-v63 .plan-card {
  position: relative;
  background: var(--white);
  border: 1.5px solid rgba(42,39,39,0.08);
  border-radius: 10px;
  padding: 18px 16px 14px;
  display: flex;
  flex-direction: column;
  transition: all 0.2s;
}
.plan-grid-v63 .plan-card.plan-highlight {
  border-color: var(--gold);
  box-shadow: 0 4px 18px rgba(201,168,76,0.18);
  transform: translateY(-4px);
}
.plan-grid-v63 .plan-card.plan-current {
  background: rgba(94,217,158,0.05);
  border-color: rgba(94,217,158,0.40);
}
.plan-bestseller {
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--gold);
  color: #fff;
  padding: 4px 12px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
}
.plan-card-head strong {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  color: var(--ch);
  display: block;
  margin-bottom: 2px;
}
.plan-tagline {
  font-size: 11px;
  color: var(--ch2);
  margin-bottom: 8px;
}
.plan-price-row {
  display: flex;
  flex-direction: column;
  margin-bottom: 12px;
}
.plan-price {
  font-size: 22px;
  font-weight: 700;
  color: var(--ch);
  font-variant-numeric: tabular-nums;
}
.plan-price-sub {
  font-size: 11px;
  color: var(--ch2);
}
.plan-features {
  list-style: none;
  padding: 0;
  margin: 0 0 14px;
  flex: 1;
}
.plan-features li {
  font-size: 12.5px;
  padding: 4px 0;
  color: var(--ch);
  border-bottom: 0.5px solid rgba(42,39,39,0.05);
}
.plan-features li:last-child { border-bottom: none; }

/* KI-Credit-Pakete */
.plan-credits-section {
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid rgba(42,39,39,0.10);
}
.plan-credits-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  margin: 0 0 4px;
  color: var(--ch);
}
.plan-credits-desc {
  font-size: 13px;
  color: var(--ch2);
  margin: 0 0 16px;
}
.plan-credits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
@media (max-width: 600px) {
  .plan-credits-grid { grid-template-columns: 1fr; }
}
.plan-credit-card {
  position: relative;
  background: var(--white);
  border: 1.5px solid rgba(42,39,39,0.08);
  border-radius: 10px;
  padding: 18px 14px;
  text-align: center;
}
.plan-credit-card.plan-credit-highlight {
  border-color: var(--gold);
  box-shadow: 0 3px 12px rgba(201,168,76,0.18);
}
.plan-credit-best {
  position: absolute;
  top: -8px;
  right: 10px;
  background: var(--gold);
  color: #fff;
  padding: 2px 8px;
  border-radius: 8px;
  font-size: 10px;
  font-weight: 700;
}
.plan-credit-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 36px;
  font-weight: 700;
  color: var(--gold);
  line-height: 1;
}
.plan-credit-label {
  font-size: 11px;
  color: var(--ch2);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.plan-credit-price {
  font-size: 18px;
  font-weight: 700;
  color: var(--ch);
}
.plan-credit-sub {
  font-size: 11px;
  color: var(--ch2);
  margin-bottom: 10px;
}

/* ═══════════════════════════════════════════════════════════════
   V63.1 — Banner-Mode (Sticky-Top wenn nur Hinweis-Banner statt Score)
   ═══════════════════════════════════════════════════════════════ */

/* Banner-Mode: Reihe 2 hat nur den Hinweis-Banner (~60px statt 86px) */
body.hdr-banner-only nav.tabs,
body.hdr-banner-only .tabs {
  top: 116px !important;     /* 48px Reihe1 + ~68px Banner-Reihe2 */
}
body.hdr-banner-only .tabs-workflow-bar {
  top: 162px !important;     /* + ~46px Tabs */
}

/* Banner kompakter machen */
body.hdr-banner-only .hdr-v61-row2 {
  padding: 8px 22px !important;
  display: block !important;
  grid-template-columns: none !important;
}
.hdr-incomplete-banner {
  padding: 10px 14px !important;
  margin: 0 !important;
}

@media (max-width: 1100px) {
  body.hdr-banner-only nav.tabs,
  body.hdr-banner-only .tabs { top: 110px !important; }
  body.hdr-banner-only .tabs-workflow-bar { top: var(--wf-top, 102px) !important; }
}

/* ═══════════════════════════════════════════════════════════════
   V63.1 — DS2 KPI-Liste (alle 24 KPIs mit Status)
   ═══════════════════════════════════════════════════════════════ */

.ds2-kpi-list-details {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 16px 24px 20px;
  margin-top: 8px;
}
.ds2-kpi-list-summary {
  cursor: pointer;
  color: var(--gold);
  font-size: 13px;
  font-weight: 600;
  padding: 8px 12px;
  background: rgba(201,168,76,0.06);
  border-radius: 6px;
  display: inline-block;
  user-select: none;
  list-style: none;
}
.ds2-kpi-list-summary::marker { content: ''; }
.ds2-kpi-list-summary::-webkit-details-marker { display: none; }
.ds2-kpi-list-summary:hover {
  background: rgba(201,168,76,0.12);
}
.ds2-kpi-list-summary::before {
  content: '▸ ';
  display: inline-block;
  transition: transform 0.2s;
  margin-right: 4px;
}
.ds2-kpi-list-details[open] .ds2-kpi-list-summary::before {
  transform: rotate(90deg);
}
.ds2-kpi-list-content {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
@media (max-width: 800px) {
  .ds2-kpi-list-content { grid-template-columns: 1fr; }
}
.ds2-kpi-list-cat {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 8px;
  padding: 12px;
}
.ds2-kpi-list-cat-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.ds2-kpi-list-cat-icon { font-size: 16px; }
.ds2-kpi-list-cat-name {
  font-weight: 600;
  color: #fff;
  font-size: 13px;
  flex: 1;
}
.ds2-kpi-list-cat-stats {
  font-size: 11px;
  color: var(--gold);
  font-variant-numeric: tabular-nums;
}
.ds2-kpi-list-rows {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ds2-kpi-li {
  display: grid;
  grid-template-columns: 18px 1fr auto;
  gap: 8px;
  align-items: center;
  font-size: 12px;
  padding: 4px 6px;
  border-radius: 4px;
}
.ds2-kpi-li-check {
  font-weight: 700;
  text-align: center;
}
.ds2-kpi-li-done {
  color: rgba(255,255,255,0.85);
}
.ds2-kpi-li-done .ds2-kpi-li-check {
  color: #6FCB91;
}
.ds2-kpi-li-todo {
  color: rgba(255,255,255,0.45);
}
.ds2-kpi-li-todo .ds2-kpi-li-check {
  color: rgba(255,255,255,0.30);
}
.ds2-kpi-li-name { font-weight: 500; }
.ds2-kpi-li-val {
  font-size: 11px;
  font-variant-numeric: tabular-nums;
  opacity: 0.85;
}
.ds2-kpi-li-todo .ds2-kpi-li-val {
  color: rgba(240,128,128,0.55);
  font-style: italic;
}

/* ═══════════════════════════════════════════════════════════════
   V63.2 — Threshold-Card (Tab Kennzahlen DS2) — heller Background
   ═══════════════════════════════════════════════════════════════ */

.ds2-threshold-card {
  background: linear-gradient(135deg, rgba(201,168,76,0.06), rgba(201,168,76,0.02));
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 12px;
  padding: 32px 28px;
  text-align: center;
  color: var(--ch);
}
.ds2-threshold-card .ds2-threshold-icon {
  font-size: 36px;
  margin-bottom: 12px;
}
.ds2-threshold-card .ds2-threshold-headline {
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px;
  font-weight: 600;
  color: var(--ch);
  margin-bottom: 8px;
}
.ds2-threshold-card .ds2-threshold-sub {
  font-size: 13.5px;
  color: var(--ch);
  margin: 0 auto 18px;
  max-width: 480px;
  line-height: 1.5;
}
.ds2-threshold-card .ds2-threshold-sub strong {
  color: var(--gold);
  font-weight: 700;
}
.ds2-threshold-card .ds2-threshold-bar {
  margin: 0 auto 18px;
  max-width: 400px;
  height: 6px;
  background: rgba(42,39,39,0.10);
  border-radius: 3px;
  overflow: hidden;
}
.ds2-threshold-card .ds2-threshold-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold), #d8b85e);
  border-radius: 3px;
  transition: width 0.4s ease;
}
.ds2-threshold-card .ds2-threshold-actions {
  margin-bottom: 12px;
}
.ds2-threshold-card .ds2-threshold-actions .btn {
  font-size: 12.5px;
  padding: 8px 18px;
}
.ds2-threshold-card .ds2-threshold-hint {
  font-size: 12px;
  color: var(--ch2, #5a5350);
  font-style: italic;
  max-width: 500px;
  margin: 0 auto;
  line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════════
   V63.2 — Scroll-Bug FINAL FIX: Header + Tabs + Workflow als Block
   ═══════════════════════════════════════════════════════════════ */

/* Trick: alle drei Sticky-Elemente haben durchgehenden Background
   damit beim Scrollen kein Spalt sichtbar wird */
header.hdr,
nav.tabs,
.tabs,
.tabs-workflow-bar {
  margin: 0 !important;
}

/* Tab-Bar bekommt expliziten oberen Border-Top damit sie sauber abschließt */
nav.tabs,
.tabs {
  border-top: 0 !important;
}

/* Spalt-Schutz: header+tabs+workflow per "after"-Bar verbinden */
header.hdr::after {
  content: '';
  display: block;
  height: 0;
  border-bottom: 0;
}

/* WICHTIG: Body-Hintergrund im sticky-Bereich — wenn die Sticky-Tops nicht exakt
   stimmen, deckt dieser Pseudo-Block die Lücke ab */
body::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 220px;
  background: linear-gradient(180deg,
    #2A2727 0px,
    #2A2727 134px,
    var(--surface, #F8F6F1) 134px,
    var(--surface, #F8F6F1) 220px);
  z-index: -1;
  pointer-events: none;
}
body.hdr-no-score::before {
  height: 92px;
  background: linear-gradient(180deg,
    #2A2727 0px,
    #2A2727 48px,
    var(--surface, #F8F6F1) 48px,
    var(--surface, #F8F6F1) 92px);
}
body.hdr-banner-only::before {
  height: 162px;
  background: linear-gradient(180deg,
    #2A2727 0px,
    #2A2727 116px,
    var(--surface, #F8F6F1) 116px,
    var(--surface, #F8F6F1) 162px);
}

/* Mobile-Anpassungen */
@media (max-width: 1100px) {
  body::before {
    height: 184px;
    background: linear-gradient(180deg,
      #2A2727 0px,
      #2A2727 130px,
      var(--surface, #F8F6F1) 130px,
      var(--surface, #F8F6F1) 184px);
  }
}
@media (max-width: 720px) {
  body::before {
    height: 160px;
    background: linear-gradient(180deg,
      #2A2727 0px,
      #2A2727 110px,
      var(--surface, #F8F6F1) 110px,
      var(--surface, #F8F6F1) 160px);
  }
}

/* ═══════════════════════════════════════════════════════════════
   V63.2 — Settings-Modal breiter + Plan-Pane professioneller
   ═══════════════════════════════════════════════════════════════ */

/* Plan-Pane braucht mehr Breite — wenn Plan-Tab aktiv, Modal breiter */
.settings-modal:has(#st-pane-plan[style*="display: block"]),
.settings-modal:has(.st-tab[data-tab="plan"].active) {
  max-width: 1180px !important;
}
/* Alternative für Browser ohne :has() — Klasse setzen */
.settings-modal.is-plan-tab {
  max-width: 1180px !important;
}

/* Plan-Karten — professionelleres Design */
.plan-grid-v63 .plan-card {
  background: var(--white);
  border: 1.5px solid rgba(42,39,39,0.10);
  border-radius: 14px;
  padding: 24px 18px 18px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.03);
}
.plan-grid-v63 .plan-card.plan-highlight {
  border-color: var(--gold);
  box-shadow: 0 8px 24px rgba(201,168,76,0.18);
  transform: translateY(-6px);
}
.plan-grid-v63 .plan-card.plan-current {
  background: linear-gradient(135deg, rgba(94,217,158,0.04), rgba(94,217,158,0.01));
  border-color: rgba(94,217,158,0.50);
}

/* Plan-Header sauberer Layout */
.plan-card-head {
  margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(42,39,39,0.08);
}
.plan-card-head strong {
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px;
  font-weight: 600;
  color: var(--ch);
  display: block;
  margin-bottom: 4px;
}
.plan-tagline {
  font-size: 12px;
  color: var(--ch2, #5a5350);
  margin-bottom: 14px;
  min-height: 14px;
}
.plan-price-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
}
.plan-price {
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px !important;
  font-weight: 700;
  color: var(--ch);
}
.plan-price-sub {
  font-size: 11px;
  color: var(--ch2);
}

/* Feature-Liste mit professionellen SVG-Icons statt Emojis */
.plan-features {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
  flex: 1;
}
.plan-features li {
  font-size: 13px;
  padding: 6px 0 6px 24px;
  color: var(--ch);
  border-bottom: 0.5px solid rgba(42,39,39,0.05);
  position: relative;
  line-height: 1.4;
}
.plan-features li:last-child { border-bottom: none; }
.plan-features li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C9A84C' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-size: 14px;
  background-repeat: no-repeat;
  background-position: center;
}
.plan-features li em {
  font-style: italic;
  color: var(--ch2);
  font-size: 12px;
}

.plan-bestseller {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(135deg, var(--gold), #d8b85e);
  color: #fff;
  padding: 5px 14px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: 0 3px 8px rgba(201,168,76,0.30);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.plan-bestseller::before {
  content: '';
  display: inline-block;
  width: 12px;
  height: 12px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polygon points='12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2'/></svg>");
  background-size: contain;
  background-repeat: no-repeat;
}

.plan-grid-v63 .btn {
  width: 100%;
  font-size: 13px;
  padding: 10px 16px;
  font-weight: 600;
}

/* Credit-Pakete sauberer */
.plan-credits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 14px;
}
.plan-credit-card {
  position: relative;
  background: var(--white);
  border: 1.5px solid rgba(42,39,39,0.10);
  border-radius: 12px;
  padding: 22px 16px 18px;
  text-align: center;
  box-shadow: 0 2px 6px rgba(0,0,0,0.03);
}
.plan-credit-card.plan-credit-highlight {
  border-color: var(--gold);
  box-shadow: 0 6px 18px rgba(201,168,76,0.18);
}
.plan-credit-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 44px;
  font-weight: 700;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 4px;
}
.plan-credit-label {
  font-size: 10.5px;
  color: var(--ch2);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.plan-credit-price {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--ch);
  margin-bottom: 2px;
}
.plan-credit-sub {
  font-size: 11px;
  color: var(--ch2);
  margin-bottom: 14px;
}

/* Toggle Monatlich/Jährlich professioneller */
.plan-billing-toggle {
  display: inline-flex;
  background: rgba(42,39,39,0.06);
  padding: 5px;
  border-radius: 10px;
  margin: 14px 0 4px;
  gap: 4px;
}
.plan-toggle-btn {
  padding: 9px 18px;
  font-size: 13px;
  font-weight: 600;
}
.plan-toggle-btn.active {
  box-shadow: 0 2px 8px rgba(201,168,76,0.30);
}

@media (max-width: 1200px) {
  .plan-grid-v63 { grid-template-columns: repeat(2, 1fr); }
  .settings-modal.is-plan-tab { max-width: 880px !important; }
}
@media (max-width: 600px) {
  .plan-grid-v63 { grid-template-columns: 1fr; }
  .plan-credits-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   V63.2 — Feature-Gating Visuelle Marker
   ═══════════════════════════════════════════════════════════════ */

.feature-locked {
  opacity: 0.55;
  position: relative;
  pointer-events: none;
}
.feature-locked::after {
  content: '🔒';
  position: absolute;
  top: 4px;
  right: 6px;
  font-size: 12px;
}

/* Logo-Section bei nicht-Berechtigung mit Upgrade-Hint */
.feature-locked-logo {
  position: relative;
}
.feature-locked-logo::before {
  content: 'Eigenes Logo nur in Investor / Pro-Plan verfügbar';
  display: block;
  background: rgba(201,168,76,0.10);
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 6px;
  padding: 8px 12px;
  margin-bottom: 12px;
  font-size: 12px;
  color: var(--gold);
  font-weight: 600;
}

/* Plan-spezifische Body-Klasse — kann für CSS-Gating genutzt werden */
body.plan-free .ds2-card,
body.plan-starter .ds2-card { display: none !important; }
body.plan-free .ds2-readonly-card,
body.plan-starter .ds2-readonly-card { display: none !important; }

/* ═══════════════════════════════════════════════════════════════
   V63.3 — FINAL Tab-Sticky-Fix + Background-Solid
   ═══════════════════════════════════════════════════════════════ */

/* Body::before war BUG — fixed-position kollidiert mit main-col als Scroll-Container.
   Stattdessen: durchgehende dunkle Border + voller Background auf alle Sticky-Elemente */
body::before {
  display: none !important;     /* V63.3: alter body::before-Trick deaktiviert */
}

/* main-col-interner Sticky: alle drei Sticky-Bereiche bekommen vollen Background */
.main-col {
  background: var(--surface, #F8F6F1) !important;
  position: relative;
}

/* Header full-cover */
.main-col > header.hdr {
  position: sticky !important;
  top: 0 !important;
  left: 0;
  right: 0;
  width: 100% !important;
  z-index: 300 !important;
  background: #2A2727 !important;
}

/* Tabs sticky direkt unter Header — durch dunkle Border-Top kein Spalt */
.main-col > nav.tabs,
.main-col > .tabs {
  position: sticky !important;
  z-index: 250 !important;
  background: var(--surface, #F8F6F1) !important;
  border-top: 4px solid #2A2727 !important;     /* V63.3: dunkle Linie verhindert Spalt */
  margin-top: -4px;                              /* gleicht den Border aus */
}

/* Workflow-Bar sticky direkt unter Tabs — gleiche Technik */
.main-col > .tabs-workflow-bar {
  position: sticky !important;
  z-index: 240 !important;
  background: var(--surface, #F8F6F1) !important;
  border-bottom: 1px solid rgba(42,39,39,0.08) !important;
}

/* Damit der Tabs-Sticky in main-col funktioniert: KEIN parent overflow:clip,
   nur main-col selbst hat overflow-y:auto (das ist der Scroll-Container) */
.main-col > .body {
  position: relative;
}

/* ═══════════════════════════════════════════════════════════════
   V63.3 — Investor-Ribbon auf Score-Karte (Aufgabe 7)
   ═══════════════════════════════════════════════════════════════ */
.hdr-score-card {
  position: relative;
}
.hdr-investor-ribbon {
  position: absolute;
  top: -1px;
  left: -1px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px 3px 6px;
  background: linear-gradient(135deg, var(--gold), #d8b85e);
  color: #1A1818;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  border-top-left-radius: 8px;
  border-bottom-right-radius: 8px;
  box-shadow: 0 2px 6px rgba(201,168,76,0.40);
  z-index: 2;
}
.hdr-investor-ribbon svg {
  flex-shrink: 0;
}
.hdr-score-card-investor {
  padding-top: 18px !important;
}
/* V63.97: Demo-Ribbon im Free-Plan — andere Farbe als Investor-Ribbon */
.hdr-investor-ribbon.hdr-demo-ribbon {
  background: linear-gradient(135deg, #6E6661, #8C7430);
  color: #F5F2EA;
  box-shadow: 0 2px 6px rgba(110,102,97,0.35);
}
.hdr-score-card-demo {
  padding-top: 18px !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.3 — Score-Hint-Boxen (Aufgaben 2 + 3)
   ═══════════════════════════════════════════════════════════════ */
.ds-score-hint {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 14px;
  margin: 0 0 12px;
  border-radius: 8px;
  font-size: 12.5px;
  line-height: 1.45;
}
.ds-score-hint-icon {
  flex-shrink: 0;
  font-size: 16px;
  margin-top: 1px;
}
.ds-score-hint-text {
  flex: 1;
  color: var(--ch);
}
.ds-score-hint-text strong {
  color: var(--ch);
  font-weight: 700;
}
.ds-score-hint-classic {
  background: rgba(94,217,158,0.06);
  border: 1px solid rgba(94,217,158,0.25);
}
.ds-score-hint-classic .ds-score-hint-icon { color: #4caf6f; }
.ds-score-hint-investor {
  background: rgba(201,168,76,0.06);
  border: 1px solid rgba(201,168,76,0.25);
}
.ds-score-hint-investor .ds-score-hint-icon { color: var(--gold); }

/* ═══════════════════════════════════════════════════════════════
   V63.3 — Empfehlung im Tab Kennzahlen (Aufgabe 6)
   ═══════════════════════════════════════════════════════════════ */
.kennzahlen-qc-rec-card {
  background: linear-gradient(135deg, #2A2727 0%, #3a3433 100%);
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 12px;
  padding: 18px 22px;
  margin: 12px 0;
  color: rgba(255,255,255,0.92);
}
.kennzahlen-qc-rec-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(201,168,76,0.25);
}
.kennzahlen-qc-rec-icon {
  font-size: 22px;
  color: var(--gold);
}
.kennzahlen-qc-rec-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.02em;
}
.kennzahlen-qc-rec-body .qc-rec-verdict {
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin-bottom: 8px;
  padding: 4px 14px;
  border-radius: 6px;
  display: inline-block;
}
.kennzahlen-qc-rec-body .qc-rec-text {
  font-size: 13.5px;
  line-height: 1.6;
  color: rgba(255,255,255,0.85);
}
.kennzahlen-qc-rec-body .qc-rec-text strong {
  color: var(--gold);
  font-weight: 700;
}

/* ═══════════════════════════════════════════════════════════════
   V63.4 — Tab-Sticky-Bug FINAL FIX (dynamisch via CSS-Variable)
   ═══════════════════════════════════════════════════════════════ */

/* CSS-Variable für Header-Höhe — wird per JS gesetzt */
:root {
  --hdr-h: 134px;          /* Default: Reihe1 (48) + Reihe2 (86) */
  --hdr-h-tabs: 44px;      /* Tab-Bar-Höhe */
}

/* Alle harten Top-Werte überschreiben — eine zentrale Wahrheit */
.main-col > nav.tabs,
.main-col > .tabs,
nav.tabs,
.tabs {
  position: sticky !important;
  top: var(--hdr-h) !important;
  z-index: 250 !important;
  background: var(--surface, #F8F6F1) !important;
  border-top: 4px solid #2A2727 !important;
  margin-top: -4px !important;
}

.main-col > .tabs-workflow-bar,
.tabs-workflow-bar {
  position: sticky !important;
  top: calc(var(--hdr-h) + var(--hdr-h-tabs)) !important;
  z-index: 240 !important;
  background: var(--surface, #F8F6F1) !important;
  border-bottom: 1px solid rgba(42,39,39,0.08) !important;
}

/* Header bleibt sticky bei top:0 mit dunklem Background */
.main-col > header.hdr,
header.hdr {
  position: sticky !important;
  top: 0 !important;
  z-index: 300 !important;
  background: #2A2727 !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.4 — Header-Toggle (Investor Deal Score minimierbar)
   ═══════════════════════════════════════════════════════════════ */
.hdr-toggle-btn {
  position: absolute;
  bottom: 6px;
  right: 14px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 14px;
  color: rgba(255,255,255,0.70);
  cursor: pointer;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  transition: all 0.15s ease;
  z-index: 305;
}
.hdr-toggle-btn:hover {
  background: rgba(201,168,76,0.12);
  border-color: rgba(201,168,76,0.40);
  color: var(--gold);
}
.hdr-toggle-ico {
  transition: transform 0.25s ease;
}

/* Collapsed-Modus: Reihe 2 ist versteckt */
body.hdr-collapsed .hdr-v61-row2 {
  display: none !important;
}
body.hdr-collapsed header.hdr {
  /* Header bleibt minimal sichtbar (nur Reihe 1) */
}
body.hdr-collapsed .hdr-toggle-btn {
  bottom: -22px;             /* Toggle-Button rutscht auf Underside */
  right: 14px;
  background: rgba(42,39,39,0.92);
  color: var(--gold);
  border-color: rgba(201,168,76,0.40);
}

/* ═══════════════════════════════════════════════════════════════
   V63.9 — Investor-Ribbon: Stempel oben links auf der Border
   (User-Wunsch: zurück auf Karten-Umrahmung, nicht mittig drüber)
   ═══════════════════════════════════════════════════════════════ */
.sbc-investor-ribbon {
  position: absolute;
  top: -1px;                            /* überlagert minimal die obere Border */
  left: 8px;                            /* oben links statt mittig */
  transform: none;                      /* kein translate mehr */
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 3px 8px 3px 6px;
  background: linear-gradient(135deg, var(--gold), #d8b85e);
  color: #1A1818;
  font-size: 8.5px;
  font-weight: 800;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  border-radius: 0 0 8px 0;             /* nur unten-rechts gerundet — sieht aus wie Etikett */
  box-shadow: 0 1px 4px rgba(0,0,0,0.25);
  z-index: 5;
  pointer-events: none;
  white-space: nowrap;
}
.sbc-investor-ribbon svg {
  flex-shrink: 0;
  width: 8px;
  height: 8px;
}
/* Top-Padding der Karte nicht mehr extra nötig — Ribbon sitzt direkt auf Border */
.sb-card.has-investor-ribbon .sbc-top {
  padding-top: 12px !important;        /* normales Padding wie ohne Ribbon */
}
.sb-card {
  position: relative;     /* damit Ribbon absolute positioniert werden kann */
  border-radius: 10px;
  border: 1px solid rgba(201,168,76,0.20);    /* V63.6: leichter Goldrand default */
  transition: all 0.2s ease;
  /* overflow: visible !important; -- V63.7: weg, sonst Sidebar-overflow überspringt */
}
.sb-card:hover {
  border-color: rgba(201,168,76,0.50);
  box-shadow: 0 4px 14px rgba(201,168,76,0.18);
}
.sb-card.active {
  border: 2px solid var(--gold) !important;
  box-shadow: 0 0 0 3px rgba(201,168,76,0.18), 0 6px 18px rgba(201,168,76,0.30) !important;
}
.sb-card .sbc-top {
  position: relative;
}

/* V63.6: Sidebar-Liste mit zusätzlichem Top-Padding — V63.7: nicht mehr nötig da Ribbon innerhalb */
#sb-list {
  padding-top: 8px;
}
#sb-list .sb-card:first-child.has-investor-ribbon {
  margin-top: 0;        /* V63.7: kein extra Margin mehr nötig */
}

/* ═══════════════════════════════════════════════════════════════
   V63.4 — Settings → Deal Score Pane (überarbeitet)
   ═══════════════════════════════════════════════════════════════ */
.ds-pane-section {
  background: var(--white);
  border: 1px solid rgba(42,39,39,0.08);
  border-radius: 12px;
  padding: 22px 22px 18px;
  margin-bottom: 18px;
}
.ds-pane-section-investor {
  background: linear-gradient(135deg, rgba(201,168,76,0.04), rgba(201,168,76,0.01));
  border-color: rgba(201,168,76,0.30);
}
.ds-pane-header {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 18px;
}
.ds-pane-icon-wrap {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ds-pane-icon-classic {
  background: rgba(94,217,158,0.10);
  color: #4caf6f;
}
.ds-pane-icon-investor {
  background: linear-gradient(135deg, var(--gold), #d8b85e);
  color: #fff;
  box-shadow: 0 2px 6px rgba(201,168,76,0.30);
}
.ds-pane-icon { font-size: 20px; }
.ds-pane-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 600;
  color: var(--ch);
  margin: 0 0 2px;
}
.ds-pane-sub {
  font-size: 12px;
  color: var(--ch2, #5a5350);
  margin: 0;
  line-height: 1.4;
}
.ds-pane-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 14px;
}

/* ═══════════════════════════════════════════════════════════════
   V63.5 — FINAL Override: alle harten Top-Werte killen
   Eine einzige zentrale Wahrheit: --hdr-h
   ═══════════════════════════════════════════════════════════════ */

/* Alle Tab-Bar-Definitionen MÜSSEN hier landen - allerletzte Regel gewinnt */
nav.tabs,
.tabs,
.main-col > nav.tabs,
.main-col > .tabs {
  top: var(--hdr-h, 134px) !important;
}

.tabs-workflow-bar,
.main-col > .tabs-workflow-bar {
  top: calc(var(--hdr-h, 134px) + var(--hdr-h-tabs, 44px)) !important;
}

/* Wenn Header komplett leer (keine Reihe 2) — Reihe 2 mit display:none */
.hdr-v61-row2:empty {
  display: none !important;
  padding: 0 !important;
  margin: 0 !important;
  height: 0 !important;
}

/* Body-Klasse hdr-no-score: Header ist schmal, nur Reihe 1 sichtbar */
body.hdr-no-score .hdr-v61-row2 {
  display: none !important;
  height: 0 !important;
  padding: 0 !important;
}

/* Body-Klasse hdr-collapsed: User hat manuell minimiert */
body.hdr-collapsed .hdr-v61-row2 {
  display: none !important;
  height: 0 !important;
  padding: 0 !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.5 — In-App-Wasserzeichen für Free-Plan (sichtbar über Workspace)
   ═══════════════════════════════════════════════════════════════ */
body.plan-free .body::before {
  content: 'DealPilot Free';
  position: fixed;
  top: 50%;
  left: calc(50% + 100px);     /* etwas rechts wegen Sidebar */
  transform: translate(-50%, -50%) rotate(-30deg);
  font-family: 'Cormorant Garamond', serif;
  font-size: 12vw;
  font-weight: 700;
  color: rgba(42, 39, 39, 0.06);
  z-index: 1;
  pointer-events: none;
  user-select: none;
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
/* V63.6: Mini-Tag entfernt — er führte zu Layout-Issues durch ::after-Extension.
   Wasserzeichen über Workspace ist deutlich genug. */

/* Feature-Gate-Karte für gesperrte Bereiche */
.feature-gate-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  background: linear-gradient(135deg, rgba(201,168,76,0.08), rgba(201,168,76,0.02));
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 10px;
  margin: 12px 0;
}
.feature-gate-card .feature-gate-icon {
  font-size: 24px;
  color: var(--gold);
  flex-shrink: 0;
}
.feature-gate-card .feature-gate-text {
  flex: 1;
  font-size: 13px;
  line-height: 1.5;
  color: var(--ch);
}
.feature-gate-card .feature-gate-text strong {
  color: var(--ch);
  display: inline-block;
  margin-bottom: 2px;
}

/* ═══════════════════════════════════════════════════════════════
   V63.6 — Sticky-Block Lückenlosigkeit garantiert
   ═══════════════════════════════════════════════════════════════ */

/* Tabs UND Workflow-Bar bekommen exakte Bündigkeit:
   Workflow-Bar überlappt visuell mit den Tabs durch negativen margin-top
   damit garantiert keine Lücke entsteht (selbst bei Sub-Pixel-Rounding) */
.tabs-workflow-bar,
.main-col > .tabs-workflow-bar {
  margin-top: -1px !important;
  border-top: 1px solid rgba(42,39,39,0.10) !important;
}

/* Im Free-Plan / Starter-Plan: Tab-Bar und Workflow-Bar haben gemeinsamen Background */
body.plan-free nav.tabs,
body.plan-free .tabs,
body.plan-starter nav.tabs,
body.plan-starter .tabs {
  background: var(--surface, #F8F6F1) !important;
  border-bottom: none !important;          /* Workflow-Bar hat ihren eigenen border-top */
}

/* ═══════════════════════════════════════════════════════════════
   V63.6 — KI-Lage erweitert: 4 Aspects + Quellen + Übernehmen
   ═══════════════════════════════════════════════════════════════ */
.ki-lage-aspects-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 14px;
}
@media (max-width: 720px) {
  .ki-lage-aspects-grid { grid-template-columns: 1fr; }
}
.ki-lage-aspect-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  padding: 14px;
}
.ki-lage-aspect-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 6px;
}
.ki-lage-aspect-title {
  font-size: 12.5px;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
}
.ki-lage-aspect-score {
  font-size: 13px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.ki-lage-aspect-bar {
  height: 4px;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: 10px;
}
.ki-lage-aspect-bar-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.4s ease;
}
.ki-lage-aspect-text {
  font-size: 12px;
  line-height: 1.5;
  color: rgba(255,255,255,0.65);
}

/* Deal-Verdict Box */
.ki-lage-deal-verdict {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-top: 16px;
  padding: 16px 18px;
  border: 2px solid currentColor;
  border-radius: 10px;
  background: rgba(255,255,255,0.03);
}
.ki-lage-deal-icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border: 2px solid currentColor;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 700;
}
.ki-lage-deal-headline {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 4px;
}
.ki-lage-deal-text {
  font-size: 13px;
  line-height: 1.55;
  color: rgba(255,255,255,0.80);
}

/* Quellen-Liste */
.ki-lage-sources {
  margin-top: 14px;
  padding: 12px 14px;
  background: rgba(201,168,76,0.05);
  border: 1px solid rgba(201,168,76,0.20);
  border-radius: 8px;
}
.ki-lage-sources-head {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: 0.05em;
  margin-bottom: 8px;
  text-transform: uppercase;
}
.ki-lage-sources-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4px 14px;
}
@media (max-width: 720px) {
  .ki-lage-sources-list { grid-template-columns: 1fr; }
}
.ki-lage-sources-list a {
  font-size: 12px;
  color: rgba(255,255,255,0.75);
  text-decoration: none;
  border-bottom: 0.5px dashed rgba(255,255,255,0.30);
  padding: 2px 0;
  display: inline-block;
}
.ki-lage-sources-list a:hover {
  color: var(--gold);
  border-color: var(--gold);
}

/* Apply-Button */
.ki-lage-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 18px;
  flex-wrap: wrap;
}
.ki-lage-apply-btn {
  font-size: 13px;
  padding: 10px 18px;
}
.ki-lage-apply-hint {
  font-size: 11.5px;
  color: rgba(255,255,255,0.55);
  font-style: italic;
}

/* ═══════════════════════════════════════════════════════════════
   V63.7 — Sidebar-Karten luftiger
   ═══════════════════════════════════════════════════════════════ */

/* Karten-Innenraum mit etwas mehr Padding */
.sb-card .sbc-top {
  padding: 10px 12px 4px;              /* V67: bottom 4px statt 10px → kein Spalt zur Mini-Card-Reihe */
}
.sb-card .sbc-top-line1 {
  margin-bottom: 4px;                  /* Abstand zur 2. Zeile (City) */
}

/* Sidebar-Karte: insgesamt etwas kompaktere Höhe + sauber abgerundet */
.sb-card {
  margin-bottom: 8px;                  /* V67: weniger Abstand zwischen Karten (war 10px) */
  border-radius: 12px !important;
}
.sb-card .sbc-mini-grid {
  padding: 4px 10px 8px;               /* V67: top 4px (war 0), bottom 8px (war 10px) */
  gap: 6px;
}
.sb-card .sbcm {
  padding: 6px 9px;                    /* V67: kompakter (war 8px 10px) */
}
.sb-card .sbcm-val {
  font-size: 14px !important;          /* bisschen kleiner damit alles schlanker wirkt */
}
.sb-card .sbc-street {
  font-size: 13px;                     /* leicht kleiner damit "Höderlinstr 1, Bad Oeynhausen" passt */
}
.sb-card .sbc-line2 {
  font-size: 11.5px;
  margin-top: 1px;
}
.sb-card .sbc-kp {
  font-size: 18px !important;          /* etwas kompakter */
  font-weight: 700;
}

/* ═══════════════════════════════════════════════════════════════
   V63.7 — Sidebar Mini-Card Toggle (CF Jahr/Monat, BMR/NMR)
   ═══════════════════════════════════════════════════════════════ */
.sbcm-toggleable {
  cursor: pointer;
  transition: background 0.15s ease, transform 0.10s ease;
}
.sbcm-toggleable:hover {
  background: rgba(201,168,76,0.10);
  transform: translateY(-1px);
}
.sbcm-toggleable:active {
  transform: translateY(0);
}
.sbcm-toggle-ico {
  font-size: 11px;
  color: rgba(255,255,255,0.45);
  margin-left: auto;
  font-weight: 700;
}
.sbcm-toggleable:hover .sbcm-toggle-ico {
  color: var(--gold);
}
.sbcm-toggleable .sbcm-head {
  display: flex !important;
  align-items: center;
  gap: 6px;
}

/* ═══════════════════════════════════════════════════════════════
   V63.7 — Legacy-Plan-Klassen NICHT mehr unterstützen
   Falls noch alter plan-business im localStorage steckt → unsichtbar
   ═══════════════════════════════════════════════════════════════ */
.sb-user-plan-pill.plan-business,
.sb-user-plan-pill.plan-enterprise {
  display: none !important;        /* alte Pills nicht mehr anzeigen */
}

/* ═══════════════════════════════════════════════════════════════
   V63.7 — TAB-BAR + WORKFLOW-BAR LÜCKENLOSIGKEIT (FINAL CRITICAL FIX)
   Eine letzte zentrale Wahrheit, alle Konflikte überschrieben.
   ═══════════════════════════════════════════════════════════════ */

/* Schritt 1: Tab-Bar muss IMMER direkt unter dem Header kleben.
   --hdr-h ist die per JS gemessene Höhe. Falls JS noch nicht gelaufen → Fallback 134px.  */
nav.tabs,
.tabs,
.main-col > nav.tabs,
.main-col > .tabs {
  position: sticky !important;
  top: var(--hdr-h, 134px) !important;
  z-index: 250 !important;
  background: var(--surface, #F8F6F1) !important;
  border-bottom: none !important;     /* keine eigene Bottom-Border, Workflow-Bar hat top-Border */
  margin-bottom: 0 !important;
}

/* Schritt 2: Workflow-Bar bündig direkt unter den Tabs.
   --hdr-h-tabs ist die per JS gemessene Tab-Höhe (~44px). */
.tabs-workflow-bar,
.main-col > .tabs-workflow-bar {
  position: sticky !important;
  top: calc(var(--hdr-h, 134px) + var(--hdr-h-tabs, 44px)) !important;
  z-index: 240 !important;
  background: var(--surface, #F8F6F1) !important;
  margin-top: 0 !important;
  border-top: 1px solid rgba(42,39,39,0.10) !important;
  border-bottom: 1px solid rgba(42,39,39,0.08) !important;
}

/* Schritt 3: Doppel-Schutz — der Bereich zwischen Tabs und Workflow-Bar bekommt
   ein Background damit auch bei Sub-Pixel-Rounding NICHTS durchscheint */
.main-col > nav.tabs::after,
.main-col > .tabs::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--surface, #F8F6F1);
  z-index: 1;
}

/* Schritt 4: Im Free-Mode (body.hdr-no-score) — Header ist nur Reihe 1 (~48px).
   Beide Bars müssen direkt drunter andocken. */
body.hdr-no-score nav.tabs,
body.hdr-no-score .tabs {
  top: var(--hdr-h, 48px) !important;
}
body.hdr-no-score .tabs-workflow-bar {
  top: calc(var(--hdr-h, 48px) + var(--hdr-h-tabs, 44px)) !important;
}

/* Schritt 5: Im collapsed-Mode (User hat Score ausgeblendet) — wie Free */
body.hdr-collapsed nav.tabs,
body.hdr-collapsed .tabs {
  top: var(--hdr-h, 48px) !important;
}
body.hdr-collapsed .tabs-workflow-bar {
  top: calc(var(--hdr-h, 48px) + var(--hdr-h-tabs, 44px)) !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.7 — Kompakter Score-Toggle (statt großem Button mit Label)
   ═══════════════════════════════════════════════════════════════ */
.hdr-toggle-btn-compact {
  position: absolute !important;
  top: 50% !important;
  right: 14px !important;
  transform: translateY(-50%) !important;
  bottom: auto !important;
  width: auto !important;
  padding: 4px 9px !important;
  font-size: 10px !important;
  letter-spacing: 0.06em !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(201,168,76,0.20) !important;
  color: rgba(255,255,255,0.65) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  height: 22px !important;
  z-index: 305 !important;
}
.hdr-toggle-btn-compact:hover {
  background: rgba(201,168,76,0.16) !important;
  border-color: rgba(201,168,76,0.50) !important;
  color: var(--gold) !important;
}
/* Bei kollabiertem Header: Toggle hängt am unteren Rand der Reihe 1 */
body.hdr-collapsed .hdr-toggle-btn-compact {
  top: 50% !important;
  background: rgba(201,168,76,0.14) !important;
  border-color: rgba(201,168,76,0.40) !important;
  color: var(--gold) !important;
}
.hdr-toggle-btn-compact .hdr-toggle-ico {
  transition: transform 0.25s ease;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════
   V63.8 — Input/Suffix-Überlappung beheben (kritischer UX-Bug)
   ═══════════════════════════════════════════════════════════════ */

/* Inputs mit Suffix (€/m²/% etc.) brauchen mehr rechtes Padding damit
   lange Werte (z.B. "73,91" oder "1.234.567") nicht über das Suffix laufen */
.iw input.tr {
  padding-right: 38px !important;     /* vorher 28px — jetzt mehr Reserve */
}
.iw input.trl {
  padding-left: 26px !important;       /* €-Präfix links */
}
/* Suffix selbst kompakter und nicht clickable */
.iw .sfx {
  right: 10px !important;
  font-size: 11px !important;
  color: var(--muted, #999) !important;
  font-weight: 500;
  background: transparent;
  white-space: nowrap;
}
/* Bei sehr langen Werten Schrift im Input etwas verkleinern */
.iw input.tr,
.iw input.trl {
  font-variant-numeric: tabular-nums;
}

/* ═══════════════════════════════════════════════════════════════
   V63.8 — Lesbarkeit-Bugs: weißer Text auf hellem Hintergrund fixen
   ═══════════════════════════════════════════════════════════════ */

/* Sicherheits-Override für alle Inputs/Selects/Textareas im hellen Bereich:
   Schriftfarbe ist die Charcoal-Farbe, nicht weiß */
.body input[type="text"],
.body input[type="number"],
.body input[type="email"],
.body input[type="date"],
.body input[type="search"],
.body select,
.body textarea {
  color: #2A2727 !important;             /* Charcoal — nicht weiß */
  background: #FFFFFF;
}
.body input::placeholder,
.body textarea::placeholder {
  color: rgba(42,39,39,0.40) !important;
}

/* Hint-Texte unter Feldern: nie weiß */
.qc-hint,
.qc-ai-src,
.hint,
.f .hint {
  color: rgba(42,39,39,0.55) !important;
}
.qc-hint-inline {
  color: rgba(42,39,39,0.50) !important;
  font-weight: 400;
}

/* Card-Titles im Body: dark */
.body .ct,
.body h3,
.body h4,
.body label {
  color: #2A2727;
}
.body label {
  color: rgba(42,39,39,0.85);
}

/* ═══════════════════════════════════════════════════════════════
   V63.8 — LTV-Erklärung
   ═══════════════════════════════════════════════════════════════ */
.ltv-explanation {
  margin: 8px 0 12px;
  padding: 10px 12px;
  background: rgba(201,168,76,0.06);
  border: 1px solid rgba(201,168,76,0.18);
  border-radius: 8px;
  font-size: 11.5px;
  line-height: 1.55;
  color: rgba(42,39,39,0.80);
}
.ltv-explanation-head {
  display: flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
  color: var(--ch);
  margin-bottom: 4px;
}
.ltv-explanation-head svg {
  flex-shrink: 0;
  color: var(--gold);
}
.ltv-explanation-body {
  font-variant-numeric: tabular-nums;
}
.ltv-explanation-detail {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  color: rgba(42,39,39,0.65);
}

/* ═══════════════════════════════════════════════════════════════
   V63.8 — Quellen-Link pro Aspect-Card / Lage-Box
   ═══════════════════════════════════════════════════════════════ */
.ki-lage-src-link {
  display: inline-block;
  margin-top: 10px;
  padding: 3px 8px;
  font-size: 11px;
  color: var(--gold);
  background: rgba(201,168,76,0.08);
  border: 0.5px solid rgba(201,168,76,0.30);
  border-radius: 6px;
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: all 0.15s ease;
}
.ki-lage-src-link:hover {
  background: rgba(201,168,76,0.18);
  border-color: var(--gold);
  text-decoration: none;
}
.ki-lage-src-link-inert {
  cursor: default;
  opacity: 0.65;
}
.ki-lage-src-link-inert:hover {
  background: rgba(201,168,76,0.08);
  border-color: rgba(201,168,76,0.30);
}

/* ═══════════════════════════════════════════════════════════════
   V63.9 — Sidebar-Karten kompakter (User-Wunsch: dichter, weniger Luft)
   ═══════════════════════════════════════════════════════════════ */

/* Karten-Innenraum kompakter */
.sb-card .sbc-top {
  padding: 10px 10px 8px !important;    /* vorher 12 12 10 */
}
.sb-card .sbc-top-line1 {
  margin-bottom: 2px !important;
  gap: 5px !important;
}
.sb-card {
  margin-bottom: 7px !important;        /* vorher 10 — dichter */
  border-radius: 10px !important;       /* vorher 12 — kompakter */
}
.sb-card .sbc-mini-grid {
  padding: 0 8px 8px !important;        /* vorher 0 10 10 */
  gap: 5px !important;
}
.sb-card .sbcm {
  padding: 6px 8px !important;          /* vorher 8 10 — luftärmer */
}
.sb-card .sbcm-val {
  font-size: 13px !important;           /* vorher 14 */
}
.sb-card .sbcm-label {
  font-size: 9.5px !important;
}
.sb-card .sbc-street {
  font-size: 12.5px !important;         /* vorher 13 */
  font-weight: 700;
}
.sb-card .sbc-line2 {
  font-size: 10.5px !important;
  margin-top: 0 !important;
}
.sb-card .sbc-kp {
  font-size: 16px !important;           /* vorher 18 — kompakter */
  font-weight: 700;
}
.sb-card .sbc-kp-row {
  margin-top: 4px !important;
}
.sb-card .sbc-thumb,
.sb-card .sbc-thumb img {
  height: 60px !important;              /* etwas niedriger als vorher */
}
.sb-card .sbcm-spark {
  height: 18px !important;              /* Sparkline kompakter */
}
.sb-card .sbcm-bar {
  height: 3px !important;
  margin-top: 3px;
}
.sb-card .sbcm-scale {
  font-size: 8px !important;
  margin-top: 1px;
}

/* ═══════════════════════════════════════════════════════════════
   V63.9 — Tab-Bar + Workflow-Bar SPALT FINAL FINAL FIX
   ═══════════════════════════════════════════════════════════════ */

/* Header (sticky) hat einen leichten Background-Bruch zur Tab-Bar.
   Damit zwischen Header und Tabs NIE Platz scheint, geben wir der
   Tab-Bar zusätzlich einen Box-Shadow nach OBEN der den Header verlängert. */
nav.tabs,
.main-col > nav.tabs {
  box-shadow: 0 -2px 0 var(--surface, #F8F6F1) !important;
  border-top: none !important;
  margin-top: 0 !important;
}

/* Tab-Bar und Workflow-Bar bilden einen visuell zusammenhängenden Block:
   beide gleicher Background, mit kleinem dunklen Trenner zwischen ihnen */
.tabs-workflow-bar,
.main-col > .tabs-workflow-bar {
  background: var(--surface, #F8F6F1) !important;
  border-top: none !important;
  margin-top: 0 !important;
  /* Trenner zwischen Tab-Bar und Workflow-Bar: zarte Linie */
  box-shadow: 0 -1px 0 rgba(42,39,39,0.10) !important;
}

/* Beim Wechsel von Workflow-Bar zum Body-Bereich:
   der Body bekommt auch surface-Background damit es bündig wirkt */
.body,
main.body {
  background: var(--surface, #F8F6F1);
}

/* ═══════════════════════════════════════════════════════════════
   V63.9 — KI-Lage Aspect-Cards: Lesbarkeit auf hellem Background
   (User-Wunsch: dunkle Schrift auf hellem Card, wie Mikro/Makro)
   ═══════════════════════════════════════════════════════════════ */

/* Aspect-Cards: helles Background mit dunkler Schrift */
.ki-lage-aspect-card {
  background: #FFFFFF !important;
  border: 1px solid rgba(42,39,39,0.10) !important;
  border-radius: 10px !important;
  padding: 14px 16px !important;
}

/* Aspect-Card Title: dunkel + lesbar */
.ki-lage-aspect-title {
  font-size: 12.5px !important;
  font-weight: 600 !important;
  color: #2A2727 !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* Score-Label rechts (z.B. "Stabil", "Stark"): farbig */
.ki-lage-aspect-score {
  font-size: 13px !important;
  font-weight: 700 !important;
  font-variant-numeric: tabular-nums;
  /* Farbe wird inline gesetzt — bleibt erhalten */
}

/* Beschreibungstext: dunkler grau, gut lesbar */
.ki-lage-aspect-text {
  font-size: 12.5px !important;
  line-height: 1.55 !important;
  color: rgba(42,39,39,0.78) !important;
}

/* Bar etwas dezenter */
.ki-lage-aspect-bar {
  height: 4px !important;
  background: rgba(42,39,39,0.08) !important;
  border-radius: 2px;
  overflow: hidden;
  margin: 8px 0 10px !important;
}

/* Quellen-Link bleibt golden */
.ki-lage-aspect-card .ki-lage-src-link {
  margin-top: 10px;
}

/* ═══════════════════════════════════════════════════════════════
   V63.20 — Investor-Badge: HORIZONTAL MITTIG auf der Border
   (User-Wunsch V22: mittig statt links, weiter auf Umrahmung)
   ═══════════════════════════════════════════════════════════════ */
.sbc-investor-ribbon {
  /* Position: oben mittig, halb über die obere Border-Kante */
  top: -1px !important;                /* sitzt auf der oberen Border */
  left: 50% !important;                /* horizontal zentriert */
  transform: translateX(-50%) !important;  /* mittig ausrichten */
  /* Border-Radius: alle 4 Ecken leicht gerundet — wirkt wie aufgesetztes Etikett */
  border-radius: 0 0 8px 8px !important;
  /* Padding bleibt wie V63.9 */
  padding: 3px 12px 3px 10px !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.20 — Tab-Bar + Workflow-Bar VERSCHMELZEN (User-Wunsch V22)
   "optisch verschmolzen, gleicher Background, keine Trennlinie"
   ═══════════════════════════════════════════════════════════════ */

/* V63.9 hatte eine zarte Trenn-Linie zwischen Tab-Bar und Workflow-Bar.
   User will das nicht — sie sollen visuell EIN BLOCK sein. */
.tabs-workflow-bar,
.main-col > .tabs-workflow-bar {
  background: var(--surface, #F8F6F1) !important;
  border-top: none !important;
  margin-top: 0 !important;
  padding-top: 8px !important;          /* statt 12px — kompakter */
  /* WICHTIG: V63.9 box-shadow Trenner ENTFERNEN */
  box-shadow: none !important;
}

/* Im Free-Modus (kein DS2-Header) extra strikt: KEIN Padding/Margin/Gap */
body.hdr-no-score .tabs-workflow-bar,
body.hdr-collapsed .tabs-workflow-bar,
body.plan-free .tabs-workflow-bar,
body.plan-starter .tabs-workflow-bar {
  margin-top: 0 !important;
  padding-top: 8px !important;
  border-top: none !important;
  box-shadow: none !important;
}

/* Tab-Bar darf auch keinen Bottom-Border/Schatten haben der Spalt vortäuscht */
nav.tabs,
.main-col > nav.tabs {
  border-bottom: none !important;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  box-shadow: 0 -2px 0 var(--surface, #F8F6F1) !important;  /* nach oben (Header verlängern), nicht nach unten */
}

/* ═══════════════════════════════════════════════════════════════
   V63.20 — DealScore-Toggle als reiner Pfeil-Chevron
   (User-Wunsch V22: kein Button-Text "Score", nur Pfeil)
   ═══════════════════════════════════════════════════════════════ */
.hdr-toggle-btn-chevron {
  /* Reset gegen V63.7 hdr-toggle-btn-compact */
  background: transparent !important;
  border: none !important;
  padding: 6px !important;
  margin: 0 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--gold, #C9A84C);
  opacity: 0.7;
  transition: opacity .15s ease, transform .15s ease;
  border-radius: 4px;
}
.hdr-toggle-btn-chevron:hover {
  opacity: 1;
  background: rgba(201,168,76,0.10) !important;
}
/* Chevron rotiert je nach State */
body.hdr-collapsed .hdr-toggle-btn-chevron .hdr-toggle-ico {
  transform: rotate(0deg);          /* nach unten = "ausklappen" */
}
body:not(.hdr-collapsed) .hdr-toggle-btn-chevron .hdr-toggle-ico {
  transform: rotate(180deg);        /* nach oben = "einklappen" */
}
.hdr-toggle-ico {
  transition: transform .2s ease;
}

/* ═══════════════════════════════════════════════════════════════
   V63.21 — TAB-BAR OPAK MACHEN, SCHIMMERN DURCH QUICK-CHECK FIXEN
   ═══════════════════════════════════════════════════════════════ */
/* Aus dem User-Screenshot: Quick-Check-Banner schimmert durch die Tab-Bar
   weil die Tab-Bar transparent/halbtransparent ist. Tab-Bar muss OPAK sein
   und über dem Inhalt liegen. */
nav.tabs,
.main-col > nav.tabs,
body.plan-free nav.tabs,
body.plan-starter nav.tabs,
body.hdr-no-score nav.tabs,
body.hdr-collapsed nav.tabs {
  background: var(--surface, #F8F6F1) !important;
  background-color: #F8F6F1 !important;     /* Fallback ohne Variable */
  /* z-index hoch damit sie über dem Quick-Check-Inhalt liegt */
  position: relative;
  z-index: 50;
}

/* Workflow-Bar gleicher Trick — opak und über dem Inhalt */
.tabs-workflow-bar,
.main-col > .tabs-workflow-bar {
  background: var(--surface, #F8F6F1) !important;
  background-color: #F8F6F1 !important;
  position: relative;
  z-index: 49;
}

/* Tab-Bar UND Workflow-Bar bilden EIN OPAKES BLOCK ohne Trennlinie */
nav.tabs + .tabs-workflow-bar,
.main-col > nav.tabs + .tabs-workflow-bar {
  margin-top: 0 !important;
  border-top: none !important;
  box-shadow: none !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.21 — Chevron-Pfeil DIREKT AN DEN HEADER kleben (User-Wunsch)
   ═══════════════════════════════════════════════════════════════ */
/* User-Bild: Pfeil ▾ liegt aktuell in der Tab-Leiste statt am Header.
   Lösung: absolut positionieren am unteren Header-Rand, horizontal mittig. */
header {
  position: relative;          /* Anker für absoluten Toggle-Button */
}
.hdr-toggle-btn-chevron {
  position: absolute !important;
  bottom: -14px !important;             /* halb über die untere Header-Border */
  left: 50% !important;
  transform: translateX(-50%) !important;
  z-index: 51 !important;               /* über Tab-Bar */
  /* Sichtbarer Hintergrund-Kreis weil halb über Header, halb über Surface */
  background: var(--ch, #2A2727) !important;
  border: 1px solid rgba(201,168,76,0.45) !important;
  border-radius: 50% !important;
  width: 28px !important;
  height: 28px !important;
  padding: 0 !important;
  opacity: 1 !important;                /* immer voll sichtbar */
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--gold, #C9A84C);
  box-shadow: 0 2px 8px rgba(0,0,0,0.35);
  transition: transform .2s ease, background .15s ease;
}
.hdr-toggle-btn-chevron:hover {
  background: rgba(201,168,76,0.18) !important;
}
/* Pfeil-Rotation per body.hdr-collapsed (V63.20 schon vorhanden, aber nochmal) */
body.hdr-collapsed .hdr-toggle-btn-chevron {
  transform: translateX(-50%) rotate(0deg) !important;
}
body:not(.hdr-collapsed) .hdr-toggle-btn-chevron {
  transform: translateX(-50%) rotate(180deg) !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.21 — Settings-Refactor CSS (Account, Plan-Hinweis, KI, Daten, Info)
   ═══════════════════════════════════════════════════════════════ */

/* Section-Headers im Settings-Modal */
.set-section-h {
  font-size: 13px;
  font-weight: 700;
  color: var(--ch, #2A2727);
  margin: 14px 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  opacity: 0.85;
}

/* Account-Plan-Box */
.account-plan-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.22);
  border-radius: 8px;
  margin-bottom: 10px;
}
.account-plan-name {
  font-weight: 700;
  color: var(--ch, #2A2727);
}
.account-plan-link {
  background: transparent;
  border: 1px solid var(--gold, #C9A84C);
  color: var(--gold, #C9A84C);
  padding: 5px 12px;
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
  font-weight: 600;
  transition: background .15s ease, color .15s ease;
}
.account-plan-link:hover {
  background: var(--gold, #C9A84C);
  color: white;
}

/* Passwort-Änderungs-Block */
.g3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
@media (max-width: 720px) {
  .g3 { grid-template-columns: 1fr; }
}
.account-pw-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
  flex-wrap: wrap;
}
.account-pw-msg {
  font-size: 12px;
  flex: 1;
  min-width: 0;
}
.account-pw-msg.ok { color: var(--green, #3FA56C); font-weight: 600; }
.account-pw-msg.err { color: var(--red, #B8625C); font-weight: 600; }

/* Logout-Reihe */
.account-logout-row {
  display: flex;
  justify-content: flex-start;
  margin-top: 6px;
}
.btn-danger {
  background: var(--red, #B8625C) !important;
  color: white !important;
  border: 1px solid var(--red, #B8625C) !important;
}
.btn-danger:hover {
  background: #A55650 !important;
}

/* Plan-Hinweis-Box im Kontakt-Tab */
.plan-hint-box {
  display: flex;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 8px;
  margin-bottom: 12px;
  font-size: 13px;
  align-items: flex-start;
}
.plan-hint-icon {
  font-size: 18px;
  flex-shrink: 0;
}
.plan-hint-content {
  line-height: 1.45;
}
.plan-hint-content strong { font-weight: 700; }
.plan-hint-free {
  background: rgba(184,98,92,0.08);
  border: 1px solid rgba(184,98,92,0.22);
  color: var(--ch, #2A2727);
}
.plan-hint-starter {
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.22);
  color: var(--ch, #2A2727);
}
.plan-hint-investor,
.plan-hint-pro {
  background: rgba(63,165,108,0.08);
  border: 1px solid rgba(63,165,108,0.25);
  color: var(--ch, #2A2727);
}

/* KI-Tab Fokus-Schwerpunkte (Checkbox-Gruppe) */
.ai-focus-checks {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px 14px;
  padding: 6px 0;
}
@media (max-width: 600px) {
  .ai-focus-checks { grid-template-columns: repeat(2, 1fr); }
}
.ai-focus-check {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  cursor: pointer;
  user-select: none;
}
.ai-focus-check input[type="checkbox"] {
  margin: 0;
  cursor: pointer;
  accent-color: var(--gold, #C9A84C);
}
.f-hint {
  font-size: 11px;
  font-weight: normal;
  opacity: 0.65;
  margin-left: 4px;
}

/* Info-Tab: Impressum + Datenschutz collapsible */
.info-section-title-collapsible {
  cursor: pointer;
  user-select: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: color .15s ease;
}
.info-section-title-collapsible:hover {
  color: var(--gold, #C9A84C);
}
.info-toggle-arrow {
  font-size: 16px;
  transition: transform .2s ease;
  margin-left: auto;
}
.info-section-title-collapsible.open .info-toggle-arrow {
  transform: rotate(180deg);
}
.info-legal-text {
  padding: 10px 14px;
  background: rgba(0,0,0,0.02);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 6px;
  font-size: 12.5px;
  line-height: 1.55;
  max-height: 400px;
  overflow-y: auto;
  margin-top: 6px;
}
.info-legal-text h4 {
  font-size: 13px;
  font-weight: 700;
  margin: 12px 0 4px;
  color: var(--ch, #2A2727);
}
.info-legal-text h4:first-child { margin-top: 0; }
.info-legal-text p {
  margin: 0 0 6px;
  color: var(--ch, #2A2727);
  opacity: 0.85;
}
.info-legal-text p strong { font-weight: 700; opacity: 1; }

/* ═══════════════════════════════════════════════════════════════
   V63.21 — DS2 Inline-Konfiguration im Settings-DealScore-Tab
   (User-Wunsch: kein Modal-über-Modal mehr)
   ═══════════════════════════════════════════════════════════════ */
.ds2-settings-body-inline {
  background: rgba(0,0,0,0.02);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 8px;
  padding: 12px;
  margin-top: 8px;
  max-height: 480px;
  overflow-y: auto;
}
.ds2-settings-body-inline .ds2-set-section {
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.ds2-settings-body-inline .ds2-set-section:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}
.ds2-settings-body-inline h4 {
  font-size: 13px;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--ch, #2A2727);
}
.ds2-settings-body-inline .ds2-set-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px 12px;
}
@media (max-width: 600px) {
  .ds2-settings-body-inline .ds2-set-grid { grid-template-columns: 1fr; }
}
.ds2-settings-body-inline .ds2-set-field {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.ds2-settings-body-inline .ds2-set-field label {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--ch, #2A2727);
  opacity: 0.85;
}
.ds2-settings-body-inline .ds2-set-field input {
  padding: 5px 8px;
  font-size: 12px;
  border: 1px solid rgba(0,0,0,0.18);
  border-radius: 4px;
  background: white;
}

/* ═══════════════════════════════════════════════════════════════
   V63.22 — Workflow-Bar BÜNDIG an Tab-Bar (kein Spalt mehr)
   User-Bug: zwischen Tab-Bar und Workflow-Bar war noch Luft.
   ═══════════════════════════════════════════════════════════════ */
/* Workflow-Bar bekommt einen NEGATIVEN margin-top, damit sie unter die
   Tab-Bar rutscht. So ist der visuelle Eindruck: ein durchgehender Block. */
.tabs-workflow-bar,
.main-col > .tabs-workflow-bar {
  margin-top: -2px !important;          /* zieht sie hoch unter die Tab-Bar */
  padding-top: 6px !important;
  padding-bottom: 6px !important;
  border-top: none !important;
  box-shadow: none !important;
  background: var(--surface, #F8F6F1) !important;
  position: relative;
  z-index: 48;                          /* knapp unter Tab-Bar (50) und Workflow nach oben (49) */
}

/* Tab-Bar bekommt Bottom-Padding null damit Workflow direkt anschließt */
nav.tabs,
.main-col > nav.tabs {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.22 — Chevron kleiner + dezenter (User-Wunsch)
   ═══════════════════════════════════════════════════════════════ */
.hdr-toggle-btn-chevron {
  bottom: -10px !important;             /* etwas weniger raus */
  width: 22px !important;               /* vorher 28 → schlanker */
  height: 22px !important;
  border: 1px solid rgba(201,168,76,0.30) !important;  /* schwächere Border */
  background: var(--ch, #2A2727) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.25) !important;   /* dezenter Schatten */
  opacity: 0.85 !important;
}
.hdr-toggle-btn-chevron:hover {
  opacity: 1 !important;
  background: rgba(201,168,76,0.18) !important;
}
.hdr-toggle-btn-chevron .hdr-toggle-ico {
  width: 11px !important;               /* Pfeil-SVG kleiner */
  height: 11px !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.22 — Info-Tab Schnellzugriff Buttons
   ═══════════════════════════════════════════════════════════════ */
.info-quick-links {
  display: flex;
  gap: 10px;
  margin: 8px 0 16px;
}
.info-quick-btn {
  flex: 1;
  padding: 10px 14px;
  background: var(--surface, #F8F6F1);
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ch, #2A2727);
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease, transform .1s ease;
}
.info-quick-btn:hover {
  background: rgba(201,168,76,0.08);
  border-color: var(--gold, #C9A84C);
}
.info-quick-btn:active {
  transform: translateY(1px);
}

/* ═══════════════════════════════════════════════════════════════
   V63.23 — Chevron GANZ RECHTS am Header (User-Wunsch)
   Vorher mittig zentriert, jetzt rechts neben "PDF Export / Speichern"
   ═══════════════════════════════════════════════════════════════ */
.hdr-toggle-btn-chevron {
  left: auto !important;
  right: 14px !important;               /* rechter Rand mit kleinem Abstand */
  bottom: -10px !important;
  transform: none !important;           /* keine translateX-Mittelung mehr */
  width: 22px !important;
  height: 22px !important;
}
/* Rotation neu definiert ohne translateX */
body.hdr-collapsed .hdr-toggle-btn-chevron {
  transform: rotate(0deg) !important;
}
body:not(.hdr-collapsed) .hdr-toggle-btn-chevron {
  transform: rotate(180deg) !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.23 — SPALT zwischen Tab-Bar und Workflow-Bar ENDGÜLTIG ZU
   ═══════════════════════════════════════════════════════════════ */
/* Aus dem User-Screenshot: zwischen Tab-Leiste und Workflow ist immer noch ein
   sichtbarer Schatten/Spalt. Die Tab-Bar (.tabs) hat einen box-shadow nach OBEN
   für den Header-Übergang — der erzeugt unten eventuell auch ein Pixel.
   Plus: Workflow-Bar hat margin-top: -2px aber padding-top wird durch line-height
   "wie ein Spalt" wahrgenommen. */

/* Tab-Bar darf KEIN bottom-spezifisches Margin/Border/Shadow haben */
nav.tabs,
.main-col > nav.tabs {
  border-bottom: none !important;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  /* Tab-Bar Background opak — verhindert Durchschimmern */
  background: var(--surface, #F8F6F1) !important;
  /* box-shadow nur nach OBEN (Header-Übergang) — nichts nach unten */
  box-shadow: 0 -2px 0 var(--surface, #F8F6F1) !important;
}

/* Workflow-Bar mit DIREKTEM Anschluss — minus 1px holt sie genau über den letzten Pixel */
.tabs-workflow-bar,
.main-col > .tabs-workflow-bar {
  margin-top: -1px !important;
  padding-top: 4px !important;
  padding-bottom: 8px !important;
  border-top: none !important;
  box-shadow: none !important;
  background: var(--surface, #F8F6F1) !important;
  background-color: #F8F6F1 !important;
  position: relative;
  z-index: 47;
}

/* Beide bilden EIN visuelles Block mit gleichem Background */
nav.tabs::after,
.tabs-workflow-bar::before {
  display: none !important;
  content: none !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.23 — QC Berechnungs-Info-Box (Bug 3: Berechnungsweg sichtbar)
   ═══════════════════════════════════════════════════════════════ */
.qc-calc-info {
  background: rgba(201,168,76,0.05);
  border: 1px solid rgba(201,168,76,0.20);
  border-radius: 8px;
  padding: 10px 14px;
  margin: 10px 0;
}
.qc-calc-info-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--ch, #2A2727);
  margin-bottom: 8px;
}
.qc-calc-info-grid {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12.5px;
}
.qc-calc-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  padding: 3px 0;
}
.qc-calc-row-strong {
  font-weight: 700;
  border-top: 1px solid rgba(201,168,76,0.20);
  margin-top: 2px;
  padding-top: 6px;
}
.qc-calc-label {
  color: var(--ch, #2A2727);
  opacity: 0.85;
}
.qc-calc-val {
  color: var(--ch, #2A2727);
  font-variant-numeric: tabular-nums;
  text-align: right;
  white-space: nowrap;
}

/* ═══════════════════════════════════════════════════════════════
   V63.24 — Bewirt-Period-Toggle (Monat/Jahr)
   ═══════════════════════════════════════════════════════════════ */
.qc-bewirt-period {
  display: inline-flex;
  gap: 4px;
  background: rgba(0,0,0,0.04);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 6px;
  padding: 3px;
}
.qc-bewirt-period-btn {
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 600;
  color: var(--ch, #2A2727);
  background: transparent;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: background .15s ease;
}
.qc-bewirt-period-btn:hover {
  background: rgba(201,168,76,0.10);
}
.qc-bewirt-period-btn.active {
  background: var(--gold, #C9A84C);
  color: white;
}


/* ═══════════════════════════════════════════════════════════════
   V63.25 — SPALT: Pixel-genauer Sticky-Stack via JS (--wf-top Variable)
   Vorherige Versuche scheiterten weil .tabs ein dynamisches "top" hat
   (mit/ohne Score-Header anders) und die Tab-Höhe nicht exakt zu den
   hardcodierten Workflow-Bar top-Werten passte.
   Lösung: JS misst die Höhe der Tab-Bar und setzt --wf-top live.
   ═══════════════════════════════════════════════════════════════ */
:root { --wf-top: 102px; }

nav.tabs,
.main-col > nav.tabs {
  background: var(--surface, #F8F6F1) !important;
  background-color: #F8F6F1 !important;
  box-shadow: none !important;
  border-bottom: none !important;
}

/* Workflow-Bar: alle vorherigen top:-Werte hart überschreiben — wir nutzen --wf-top */
.tabs-workflow-bar,
.main-col > .tabs-workflow-bar {
  position: sticky !important;
  top: var(--wf-top) !important;
  margin-top: 0 !important;
  padding-top: 6px !important;
  padding-bottom: 8px !important;
  border-top: none !important;
  background: var(--surface, #F8F6F1) !important;
  background-color: #F8F6F1 !important;
  box-shadow: none !important;
  z-index: 199;
}
@media (max-width: 1100px) {
  .tabs-workflow-bar { top: var(--wf-top) !important; }
}
@media (max-width: 720px) {
  .tabs-workflow-bar { top: var(--wf-top) !important; }
}

/* ═══════════════════════════════════════════════════════════════
   V63.25 — Duplikat-ID-Markierung in Sidebar-Karten
   ═══════════════════════════════════════════════════════════════ */
.sbc-seq-dup {
  background: rgba(184,98,92,0.18) !important;       /* rot-tint */
  color: var(--red, #B8625C) !important;
  border: 1px solid var(--red, #B8625C) !important;
  font-weight: 700 !important;
}
.sb-card.has-investor-ribbon .sbc-seq-dup,
.sb-card .sbc-seq-dup {
  /* Override even on Investor-Card */
  background: rgba(184,98,92,0.18) !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.25 — DS2-Hinweis auf Karte für Plan-Upgrade-Pfad
   Wenn Plan investor/pro UND Objekt hat noch keinen DS2 → kleines Badge
   ═══════════════════════════════════════════════════════════════ */
.sbc-ds2-hint {
  display: inline-flex;
  align-items: center;
  padding: 1px 6px;
  background: rgba(201,168,76,0.15);
  border: 1px solid rgba(201,168,76,0.40);
  border-radius: 4px;
  color: var(--gold, #C9A84C);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.3px;
  cursor: help;
}

/* ═══════════════════════════════════════════════════════════════
   V63.26 — Settings-Modal Deal Score Tab: Inputs sichtbar machen
   Bug: ds2-set-row Styles waren für dunkles Modal designed (weißer Text).
   Im hellen Settings-Modal wurde das unsichtbar.
   ═══════════════════════════════════════════════════════════════ */
.ds2-settings-body-inline .ds2-set-section h4 {
  color: var(--ch, #2A2727) !important;
}
.ds2-settings-body-inline .ds2-set-row label {
  color: var(--ch, #2A2727) !important;
  opacity: 0.85;
}
.ds2-settings-body-inline .ds2-set-row input {
  background: #FFFFFF !important;
  border: 1px solid rgba(42,39,39,0.20) !important;
  color: var(--ch, #2A2727) !important;
}
.ds2-settings-body-inline .ds2-set-row input:focus {
  border-color: var(--gold, #C9A84C) !important;
  box-shadow: 0 0 0 2px rgba(201,168,76,0.18) !important;
}
.ds2-settings-body-inline .ds2-set-unit {
  color: var(--ch, #2A2727) !important;
  opacity: 0.65;
}
.ds2-settings-body-inline .ds2-set-hint {
  color: rgba(42,39,39,0.65) !important;
}
.ds2-settings-body-inline .ds2-set-hint code {
  background: rgba(42,39,39,0.08) !important;
  color: var(--ch, #2A2727) !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.26 — SPALT FINAL: --wf-top mit höchster Spezifität durchsetzen.
   V63.25 hatte --wf-top schon, aber alte Selektoren wie
   `body.hdr-banner-only .tabs-workflow-bar` hatten höhere Spezifität.
   ═══════════════════════════════════════════════════════════════ */
html body .tabs-workflow-bar,
html body .main-col > .tabs-workflow-bar,
html body.hdr-no-score .tabs-workflow-bar,
html body.hdr-banner-only .tabs-workflow-bar,
html body.hdr-collapsed .tabs-workflow-bar {
  top: var(--wf-top, 174px) !important;
  position: sticky !important;
  margin-top: 0 !important;
  background: var(--surface, #F8F6F1) !important;
  background-color: #F8F6F1 !important;
  border-top: none !important;
  box-shadow: none !important;
}
@media (max-width: 1100px) {
  html body .tabs-workflow-bar,
  html body.hdr-no-score .tabs-workflow-bar,
  html body.hdr-banner-only .tabs-workflow-bar { top: var(--wf-top, 174px) !important; }
}
@media (max-width: 720px) {
  html body .tabs-workflow-bar,
  html body.hdr-no-score .tabs-workflow-bar,
  html body.hdr-banner-only .tabs-workflow-bar { top: var(--wf-top, 142px) !important; }
}

/* ═══════════════════════════════════════════════════════════════
   V63.26 — KI-Mietpreis-Analyse Result-Styles
   ═══════════════════════════════════════════════════════════════ */
.ki-miete-result {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ki-miete-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 6px 10px;
  background: rgba(255,255,255,0.04);
  border-radius: 6px;
  font-size: 13px;
}
.ki-miete-row-diff {
  font-weight: 700;
  background: rgba(255,255,255,0.08);
}
.ki-miete-row-label {
  color: rgba(255,255,255,0.78);
}
.ki-miete-row-value {
  color: #fff;
  font-variant-numeric: tabular-nums;
}
.ki-miete-abs {
  opacity: 0.6;
  font-size: 11.5px;
}
.ki-miete-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 6px;
}
.ki-miete-hint {
  font-size: 11.5px;
  color: rgba(255,255,255,0.55);
  font-style: italic;
  margin-top: 4px;
}

/* ═══════════════════════════════════════════════════════════════
   V63.27 — Sidebar Sort-Toggle
   ═══════════════════════════════════════════════════════════════ */
.sb-section-title-with-sort {
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}
.sb-sort-toggle {
  display: inline-flex;
  gap: 2px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 5px;
  padding: 2px;
}
.sb-sort-btn {
  width: 22px;
  height: 22px;
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.5);
  font-size: 11px;
  cursor: pointer;
  border-radius: 3px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  transition: background .15s, color .15s;
}
.sb-sort-btn:hover {
  background: rgba(201,168,76,0.15);
  color: var(--gold, #C9A84C);
}
.sb-sort-btn.active {
  background: var(--gold, #C9A84C);
  color: #2A2727;
}

/* ═══════════════════════════════════════════════════════════════
   V63.27 — KI-Mietpreis-Analyse Block-Styles (analog ki-lage)
   ═══════════════════════════════════════════════════════════════ */
.ki-miete-loading {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
  color: rgba(42,39,39,0.65);
  font-size: 13px;
}
.ki-miete-spinner {
  width: 16px;
  height: 16px;
  border: 2px solid rgba(201,168,76,0.20);
  border-top-color: var(--gold, #C9A84C);
  border-radius: 50%;
  animation: kimspin 0.8s linear infinite;
}
@keyframes kimspin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.ki-miete-err {
  background: rgba(184,98,92,0.10);
  border: 1px solid rgba(184,98,92,0.30);
  border-radius: 6px;
  padding: 10px 14px;
  color: var(--red, #B8625C);
  font-size: 13px;
}

.ki-miete-block {
  background: rgba(201,168,76,0.06);
  border: 1px solid rgba(201,168,76,0.20);
  border-radius: 8px;
  padding: 12px 14px;
  margin-bottom: 10px;
}
.ki-miete-block-header {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.ki-miete-block-icon {
  font-size: 16px;
}
.ki-miete-block-title {
  font-weight: 700;
  color: var(--ch, #2A2727);
  font-size: 14px;
  flex: 1;
}
.ki-miete-block-value {
  font-weight: 700;
  font-size: 14px;
  color: var(--gold, #C9A84C);
  font-variant-numeric: tabular-nums;
}
.ki-miete-compare {
  display: flex;
  flex-direction: column;
  gap: 4px;
  background: rgba(255,255,255,0.40);
  border-radius: 6px;
  padding: 8px 10px;
  margin-bottom: 8px;
  font-size: 12.5px;
  font-variant-numeric: tabular-nums;
}
.ki-miete-compare-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--ch, #2A2727);
}
.ki-miete-compare-row strong {
  color: var(--ch, #2A2727);
}
.ki-miete-reasoning {
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--ch, #2A2727);
  opacity: 0.85;
  margin-bottom: 6px;
}
.ki-miete-source {
  font-size: 11.5px;
  color: rgba(42,39,39,0.60);
  margin-bottom: 8px;
}
.ki-miete-source a {
  color: var(--gold, #C9A84C);
  text-decoration: none;
}
.ki-miete-source a:hover {
  text-decoration: underline;
}
.ki-miete-disclaimer {
  font-size: 11.5px;
  color: rgba(42,39,39,0.55);
  font-style: italic;
  margin-top: 6px;
  padding: 6px 10px;
  background: rgba(0,0,0,0.03);
  border-radius: 4px;
}

/* ═══════════════════════════════════════════════════════════════
   V63.27 — KI-Miete-Box: heller Hintergrund (Tab Miete ist hell)
   ═══════════════════════════════════════════════════════════════ */
#ki-miete-box {
  background: #FFFFFF !important;
  border: 1px solid rgba(42,39,39,0.10) !important;
  border-radius: 8px !important;
  padding: 14px 16px !important;
  margin-top: 14px !important;
}
#ki-miete-box .ki-lage-header {
  margin-bottom: 10px;
}
#ki-miete-box .ki-lage-title {
  color: var(--ch, #2A2727);
}
#ki-miete-box .ki-lage-tag {
  background: rgba(201,168,76,0.15);
  color: var(--gold, #C9A84C);
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
#ki-miete-box .ki-lage-empty {
  color: rgba(42,39,39,0.65);
  padding: 10px 0;
  font-size: 13px;
}

/* ═══════════════════════════════════════════════════════════════
   V63.28 — Workflow-Bar STICKY (fest beim Scrollen)
   V63.27 hatte position:static gemacht — Bar scrollte mit weg.
   User-Wunsch: Bar bleibt fest unter Tab-Bar beim Scrollen.
   Spalt-Lösung: position:sticky mit pixel-genauer top via JS-Variable --wf-top.
   ═══════════════════════════════════════════════════════════════ */
:root { --wf-top: 102px; }   /* Default falls JS noch nicht gelaufen */

html body .tabs-workflow-bar,
html body .main-col > .tabs-workflow-bar,
html body.hdr-no-score .tabs-workflow-bar,
html body.hdr-banner-only .tabs-workflow-bar,
html body.hdr-collapsed .tabs-workflow-bar {
  position: sticky !important;
  top: var(--wf-top) !important;
  margin-top: 0 !important;
  padding-top: 6px !important;
  padding-bottom: 8px !important;
  border-top: none !important;
  border-bottom: 1px solid rgba(42,39,39,0.06) !important;
  background: var(--surface, #F8F6F1) !important;
  background-color: #F8F6F1 !important;
  box-shadow: none !important;
  z-index: 199;
}
/* Tab-Bar darf nichts unten anhängen */
html body nav.tabs,
html body .tabs {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  border-bottom: none !important;
  box-shadow: none !important;
}
html body .body {
  padding-top: 14px !important;
}
@media (max-width: 1100px) {
  html body .tabs-workflow-bar { top: var(--wf-top, 174px) !important; }
}
@media (max-width: 720px) {
  html body .tabs-workflow-bar { top: var(--wf-top, 142px) !important; }
}

/* ═══════════════════════════════════════════════════════════════
   V63.29 — Workflow-Bar bündig zur Tab-Bar + min. 10px Höhe
   - top wird via --wf-top präzise gesetzt (calc.js _updateWfTop)
   - kompaktes padding (4px oben/unten) + min-height 10px Inhalt
   - Übergang nahtlos durch matching background
   ═══════════════════════════════════════════════════════════════ */
html body .tabs-workflow-bar,
html body.hdr-no-score .tabs-workflow-bar,
html body.hdr-banner-only .tabs-workflow-bar,
html body.hdr-collapsed .tabs-workflow-bar {
  padding-top: 4px !important;
  padding-bottom: 4px !important;
  min-height: 10px !important;
  margin-top: 0 !important;
  border-top: none !important;
  /* Bottom-Border subtiler als V63.28 */
  border-bottom: 1px solid rgba(42,39,39,0.05) !important;
}

/* Workflow-Bar-Innenhalt etwas kompakter */
html body .tabs-workflow-bar .wf-tab-title { font-size: 22px !important; line-height: 1.1 !important; }
html body .tabs-workflow-bar .wf-tab-sub   { font-size: 11px !important; }
html body .tabs-workflow-bar .wf-tab-progress-text { font-size: 11px !important; }

/* Body bündig anschließen (kein Pad oben) */
html body .body {
  padding-top: 10px !important;
}

/* V63.43: Vermögenszuwachs Erklärungs-Boxen — einklappbar (details/summary) */
.vz-explainer summary::-webkit-details-marker { display: none; }
.vz-explainer summary::marker { display: none; content: ''; }
.vz-explainer summary { transition: background .15s; user-select: none; }
.vz-explainer summary:hover { background: rgba(201,168,76,.08); }
.vz-explainer .vz-arrow { display: inline-block; transition: transform .2s; margin-right: 6px; font-size: .7em; color: var(--gold); }
.vz-explainer[open] .vz-arrow { transform: rotate(90deg); }
.vz-explainer[open] summary span:last-child { opacity: 0.6; }

/* V63.44: Sidebar-Aktionen — Sektion-Titel zwischen Hauptaktionen und Import/Export */
.sb-act-section-title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--gold);
  padding: 14px 16px 6px 16px;
  margin: 4px 0 0 0;
  border-top: 1px solid rgba(201,168,76,0.18);
  position: relative;
}
.sb-act-section-title::before {
  content: '';
  position: absolute;
  left: 16px;
  top: -1px;
  width: 22px;
  height: 2px;
  background: var(--gold);
}
.sb-act-section-title:first-child {
  border-top: none;
  margin-top: 0;
}

/* V63.44: Settings-Tab-Icons (SVG statt Emoji) */
.st-tab-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  margin-right: 6px;
  vertical-align: middle;
  color: var(--gold);
}
.st-tab-ico svg {
  width: 14px;
  height: 14px;
  display: block;
}
.st-tab.active .st-tab-ico { color: var(--gold); }
.st-tab:not(.active) .st-tab-ico { color: rgba(42,39,39,0.5); }

/* ═══════════════════════════════════════════════════════════════════
   V63.44: MOBILE-RESPONSIVE — Tablet & Phone
   ═══════════════════════════════════════════════════════════════════ */

/* ─── Tablet (≤ 1024px) ─── */
@media (max-width: 1024px) {
  /* Sidebar schmaler */
  .sidebar { width: 240px !important; }
  .body { margin-left: 240px !important; padding: 16px !important; }

  /* Cards einspaltig wenn 2-Spalten zu eng */
  .col2, .col3, .g2, .g3, .kpi-grid { grid-template-columns: 1fr !important; }

  /* KPI-Grid: 2 Spalten statt 4 */
  .kpi-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* Tab-Bar horizontal scrollbar */
  .tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .tabs::-webkit-scrollbar { height: 3px; }
  .tabs::-webkit-scrollbar-thumb { background: rgba(201,168,76,0.4); }

  /* Settings-Tabs ebenfalls scrollbar */
  .settings-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap !important; }
  .settings-tabs .st-tab { flex-shrink: 0; }
}

/* ─── Phone (≤ 768px) ─── */
@media (max-width: 768px) {
  /* Sidebar als Off-Canvas-Drawer */
  .sidebar {
    position: fixed !important;
    top: 0; left: 0;
    width: 280px !important;
    height: 100vh !important;
    z-index: 1050;
    transform: translateX(-100%);
    transition: transform 0.25s ease;
    box-shadow: 4px 0 24px rgba(0,0,0,0.18);
  }
  .sidebar.sb-mobile-open { transform: translateX(0); }
  .body { margin-left: 0 !important; padding: 12px !important; }

  /* Mobile-Header mit Hamburger-Toggle (oben fix) */
  .mobile-topbar {
    display: flex !important;
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--surface);
    border-bottom: 1px solid rgba(42,39,39,0.08);
    padding: 8px 12px;
    align-items: center;
    gap: 12px;
    margin: -12px -12px 12px -12px;
  }
  .mobile-topbar .mt-btn {
    background: none; border: none; cursor: pointer;
    color: var(--ch); padding: 6px;
    display: flex; align-items: center; justify-content: center;
  }
  .mobile-topbar .mt-title {
    font-weight: 700; color: var(--ch); font-size: 15px;
  }
  .mobile-topbar .mt-spacer { flex: 1; }
  .mobile-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,0.4);
    z-index: 1040;
    display: none;
    backdrop-filter: blur(2px);
  }
  .mobile-overlay.active { display: block; }

  /* KPI-Tiles: 1-spaltig */
  .kpi-grid { grid-template-columns: 1fr !important; gap: 8px !important; }
  .kpi-tile { padding: 12px !important; }
  .kpi-tile .kpi-val { font-size: 22px !important; }
  .kpi-tile .kpi-l { font-size: 11px !important; }

  /* Karten/Sections kompakter */
  .card { padding: 12px !important; margin-bottom: 12px !important; }
  .card .ct { font-size: 12px !important; }
  h1 { font-size: 20px !important; }
  h2 { font-size: 17px !important; }
  h3 { font-size: 15px !important; }

  /* Tabs */
  .tabs .tab {
    padding: 8px 10px !important;
    font-size: 12px !important;
    white-space: nowrap;
  }

  /* Tabellen scrollbar */
  table { font-size: 12px !important; }
  .cft, .phase-table, .zaer-table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }

  /* Inputs größer für Touch */
  input[type=text], input[type=number], input[type=email], input[type=password],
  input[type=date], select, textarea {
    min-height: 40px !important;
    font-size: 16px !important;  /* prevents iOS zoom on focus */
    padding: 8px 10px !important;
  }

  /* Buttons Touch-Optimiert */
  .btn, button {
    min-height: 40px;
    padding: 8px 14px !important;
  }

  /* Modals fullscreen auf Phone */
  .modal-overlay .modal,
  .settings-modal,
  #settings-modal .settings-modal-content {
    max-width: 100vw !important;
    max-height: 100vh !important;
    width: 100vw !important;
    border-radius: 0 !important;
    margin: 0 !important;
  }

  /* Settings-Tabs: Icons-only auf Mobile */
  .settings-tabs .st-tab { font-size: 0; padding: 10px 12px !important; }
  .settings-tabs .st-tab .st-tab-ico { margin-right: 0; width: 18px; height: 18px; }
  .settings-tabs .st-tab .st-tab-ico svg { width: 18px; height: 18px; }

  /* Workflow-Bar kompakter */
  .tabs-workflow-bar .wf-tab-title { font-size: 16px !important; }
  .tabs-workflow-bar .wf-tab-sub { font-size: 10px !important; }

  /* Header-Logo links kleiner */
  .hdr-bar img, .sb-dealpilot-logo { max-width: 140px !important; }
}

/* ─── Sehr kleine Phones (≤ 420px) ─── */
@media (max-width: 420px) {
  .body { padding: 8px !important; }
  .card { padding: 10px !important; }
  .tabs .tab { padding: 6px 8px !important; font-size: 11px !important; }
  .kpi-tile .kpi-val { font-size: 19px !important; }
  h1 { font-size: 18px !important; }
}

/* Mobile-Topbar standardmäßig ausgeblendet (nur < 768px sichtbar) */
.mobile-topbar { display: none; }

/* ═══════════════════════════════════════════════════════════════════
   V63.45: Chart-Cards — Pro-Stil mit fester Höhe & Premium-Look
   ═══════════════════════════════════════════════════════════════════ */
.chart-card {
  background: linear-gradient(180deg, #ffffff 0%, var(--surface) 100%);
  border: 1px solid rgba(201,168,76,0.15);
  border-radius: 12px;
  padding: 16px 18px 14px 18px;
  margin-bottom: 14px;
  position: relative;
  box-shadow: 0 2px 12px rgba(42,39,39,0.04);
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.chart-card:hover {
  box-shadow: 0 6px 20px rgba(42,39,39,0.08);
}
.chart-card .chart-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--ch);
  letter-spacing: 0.2px;
  margin-bottom: 12px;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}
.chart-card .chart-title::before {
  content: '';
  display: inline-block;
  width: 3px;
  height: 14px;
  background: var(--gold);
  border-radius: 2px;
  margin-right: 9px;
  vertical-align: middle;
}
.chart-card .chart-lbl {
  font-size: 10.5px;
  font-weight: 400;
  color: var(--muted, #7A7370);
  letter-spacing: 0;
}

/* Canvas-Container braucht feste Höhe damit Chart.js sauber rendert */
.chart-card canvas {
  width: 100% !important;
  max-width: 100% !important;
}
#cfChart    { height: 220px !important; }
#valChart   { height: 280px !important; }
#vermChart  { height: 280px !important; }
#scherChart { height: 320px !important; }

@media (max-width: 768px) {
  #cfChart    { height: 180px !important; }
  #valChart   { height: 220px !important; }
  #vermChart  { height: 220px !important; }
  #scherChart { height: 260px !important; }
  .chart-card { padding: 12px 14px 10px 14px; }
  .chart-card .chart-title { font-size: 12px; }
}

/* ═══════════════════════════════════════════════════════════════════
   V63.46: Import/Export-Modal — DealPilot-Stil
   ═══════════════════════════════════════════════════════════════════ */
.iexp-overlay {
  position: fixed; inset: 0;
  background: rgba(20, 18, 18, 0.55);
  backdrop-filter: blur(4px);
  z-index: 1100;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: iexpFadeIn 0.18s ease;
}
@keyframes iexpFadeIn { from { opacity: 0; } to { opacity: 1; } }

.iexp-modal {
  background: #fff;
  border-radius: 14px;
  width: 100%; max-width: 920px;
  max-height: calc(100vh - 48px);
  display: flex; flex-direction: column;
  box-shadow: 0 24px 60px rgba(0,0,0,0.32), 0 0 0 1px rgba(201,168,76,0.18);
  overflow: hidden;
  animation: iexpSlideUp 0.22s ease;
}
@keyframes iexpSlideUp { from { transform: translateY(12px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

.iexp-header {
  display: flex; align-items: flex-start; gap: 18px;
  padding: 22px 24px 18px 24px;
  border-bottom: 1px solid rgba(42,39,39,0.08);
  background: linear-gradient(180deg, var(--surface, #F8F6F1) 0%, #fff 100%);
}
.iexp-h-text { flex: 1; min-width: 0; }
.iexp-h-text h2 {
  margin: 0 0 4px 0;
  font-size: 19px; font-weight: 700;
  color: var(--ch, #2A2727);
  letter-spacing: -0.01em;
}
.iexp-h-text p {
  margin: 0;
  font-size: 13px; color: #7A7370;
}
.iexp-close {
  background: rgba(42,39,39,0.06);
  border: none; border-radius: 8px;
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--ch, #2A2727);
  transition: background 0.15s;
}
.iexp-close:hover { background: rgba(42,39,39,0.12); }

.iexp-body {
  flex: 1; min-height: 0;
  overflow-y: auto;
  padding: 22px 24px 26px 24px;
}

.iexp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}

.iexp-card {
  background: #fff;
  border: 1px solid rgba(42,39,39,0.10);
  border-radius: 12px;
  padding: 18px 18px 16px 18px;
  cursor: pointer;
  transition: all 0.18s ease;
  position: relative;
  display: flex; flex-direction: column;
}
.iexp-card:hover {
  border-color: var(--gold, #C9A84C);
  box-shadow: 0 8px 22px rgba(201,168,76,0.18);
  transform: translateY(-2px);
}
.iexp-card-ico {
  width: 44px; height: 44px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 12px;
}
.iexp-ico-blue   { background: rgba(60,102,148,0.12);  color: #3C6694; }
.iexp-ico-gold   { background: rgba(201,168,76,0.16);  color: var(--gold, #C9A84C); }
.iexp-ico-green  { background: rgba(63,165,108,0.14);  color: var(--green, #3FA56C); }
.iexp-ico-red    { background: rgba(184,98,92,0.12);   color: var(--red, #B8625C); }

.iexp-card-tag {
  font-size: 10px; font-weight: 700;
  letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--gold, #C9A84C);
  margin-bottom: 6px;
}
.iexp-card h3 {
  margin: 0 0 8px 0;
  font-size: 15px; font-weight: 700;
  color: var(--ch, #2A2727);
}
.iexp-card p {
  font-size: 12.5px; line-height: 1.5;
  color: #555050;
  margin: 0 0 8px 0;
}
.iexp-card .iexp-bullets {
  margin: 4px 0 8px 0;
  padding-left: 16px;
  font-size: 12px; color: #555050;
}
.iexp-card .iexp-bullets li { margin-bottom: 3px; line-height: 1.4; }
.iexp-card .iexp-warn {
  font-size: 11.5px; color: #B8625C;
  padding: 6px 8px;
  background: rgba(184,98,92,0.06);
  border-left: 2px solid rgba(184,98,92,0.4);
  border-radius: 3px;
  margin: 4px 0 0 0;
}
.iexp-card-cta {
  margin-top: auto; padding-top: 12px;
  font-size: 13px; font-weight: 600;
  color: var(--gold, #C9A84C);
  display: flex; align-items: center; justify-content: space-between;
  border-top: 1px solid rgba(201,168,76,0.18);
  padding-top: 10px;
}
.iexp-card-cta span {
  font-size: 18px; font-weight: 400;
  transition: transform 0.15s;
}
.iexp-card:hover .iexp-card-cta span { transform: translateX(3px); }

/* Stage 2: Objekt-Auswahl für PDF-Export */
.iexp-back {
  display: inline-block;
  margin-bottom: 14px;
  font-size: 13px; color: var(--gold, #C9A84C);
  cursor: pointer; font-weight: 500;
  padding: 4px 0;
}
.iexp-back:hover { text-decoration: underline; }
.iexp-stage-title {
  margin: 0 0 4px 0;
  font-size: 16px; font-weight: 700;
  color: var(--ch, #2A2727);
}
.iexp-stage-sub {
  margin: 0 0 16px 0;
  font-size: 13px; color: #7A7370;
}
/* V118: Choice-Row für JSON/Excel-Export-Auswahl (alle vs. einzeln) */
.iexp-choice-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 6px;
}
@media (max-width: 600px) {
  .iexp-choice-row { grid-template-columns: 1fr; }
}
.iexp-choice-btn {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  padding: 18px 18px 16px;
  background: var(--surface, #F8F6F1);
  border: 1.5px solid rgba(201,168,76,0.20);
  border-radius: 12px;
  cursor: pointer;
  text-align: left;
  transition: all 0.15s;
  font-family: inherit;
  color: var(--ch, #2A2727);
}
.iexp-choice-btn:hover {
  border-color: var(--gold, #C9A84C);
  background: #fff;
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(201,168,76,0.18);
}
.iexp-choice-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--gold, #C9A84C), #9a7f33);
  color: #1a1414;
  margin-bottom: 4px;
}
.iexp-choice-l {
  font-size: 14px;
  font-weight: 700;
  color: var(--ch, #2A2727);
  line-height: 1.3;
}
.iexp-choice-d {
  font-size: 12px;
  color: #7A7370;
  line-height: 1.4;
}
.iexp-obj-list {
  display: flex; flex-direction: column;
  gap: 8px;
}
.iexp-obj-row {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 16px;
  background: var(--surface, #F8F6F1);
  border: 1px solid rgba(42,39,39,0.08);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.15s;
}
.iexp-obj-row:hover {
  border-color: var(--gold, #C9A84C);
  background: #fff;
  box-shadow: 0 4px 12px rgba(201,168,76,0.12);
}
.iexp-obj-current {
  border-color: rgba(201,168,76,0.5) !important;
  background: rgba(201,168,76,0.06) !important;
}
.iexp-obj-info { flex: 1; min-width: 0; }
.iexp-obj-name {
  font-size: 14px; font-weight: 600;
  color: var(--ch, #2A2727);
  margin-bottom: 2px;
}
.iexp-obj-badge {
  display: inline-block;
  font-size: 9.5px; font-weight: 700;
  letter-spacing: 0.8px; text-transform: uppercase;
  color: var(--gold, #C9A84C);
  background: rgba(201,168,76,0.15);
  padding: 2px 7px;
  border-radius: 10px;
  margin-left: 6px;
}
.iexp-obj-sub {
  font-size: 12px; color: #7A7370;
}
.iexp-obj-kpi {
  font-size: 11.5px; color: #555050;
  margin-top: 2px;
}
.iexp-obj-arrow {
  font-size: 22px; color: var(--gold, #C9A84C);
  font-weight: 300;
}

.iexp-loading, .iexp-empty {
  text-align: center;
  padding: 40px 20px;
  font-size: 13px; color: #7A7370;
}

/* Mobile */
@media (max-width: 768px) {
  .iexp-overlay { padding: 0; }
  .iexp-modal {
    border-radius: 0;
    max-width: 100%;
    max-height: 100vh;
    height: 100vh;
  }
  .iexp-grid { grid-template-columns: 1fr; }
  .iexp-header { padding: 16px 18px 14px 18px; }
  .iexp-h-text h2 { font-size: 17px; }
  .iexp-body { padding: 16px 18px 22px 18px; }
}

/* ═══════════════════════════════════════════════════════════════════
   V63.50: Button-Styles in den Content-Bereichen lesbar machen.
   ".btn-ghost" wurde original für den dunklen Header gebaut (weiß auf
   charcoal). In den Cards (heller Hintergrund) ist das unsichtbar.
   Lösung: spezifischer Selektor für Buttons innerhalb von .card.
   ═══════════════════════════════════════════════════════════════════ */
.card .btn-ghost,
.sec .btn-ghost {
  background: rgba(201, 168, 76, 0.06);
  color: var(--gold, #C9A84C) !important;
  border: 1px solid rgba(201, 168, 76, 0.35);
  font-weight: 600;
  padding: 7px 14px;
  border-radius: 7px;
  cursor: pointer;
  transition: all 0.15s ease;
  font-size: 12.5px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.card .btn-ghost:hover,
.sec .btn-ghost:hover {
  background: var(--gold, #C9A84C);
  color: #fff !important;
  border-color: var(--gold, #C9A84C);
  box-shadow: 0 2px 8px rgba(201, 168, 76, 0.30);
}
.card .btn-ghost.btn-sm,
.sec .btn-ghost.btn-sm {
  padding: 6px 12px;
  font-size: 12px;
}

/* Primary-Button für Modals */
.btn-primary {
  background: var(--gold, #C9A84C);
  color: #fff !important;
  border: 1px solid var(--gold, #C9A84C);
  font-weight: 600;
  padding: 8px 18px;
  border-radius: 7px;
  cursor: pointer;
  transition: all 0.15s ease;
  font-size: 13px;
}
.btn-primary:hover {
  background: #b8932f;
  border-color: #b8932f;
  box-shadow: 0 4px 12px rgba(201, 168, 76, 0.35);
}
.btn-primary.btn-sm { padding: 7px 14px; font-size: 12px; }
/* ═══════════════════════════════════════════════════════════════
   V25 — BANK-CHARTS STYLES (4 SVG-basierte Charts)
   ═══════════════════════════════════════════════════════════════ */

/* Card-Container */
.bc-card {
  background: #FAFAF7;
  border-radius: 14px;
  border: 1px solid rgba(42,39,39,0.08);
  box-shadow: 0 8px 28px rgba(0,0,0,0.06);
  margin-bottom: 22px;
  overflow: hidden;
  position: relative;
}
.bc-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 0%, var(--gold) 25%, #E2C97E 50%, var(--gold) 75%, transparent 100%);
  z-index: 5;
  pointer-events: none;
}

/* Header */
.bc-head {
  padding: 22px 32px 18px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  border-bottom: 1px solid rgba(42,39,39,0.08);
  flex-wrap: wrap;
}
.bc-head-left { flex: 1; min-width: 0; }
.bc-head-eyebrow {
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #A68A36;
  font-weight: 700;
  margin-bottom: 5px;
  display: flex;
  align-items: center;
  gap: 7px;
}
.bc-head-eyebrow::before {
  content: '';
  width: 14px; height: 1.5px;
  background: var(--gold);
}
.bc-head-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px;
  font-weight: 600;
  color: var(--ch);
  letter-spacing: -0.005em;
  line-height: 1.15;
  margin: 0 0 4px 0;
}
.bc-head-title .accent {
  color: var(--gold);
  font-weight: 700;
}
.bc-head-sub {
  font-size: 13px;
  color: rgba(42,39,39,0.55);
  line-height: 1.5;
  max-width: 600px;
  margin: 0;
}
.bc-head-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  min-width: 160px;
}
.bc-headline-kpi-label {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(42,39,39,0.55);
  font-weight: 600;
}
.bc-headline-kpi {
  font-family: 'Cormorant Garamond', serif;
  font-size: 34px;
  font-weight: 700;
  color: #2D7B4F;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.015em;
  line-height: 1;
}
.bc-headline-kpi-trend {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(63,165,108,0.10);
  color: #2D7B4F;
  padding: 3px 9px;
  border-radius: 99px;
  font-size: 10.5px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  margin-top: 4px;
}

/* Body */
.bc-body {
  padding: 24px 32px 28px;
  background:
    radial-gradient(circle at 0% 100%, rgba(63,165,108,0.04) 0%, transparent 40%),
    radial-gradient(circle at 100% 0%, rgba(184,98,92,0.03) 0%, transparent 40%);
}
.bc-body-pad {
  padding: 32px 40px 32px;
  background: transparent;
}
.bc-body-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  padding: 0;
  background: transparent;
}
.bc-side {
  padding: 24px 32px;
}
.bc-side + .bc-side {
  border-left: 1px solid rgba(42,39,39,0.08);
}

/* SVG-Wrapper */
.bc-svg-wrap {
  position: relative;
  width: 100%;
  height: 380px;
}
.bc-svg-wrap svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* Empty-State */
.bc-empty {
  padding: 60px 24px;
  text-align: center;
  color: rgba(42,39,39,0.45);
  font-size: 13px;
  font-style: italic;
}

/* Legend */
.bc-legend {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-top: 18px;
  flex-wrap: wrap;
}
.bc-legend-item {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 12px;
  color: var(--ch);
  font-weight: 500;
}
.bc-legend-dot {
  width: 12px; height: 12px;
  border-radius: 3px;
  flex-shrink: 0;
}

/* Footer-KPIs */
.bc-footer-grid {
  display: grid;
  border-top: 1px solid rgba(42,39,39,0.08);
  background: rgba(42,39,39,0.02);
}
.bc-footer-4 { grid-template-columns: repeat(4, 1fr); }
.bc-footer-5 { grid-template-columns: repeat(5, 1fr); }
.bc-footer-3 { grid-template-columns: 2fr 1fr 1fr; }
.bc-footer-cell {
  padding: 16px 22px;
  border-right: 1px solid rgba(42,39,39,0.06);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.bc-footer-cell:last-child { border-right: none; }
.bc-footer-cell-highlight {
  background: linear-gradient(135deg, rgba(201,168,76,0.10) 0%, rgba(201,168,76,0.04) 100%);
}
.bc-footer-label {
  font-size: 9.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(42,39,39,0.55);
  font-weight: 700;
}
.bc-footer-value {
  font-size: 18px;
  font-weight: 700;
  color: var(--ch);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.005em;
}
.bc-footer-cell .bc-footer-value.green { color: #2D7B4F; }
.bc-footer-cell .bc-footer-value.gold { color: #A68A36; }
.bc-footer-cell .bc-footer-value.red { color: var(--red, #B8625C); }
.bc-footer-sub {
  font-size: 10.5px;
  color: rgba(42,39,39,0.55);
  font-weight: 500;
  line-height: 1.4;
}
.bc-footer-wide .bc-footer-value {
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px;
  letter-spacing: -0.015em;
}

/* ═══ COCKPIT-Spezifische Styles ═══ */
.bc-kpi-label {
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(42,39,39,0.55);
  font-weight: 600;
  margin-bottom: 14px;
}
.bc-kpi-headline {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 4px;
}
.bc-kpi-headline-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 44px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  line-height: 1;
}
.bc-kpi-headline-num.green { color: #2D7B4F; }
.bc-kpi-headline-num.gold { color: #A68A36; }
.bc-kpi-headline-num.red { color: #B8625C; }
.bc-kpi-status {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 99px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.bc-kpi-status::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.bc-kpi-status-good {
  background: rgba(63,165,108,0.10);
  color: #2D7B4F;
  border: 1px solid rgba(63,165,108,0.25);
}
.bc-kpi-status-ok {
  background: rgba(63,165,108,0.10);
  color: #2D7B4F;
  border: 1px solid rgba(63,165,108,0.25);
}
.bc-kpi-status-warn {
  background: rgba(201,168,76,0.10);
  color: #A68A36;
  border: 1px solid rgba(201,168,76,0.30);
}
.bc-kpi-status-bad,
.bc-kpi-status-critical {
  background: rgba(184,98,92,0.10);
  color: #B8625C;
  border: 1px solid rgba(184,98,92,0.25);
}

/* Track-Visualisierung */
.bc-kpi-track {
  position: relative;
  height: 60px;
  margin: 18px 0 8px;
}
.bc-kpi-track-bar {
  position: absolute;
  top: 28px;
  left: 0; right: 0;
  height: 8px;
  border-radius: 4px;
  overflow: hidden;
}
.bc-kpi-track-bar-dscr {
  /* DSCR Skala 0..2.0 → Marker bei dscr/2.0×100. Schwellen: <1.0 rot (=50%), 1.0-1.2 gold (50-60%), ≥1.2 grün */
  background: linear-gradient(90deg,
    rgba(184,98,92,0.20) 0%, rgba(184,98,92,0.20) 50%,
    rgba(201,168,76,0.20) 50%, rgba(201,168,76,0.20) 60%,
    rgba(63,165,108,0.20) 60%, rgba(63,165,108,0.20) 100%);
}
.bc-kpi-track-bar-ltv {
  /* V63.65: System-Schwellen ≤60 grün/sehr sicher · ≤85 grün/solide · ≤100 gold/erhöht · >100 rot */
  background: linear-gradient(90deg,
    rgba(63,165,108,0.20) 0%, rgba(63,165,108,0.20) 60%,
    rgba(63,165,108,0.20) 60%, rgba(63,165,108,0.20) 85%,
    rgba(201,168,76,0.20) 85%, rgba(201,168,76,0.20) 100%);
}
.bc-kpi-track-marker {
  position: absolute;
  top: 22px;
  width: 4px;
  height: 20px;
  background: var(--ch);
  border-radius: 2px;
  transform: translateX(-50%);
  box-shadow: 0 0 0 3px rgba(255,255,255,0.95), 0 4px 8px rgba(0,0,0,0.20);
  z-index: 3;
}
.bc-kpi-track-marker::after {
  content: attr(data-val);
  position: absolute;
  top: -22px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--ch);
  color: #fff;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 10.5px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.bc-kpi-track-marker::before {
  content: '';
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translateX(-50%);
  border: 4px solid transparent;
  border-top-color: var(--ch);
}
.bc-kpi-track-scale {
  position: absolute;
  top: 42px;
  left: 0; right: 0;
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  color: rgba(42,39,39,0.55);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}
.bc-kpi-track-scale span:nth-child(1) { color: var(--red, #B8625C); font-weight: 700; }
.bc-kpi-track-scale span:nth-child(4) { color: #2D7B4F; font-weight: 700; }

/* Trend */
.bc-kpi-trend {
  margin-top: 24px;
  padding-top: 18px;
  border-top: 1px solid rgba(42,39,39,0.06);
}
.bc-kpi-trend-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.bc-kpi-trend-label {
  font-size: 10.5px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(42,39,39,0.55);
  font-weight: 600;
}
.bc-kpi-trend-direction {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 700;
}
.bc-kpi-trend-direction.up { color: #2D7B4F; }
.bc-kpi-trend-direction.down { color: var(--red, #B8625C); }
.bc-mini-trend-svg {
  width: 100%;
  height: 100px;
  display: block;
}
.bc-kpi-trend-bench {
  display: flex;
  justify-content: space-between;
  margin-top: 14px;
  font-size: 10.5px;
}
.bc-kpi-trend-bench-cell {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.bc-kpi-trend-bench-label {
  color: rgba(42,39,39,0.55);
  font-size: 9.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 600;
}
.bc-kpi-trend-bench-val {
  font-size: 14px;
  font-weight: 700;
  color: var(--ch);
  font-variant-numeric: tabular-nums;
}
.bc-kpi-trend-bench-val.end { color: #2D7B4F; }
.bc-kpi-trend-bench-val.red { color: #B8625C; }

/* Bank-Tag (Zitat) */
.bc-bank-tag {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  background: linear-gradient(180deg, rgba(63,165,108,0.10) 0%, rgba(63,165,108,0.04) 100%);
  border: 1px solid rgba(63,165,108,0.30);
  border-left: 3px solid var(--green, #3FA56C);
  padding: 9px 13px;
  border-radius: 6px;
  font-size: 11.5px;
  color: var(--ch);
  margin-top: 16px;
  line-height: 1.4;
}
.bc-bank-tag.bc-bank-tag-warn,
.bc-stress-footer .bc-bank-tag {
  background: linear-gradient(180deg, rgba(201,168,76,0.10) 0%, rgba(201,168,76,0.04) 100%);
  border-color: rgba(201,168,76,0.30);
  border-left-color: var(--gold);
}
.bc-bank-tag svg {
  width: 14px; height: 14px;
  flex-shrink: 0;
  margin-top: 1px;
  color: #2D7B4F;
}
.bc-bank-tag.bc-bank-tag-warn svg,
.bc-stress-footer .bc-bank-tag svg { color: #A68A36; }
.bc-bank-tag strong { font-weight: 700; }

/* ═══ STRESS-MATRIX ═══ */
.bc-matrix-wrap {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 0;
}
.bc-matrix-axis-y {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0;
  padding-right: 14px;
  padding-bottom: 50px;
}
.bc-matrix-axis-y-label {
  font-size: 9.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #A68A36;
  font-weight: 700;
  margin-bottom: 12px;
  text-align: right;
}
.bc-matrix-axis-y-row {
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  font-size: 12px;
  color: var(--ch);
  font-weight: 600;
  text-align: right;
}
.bc-matrix-axis-y-row .bc-delta {
  font-size: 10.5px;
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  color: rgba(42,39,39,0.55);
}
.bc-matrix-axis-y-row.bad .bc-delta { color: var(--red, #B8625C); }
.bc-matrix-axis-y-row.good .bc-delta { color: #2D7B4F; }

.bc-matrix-grid {
  display: grid;
  grid-template-rows: auto repeat(5, 100px) auto;
}
.bc-matrix-axis-x-label {
  font-size: 9.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #A68A36;
  font-weight: 700;
  text-align: center;
  margin-bottom: 12px;
}
.bc-matrix-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
}
.bc-matrix-cell {
  position: relative;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 10px 8px;
  border: 1px solid transparent;
  transition: all 0.2s ease;
}
.bc-matrix-cell:hover {
  transform: scale(1.04);
  z-index: 5;
  box-shadow: 0 8px 20px rgba(0,0,0,0.15);
}
.bc-matrix-cell-val {
  font-size: 16px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--ch);
  line-height: 1;
  letter-spacing: -0.01em;
}
.bc-matrix-cell-label {
  font-size: 9px;
  font-weight: 600;
  margin-top: 4px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(42,39,39,0.55);
}
.bc-matrix-cell.s-good { background: linear-gradient(135deg, rgba(63,165,108,0.35) 0%, rgba(63,165,108,0.18) 100%); border-color: rgba(63,165,108,0.40); }
.bc-matrix-cell.s-good .bc-matrix-cell-val { color: #2D7B4F; }
.bc-matrix-cell.s-ok { background: linear-gradient(135deg, rgba(63,165,108,0.18) 0%, rgba(63,165,108,0.08) 100%); border-color: rgba(63,165,108,0.25); }
.bc-matrix-cell.s-ok .bc-matrix-cell-val { color: #2D7B4F; }
.bc-matrix-cell.s-warn { background: linear-gradient(135deg, rgba(201,168,76,0.20) 0%, rgba(201,168,76,0.08) 100%); border-color: rgba(201,168,76,0.30); }
.bc-matrix-cell.s-warn .bc-matrix-cell-val { color: #A68A36; }
.bc-matrix-cell.s-bad { background: linear-gradient(135deg, rgba(184,98,92,0.20) 0%, rgba(184,98,92,0.08) 100%); border-color: rgba(184,98,92,0.30); }
.bc-matrix-cell.s-bad .bc-matrix-cell-val { color: var(--red, #B8625C); }
.bc-matrix-cell.s-critical { background: linear-gradient(135deg, rgba(184,98,92,0.40) 0%, rgba(184,98,92,0.20) 100%); border-color: rgba(184,98,92,0.50); }
.bc-matrix-cell.s-critical .bc-matrix-cell-val { color: #8E3F39; }
.bc-matrix-cell.is-base {
  border-width: 2.5px;
  border-color: var(--gold) !important;
  box-shadow: 0 0 0 3px rgba(201,168,76,0.18), 0 4px 16px rgba(201,168,76,0.30);
}
.bc-matrix-cell.is-base::before {
  content: 'BASE';
  position: absolute;
  top: -9px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--gold);
  color: #1A1414;
  font-size: 8.5px;
  font-weight: 800;
  padding: 2px 7px;
  border-radius: 3px;
  letter-spacing: 0.10em;
}
.bc-matrix-axis-x {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
  padding-top: 14px;
}
.bc-matrix-axis-x-cell {
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: var(--ch);
}
.bc-matrix-axis-x-cell .bc-delta {
  font-size: 10.5px;
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  display: block;
  margin-top: 2px;
}
.bc-matrix-axis-x-cell.bad .bc-delta { color: var(--red, #B8625C); }
.bc-matrix-axis-x-cell.good .bc-delta { color: #2D7B4F; }

.bc-stress-footer {
  margin-top: 30px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 22px;
  border-top: 1px solid rgba(42,39,39,0.08);
  flex-wrap: wrap;
  gap: 16px;
}
.bc-legend-scale {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.bc-legend-chip {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--ch);
  font-weight: 500;
}
.bc-legend-chip-dot {
  width: 16px; height: 16px;
  border-radius: 4px;
  border: 1px solid;
}
.bc-stress-footer .bc-bank-tag {
  flex: 1;
  min-width: 350px;
  margin-top: 0;
}

/* Mobile-Responsive */
@media (max-width: 900px) {
  .bc-body-2col { grid-template-columns: 1fr; }
  .bc-side + .bc-side { border-left: none; border-top: 1px solid rgba(42,39,39,0.08); }
  .bc-footer-4 { grid-template-columns: 1fr 1fr; }
  .bc-footer-5 { grid-template-columns: 1fr 1fr; }
  .bc-footer-3 { grid-template-columns: 1fr; }
  .bc-footer-cell { border-right: none; border-bottom: 1px solid rgba(42,39,39,0.06); }
  .bc-matrix-wrap { grid-template-columns: 100px 1fr; }
  .bc-matrix-cell-val { font-size: 13px; }
}

/* PDF-print: Schatten und Effekte raus, optimiert für DIN-A4 */
@media print {
  .bc-card { box-shadow: none; break-inside: avoid; }
  .bc-card::before { background: var(--gold); }
}

/* V25 — Bank-Präsentation Section-Header */
.bc-section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin: 28px 0 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(201,168,76,0.25);
}
.bc-section-eyebrow {
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #A68A36;
  font-weight: 700;
  margin-bottom: 5px;
  display: flex;
  align-items: center;
  gap: 7px;
}
.bc-section-eyebrow::before {
  content: '';
  width: 14px; height: 1.5px;
  background: var(--gold);
}
.bc-section-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px;
  font-weight: 600;
  color: var(--ch);
  margin: 0;
  letter-spacing: -0.005em;
  flex: 1;
  min-width: 0;
}
.bc-pdf-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  background: linear-gradient(180deg, #D4B259 0%, #B8973F 100%);
  color: #1A1414;
  border: none;
  border-radius: 8px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(201,168,76,0.25);
  transition: all 0.15s ease;
  white-space: nowrap;
}
.bc-pdf-btn:hover {
  background: linear-gradient(180deg, #DEC069 0%, #C2A148 100%);
  box-shadow: 0 6px 20px rgba(201,168,76,0.35);
  transform: translateY(-1px);
}
.bc-pdf-btn:disabled {
  opacity: 0.5;
  cursor: wait;
  transform: none;
}
.bc-pdf-btn [data-ico] svg { vertical-align: middle; }

/* ═══════════════════════════════════════════════════════════════
   V63.70 — User-Hilfe-Modal
═══════════════════════════════════════════════════════════════ */
.help-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: rgba(20, 18, 18, 0.78);
  backdrop-filter: blur(6px);
  align-items: center;
  justify-content: center;
  padding: 20px;
}
/* V122: Cream-Classic-Override (wie Einstellungen) — heller Hintergrund, schwarzer Text.
   Marcel: "Bei den Einstellungen ist der Text halt in schwarz. Das musst du ändern."
   Layout-Struktur (Sidebar + Content + AI-Foot) bleibt wie bisher. */
.help-modal.global-view-overlay {
  background: rgba(42, 39, 39, 0.55);
  backdrop-filter: blur(4px);
  padding: 24px;
}
.help-modal.global-view-overlay .help-modal-inner.global-view-modal {
  background: #FAFAF7 !important;
  color: var(--ch, #2A2727) !important;
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 14px;
  width: 100%;
  max-width: 1180px !important;
  height: auto;
  max-height: 92vh;
  display: grid;
  grid-template-columns: 280px 1fr;
  grid-template-rows: 1fr;
  overflow: hidden;
  box-shadow: 0 24px 70px rgba(0,0,0,0.35);
  flex-direction: unset;
  padding: 0 !important;
}
@media (max-width: 800px) {
  .help-modal.global-view-overlay .help-modal-inner.global-view-modal {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
    max-height: 96vh;
  }
}

/* V123: Sidebar (links) — DUNKEL Pure-Obsidian wie ursprünglich gewünscht.
   Content rechts bleibt cream/hell mit schwarzem Text. */
.help-modal.global-view-overlay .help-modal-side {
  background: linear-gradient(180deg, #1A1717 0%, #131010 100%);
  border-right: 1px solid rgba(201,168,76,0.25);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 0;
}
.help-modal.global-view-overlay .help-modal-side .ms-h {
  padding: 18px 22px 12px;
  border-bottom: 1px solid rgba(201,168,76,0.18);
  background: linear-gradient(180deg, rgba(201,168,76,0.05), transparent);
}
.help-modal.global-view-overlay .help-modal-side .ms-title {
  display: flex; align-items: center; gap: 10px;
  font-size: 17px; font-weight: 700;
  color: rgba(255,255,255,0.92);
}
.help-modal.global-view-overlay .help-modal-side .ms-title .gold { color: var(--gold, #C9A84C); }
.help-modal.global-view-overlay .help-modal-side .ms-title .ic { color: var(--gold, #C9A84C); }
.help-modal.global-view-overlay .help-modal-side .ms-sub {
  font-size: 11.5px;
  color: rgba(255,255,255,0.55);
  margin-top: 4px;
}
.help-modal.global-view-overlay .help-modal-side .help-modal-search {
  padding: 12px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background: rgba(0,0,0,0.20);
}
.help-modal.global-view-overlay .help-modal-side .help-modal-search input {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid rgba(201,168,76,0.20);
  border-radius: 8px;
  background: rgba(255,255,255,0.04);
  font-size: 13px;
  font-family: inherit;
  color: rgba(255,255,255,0.92);
}
.help-modal.global-view-overlay .help-modal-side .help-modal-search input::placeholder {
  color: rgba(255,255,255,0.40);
}
.help-modal.global-view-overlay .help-modal-side .help-modal-search input:focus {
  outline: 0;
  border-color: var(--gold, #C9A84C);
  box-shadow: 0 0 0 3px rgba(201,168,76,0.15);
}
.help-modal.global-view-overlay .help-sidebar-list {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 8px;
}
.help-modal.global-view-overlay .help-sidebar-item {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 2px;
  padding: 9px 12px !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  border-radius: 8px;
  cursor: pointer;
  text-align: left;
  transition: all 0.12s;
  color: rgba(255,255,255,0.85) !important;
  font-family: inherit;
  width: 100%;
}
.help-modal.global-view-overlay .help-sidebar-item:hover {
  background: rgba(201,168,76,0.10) !important;
  border-color: rgba(201,168,76,0.22) !important;
  color: rgba(255,255,255,0.95) !important;
}
.help-modal.global-view-overlay .help-sidebar-item.active,
.help-modal.global-view-overlay .help-sidebar-item.help-sidebar-item-active {
  background: linear-gradient(135deg, rgba(201,168,76,0.22), rgba(201,168,76,0.08)) !important;
  border-color: rgba(201,168,76,0.50) !important;
  box-shadow: 0 2px 10px rgba(201,168,76,0.20);
}
.help-modal.global-view-overlay .help-sidebar-item-row {
  display: flex;
  align-items: center;
  gap: 9px;
  width: 100%;
}
.help-modal.global-view-overlay .help-sidebar-item-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 6px;
  background: rgba(201,168,76,0.14);
  color: var(--gold, #C9A84C);
  flex-shrink: 0;
  transition: all 0.12s;
}
.help-modal.global-view-overlay .help-sidebar-item-icon svg {
  stroke: currentColor;
  fill: none;
}
.help-modal.global-view-overlay .help-sidebar-item.active .help-sidebar-item-icon,
.help-modal.global-view-overlay .help-sidebar-item.help-sidebar-item-active .help-sidebar-item-icon {
  background: linear-gradient(135deg, var(--gold, #C9A84C), #9a7f33);
  color: #1a1414;
}
.help-modal.global-view-overlay .help-sidebar-item-title {
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,0.92) !important;
}
.help-modal.global-view-overlay .help-sidebar-item.active .help-sidebar-item-title,
.help-modal.global-view-overlay .help-sidebar-item.help-sidebar-item-active .help-sidebar-item-title {
  color: var(--gold, #C9A84C) !important;
}
.help-modal.global-view-overlay .help-sidebar-item-desc {
  font-size: 10.5px;
  color: rgba(255,255,255,0.50) !important;
  font-weight: 400;
  line-height: 1.35;
  margin-left: 33px;
}

/* Content (rechts) — Cream-Classic */
.help-modal.global-view-overlay .help-modal-content {
  display: grid;
  grid-template-rows: 1fr auto;
  overflow: hidden;
  background: #FAFAF7;
  position: relative;
}
.help-modal.global-view-overlay .help-modal-content .set-modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 36px;
  height: 36px;
  background: rgba(42,39,39,0.06);
  border: 1px solid rgba(42,39,39,0.10);
  border-radius: 9px;
  cursor: pointer;
  color: rgba(42,39,39,0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: all 0.15s;
}
.help-modal.global-view-overlay .help-modal-content .set-modal-close:hover {
  background: rgba(184,98,92,0.12);
  border-color: rgba(184,98,92,0.30);
  color: #B8625C;
}
.help-modal.global-view-overlay .help-content-wrap {
  overflow-y: auto;
  padding: 26px 32px 18px;
}
.help-modal.global-view-overlay .help-content {
  color: var(--ch, #2A2727) !important;
  background: transparent;
}

/* Topic-Headline mit Icon */
.help-modal.global-view-overlay .help-topic-head {
  margin-bottom: 18px !important;
  padding-bottom: 14px !important;
  border-bottom: 1px solid rgba(42,39,39,0.10) !important;
}
.help-modal.global-view-overlay .help-topic-head-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 4px;
}
.help-modal.global-view-overlay .help-topic-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 9px;
  background: linear-gradient(135deg, rgba(201,168,76,0.20), rgba(201,168,76,0.06));
  border: 1px solid rgba(201,168,76,0.35);
  color: var(--gold, #C9A84C);
  flex-shrink: 0;
}
.help-modal.global-view-overlay .help-topic-icon svg {
  stroke: currentColor;
  fill: none;
}
.help-modal.global-view-overlay .help-modal-inner.global-view-modal h2,
.help-modal.global-view-overlay .help-topic-head h2 {
  font-size: 24px !important;
  color: var(--ch, #2A2727) !important;
  margin: 0 !important;
  font-weight: 700 !important;
  font-family: inherit !important;
}
.help-modal.global-view-overlay .help-topic-desc {
  color: #7A7370 !important;
  font-size: 14px !important;
  margin: 0 0 18px 0 !important;
}

/* Section-Karten — weiß auf cream, schwarzer Text */
.help-modal.global-view-overlay .help-section {
  margin-bottom: 16px !important;
  padding: 16px 18px !important;
  background: #fff !important;
  border: 1px solid rgba(201,168,76,0.25) !important;
  border-radius: 10px !important;
}
.help-modal.global-view-overlay .help-section h3 {
  font-size: 14.5px !important;
  font-weight: 700 !important;
  color: var(--gold, #C9A84C) !important;
  margin: 0 0 10px 0 !important;
}
.help-modal.global-view-overlay .help-section-body,
.help-modal.global-view-overlay .help-section-body p,
.help-modal.global-view-overlay .help-section-body div,
.help-modal.global-view-overlay .help-section-body span,
.help-modal.global-view-overlay .help-section-body li {
  font-size: 13.5px !important;
  line-height: 1.6 !important;
  color: var(--ch, #2A2727) !important;
}
.help-modal.global-view-overlay .help-section-body strong,
.help-modal.global-view-overlay .help-section-body b {
  color: #1a1414 !important;
  font-weight: 700 !important;
}
.help-modal.global-view-overlay .help-section-body code {
  background: rgba(201,168,76,0.15) !important;
  color: #6a5a25 !important;
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 12.5px;
}

/* AI-Foot — Cream */
.help-modal.global-view-overlay .help-ai-foot {
  border-top: 1px solid rgba(201,168,76,0.15);
  padding: 14px 22px;
  background: rgba(201,168,76,0.04);
}
.help-modal.global-view-overlay .help-ai-bar {
  display: flex; gap: 10px; align-items: center;
}
.help-modal.global-view-overlay .help-ai-bar input {
  flex: 1;
  padding: 10px 14px;
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 8px;
  background: #fff;
  font-size: 13px;
  color: var(--ch, #2A2727);
}
.help-modal.global-view-overlay .help-ai-bar input::placeholder {
  color: rgba(42,39,39,0.45);
}
.help-modal.global-view-overlay .help-ai-bar input:focus {
  outline: 0;
  border-color: var(--gold, #C9A84C);
  box-shadow: 0 0 0 3px rgba(201,168,76,0.15);
}
.help-modal.global-view-overlay .help-ai-btn {
  padding: 10px 18px;
  background: linear-gradient(135deg, var(--gold, #C9A84C), #9a7f33);
  color: #1a1414;
  border: 0;
  border-radius: 8px;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  transition: all 0.15s;
}
.help-modal.global-view-overlay .help-ai-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(201,168,76,0.40);
}
.help-modal.global-view-overlay .help-ai-response {
  margin-top: 10px;
  font-size: 13px;
  color: var(--ch, #2A2727);
  max-height: 200px;
  overflow-y: auto;
}
.help-modal.global-view-overlay .help-ai-response:empty { display: none; }
.help-modal.help-modal-open { display: flex; animation: helpFadeIn 0.18s ease; }
@keyframes helpFadeIn { from { opacity: 0; } to { opacity: 1; } }

.help-modal-inner {
  background: #1A1717;
  color: rgba(255,255,255,0.92);
  border-radius: 14px;
  width: 100%;
  max-width: 1100px;
  height: 100%;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,0.6);
  border: 1px solid rgba(201,168,76,0.18);
}

.help-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 22px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background: linear-gradient(180deg, rgba(201,168,76,0.06), transparent);
}
.help-modal-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 22px;
  font-weight: 600;
  color: var(--gold);
}
.help-modal-icon { font-size: 22px; }
.help-modal-close {
  background: rgba(255,255,255,0.06);
  border: none;
  color: rgba(255,255,255,0.7);
  width: 34px;
  height: 34px;
  border-radius: 8px;
  font-size: 22px;
  cursor: pointer;
  line-height: 1;
  transition: all 0.15s;
}
.help-modal-close:hover { background: rgba(255,255,255,0.12); color: #fff; }

.help-modal-search {
  padding: 14px 22px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.help-modal-search input {
  width: 100%;
  padding: 11px 14px;
  background: rgba(255,255,255,0.05);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 8px;
  font-size: 14px;
  outline: none;
  transition: border-color 0.15s;
}
.help-modal-search input:focus { border-color: var(--gold); }
.help-modal-search input::placeholder { color: rgba(255,255,255,0.40); }

.help-modal-body {
  flex: 1;
  display: grid;
  grid-template-columns: 280px 1fr;
  overflow: hidden;
}

.help-sidebar {
  background: rgba(255,255,255,0.02);
  border-right: 1px solid rgba(255,255,255,0.06);
  overflow-y: auto;
  padding: 12px 8px;
}
.help-sidebar-item {
  display: block;
  width: 100%;
  text-align: left;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 8px;
  padding: 10px 12px;
  margin-bottom: 4px;
  cursor: pointer;
  color: rgba(255,255,255,0.78);
  transition: all 0.14s;
}
.help-sidebar-item:hover {
  background: rgba(255,255,255,0.05);
  color: #fff;
}
.help-sidebar-item-active {
  background: rgba(201,168,76,0.14) !important;
  border-color: rgba(201,168,76,0.30) !important;
  color: var(--gold) !important;
}
.help-sidebar-item-title {
  display: block;
  font-weight: 600;
  font-size: 13.5px;
  margin-bottom: 2px;
}
.help-sidebar-item-desc {
  display: block;
  font-size: 11.5px;
  color: rgba(255,255,255,0.45);
}
.help-sidebar-item-active .help-sidebar-item-desc { color: rgba(201,168,76,0.65); }

.help-content {
  overflow-y: auto;
  padding: 24px 30px;
}
.help-topic-head {
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.help-topic-head h2 {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 26px;
  font-weight: 600;
  color: var(--gold);
  margin: 0 0 4px;
}
.help-topic-desc {
  color: rgba(255,255,255,0.55);
  font-size: 13.5px;
  margin: 0;
}

.help-section {
  margin-bottom: 22px;
  padding: 14px 18px;
  background: rgba(255,255,255,0.025);
  border-radius: 8px;
  border-left: 2px solid rgba(201,168,76,0.40);
}
.help-section h3 {
  margin: 0 0 8px;
  color: var(--gold);
  font-size: 15px;
  font-weight: 700;
}
.help-section-body {
  color: rgba(255,255,255,0.85);
  font-size: 13.5px;
  line-height: 1.6;
}
.help-section-body p { margin: 0 0 8px; }
.help-section-body p:last-child { margin-bottom: 0; }
.help-section-body strong { color: rgba(255,255,255,1); font-weight: 700; }
.help-section-body code {
  background: rgba(255,255,255,0.06);
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 12.5px;
  color: #E2C97E;
}

.help-section-hit {
  border-left-color: var(--green);
}
.help-hit-topic {
  font-size: 11px;
  letter-spacing: 0.06em;
  color: rgba(63,165,108,0.80);
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 4px;
}

.help-empty {
  text-align: center;
  padding: 40px 20px;
  color: rgba(255,255,255,0.55);
}
.help-empty h2 {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 22px;
  color: rgba(255,255,255,0.75);
  margin: 0 0 8px;
}

.help-modal-foot {
  border-top: 1px solid rgba(255,255,255,0.06);
  padding: 14px 22px;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,0.02));
}
.help-ai-bar {
  display: flex;
  gap: 10px;
}
.help-ai-bar input {
  flex: 1;
  padding: 10px 12px;
  background: rgba(255,255,255,0.05);
  color: #fff;
  border: 1px solid rgba(201,168,76,0.20);
  border-radius: 8px;
  font-size: 13.5px;
  outline: none;
}
.help-ai-bar input::placeholder { color: rgba(255,255,255,0.35); }
.help-ai-bar input:focus { border-color: var(--gold); }
.help-ai-btn {
  background: var(--gold);
  color: #1A1414;
  border: none;
  padding: 0 18px;
  border-radius: 8px;
  font-weight: 700;
  cursor: pointer;
  font-size: 13.5px;
  transition: opacity 0.15s;
}
.help-ai-btn:hover { opacity: 0.88; }
.help-ai-btn:disabled { opacity: 0.5; cursor: wait; }

.help-ai-response { margin-top: 12px; }
.help-ai-response:empty { margin-top: 0; }
.help-ai-hint, .help-ai-error, .help-ai-loading, .help-ai-answer {
  padding: 10px 14px;
  border-radius: 6px;
  font-size: 13px;
  line-height: 1.55;
}
.help-ai-hint { background: rgba(255,255,255,0.04); color: rgba(255,255,255,0.55); }
.help-ai-loading {
  display: flex;
  align-items: center;
  gap: 4px;
  background: rgba(201,168,76,0.06);
  color: rgba(255,255,255,0.7);
}
.help-ai-loading-text { margin-left: 8px; font-size: 12.5px; }
.help-ai-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--gold);
  display: inline-block;
  animation: helpDot 1.4s infinite ease-in-out;
}
.help-ai-dot:nth-child(2) { animation-delay: 0.2s; }
.help-ai-dot:nth-child(3) { animation-delay: 0.4s; }
@keyframes helpDot {
  0%, 60%, 100% { opacity: 0.3; transform: scale(0.85); }
  30% { opacity: 1; transform: scale(1); }
}
.help-ai-error {
  background: rgba(184,98,92,0.10);
  color: rgba(245,200,195,0.95);
  border: 1px solid rgba(184,98,92,0.25);
}
.help-ai-error-hint { display: block; margin-top: 4px; font-size: 12px; opacity: 0.75; }
.help-ai-answer {
  background: rgba(63,165,108,0.08);
  border: 1px solid rgba(63,165,108,0.25);
  color: rgba(255,255,255,0.92);
}
.help-ai-answer-q {
  font-size: 12px;
  color: rgba(255,255,255,0.55);
  margin-bottom: 6px;
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.help-ai-answer-a p { margin: 0 0 6px; }
.help-ai-answer-a p:last-child { margin-bottom: 0; }
.help-ai-answer-a strong { color: var(--gold); }

/* Help-Tile-Akzent im Aktionen-Panel */
.bsheet-tile-help {
  border-color: rgba(201,168,76,0.18) !important;
}
.bsheet-tile-help .bsheet-tile-ico { color: var(--gold); }

@media (max-width: 760px) {
  .help-modal-body { grid-template-columns: 1fr; }
  .help-sidebar {
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    max-height: 130px;
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    gap: 6px;
    padding: 10px;
  }
  .help-sidebar-item {
    min-width: 130px;
    margin: 0;
    flex-shrink: 0;
  }
  .help-content { padding: 18px 20px; }
  .help-modal-inner { max-height: 100vh; height: 100vh; border-radius: 0; }
}

/* V63.72 — Toggle-Switch für Settings */
.dp-switch {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
  flex-shrink: 0;
}
.dp-switch input { opacity: 0; width: 0; height: 0; }
.dp-switch-slider {
  position: absolute;
  cursor: pointer;
  inset: 0;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 24px;
  transition: 0.2s;
}
.dp-switch-slider::before {
  position: absolute;
  content: "";
  height: 16px;
  width: 16px;
  left: 3px;
  top: 3px;
  background: rgba(255,255,255,0.85);
  border-radius: 50%;
  transition: 0.2s;
}
.dp-switch input:checked + .dp-switch-slider {
  background: var(--gold);
  border-color: var(--gold);
}
.dp-switch input:checked + .dp-switch-slider::before {
  transform: translateX(20px);
  background: #1A1414;
}

/* ═══════════════════════════════════════════════════════════════
   V63.73 — Feedback & Support Modal (im DealPilot-Stil)
═══════════════════════════════════════════════════════════════ */
.fb-overlay {
  position: fixed;
  inset: 0;
  z-index: 10001;
  background: rgba(20, 18, 18, 0.78);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: fbFadeIn 0.18s ease;
}
@keyframes fbFadeIn { from { opacity: 0; } to { opacity: 1; } }

.fb-modal {
  background: #1A1717;
  color: rgba(255,255,255,0.92);
  border-radius: 14px;
  width: 100%;
  max-width: 720px;
  max-height: 92vh;
  overflow-y: auto;
  position: relative;
  box-shadow: 0 24px 70px rgba(0,0,0,0.65);
  border: 1px solid rgba(201,168,76,0.20);
}

.fb-close {
  position: absolute;
  top: 12px; right: 12px;
  width: 34px; height: 34px;
  background: rgba(255,255,255,0.06);
  border: none;
  color: rgba(255,255,255,0.7);
  border-radius: 8px;
  font-size: 22px;
  cursor: pointer;
  line-height: 1;
  z-index: 5;
  transition: all 0.15s;
}
.fb-close:hover { background: rgba(255,255,255,0.12); color: #fff; }

.fb-head {
  padding: 30px 32px 18px;
  background: linear-gradient(180deg, rgba(201,168,76,0.10), transparent);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.fb-head-eyebrow {
  font-size: 11px;
  letter-spacing: 0.14em;
  font-weight: 700;
  color: var(--gold);
  margin-bottom: 6px;
}
.fb-head-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 28px;
  font-weight: 600;
  color: #fff;
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}
.fb-head-sub {
  font-size: 13.5px;
  color: rgba(255,255,255,0.60);
  margin: 0;
  line-height: 1.55;
}

/* Type-Tabs */
.fb-type-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 18px 32px 0;
}
.fb-type-tab {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 14px;
  background: rgba(255,255,255,0.03);
  border: 1.5px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.14s;
  text-align: left;
}
.fb-type-tab:hover {
  background: rgba(255,255,255,0.05);
  border-color: rgba(201,168,76,0.30);
}
.fb-type-tab-active {
  background: rgba(201,168,76,0.10) !important;
  border-color: var(--gold) !important;
}
.fb-type-icon { font-size: 22px; flex-shrink: 0; }
.fb-type-text { flex: 1; }
.fb-type-l {
  font-weight: 700;
  font-size: 14px;
  color: #fff;
  margin-bottom: 2px;
}
.fb-type-tab-active .fb-type-l { color: var(--gold); }
.fb-type-d {
  font-size: 12px;
  color: rgba(255,255,255,0.50);
}

/* Pane sections */
.fb-pane { padding: 18px 32px 0; }

.fb-section { margin-bottom: 22px; }
.fb-section-l {
  font-weight: 700;
  font-size: 13.5px;
  color: rgba(255,255,255,0.92);
  margin-bottom: 4px;
}
.fb-section-d {
  font-size: 12px;
  color: rgba(255,255,255,0.50);
  margin-bottom: 10px;
}

/* Stars */
.fb-stars {
  display: flex;
  align-items: center;
  gap: 4px;
}
.fb-star {
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.20);
  font-size: 30px;
  cursor: pointer;
  padding: 0 2px;
  transition: all 0.14s;
  line-height: 1;
}
.fb-star:hover { color: rgba(201,168,76,0.55); }
.fb-star-active { color: var(--gold); }
.fb-stars-label {
  margin-left: 12px;
  font-size: 12.5px;
  color: rgba(255,255,255,0.55);
  font-style: italic;
}

/* Criteria */
.fb-criteria {
  display: grid;
  gap: 10px;
}
.fb-criterion {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 8px;
}
.fb-crit-head {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
}
.fb-crit-icon { font-size: 18px; flex-shrink: 0; }
.fb-crit-text { flex: 1; min-width: 0; }
.fb-crit-label {
  font-weight: 600;
  font-size: 13px;
  color: rgba(255,255,255,0.88);
}
.fb-crit-desc {
  font-size: 11.5px;
  color: rgba(255,255,255,0.45);
  margin-top: 1px;
}
.fb-crit-stars {
  display: flex;
  gap: 1px;
  flex-shrink: 0;
}
.fb-mini-star {
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.18);
  font-size: 18px;
  cursor: pointer;
  padding: 0 2px;
  line-height: 1;
  transition: color 0.14s;
}
.fb-mini-star:hover { color: rgba(201,168,76,0.55); }
.fb-mini-star-active { color: var(--gold); }

/* Textarea */
.fb-pane textarea, .fb-pane input[type="email"] {
  width: 100%;
  padding: 11px 13px;
  background: rgba(255,255,255,0.04);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 8px;
  font-size: 13.5px;
  font-family: inherit;
  outline: none;
  resize: vertical;
  transition: border-color 0.14s;
}
.fb-pane textarea:focus, .fb-pane input[type="email"]:focus {
  border-color: var(--gold);
}
.fb-pane textarea::placeholder, .fb-pane input::placeholder {
  color: rgba(255,255,255,0.35);
}
.fb-textcount {
  text-align: right;
  font-size: 11px;
  color: rgba(255,255,255,0.40);
  margin-top: 4px;
}

/* Categories grid */
.fb-cat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.fb-cat {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.03);
  border: 1.5px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  cursor: pointer;
  text-align: left;
  transition: all 0.14s;
}
.fb-cat:hover {
  background: rgba(255,255,255,0.05);
  border-color: rgba(201,168,76,0.25);
}
.fb-cat-active {
  background: rgba(201,168,76,0.10) !important;
  border-color: var(--gold) !important;
}
.fb-cat-icon { font-size: 18px; flex-shrink: 0; }
.fb-cat-l {
  font-weight: 600;
  font-size: 12.5px;
  color: rgba(255,255,255,0.88);
}
.fb-cat-active .fb-cat-l { color: var(--gold); }
.fb-cat-d {
  font-size: 11px;
  color: rgba(255,255,255,0.45);
  margin-top: 1px;
}

/* Diagnose */
.fb-diag {
  margin: 0 32px 14px;
  padding: 0;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 8px;
  overflow: hidden;
}
.fb-diag details { padding: 0; }
.fb-diag summary {
  cursor: pointer;
  padding: 10px 14px;
  font-size: 12.5px;
  color: rgba(255,255,255,0.65);
  user-select: none;
}
.fb-diag summary:hover { color: rgba(255,255,255,0.85); }
.fb-hint {
  color: rgba(255,255,255,0.40);
  font-weight: 400;
  font-size: 11px;
}
.fb-diag-content {
  padding: 4px 14px 12px;
  font-family: ui-monospace, monospace;
  font-size: 11px;
  color: rgba(255,255,255,0.55);
}
.fb-diag-line { padding: 1px 0; }

/* Footer */
.fb-foot {
  padding: 16px 32px 24px;
  border-top: 1px solid rgba(255,255,255,0.06);
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.20));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.fb-foot-hint {
  font-size: 11.5px;
  color: rgba(255,255,255,0.45);
}
.fb-foot-actions { display: flex; gap: 10px; }

.fb-btn {
  padding: 10px 18px;
  border: none;
  border-radius: 8px;
  font-weight: 700;
  font-size: 13.5px;
  cursor: pointer;
  transition: all 0.15s;
  text-decoration: none;
  display: inline-block;
  font-family: inherit;
}
.fb-btn-ghost {
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.75);
}
.fb-btn-ghost:hover { background: rgba(255,255,255,0.12); }
.fb-btn-gold {
  background: var(--gold);
  color: #1A1414;
}
.fb-btn-gold:hover { opacity: 0.90; }
.fb-btn:disabled { opacity: 0.55; cursor: wait; }

/* Success / Mailto Fallback */
.fb-success {
  text-align: center;
  padding: 40px 32px 32px;
}
.fb-success-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px; height: 64px;
  background: rgba(63,165,108,0.18);
  color: #6CCB94;
  border-radius: 50%;
  font-size: 32px;
  margin-bottom: 16px;
}
.fb-success-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 26px;
  color: #fff;
  margin: 0 0 8px;
}
.fb-success-sub {
  font-size: 13.5px;
  color: rgba(255,255,255,0.60);
  margin: 0 0 22px;
  line-height: 1.55;
}

/* Toast */
.fb-toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: #1A1717;
  color: #fff;
  padding: 12px 20px;
  border-radius: 8px;
  font-size: 13.5px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.55);
  z-index: 11000;
  opacity: 0;
  transition: all 0.25s;
  border: 1px solid rgba(255,255,255,0.10);
}
.fb-toast-show { opacity: 1; transform: translateX(-50%) translateY(0); }
.fb-toast-error { border-color: rgba(184,98,92,0.50); }
.fb-toast-info { border-color: rgba(201,168,76,0.30); }

/* Help/Feedback Sidebar-Tile-Akzent */
.sb-act-help { color: var(--gold); }
.sb-act-help .sb-act-ico { color: var(--gold); }
.sb-act-feedback { color: rgba(108,160,200,0.95); }

/* Mobile */
@media (max-width: 700px) {
  .fb-modal { max-height: 100vh; height: 100vh; border-radius: 0; }
  .fb-head { padding: 24px 20px 14px; }
  .fb-pane, .fb-foot { padding-left: 20px; padding-right: 20px; }
  .fb-diag { margin: 0 20px 14px; }
  .fb-type-tabs { padding: 14px 20px 0; grid-template-columns: 1fr; }
  .fb-cat-grid { grid-template-columns: 1fr; }
  .fb-criterion { flex-direction: column; align-items: flex-start; gap: 6px; }
  .fb-foot { flex-direction: column; align-items: stretch; }
  .fb-foot-actions { justify-content: flex-end; }
}

/* ═══════════════════════════════════════════════════════════════
   V63.74 — Feedback-Modal Erweiterungen
═══════════════════════════════════════════════════════════════ */
.fb-section-opt {
  font-weight: 400;
  color: rgba(255,255,255,0.5);
  font-size: 11px;
  margin-left: 6px;
}

.fb-attach-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.fb-attach-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(201,168,76,0.12);
  color: #E2C97E;
  border: 1px solid rgba(201,168,76,0.4);
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
}
.fb-attach-btn:hover {
  background: rgba(201,168,76,0.22);
  border-color: rgba(201,168,76,0.7);
}
.fb-attach-info {
  font-size: 12px;
  color: rgba(255,255,255,0.55);
}
.fb-attach-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 10px;
}
.fb-attach-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 6px;
  font-size: 12px;
}
.fb-attach-name {
  flex: 1;
  color: rgba(255,255,255,0.85);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.fb-attach-size {
  color: rgba(255,255,255,0.45);
  font-size: 11px;
}
.fb-attach-rm {
  background: transparent;
  border: 0;
  color: rgba(255,255,255,0.45);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  padding: 0 4px;
}
.fb-attach-rm:hover { color: #E47A7A; }

.fb-toggle-row {
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  user-select: none;
  padding: 10px 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
}
.fb-toggle-row:hover { background: rgba(255,255,255,0.06); }
.fb-toggle-cb {
  width: 18px;
  height: 18px;
  accent-color: #C9A84C;
  cursor: pointer;
}
.fb-toggle-text {
  font-size: 13px;
  color: rgba(255,255,255,0.85);
}

/* Diag-Lines mit k/v */
.fb-diag-line {
  padding: 3px 0;
  font-size: 11px;
  font-family: ui-monospace, "SFMono-Regular", Consolas, monospace;
  color: rgba(255,255,255,0.7);
  display: flex;
  gap: 8px;
}
.fb-diag-k {
  color: rgba(255,255,255,0.45);
  min-width: 110px;
  flex-shrink: 0;
}
.fb-diag-v {
  color: rgba(255,255,255,0.85);
  word-break: break-all;
}

/* Icons in Feedback-Buttons sollen dezent sein */
.fb-type-icon svg, .fb-cat-icon svg, .fb-crit-icon svg {
  display: block;
}
.fb-icon-fallback {
  display: inline-block;
  width: 16px;
  height: 16px;
}
/* ═══════════════════════════════════════════════════════════════
   V114 — Feedback & Support Modal · GLASSMORPHIC LUXE
   V115 — Lesbarkeits-Fix: Free-Watermark im Modal blockieren,
          alle Inhalte garantiert über z-index, Klasse "body"
          entfernt (kollidierte mit body.plan-free .body::before).
═══════════════════════════════════════════════════════════════ */
/* V115: Free-Plan-Watermark "DealPilot Free" liegt global mit z-index:1
   über allem. Das Feedback-Modal liegt zwar bei z-index:10001, aber das
   Watermark wird via body::before gerendert — pointer-events:none verhindert
   Klick-Probleme, aber visuell scheint es durch unsere semi-transparenten
   Modal-Hintergründe durch. Lösung: alles im Modal-Wrapper kriegt einen
   eigenen Stacking-Context, der das Watermark hinter dem Modal "abschneidet". */
#feedback-modal.fb-overlay {
  isolation: isolate;
}
/* V115: Free-Plan-Watermark hart ausblenden während das Feedback-Modal offen ist.
   Sonst scheint "DealPilot Free" durch die semi-transparenten Modal-Hintergründe
   und überlagert die Headlines unlesbar (Marcels Screenshot). */
body.fb-modal-open.plan-free .body::before {
  display: none !important;
}
#feedback-modal.fb-overlay {
  position: fixed;
  inset: 0;
  z-index: 10001;
  background: radial-gradient(ellipse at center, rgba(20,15,5,.5) 0%, rgba(0,0,0,.92) 70%);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 30px;
  overflow: hidden;
  animation: fbFadeIn .25s ease-out;
}
/* Particles im Backdrop */
#feedback-modal.fb-overlay::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1px 1px at 20% 20%, rgba(201,168,76,.4) 50%, transparent 100%),
    radial-gradient(1px 1px at 80% 60%, rgba(201,168,76,.3) 50%, transparent 100%),
    radial-gradient(2px 2px at 50% 80%, rgba(201,168,76,.4) 50%, transparent 100%),
    radial-gradient(1px 1px at 70% 30%, rgba(201,168,76,.35) 50%, transparent 100%);
  background-size: 300px 400px;
  animation: fbBgPart 25s linear infinite;
  pointer-events: none;
}
@keyframes fbBgPart { to { background-position: 0 -400px, 0 -400px, 0 -400px, 0 -400px; } }

/* Modal-Körper — Frosted Glass mit Gold-Border und Halo
   V115: deckendes Schwarz statt semi-transparent (rgba .92/.95) — sonst
   schimmert das DealPilot-Free-Watermark der App durch das Modal. */
#feedback-modal .fb-modal {
  width: 760px;
  max-width: 100%;
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 60px);
  background:
    linear-gradient(135deg, rgba(15,12,5,1) 0%, rgba(8,6,4,1) 100%),
    #050404;
  backdrop-filter: blur(20px);
  border: 1.5px solid #C9A84C;
  box-shadow:
    0 30px 80px rgba(0,0,0,.6),
    0 0 0 1px rgba(201,168,76,.2),
    inset 0 1px 0 rgba(255,255,255,.05);
  color: #e8e2d4;
  font-family: -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", sans-serif;
  font-size: 13px;
  line-height: 1.45;
}
/* V116: Globaler SVG-Größen-Schutz — ein SVG im Modal das KEINEN expliziten
   width/height bekommen hat, würde sonst auf 100% des Containers expandieren
   (Marcels Diagnose-Screenshot). Zwinge alle SVGs auf "an Container anpassen". */
#feedback-modal svg {
  max-width: 100%;
  max-height: 100%;
  display: block;
}
#feedback-modal .ic {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 0;
  flex-shrink: 0;
  vertical-align: middle;
}
#feedback-modal .ic > svg {
  width: 100%;
  height: 100%;
  display: block;
}
#feedback-modal .fb-modal::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 16px;
  background: radial-gradient(ellipse 600px 200px at 50% 0%, rgba(201,168,76,.18) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}
#feedback-modal .fb-modal > * { position: relative; z-index: 1; }

/* Close-Button */
#feedback-modal .fb-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: 9px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.6);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
  z-index: 10;
  backdrop-filter: blur(8px);
  font-size: 0;
}
#feedback-modal .fb-close:hover {
  background: rgba(184,98,92,.2);
  border-color: rgba(184,98,92,.4);
  color: #e07a82;
}
#feedback-modal .fb-close .ic { width: 14px; height: 14px; }
#feedback-modal .fb-close .ic svg { width: 100%; height: 100%; display: block; }

/* Hero */
#feedback-modal .hero {
  padding: 28px 30px 22px;
  border-bottom: 1px solid rgba(201,168,76,.15);
  position: relative;
  background: transparent;
}
#feedback-modal .hero-cat {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 3px;
  color: #C9A84C;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
}
#feedback-modal .hero-cat .ic { width: 11px; height: 11px; display: inline-flex; }
#feedback-modal .hero-cat .ic svg { width: 100%; height: 100%; }
#feedback-modal .hero-h {
  font-family: Georgia, "Cormorant Garamond", serif;
  font-size: 30px;
  color: #fff;
  margin: 8px 0 0;
  font-weight: 400;
  letter-spacing: -.4px;
  font-style: italic;
}
#feedback-modal .hero-h .gold { color: #E8C964; }
#feedback-modal .hero-d {
  font-size: 13px;
  color: #a8a299;
  margin: 6px 0 0;
  line-height: 1.5;
}

/* Body (scrollbar) */
#feedback-modal .fb-body {
  padding: 22px 30px;
  overflow: auto;
  flex: 1;
}

/* Goldene Scrollbar */
#feedback-modal .fb-body::-webkit-scrollbar { width: 10px; height: 10px; }
#feedback-modal .fb-body::-webkit-scrollbar-track {
  background: rgba(0,0,0,.4);
  border-radius: 5px;
  border: 1px solid rgba(201,168,76,.08);
}
#feedback-modal .fb-body::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #9a7f33, rgba(201,168,76,.5));
  border-radius: 5px;
  border: 1px solid rgba(201,168,76,.2);
  box-shadow: 0 0 6px rgba(201,168,76,.3), inset 0 1px 0 rgba(255,255,255,.1);
}
#feedback-modal .fb-body::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #E8C964, #9a7f33);
  box-shadow: 0 0 12px rgba(201,168,76,.5), inset 0 1px 0 rgba(255,255,255,.2);
}
#feedback-modal .fb-body::-webkit-scrollbar-corner { background: transparent; }
#feedback-modal .fb-body { scrollbar-width: thin; scrollbar-color: rgba(201,168,76,.5) rgba(0,0,0,.4); }

/* Toggle-Row */
#feedback-modal .toggle-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 11px;
  margin-bottom: 22px;
  padding: 0;
  background: transparent;
  border: 0;
}
#feedback-modal .toggle {
  padding: 14px 16px;
  border-radius: 11px;
  border: 1.5px solid rgba(201,168,76,.2);
  background: rgba(255,255,255,.025);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 11px;
  transition: all .2s;
  text-align: left;
  color: inherit;
  font-family: inherit;
  width: 100%;
}
#feedback-modal .toggle:hover {
  border-color: rgba(201,168,76,.4);
  background: rgba(201,168,76,.04);
}
#feedback-modal .toggle.act {
  background: linear-gradient(135deg, rgba(201,168,76,.18), rgba(201,168,76,.06));
  border-color: #C9A84C;
  box-shadow: 0 0 18px rgba(201,168,76,.2), inset 0 1px 0 rgba(201,168,76,.1);
}
#feedback-modal .toggle-ic {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  background: linear-gradient(135deg, rgba(201,168,76,.15), rgba(201,168,76,.04));
  border: 1px solid rgba(201,168,76,.3);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #E8C964;
  flex-shrink: 0;
}
#feedback-modal .toggle.act .toggle-ic {
  background: linear-gradient(135deg, #E8C964, #9a7f33);
  color: #2A2727;
  box-shadow: 0 4px 12px rgba(201,168,76,.4);
  border-color: transparent;
}
#feedback-modal .toggle-ic .ic { width: 16px; height: 16px; }
#feedback-modal .toggle-ic .ic svg { width: 100%; height: 100%; }
#feedback-modal .toggle-l {
  font-size: 13.5px;
  color: #fff;
  font-weight: 600;
  text-transform: none;
  letter-spacing: normal;
}
#feedback-modal .toggle.act .toggle-l { color: #E8C964; }
#feedback-modal .toggle-d {
  font-size: 11px;
  color: #a8a299;
  margin-top: 1px;
}

/* Sections mit numbered pill */
#feedback-modal .section { margin-bottom: 18px; }
#feedback-modal .section-h {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
#feedback-modal .section-h-num {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: linear-gradient(135deg, #E8C964, #9a7f33);
  color: #2A2727;
  font-size: 10.5px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: ui-monospace, monospace;
  box-shadow: 0 4px 10px rgba(201,168,76,.4);
  flex-shrink: 0;
}
#feedback-modal .section-l {
  font-size: 14px;
  color: #fff;
  font-weight: 700;
  letter-spacing: -.1px;
  margin: 0;
  text-transform: none;
}
#feedback-modal .section-d {
  font-size: 12px;
  color: #a8a299;
  margin: 0 0 11px 30px;
}

/* Stars */
#feedback-modal .star {
  font-size: 22px;
  color: rgba(255,255,255,.18);
  cursor: pointer;
  transition: all .15s;
  line-height: 1;
  font-family: Georgia, serif;
  background: transparent;
  border: 0;
  padding: 0;
  width: auto;
  height: auto;
}
#feedback-modal .star.f,
#feedback-modal .star.fb-star-active,
#feedback-modal .star.fb-mini-star-active {
  color: #E8C964;
  text-shadow: 0 0 12px rgba(201,168,76,.6);
}
#feedback-modal .star:hover { transform: scale(1.15); color: rgba(232,201,100,.65); }
#feedback-modal .stars-big {
  display: flex;
  gap: 6px;
  align-items: center;
  margin-left: 30px;
  padding: 0;
  background: transparent;
  border: 0;
}
#feedback-modal .stars-big .star { font-size: 28px; }
#feedback-modal .stars-label {
  margin-left: 11px;
  font-size: 12px;
  color: #a8a299;
  font-style: italic;
}

/* Detail-Grid */
#feedback-modal .detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 9px;
}
#feedback-modal .detail {
  padding: 11px 13px;
  border-radius: 9px;
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(201,168,76,.12);
  display: flex;
  align-items: center;
  gap: 11px;
  transition: all .15s;
  text-align: left;
  color: inherit;
  font-family: inherit;
  width: 100%;
}
#feedback-modal .detail:hover {
  border-color: rgba(201,168,76,.3);
  background: rgba(201,168,76,.04);
}
#feedback-modal .detail.act {
  background: linear-gradient(135deg, rgba(201,168,76,.18), rgba(201,168,76,.06));
  border-color: #C9A84C;
  box-shadow: 0 0 14px rgba(201,168,76,.18);
}
#feedback-modal .detail-ic {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(201,168,76,.12), rgba(0,0,0,.4));
  border: 1px solid rgba(201,168,76,.2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #E8C964;
  flex-shrink: 0;
  font-size: 0;
}
#feedback-modal .detail-ic .ic { width: 14px; height: 14px; display: inline-flex; }
#feedback-modal .detail-ic .ic svg { width: 100%; height: 100%; }
#feedback-modal .detail-info { flex: 1; min-width: 0; }
#feedback-modal .detail-l {
  font-size: 12.5px;
  color: #fff;
  font-weight: 600;
  letter-spacing: -.1px;
}
#feedback-modal .detail-d {
  font-size: 10.5px;
  color: #a8a299;
  margin-top: 1px;
}
#feedback-modal .detail-stars {
  display: flex;
  gap: 2px;
  flex-shrink: 0;
}
#feedback-modal .detail-stars .star { font-size: 13px; }

/* Textarea + Email-Input — gleiche Optik */
#feedback-modal .ta,
#feedback-modal #fb-text-feedback,
#feedback-modal #fb-text-support,
#feedback-modal #fb-contact-email {
  width: calc(100% - 30px);
  margin-left: 30px;
  padding: 11px 14px;
  border-radius: 8px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(201,168,76,.2);
  color: #fff;
  font-family: inherit;
  font-size: 13px;
  resize: vertical;
  min-height: 80px;
  transition: all .15s;
  display: block;
  box-sizing: border-box;
}
#feedback-modal #fb-contact-email { min-height: 0; resize: none; }
#feedback-modal .ta:focus,
#feedback-modal #fb-text-feedback:focus,
#feedback-modal #fb-text-support:focus,
#feedback-modal #fb-contact-email:focus {
  outline: 0;
  border-color: #C9A84C;
  background: rgba(255,255,255,.06);
  box-shadow: 0 0 0 3px rgba(201,168,76,.15);
}
#feedback-modal .fb-textcount {
  margin-left: 30px;
  font-size: 10.5px;
  color: #7a7570;
  margin-top: 4px;
  text-align: right;
  padding-right: 4px;
}

/* Cat-Grid (Support-Pane) — wie Detail-Tiles aber 1-spaltig */
#feedback-modal .fb-cat-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 9px;
  margin-left: 30px;
}
#feedback-modal .fb-cat {
  padding: 12px 14px;
  cursor: pointer;
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(201,168,76,.12);
  border-radius: 9px;
  display: flex;
  align-items: center;
  gap: 11px;
  transition: all .15s;
  text-align: left;
  color: inherit;
  font-family: inherit;
}
#feedback-modal .fb-cat:hover {
  border-color: rgba(201,168,76,.3);
  background: rgba(201,168,76,.04);
}
#feedback-modal .fb-cat.act,
#feedback-modal .fb-cat.fb-cat-active {
  background: linear-gradient(135deg, rgba(201,168,76,.18), rgba(201,168,76,.06));
  border-color: #C9A84C;
  box-shadow: 0 0 14px rgba(201,168,76,.18);
}

/* Attach-Buttons + Toggle */
#feedback-modal .fb-attach-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-left: 30px;
}
#feedback-modal .fb-attach-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(201,168,76,.12);
  color: #E8C964;
  border: 1px solid rgba(201,168,76,.4);
  padding: 9px 14px;
  border-radius: 8px;
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
  font-family: inherit;
}
#feedback-modal .fb-attach-btn:hover {
  background: rgba(201,168,76,.22);
  border-color: rgba(201,168,76,.7);
}
#feedback-modal .fb-attach-btn .ic { width: 14px; height: 14px; display: inline-flex; }
#feedback-modal .fb-attach-info {
  font-size: 11px;
  color: #a8a299;
}
#feedback-modal .fb-attach-list {
  margin-left: 30px;
  margin-top: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
#feedback-modal .fb-toggle-row {
  margin-left: 30px;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-size: 12.5px;
  color: #e8e2d4;
}
#feedback-modal .fb-toggle-cb {
  accent-color: #C9A84C;
  width: 16px;
  height: 16px;
}
#feedback-modal .fb-section-opt {
  font-weight: 400;
  color: #7a7570;
  font-size: 11px;
  margin-left: 6px;
}

/* Diagnose */
#feedback-modal .fb-diag {
  /* V116: eigener Stacking-Context damit nichts vom Watermark/Backdrop durchschimmert */
  position: relative;
  isolation: isolate;
}
#feedback-modal .fb-diag summary {
  cursor: pointer;
  font-size: 12px;
  color: #a8a299;
  padding: 8px 12px;
  border-radius: 8px;
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(201,168,76,.12);
  list-style: none;
  list-style-type: none;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: 30px;
  appearance: none;
  -webkit-appearance: none;
}
/* V116: Default-Marker komplett blockieren (Webkit + Firefox + Safari) */
#feedback-modal .fb-diag summary::-webkit-details-marker { display: none !important; }
#feedback-modal .fb-diag summary::marker { content: ""; display: none; font-size: 0; }
#feedback-modal .fb-diag summary > * { flex-shrink: 0; }
/* V116: Das Help-Icon im Diagnose-Summary war im Browser teilweise riesig gerendert
   (Marcels Screenshot zeigte einen großen weißen Bogen). Ursache war ein <span class="ic">
   ohne explizites display/Größe, das zusammen mit dem SVG ohne width/height-Attribut
   im Flex-Container expandierte. Hard-fix: Span erzwingt 12×12, SVG erbt das streng. */
#feedback-modal .fb-diag summary .ic {
  display: inline-flex !important;
  width: 12px !important;
  height: 12px !important;
  min-width: 12px;
  max-width: 12px;
  min-height: 12px;
  max-height: 12px;
  flex-shrink: 0;
  line-height: 0;
  align-items: center;
  justify-content: center;
}
#feedback-modal .fb-diag summary .ic svg {
  width: 12px !important;
  height: 12px !important;
  display: block;
  flex-shrink: 0;
}
#feedback-modal .fb-diag .fb-hint { color: #7a7570; font-size: 11px; }
#feedback-modal .fb-diag-content {
  margin-left: 30px;
  margin-top: 8px;
  padding: 10px 12px;
  border-radius: 6px;
  background: rgba(0,0,0,.4);
  border: 1px solid rgba(201,168,76,.12);
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 11px;
  color: #cfc8b8;
  line-height: 1.55;
}

/* Footer */
#feedback-modal .footer {
  padding: 16px 30px;
  border-top: 1px solid rgba(201,168,76,.15);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(0,0,0,.4);
  gap: 12px;
  flex-wrap: wrap;
}
#feedback-modal .footer-info {
  font-size: 11.5px;
  color: #a8a299;
  display: flex;
  align-items: center;
  gap: 6px;
}
#feedback-modal .footer-info .ic { width: 11px; height: 11px; color: #C9A84C; display: inline-flex; }
#feedback-modal .fb-foot-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Submit-Button */
#feedback-modal .submit-btn,
#feedback-modal .fb-btn-gold {
  background: linear-gradient(135deg, #E8C964, #9a7f33);
  color: #2A2727;
  border: 0;
  padding: 11px 22px;
  border-radius: 9px;
  font-weight: 700;
  font-size: 13px;
  cursor: pointer;
  letter-spacing: .4px;
  box-shadow: 0 6px 18px rgba(201,168,76,.4), inset 0 1px 0 rgba(255,255,255,.4);
  transition: all .25s;
  font-family: inherit;
  display: flex;
  align-items: center;
  gap: 8px;
}
#feedback-modal .submit-btn:hover,
#feedback-modal .fb-btn-gold:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(201,168,76,.55), inset 0 1px 0 rgba(255,255,255,.4);
}
#feedback-modal .submit-btn .ic,
#feedback-modal .fb-btn-gold .ic { width: 14px; height: 14px; display: inline-flex; }
#feedback-modal .fb-btn-ghost {
  background: rgba(255,255,255,.05);
  color: #e8e2d4;
  border: 1px solid rgba(255,255,255,.1);
  padding: 11px 18px;
  border-radius: 9px;
  font-weight: 600;
  font-size: 12.5px;
  cursor: pointer;
  font-family: inherit;
  transition: all .15s;
}
#feedback-modal .fb-btn-ghost:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.2);
}

/* Mobile-Anpassung */
@media (max-width: 700px) {
  #feedback-modal.fb-overlay { padding: 0; }
  #feedback-modal .fb-modal {
    max-height: 100vh;
    height: 100vh;
    border-radius: 0;
    border-left: 0;
    border-right: 0;
    width: 100%;
  }
  #feedback-modal .hero { padding: 22px 20px 18px; }
  #feedback-modal .hero-h { font-size: 24px; }
  #feedback-modal .fb-body { padding: 18px 20px; }
  #feedback-modal .toggle-row { grid-template-columns: 1fr; }
  #feedback-modal .detail-grid { grid-template-columns: 1fr; }
  #feedback-modal .detail[style*="grid-column"] { grid-column: 1 / -1 !important; }
  #feedback-modal .footer { padding: 14px 20px; flex-direction: column; align-items: stretch; }
  #feedback-modal .fb-foot-actions { justify-content: flex-end; }
  #feedback-modal .section-d,
  #feedback-modal .stars-big,
  #feedback-modal .ta,
  #feedback-modal #fb-text-feedback,
  #feedback-modal #fb-text-support,
  #feedback-modal #fb-contact-email,
  #feedback-modal .fb-cat-grid,
  #feedback-modal .fb-attach-row,
  #feedback-modal .fb-attach-list,
  #feedback-modal .fb-toggle-row,
  #feedback-modal .fb-diag summary,
  #feedback-modal .fb-diag-content,
  #feedback-modal .fb-textcount { margin-left: 0; }
  #feedback-modal .ta,
  #feedback-modal #fb-text-feedback,
  #feedback-modal #fb-text-support,
  #feedback-modal #fb-contact-email { width: 100%; }
}

/* ═══════════════════════════════════════════════════════════════
   V63.73 — Deal-Aktion (Tab s8)
═══════════════════════════════════════════════════════════════ */
.da-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
@media (max-width: 760px) {
  .da-grid { grid-template-columns: 1fr; }
}
.da-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.da-card:hover {
  border-color: var(--gold);
  box-shadow: 0 4px 14px rgba(201,168,76,.12);
  transform: translateY(-1px);
}
.da-card-icon { font-size: 28px; line-height: 1; margin-bottom: 4px; }
.da-card-title { font-size: 17px; font-weight: 700; color: var(--ch); }
.da-card-sub { font-size: 13px; color: var(--gold); font-weight: 600; margin-top: -2px; }
.da-card-desc { font-size: 13px; color: var(--muted); line-height: 1.5; flex: 1; margin-top: 6px; }
.da-card-status {
  font-size: 12px;
  padding: 6px 10px;
  background: var(--surface);
  border-radius: 6px;
  color: var(--ch);
  font-weight: 600;
  align-self: flex-start;
}
.da-card-cta { margin-top: 10px; align-self: stretch; justify-content: center; }

/* Modal */
.da-modal-ov {
  position: fixed; inset: 0;
  background: rgba(42, 39, 39, 0.55);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  backdrop-filter: blur(2px);
}
.da-modal {
  background: #fff;
  border-radius: 14px;
  width: 100%;
  max-width: 720px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  overflow: hidden;
}
.da-modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 22px; border-bottom: 1px solid var(--line);
  background: var(--surface);
}
.da-modal-head h3 { margin: 0; font-size: 17px; color: var(--ch); }
.da-modal-close {
  background: transparent; border: 0; font-size: 26px;
  cursor: pointer; color: var(--muted); padding: 4px 10px; line-height: 1;
}
.da-modal-close:hover { color: var(--ch); }
.da-modal-body { padding: 20px 22px; overflow-y: auto; flex: 1; }
.da-modal-foot {
  display: flex; gap: 10px; justify-content: flex-end;
  padding: 14px 22px; border-top: 1px solid var(--line); background: var(--surface);
}

/* Stepper */
.da-stepper {
  display: flex; align-items: center; gap: 0;
  margin-bottom: 18px; padding: 6px 0;
}
.da-step-pill {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 12px; border-radius: 20px;
  background: var(--surface); color: var(--muted);
  font-size: 12px; font-weight: 600;
  transition: all .15s ease;
}
.da-step-pill.active { background: var(--gold); color: #1A1414; }
.da-step-pill.done   { background: var(--green); color: #fff; }
.da-step-num {
  width: 20px; height: 20px; border-radius: 50%;
  background: rgba(0,0,0,.08);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px;
}
.da-step-pill.active .da-step-num,
.da-step-pill.done .da-step-num { background: rgba(255,255,255,.25); }
.da-step-sep {
  flex: 1; height: 2px; background: var(--line); margin: 0 4px;
}

/* Object preview */
.da-preview {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 16px;
}
.da-prev-head { font-size: 12px; font-weight: 700; color: var(--ch); margin-bottom: 8px; text-transform: uppercase; letter-spacing: .04em; }
.da-prev-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 16px; }
.da-prev-row { display: flex; justify-content: space-between; padding: 3px 0; font-size: 13px; }
.da-prev-k { color: var(--muted); }
.da-prev-v { color: var(--ch); font-weight: 600; }
.da-prev-hint { margin-top: 8px; font-size: 11px; color: var(--muted); text-align: right; }
.da-prev-hint a { color: var(--gold); text-decoration: none; }
.da-prev-hint a:hover { text-decoration: underline; }

/* Comment / textarea blocks */
.da-cmt { margin-top: 14px; }
.da-cmt label { display: block; font-size: 12px; font-weight: 600; color: var(--ch); margin-bottom: 6px; }
.da-cmt textarea {
  width: 100%; padding: 10px 12px; border: 1px solid var(--line);
  border-radius: 8px; font-family: inherit; font-size: 13px;
  resize: vertical; box-sizing: border-box;
}
.da-cmt textarea:focus { outline: none; border-color: var(--gold); }

/* Document list */
.da-doclist { display: flex; flex-direction: column; gap: 8px; }
.da-doc {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; background: var(--surface);
  border: 1px solid var(--line); border-radius: 8px; gap: 12px;
}
.da-doc-info { display: flex; align-items: center; gap: 10px; min-width: 0; flex: 1; }
.da-doc-status {
  width: 22px; height: 22px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: #fff; border: 1px solid var(--line);
  color: var(--muted); font-weight: 700; flex-shrink: 0;
}
.da-doc-status.ok { background: var(--green); color: #fff; border-color: var(--green); }
.da-doc-lbl { font-size: 13px; color: var(--ch); }
.da-doc-lbl em { font-style: normal; color: var(--muted); font-size: 11px; }
.da-doc-actions { display: flex; align-items: center; gap: 8px; }
.da-doc-btn { font-size: 12px; padding: 6px 10px; }
.da-doc-fname { font-size: 11px; color: var(--green); max-width: 160px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* AI check box */
.da-ai-info {
  margin-top: 14px; padding: 12px 14px;
  background: rgba(201,168,76,.08); border: 1px solid var(--gold);
  border-radius: 8px; font-size: 12px; color: var(--ch);
}
.da-aicheck, .da-summary { padding: 4px 0; }
.da-ai-head { font-size: 14px; font-weight: 700; color: var(--ch); margin-bottom: 10px; }
.da-ai-list { display: flex; flex-direction: column; gap: 6px; }
.da-ai-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px; background: var(--surface);
  border-radius: 6px; font-size: 12px;
}
.da-ai-icon { font-weight: 800; font-size: 14px; min-width: 16px; text-align: center; }
.da-ai-doc { flex: 1; color: var(--ch); }
.da-ai-msg { color: var(--muted); font-size: 11px; }
.da-ai-foot { margin-top: 12px; font-size: 12px; color: var(--muted); }

/* Option radio cards (Gutachten-Typ) */
.da-opt-grid { display: flex; flex-direction: column; gap: 8px; }
.da-opt {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 12px 14px; background: var(--surface);
  border: 1px solid var(--line); border-radius: 8px;
  cursor: pointer; transition: all .15s ease;
}
.da-opt:hover { border-color: var(--gold); }
.da-opt input[type="radio"] { margin-top: 3px; accent-color: var(--gold); }
.da-opt input[type="radio"]:checked ~ * .da-opt-lbl { color: var(--gold); }
.da-opt-lbl { font-size: 13px; font-weight: 600; color: var(--ch); }
.da-opt-hint { font-size: 11px; color: var(--muted); margin-top: 2px; }

/* Consult cards */
.da-consult-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
@media (max-width: 540px) {
  .da-consult-grid { grid-template-columns: 1fr; }
}
.da-consult-card {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 10px; padding: 18px 16px;
  display: flex; flex-direction: column; gap: 8px;
}
.da-consult-icon { font-size: 24px; line-height: 1; }
.da-consult-title { font-size: 15px; font-weight: 700; color: var(--ch); }
.da-consult-desc { font-size: 12px; color: var(--muted); line-height: 1.5; flex: 1; }
.da-consult-price { font-size: 13px; font-weight: 700; color: var(--gold); margin: 4px 0; }
.da-consult-options { display: flex; flex-direction: column; gap: 6px; margin-top: 6px; }

/* Success state */
.da-ok { text-align: center; padding: 24px 16px; }
.da-ok-icon {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--green); color: #fff;
  font-size: 28px; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 12px;
}
.da-ok h3 { margin: 0 0 8px 0; color: var(--ch); }
.da-ok p { margin: 6px 0; color: var(--ch); font-size: 14px; line-height: 1.5; }
.da-ok p em { font-style: normal; color: var(--gold); font-weight: 600; }

/* ═══════════════════════════════════════════════════════════════
   V63.74 — Sidebar User-Box vereinfacht (Inline-Icons statt Submenu)
═══════════════════════════════════════════════════════════════ */
.sb-user-box .sb-user-main {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  cursor: default;
}
.sb-user-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-left: auto;
}
.sb-user-iconbtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 8px;
  color: rgba(255,255,255,0.55);
  cursor: pointer;
  transition: all 0.15s ease;
  padding: 0;
}
.sb-user-iconbtn:hover {
  background: rgba(201,168,76,0.14);
  color: var(--gold);
  border-color: rgba(201,168,76,0.35);
}
.sb-user-iconbtn-danger:hover {
  background: rgba(184,98,92,0.14);
  color: var(--red);
  border-color: rgba(184,98,92,0.35);
}
.sb-user-iconbtn svg { display: block; }

/* Mode-Badge mit SVG-Icon */
.sb-user-name .sb-mode-badge {
  display: inline-flex;
  align-items: center;
  margin-left: 6px;
  color: rgba(255,255,255,0.55);
  vertical-align: middle;
}
.sb-user-name .sb-mode-badge.api { color: var(--gold); }
.sb-user-name .sb-mode-badge svg { display: block; }

/* ═══════════════════════════════════════════════════════════════
   V63.75 — Deal-Aktion: Selbstauskunft-Button + Bankexport-Hinweis
═══════════════════════════════════════════════════════════════ */
.da-doc-tplbtn {
  font-size: 11px !important;
  padding: 5px 10px !important;
  background: rgba(201,168,76,0.10) !important;
  color: var(--gold) !important;
  border: 1px solid rgba(201,168,76,0.30) !important;
}
.da-doc-tplbtn:hover {
  background: rgba(201,168,76,0.18) !important;
  border-color: rgba(201,168,76,0.55) !important;
}
.da-doc-req {
  font-style: normal;
  color: var(--red, #B8625C);
  font-size: 10px;
  font-weight: 600;
  margin-left: 6px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.da-bankexp-info {
  margin-top: 12px;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.da-bankexp-info-ok {
  background: rgba(63, 165, 108, 0.10);
  border: 1px solid rgba(63, 165, 108, 0.35);
  color: var(--green, #3FA56C);
}
.da-bankexp-info-upgrade {
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.30);
  color: var(--gold);
}
.da-bankexp-info svg { flex-shrink: 0; }

/* Object preview — sub-line für Header */
.da-prev-sub {
  font-weight: 400;
  color: var(--muted);
  margin-left: 6px;
  font-size: 11px;
  text-transform: none;
  letter-spacing: 0;
}

/* Consult-Foot mit Webseite */
.da-consult-foot {
  text-align: center;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.da-consult-weblink {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--gold);
  text-decoration: none;
}
.da-consult-weblink:hover { text-decoration: underline; }
.da-consult-cal-hint {
  font-size: 11px;
  color: var(--muted);
  margin-top: 6px;
  text-align: center;
}

/* ═══════════════════════════════════════════════════════════════
   V63.76 — Quick-Check Standalone-Mode
   Body-Klasse .qc-standalone-active blendet Tab-Bar + Workflow-Bar aus.
   Die Quick-Check-View nutzt die volle Breite des Content-Bereichs.
═══════════════════════════════════════════════════════════════ */
body.qc-standalone-active .tabs,
body.qc-standalone-active .tabs-workflow-bar,
body.qc-standalone-active .wf-tab-bar,
body.qc-standalone-active .workflow-tab-bar {
  display: none !important;
}

/* Standalone-Section sichtbar wenn body-Klasse gesetzt ist */
body.qc-standalone-active #s-quick {
  display: block !important;
  padding-top: 12px;
}

/* Hint-Banner oben in der Standalone-View, das den Modus erklärt */
body.qc-standalone-active #s-quick::before {
  content: '⚡ Quick-Check';
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  color: var(--gold);
  text-align: center;
  padding: 10px 0 4px;
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════════
   V63.76 — Investmentprofil-Pane (Settings-Tab)
═══════════════════════════════════════════════════════════════ */
.set-modal-v2 .ip-section {
  font-size: 11px;
  letter-spacing: 1.4px;
  color: var(--gold);
  font-weight: 700;
  text-transform: uppercase;
  margin: 22px 0 10px;
}
.set-modal-v2 .ip-section:first-child { margin-top: 6px; }
.set-modal-v2 .ip-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 18px;
  margin-bottom: 6px;
}
@media (max-width: 600px) {
  .set-modal-v2 .ip-grid { grid-template-columns: 1fr; }
}
.set-modal-v2 .ip-field { display: flex; flex-direction: column; gap: 4px; }
.set-modal-v2 .ip-field-row {
  display: flex;
  align-items: stretch;
  gap: 8px;
}
.set-modal-v2 .ip-field input:focus,
.set-modal-v2 .ip-field select:focus {
  outline: none;
  border-color: rgba(201,168,76,0.6);
  background: rgba(255,255,255,0.07);
}
.set-modal-v2 .ip-suffix {
  display: inline-flex;
  align-items: center;
  padding: 0 12px;
  background: rgba(201,168,76,0.10);
  border: 1px solid rgba(201,168,76,0.25);
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  color: var(--gold);
  white-space: nowrap;
}
.set-modal-v2 .ip-actions {
  display: flex;
  gap: 10px;
  margin-top: 22px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

/* ═══════════════════════════════════════════════════════════════
   V63.76 — KI-Anweisungs-Vorschläge (Settings → KI)
═══════════════════════════════════════════════════════════════ */
.set-modal-v2 .ai-suggestions {
  margin-top: 14px;
  padding: 14px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
}
.set-modal-v2 .ai-sugg-head {
  font-size: 11px;
  font-weight: 700;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 10px;
}
.set-modal-v2 .ai-sugg-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.set-modal-v2 .ai-sugg-chip:active {
  transform: scale(0.99);
}

/* ═══════════════════════════════════════════════════════════════
   V63.76 — Danger Zone (Account-Löschung)
═══════════════════════════════════════════════════════════════ */
.set-modal-v2 .danger-zone {
  background: rgba(184,98,92,0.08);
  border: 1px solid rgba(184,98,92,0.30);
  border-radius: 10px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.set-modal-v2 .danger-text strong {
  color: var(--red, #E47A7A);
}
.set-modal-v2 .danger-zone .btn-danger:hover {
  background: #d97570;
}

/* ═══════════════════════════════════════════════════════════════
   V63.77 — Settings-Modal weitere Lesbarkeit-Fixes
═══════════════════════════════════════════════════════════════ */

/* Account-Logout-Row */
.set-modal-v2 .account-logout-row {
  display: flex;
  justify-content: flex-end;
  margin: 12px 0;
}

/* Hint-Texte überall hell */

/* alle inputs/selects/textareas im Modal explizit hell */
.set-modal-v2 input:focus,
.set-modal-v2 select:focus,
.set-modal-v2 textarea:focus {
  border-color: rgba(201,168,76,0.6) !important;
  background: rgba(255,255,255,0.08) !important;
}

/* readonly inputs spezifisch */

/* Select-Optionen sollen im Browser-Dropdown lesbar sein (System default) */

/* Buttons in Settings — sicherstellen dass alle hell genug sind */
.set-modal-v2 .btn,
.set-modal-v2 button:not(.st-tab):not(.pricing-close):not(.fb-mini-star):not(.fb-star):not(.ai-sugg-chip) {
  color: inherit;
}
.set-modal-v2 .btn-outline:hover {
  background: rgba(201,168,76,0.12) !important;
  color: var(--gold) !important;
  border-color: rgba(201,168,76,0.40) !important;
}
.set-modal-v2 .btn-sm { font-size: 12.5px; padding: 7px 14px; }

/* DealScore-Inline-Settings: alle alten weiß-auf-weiß-Stellen aufheben */

/* Plan-Pane (Pricing-Karten innerhalb Settings) */

/* Startup-View-Selektor — sauberes Layout */
.set-modal-v2 .startup-view-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.03);
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.06);
  flex-wrap: wrap;
}
.set-modal-v2 .startup-view-row select {
  min-width: 220px;
}

/* ═══════════════════════════════════════════════════════════════
   V63.77 — RND-Modul Integration in Deal-Aktion
═══════════════════════════════════════════════════════════════ */
.da-rnd-host {
  min-height: 400px;
  max-height: 70vh;
  overflow-y: auto;
  padding: 4px;
}
.da-rnd-upsell {
  background: rgba(201,168,76,0.10);
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 8px;
  padding: 12px 14px;
  margin: 14px 0;
  font-size: 13px;
  color: var(--ch);
  line-height: 1.5;
}
.da-rnd-upsell strong { color: var(--gold); display: block; margin-bottom: 4px; }

/* V63.77: Wenn das Deal-Aktion-Modal das RND-Modul rendert, mehr Breite + Höhe geben */
.da-modal:has(.da-rnd-host) {
  max-width: 1100px !important;
  max-height: 95vh !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.78 — Settings-Modal FINAL (alle Inkonsistenzen aufgeräumt)
   Marcel-Feedback V63.77→V63.78:
   - Inputs zu hell (sahen wie "ausgefüllt" aus)
   - Buttons inkonsistent
   - DealScore weiß-auf-weiß
   - Kontakt: graue Schrift, grüne Box unleserlich, Logo-Box weiß
   - Disketten-Icons → SVG
   - Investor-Score graue Schrift, passt nicht ins Layout
   - Vorlagen-Modal Umrandung schließt zu früh
   - Form-Layout schließt vor "Account löschen"
═══════════════════════════════════════════════════════════════ */

/* ── 1) Modal-Container: Padding + Section-Layout ───────────── */
.set-modal-v2 .st-pane {
  padding: 24px 32px 36px !important;
  /* Section-Trennung sichtbar machen */
}
.set-modal-v2 .st-pane > * + .set-section-h {
  margin-top: 28px !important;
}
.set-modal-v2 .st-pane hr.dvd {
  border: none;
  border-top: 1px solid rgba(255,255,255,0.10);
  margin: 24px 0;
}

/* Section-H2 (für die zusammengeführten Sub-Sections) */

/* ── 2) Inputs/Selects/Textareas — eingegebene Werte normal hell, Placeholder gedämpft ── */
.set-modal-v2 input[type="text"],
.set-modal-v2 input[type="email"],
.set-modal-v2 input[type="password"],
/* Platzhalter dezenter — damit eingegebene Werte CLEAR von Vorschlägen unterscheidbar sind */
.set-modal-v2 input:focus,
.set-modal-v2 select:focus,
.set-modal-v2 textarea:focus {
  background: rgba(255,255,255,0.07) !important;
  border-color: rgba(201,168,76,0.55) !important;
  outline: none;
}

/* ── 3) Labels deutlich gold-akzentuiert (nicht grau) ──────── */

/* ── 4) Buttons KONSISTENT (Disketten-Icon raus war im JS schon, hier Optik) ── */
.set-modal-v2 .btn,
.set-modal-v2 button.btn-sm {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  font-family: inherit !important;
  font-weight: 600 !important;
  border-radius: 8px !important;
  padding: 9px 16px !important;
  font-size: 13px !important;
  cursor: pointer;
  border: 1px solid transparent !important;
  transition: all 0.15s ease !important;
  line-height: 1.2 !important;
}
.set-modal-v2 .btn-gold {
  background: var(--gold) !important;
  color: #1A1414 !important;
  border-color: var(--gold) !important;
}
.set-modal-v2 .btn-gold:hover { background: #d8b85e !important; }
.set-modal-v2 .btn-primary {
  background: var(--gold) !important;
  color: #1A1414 !important;
  border-color: var(--gold) !important;
}
.set-modal-v2 .btn-primary:hover { background: #d8b85e !important; }
.set-modal-v2 .btn-outline:hover {
  background: rgba(201,168,76,0.10) !important;
  color: var(--gold) !important;
  border-color: rgba(201,168,76,0.40) !important;
}
.set-modal-v2 .btn-danger {
  background: rgba(184,98,92,0.16) !important;
  color: #E8918B !important;
  border-color: rgba(184,98,92,0.45) !important;
}
.set-modal-v2 .btn-sm { padding: 7px 13px !important; font-size: 12px !important; }
.set-modal-v2 .btn svg { display: block; }

/* ── 5) DealScore-Tab: BEIDE Sektionen (Klassisch + Investor) dunkel ── */
.set-modal-v2 .ds-pane-section-investor {
  background: linear-gradient(135deg, rgba(201,168,76,0.08), rgba(201,168,76,0.02)) !important;
  border-color: rgba(201,168,76,0.30) !important;
}
/* Slider-Werte (Zahlen neben den Reglern) lesbar */
.set-modal-v2 .ds-pane-section .ds2-set-field input[type="number"] {
  text-align: right;
}

/* ── 6) Kontakt & Logo: Lesbarkeit ──────────────────────────── */
/* Hint-Header über dem Kontakt-Block */
/* Grüne / Info-Boxen: kontraststark */
/* Logo-Vorschau-Box ("Kein Logo gesetzt") */

/* ── 7) Account-Pane: Layout-Korrektur (Account löschen war "draußen") ── */
.set-modal-v2 [data-pane="account"] {
  display: flex;
  flex-direction: column;
}
.set-modal-v2 [data-pane="account"] .account-logout-row,
.set-modal-v2 [data-pane="account"] .danger-zone {
  margin-top: 16px;
}

/* ── 8) Vorlagen-Modal (Selbstauskunft etc.) — Umrandung passt ── */
.set-modal-v2 .modal,
.set-modal-v2 .preview-modal {
  background: #2A2727 !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
}

/* ── 9) Plan-Pane (Pricing innerhalb Settings) ── */
.set-modal-v2 [data-pane="plan"] {
  padding: 24px 24px 36px !important;
}

/* ── 10) Investmentprofil-Pane: weiter unten alles abschließen ── */
.set-modal-v2 .ip-actions {
  margin-top: 28px !important;
  padding-top: 18px !important;
  border-top: 1px solid rgba(255,255,255,0.08);
  flex-wrap: wrap;
}

/* ── 11) Info-Pane: bessere Lesbarkeit + Scrolling ── */
.set-modal-v2 [data-pane="info"] {
  max-height: 70vh;
  overflow-y: auto;
}
.set-modal-v2 [data-pane="info"] a {
  color: var(--gold) !important;
}

/* ── 12) Tab-Bar Scroll auf schmalen Screens ──────────────── */
.set-modal-v2 .settings-tabs {
  overflow-x: auto;
  scrollbar-width: thin;
}
.set-modal-v2 .settings-tabs::-webkit-scrollbar { height: 4px; }
.set-modal-v2 .settings-tabs::-webkit-scrollbar-thumb {
  background: rgba(201,168,76,0.30);
  border-radius: 2px;
}

/* ── 13) Mobile ── */
@media (max-width: 700px) {
  .set-modal-v2 .st-pane { padding: 18px 18px 30px !important; }
  .set-modal-v2 [data-pane="info"] { max-height: 60vh; }
}

/* V63.78 — KI-Vorlagen kategorisiert mit Multi-Select */
.set-modal-v2 .ai-suggestions {
  margin-top: 14px;
  padding: 16px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
}
.set-modal-v2 .ai-sugg-head {
  font-size: 11px;
  font-weight: 700;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.set-modal-v2 .ai-sugg-apply {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--gold) !important;
  color: #1A1414 !important;
  border: 0 !important;
  border-radius: 6px !important;
  padding: 6px 12px !important;
  font-size: 11.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em;
  cursor: pointer;
  text-transform: none;
}
.set-modal-v2 .ai-sugg-apply:hover { background: #d8b85e !important; }

.set-modal-v2 .ai-sugg-cat {
  margin-bottom: 12px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 8px;
  overflow: hidden;
}
.set-modal-v2 .ai-sugg-cat:last-child { margin-bottom: 0; }
.set-modal-v2 .ai-sugg-cat-items {
  display: flex;
  flex-direction: column;
}
.set-modal-v2 .ai-sugg-item:last-child { border-bottom: 0; }
/* V63.96: Vorlagen-Item — Abstand zwischen Checkbox-Zeilen, Hover, Padding */
.set-modal-v2 .ai-sugg-item {
  display: flex;
  align-items: flex-start;
  gap: 11px;
  padding: 11px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  cursor: pointer;
  transition: background-color 0.12s;
  font-size: 12.5px;
  line-height: 1.5;
  color: rgba(255,255,255,0.85);
}
.set-modal-v2 .ai-sugg-item:hover {
  background-color: rgba(201,168,76,0.06);
}
.set-modal-v2 .ai-sugg-item span {
  flex: 1;
  text-transform: none;
}
/* V63.96: Cat-Header mit Icon vor Label */
.set-modal-v2 .ai-sugg-cat-head {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 11px 14px;
  background: rgba(201,168,76,0.10);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--gold);
}
.set-modal-v2 .ai-sugg-cat-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 5px;
  background: rgba(201,168,76,0.18);
  color: var(--gold);
  flex-shrink: 0;
}
.set-modal-v2 .ai-sugg-cat-icon svg {
  width: 14px;
  height: 14px;
  stroke: var(--gold);
}
.set-modal-v2 .ai-sugg-cb {
  margin: 2px 0 0 0 !important;
  width: 16px !important;
  height: 16px !important;
  flex-shrink: 0;
  accent-color: var(--gold);
  cursor: pointer;
  padding: 0 !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.78 — RND-Modul Polish (Pro-Mode in Deal-Aktion)
═══════════════════════════════════════════════════════════════ */
.da-rnd-headline {
  background: linear-gradient(135deg, rgba(201,168,76,0.14), rgba(201,168,76,0.04));
  border: 1px solid rgba(201,168,76,0.40);
  border-radius: 12px;
  padding: 22px 26px;
  margin-bottom: 18px;
  text-align: center;
}
.da-rnd-headline-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  margin-bottom: 6px;
}
.da-rnd-headline-value {
  font-family: 'Cormorant Garamond', serif;
  font-size: 56px;
  font-weight: 600;
  line-height: 1;
  color: var(--ch);
  letter-spacing: -0.02em;
}
.da-rnd-headline-unit {
  font-size: 22px;
  color: var(--muted);
  margin-left: 8px;
  font-weight: 400;
  font-style: italic;
}
.da-rnd-headline-method {
  font-size: 12px;
  color: var(--muted);
  margin-top: 6px;
}

/* CTA: Restnutzungsdauer-Gutachten beantragen */
.da-rnd-cta {
  background: linear-gradient(135deg, var(--gold), #d8b85e) !important;
  color: #1A1414 !important;
  font-size: 14px !important;
  padding: 11px 22px !important;
  font-weight: 700 !important;
  border: 0 !important;
  box-shadow: 0 4px 12px rgba(201,168,76,0.30);
}
.da-rnd-cta:hover {
  filter: brightness(1.05);
  box-shadow: 0 6px 16px rgba(201,168,76,0.40);
}

/* RND-Modul Pro-Mode: Export-Card + AfA-Card + Override-Card verstecken
   (das ist Berater-Kram — User soll nur die Empfehlung sehen + CTA) */
.da-rnd-host-pro .rnd-card:has(h3:not(:first-of-type)) {
  /* nichts — wir blenden gezielt aus */
}
.da-rnd-host-pro .rnd-card h3 {
  /* Wir matchen über Inhalt: alle Cards mit "Export", "AfA-Vergleich", "Sachverständigen-Override" */
}

/* Pragmatisches CSS — Cards nach Header-Text ausblenden */
.da-rnd-host-pro .rnd-card:has(> h3:is(:contains("Export"))),
.da-rnd-host-pro .rnd-card:has(> h3) { /* Fallback */ }

/* Direkter Weg: Ich blende per Klassennamen aus, die das RND-Modul setzt — falls vorhanden.
   Wenn nicht, JS-Code blendet die Cards nachträglich aus (siehe deal-action.js _hideRNDExtras). */

/* ═══════════════════════════════════════════════════════════════
   V63.79 — Settings-Modal Bug-Fixes aus Marcels Screenshots
   ═══════════════════════════════════════════════════════════════
   Konkrete Bugs aus Bild 1 + 2:
   - %-Suffix sieht aus wie klickbarer Button → flacher, ohne Button-Optik
   - "Tab Objekt (Default)"-Dropdown sieht aus wie Read-Only → klar als Dropdown
   - Form-Padding/Section-Abstände im Account-Tab
   - Modal-Footer mit "ungespeicherte Änderungen" + Abbrechen + Speichern
   ═══════════════════════════════════════════════════════════════ */

/* ── 1) %-Suffix entschärfen — sieht jetzt aus wie ein Tag, nicht wie ein Button */

/* %-Suffix-Spalte etwas breiter wenn der Text "% v. KP" oder ähnlich lang ist */
.set-modal-v2 .ip-field-row {
  align-items: stretch !important;
  gap: 0 !important;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 8px;
  padding: 0 10px;
  transition: border-color 0.15s, background 0.15s;
}
.set-modal-v2 .ip-field-row:focus-within {
  border-color: rgba(201,168,76,0.55);
  background: rgba(255,255,255,0.07);
}
.set-modal-v2 .ip-field-row input {
  background: transparent !important;
  border: none !important;
  padding: 9px 0 !important;
}

/* ── 2) Startup-View-Dropdown — eindeutig als Dropdown erkennbar */
.set-modal-v2 .startup-view-row select {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.15) !important;
  cursor: pointer !important;
  /* Native Dropdown-Pfeil sichtbar */
  -webkit-appearance: menulist !important;
  -moz-appearance: menulist !important;
  appearance: menulist !important;
  padding-right: 30px !important;
}
.set-modal-v2 .startup-view-row select:hover {
  background: rgba(255,255,255,0.09) !important;
  border-color: rgba(201,168,76,0.40) !important;
}

/* ── 3) Modal-Footer: "ungespeicherte Änderungen" + Abbrechen + Speichern */
.set-modal-v2 .set-foot,
.set-modal-v2 .settings-foot,
.set-modal-v2 [class*="-foot"]:has(button) {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 14px 24px !important;
  background: rgba(0,0,0,0.20) !important;
  border-top: 1px solid rgba(255,255,255,0.08) !important;
  position: sticky;
  bottom: 0;
  z-index: 5;
}

/* Dirty-Hint klar sichtbar (war zu dezent) */
.set-modal-v2 .set-dirty-hint,
.set-modal-v2 [class*="dirty"] {
  font-size: 12px !important;
  color: var(--gold) !important;
  display: flex;
  align-items: center;
  gap: 6px;
}
.set-modal-v2 .set-dirty-hint::before,
.set-modal-v2 [class*="dirty"]::before {
  content: '●';
  color: var(--gold);
  font-size: 10px;
}

/* ── 4) Account-Tab: Sections klar voneinander getrennt */
.set-modal-v2 [data-pane="account"] hr.dvd {
  border: none !important;
  border-top: 1px solid rgba(255,255,255,0.10) !important;
  margin: 24px 0 !important;
}
.set-modal-v2 [data-pane="account"] .set-section-h {
  margin: 0 0 12px !important;
  padding: 0 !important;
}

/* "Aktueller Plan"-Box im Account-Tab */

/* "Plan ändern →" Button im Account-Tab */

/* "Passwort ändern"-Block */
.set-modal-v2 [data-pane="account"] input[type="password"] {
  letter-spacing: 0.15em;
}

/* "Account löschen"-Box: Roten Header und Inhalt klar separiert */
.set-modal-v2 [data-pane="account"] .danger-zone {
  background: rgba(184,98,92,0.08) !important;
  border: 1px solid rgba(184,98,92,0.30) !important;
  border-radius: 10px !important;
  padding: 14px 18px !important;
  margin-top: 8px;
}
.set-modal-v2 [data-pane="account"] .danger-zone .danger-text strong {
  color: #E47A7A !important;
}

/* ── 5) Modal-Container: insgesamt mehr Atmen, klare Begrenzung */
.set-modal-v2 {
  max-height: 92vh !important;
  display: flex !important;
  flex-direction: column !important;
}
.set-modal-v2 .settings-tabs {
  flex-shrink: 0;
}
.set-modal-v2 .st-pane-wrap,
.set-modal-v2 .settings-content {
  flex: 1;
  overflow-y: auto;
}

/* ═══════════════════════════════════════════════════════════════
   V63.80 — 2FA-Sicherheit-Tab
═══════════════════════════════════════════════════════════════ */
.set-modal-v2 .sec-2fa-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 12px;
  padding: 22px;
  margin-bottom: 16px;
}
.set-modal-v2 .sec-2fa-card.sec-2fa-active {
  background: linear-gradient(135deg, rgba(63,165,108,0.06), rgba(63,165,108,0.02));
  border-color: rgba(63,165,108,0.30);
}
.set-modal-v2 .sec-2fa-card.sec-2fa-disable {
  border-color: rgba(184,98,92,0.30);
}
.set-modal-v2 .sec-2fa-row {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 14px;
}
.set-modal-v2 .sec-2fa-icon-ok {
  background: rgba(63,165,108,0.15);
  color: #5EE09A;
}
.set-modal-v2 .sec-2fa-text { flex: 1; }
.set-modal-v2 .sec-2fa-warn { color: #E4B056; font-weight: 600; }

.set-modal-v2 .sec-2fa-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}


.set-modal-v2 .sec-2fa-qr-wrap {
  display: flex;
  justify-content: center;
  background: #fff;
  padding: 16px;
  border-radius: 10px;
  margin: 0 auto 14px;
  max-width: 260px;
}
.set-modal-v2 .sec-2fa-qr {
  display: block;
  width: 220px; height: 220px;
}

.set-modal-v2 .sec-2fa-manual {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 8px;
  padding: 0;
  margin-bottom: 6px;
}
.set-modal-v2 .sec-2fa-manual summary::-webkit-details-marker { display: none; }
.set-modal-v2 .sec-2fa-manual summary::before { content: '▸ '; color: var(--gold); }
.set-modal-v2 .sec-2fa-manual[open] summary::before { content: '▾ '; }
.set-modal-v2 .sec-2fa-secret-box {
  display: flex; gap: 8px; align-items: center;
  padding: 12px 14px;
  background: rgba(0,0,0,0.20);
  border-top: 1px solid rgba(255,255,255,0.08);
}
.set-modal-v2 .sec-2fa-secret-box code {
  font-family: 'Courier New', monospace;
  font-size: 13px;
  color: var(--gold);
  letter-spacing: 0.05em;
  flex: 1;
  word-break: break-all;
}

/* TOTP-Code-Input — groß, mittig, leserlich */
.set-modal-v2 .sec-2fa-code-row {
  display: flex; gap: 10px; align-items: center;
}
.set-modal-v2 .sec-2fa-code-row input:focus {
  border-color: var(--gold) !important;
  background: rgba(255,255,255,0.09) !important;
}

/* Recovery-Codes-Box */
.set-modal-v2 .sec-2fa-recovery-warn strong { color: #E4B056; }
.set-modal-v2 .sec-2fa-recovery-codes textarea {
  width: 100%;
  padding: 14px !important;
  font-family: 'Courier New', monospace !important;
  font-size: 13.5px !important;
  letter-spacing: 0.05em !important;
  background: #1A1414 !important;
  border: 1px solid var(--gold) !important;
  color: var(--gold) !important;
  border-radius: 8px !important;
  resize: none !important;
  text-align: center;
  line-height: 1.7;
}
.set-modal-v2 .sec-2fa-recovery-actions {
  display: flex; gap: 8px;
  margin-top: 10px;
  flex-wrap: wrap;
}
.set-modal-v2 .sec-2fa-confirm-saved input[type="checkbox"] {
  width: 18px !important; height: 18px !important;
  accent-color: var(--gold);
  cursor: pointer;
  margin: 0 !important;
  padding: 0 !important;
}

.set-modal-v2 .sec-2fa-error {
  color: #E47A7A;
  background: rgba(184,98,92,0.10);
  border: 1px solid rgba(184,98,92,0.30);
  border-radius: 8px;
}

/* Mobile */
@media (max-width: 600px) {
  .set-modal-v2 .sec-2fa-code-row { flex-direction: column; align-items: stretch; }
  .set-modal-v2 .sec-2fa-actions { flex-direction: column; align-items: stretch; }
  .set-modal-v2 .sec-2fa-actions .btn { width: 100%; }
}

/* V63.81 — Cashflow-Projektion Footer (Σ / ⌀-Zeile) */
.cft tr.proj-footer {
  background: rgba(201,168,76,0.10);
  border-top: 2px solid var(--gold);
  font-weight: 600;
}
.cft tr.proj-footer td {
  padding-top: 11px !important;
  padding-bottom: 11px !important;
  border-bottom: none !important;
}
.cft tr.proj-footer strong {
  font-weight: 700;
}

/* ═══════════════════════════════════════════════════════════════
   V63.81 — Settings-Modal Scroll-Container + Polish-Fixes
   ═══════════════════════════════════════════════════════════════ */

/* Modal als Flex-Column, damit Tabs + Footer fix bleiben und Mitte scrollt */
.set-modal-v2 {
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;     /* Wichtig: Border-Radius würde sonst durch inneres Scrolling überlappt */
}
.set-modal-v2 .set-head-v2,
.set-modal-v2 .settings-tabs {
  flex-shrink: 0 !important;
}

/* Alle Panes (st-pane) sind absolut positioniert ABER nur der aktive ist sichtbar.
   Damit der aktive Pane scrollt: */
.set-modal-v2 .st-pane {
  flex: 1 1 auto;
  overflow-y: auto !important;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(201,168,76,0.30) transparent;
}
.set-modal-v2 .st-pane::-webkit-scrollbar { width: 6px; }
.set-modal-v2 .st-pane::-webkit-scrollbar-thumb {
  background: rgba(201,168,76,0.30);
  border-radius: 3px;
}
.set-modal-v2 .st-pane:not(.active) {
  display: none !important;        /* sicherstellen dass nicht-aktive Panes vollständig weg sind */
}

/* Footer (Speichern + Abbrechen) bleibt unten sticky innerhalb des Modal-Containers.
   Wenn der Footer eine eigene Klasse hat — wir matchen alle Varianten */
.set-modal-v2 .set-foot,
.set-modal-v2 .settings-foot,
.set-modal-v2 [class*="set-foot"],
.set-modal-v2 > div[class*="foot"]:has(button.btn) {
  flex-shrink: 0 !important;
  background: rgba(0,0,0,0.30) !important;
  border-top: 1px solid rgba(255,255,255,0.10) !important;
  z-index: 5;
}

/* ── "Passwort ändern"-Button: Text war weiß auf hell, deshalb unleserlich */
.set-modal-v2 [data-pane="account"] button[type="button"]:not(.btn-danger):not(.btn-gold):not(.pricing-close),
.set-modal-v2 button:has(> :is(text):contains("Passwort")) {
  /* Pragmatischer Fix per Klassenname */
}

/* ── DealScore-Tab: Inputs UND Labels lesbar */
.set-modal-v2 [data-pane="dealscore"] {
  background: transparent !important;
}

/* DealScore-Section-Wrapper hat oft eine eigene Card-Optik — die soll auch dunkel sein */
.set-modal-v2 [data-pane="dealscore"] .ds-pane-section-investor {
  background: linear-gradient(135deg, rgba(201,168,76,0.10), rgba(201,168,76,0.03)) !important;
  border-color: rgba(201,168,76,0.30) !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.81 — Tilgungsplan-Modal: passt zu Settings-Theme (dunkel + gold)
   ═══════════════════════════════════════════════════════════════ */
.tilgplan-modal {
  background: #1A1717 !important;
  color: rgba(255,255,255,0.92) !important;
  border: 1px solid rgba(201,168,76,0.20) !important;
  border-radius: 14px !important;
  box-shadow: 0 24px 70px rgba(0,0,0,0.65) !important;
  overflow: hidden !important;
}
.tilgplan-modal .iexp-header {
  background: rgba(255,255,255,0.02) !important;
  border-bottom: 1px solid rgba(255,255,255,0.10) !important;
}
.tilgplan-modal .iexp-header h2 {
  color: #fff !important;
  font-family: 'Cormorant Garamond', serif;
}
.tilgplan-modal .iexp-header p {
  color: rgba(255,255,255,0.72) !important;
}
.tilgplan-modal .iexp-close {
  background: rgba(255,255,255,0.06) !important;
  color: rgba(255,255,255,0.7) !important;
  border: none !important;
}
.tilgplan-modal .iexp-close:hover {
  background: rgba(255,255,255,0.12) !important;
  color: #fff !important;
}

/* Statusbar oben */
.tilgplan-modal #tilgplan-statusbar {
  background: rgba(63,165,108,0.10) !important;
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
}
.tilgplan-modal #tilgplan-status-text {
  color: rgba(255,255,255,0.92) !important;
}
.tilgplan-modal .btn-ghost {
  background: rgba(255,255,255,0.06) !important;
  color: rgba(255,255,255,0.85) !important;
  border: 1px solid rgba(255,255,255,0.18) !important;
}
.tilgplan-modal .btn-primary {
  background: var(--gold) !important;
  color: #1A1414 !important;
}

/* Tabelle */
.tilgplan-modal .tilgplan-table {
  border-collapse: separate;
  border-spacing: 0;
  color: rgba(255,255,255,0.92);
}
.tilgplan-modal .tilgplan-table thead {
  background: #1A1717 !important;
}
.tilgplan-modal .tilgplan-table thead th {
  background: rgba(255,255,255,0.04) !important;
  color: rgba(255,255,255,0.65) !important;
  text-transform: uppercase;
  font-size: 11px !important;
  letter-spacing: 0.5px;
  font-weight: 600;
  padding: 12px 10px !important;
  border-bottom: 1px solid rgba(255,255,255,0.10) !important;
  white-space: nowrap;
}
.tilgplan-modal .tilgplan-table tbody td {
  padding: 10px !important;
  border-bottom: 1px solid rgba(255,255,255,0.05) !important;
  color: rgba(255,255,255,0.90);
  white-space: nowrap;            /* Werte nicht umbrechen */
}
.tilgplan-modal .tilgplan-table tbody tr:hover td {
  background: rgba(201,168,76,0.06) !important;
}
.tilgplan-modal .tilgplan-table .num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* Editierbare Zellen */
.tilgplan-modal .tilgplan-table input,
.tilgplan-modal .tilgplan-table .edit-cell input {
  background: rgba(255,255,255,0.04) !important;
  color: rgba(255,255,255,0.95) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  border-radius: 4px !important;
  padding: 4px 6px !important;
  font-size: 12px !important;
  text-align: right;
  width: 100%;
  font-variant-numeric: tabular-nums;
}
.tilgplan-modal .tilgplan-table input:focus {
  border-color: rgba(201,168,76,0.55) !important;
  background: rgba(255,255,255,0.07) !important;
}

.tilgplan-modal .hint {
  color: rgba(255,255,255,0.55);
  font-size: 11px;
  font-style: italic;
}

/* V63.81: Cashflow-Projektion Summen-Zeile */
.cft tbody tr.proj-sum-row {
  background: linear-gradient(135deg, rgba(201,168,76,0.10), rgba(201,168,76,0.04)) !important;
  border-top: 2px solid var(--gold) !important;
  font-weight: 600;
}
.cft tbody tr.proj-sum-row td {
  border-top: 2px solid var(--gold) !important;
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.82 — Pricing-Modal Erweiterungen (Service-Levels + Feature-Tabelle)
═══════════════════════════════════════════════════════════════ */

/* Feature-Übersicht-Tabelle */
.dp-feature-table-wrap {
  background: rgba(255,255,255,0.02);
  border-radius: 14px;
  padding: 28px 22px;
  margin: 28px 0;
}
.dp-feature-table-h {
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px;
  font-weight: 600;
  color: #fff;
  margin: 0 0 6px;
  text-align: center;
}
.dp-feature-table-sub {
  font-size: 13.5px;
  color: rgba(255,255,255,0.65);
  text-align: center;
  margin-bottom: 22px;
}
.dp-feature-table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.08);
}
.dp-feature-table {
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
  font-size: 13px;
}
.dp-feature-table thead th {
  background: rgba(0,0,0,0.30);
  color: rgba(255,255,255,0.92);
  padding: 14px 12px;
  text-align: center;
  font-weight: 600;
  font-size: 13.5px;
  border-bottom: 2px solid rgba(201,168,76,0.35);
  position: sticky;
  top: 0;
  z-index: 2;
}
.dp-feature-table thead th.dp-ft-feature {
  text-align: left;
  width: 32%;
}
.dp-feature-table thead th.dp-ft-plan-best {
  background: linear-gradient(180deg, rgba(201,168,76,0.30), rgba(201,168,76,0.10));
  color: var(--gold);
  font-weight: 700;
}
.dp-feature-table tr.dp-ft-cat-row td {
  background: rgba(201,168,76,0.10);
  color: var(--gold);
  font-weight: 700;
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 10px 14px;
  border-top: 1px solid rgba(201,168,76,0.20);
  border-bottom: 1px solid rgba(201,168,76,0.20);
}
.dp-feature-table tbody td {
  padding: 11px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  color: rgba(255,255,255,0.85);
}
.dp-feature-table tbody td.dp-ft-feature {
  color: rgba(255,255,255,0.92);
  font-weight: 500;
}
.dp-feature-table tbody td.dp-ft-cell {
  text-align: center;
  font-size: 13px;
}
.dp-feature-table tbody td.dp-ft-cell-best {
  background: rgba(201,168,76,0.06);
}
.dp-ft-yes {
  color: #5EE09A;
  font-weight: 700;
  font-size: 16px;
}
.dp-ft-no {
  color: rgba(255,255,255,0.30);
  font-size: 16px;
}
.dp-ft-text {
  color: rgba(255,255,255,0.75);
  font-size: 12px;
  font-style: italic;
}

/* Service-Levels (Silver / Gold / Platinum) */
.dp-services {
  margin: 28px 0;
}
.dp-services-h {
  font-family: 'Cormorant Garamond', serif;
  font-size: 26px;
  font-weight: 600;
  color: #fff;
  margin: 0 0 6px;
  text-align: center;
}
.dp-services-sub {
  font-size: 13.5px;
  color: rgba(255,255,255,0.65);
  text-align: center;
  margin-bottom: 22px;
}
.dp-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.dp-service-card {
  position: relative;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 12px;
  padding: 22px 18px;
  text-align: center;
  transition: border-color 0.15s, transform 0.15s;
}
.dp-service-card:hover {
  border-color: rgba(201,168,76,0.40);
  transform: translateY(-2px);
}
.dp-service-card-best {
  background: linear-gradient(135deg, rgba(201,168,76,0.10), rgba(201,168,76,0.03));
  border-color: rgba(201,168,76,0.40);
}
.dp-service-best-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--gold);
  color: #1A1414;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 4px 10px;
  border-radius: 4px;
  text-transform: uppercase;
}
.dp-service-icon {
  font-size: 32px;
  margin-bottom: 8px;
  line-height: 1;
}
.dp-service-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 18px;
  font-weight: 600;
  color: #fff;
  margin-bottom: 4px;
}
.dp-service-price {
  font-size: 14px;
  color: var(--gold);
  font-weight: 700;
  margin-bottom: 14px;
}
.dp-service-list {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
  text-align: left;
}
.dp-service-list li {
  font-size: 12.5px;
  color: rgba(255,255,255,0.80);
  padding: 5px 0 5px 20px;
  position: relative;
  line-height: 1.45;
}
.dp-service-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: #5EE09A;
  font-weight: 700;
}
.dp-service-cta {
  background: rgba(255,255,255,0.06);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.18);
  padding: 9px 18px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
}
.dp-service-cta:hover {
  background: var(--gold);
  color: #1A1414;
  border-color: var(--gold);
}
.dp-service-card-best .dp-service-cta {
  background: var(--gold);
  color: #1A1414;
  border-color: var(--gold);
}

/* Mobile: Service-Cards untereinander */
@media (max-width: 720px) {
  .dp-services-grid { grid-template-columns: 1fr; }
}

/* V63.82 — Account Plan-Box mit Meta-Info */
.set-modal-v2 .account-plan-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
  background: rgba(201,168,76,0.06);
  border: 1px solid rgba(201,168,76,0.25);
  border-radius: 10px;
}
.set-modal-v2 .account-plan-name-wrap {
  flex: 1 1 auto;
}
.set-modal-v2 .account-plan-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 22px;
  font-weight: 600;
  color: var(--gold);
  margin-bottom: 3px;
}
.set-modal-v2 .account-plan-link:hover {
  background: var(--gold) !important;
  color: #1A1414 !important;
  border-color: var(--gold) !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.83 — Plan-Hint-Boxen im Settings-Modal lesbar
   (Bug Bild 1: grüne Box "Pro-Plan: Vollständiges Branding..." war unleserlich
   weil .plan-hint-pro Text-Farbe dunkelgrau auf dunklem Hintergrund hat)
═══════════════════════════════════════════════════════════════ */
.set-modal-v2 .plan-hint-investor strong,
.set-modal-v2 .plan-hint-pro strong {
  color: #5EE09A !important;
}
.set-modal-v2 .plan-hint-starter strong {
  color: var(--gold) !important;
}
.set-modal-v2 .plan-hint-free strong {
  color: #E47A7A !important;
}
.set-modal-v2 .plan-hint-icon {
  color: inherit !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.83 — DealScore Investor-Box Lesbarkeit
   (Bild 2 zeigt: Labels in der goldenen Box waren unlesbar)
   Lösung: Investor-Box-Hintergrund deutlich dunkler — gold-Akzent nur am Rand
═══════════════════════════════════════════════════════════════ */
.set-modal-v2 .ds-pane-section-investor {
  background: rgba(255,255,255,0.03) !important;            /* gleiches Dunkel wie DealPilot Score */
  border: 1px solid rgba(201,168,76,0.40) !important;       /* gold-Rand statt gold-Hintergrund */
  position: relative;
}
.set-modal-v2 .ds-pane-section-investor::before {
  /* dünner gold-Akzentstreifen oben statt voller Verlauf */
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  border-radius: 12px 12px 0 0;
  pointer-events: none;
}

/* Labels in BEIDEN Score-Boxen einheitlich lesbar */

/* Section-Header (HAUPTGEWICHTUNGEN, UNTERGEWICHTUNGEN — RENDITE) */
.set-modal-v2 .ds-pane-section .ds2-section-h,
.set-modal-v2 .ds-pane-section-investor .ds2-section-h,
.set-modal-v2 .ds-pane-section [class*="section-h"],
.set-modal-v2 .ds-pane-section-investor [class*="section-h"] {
  color: rgba(201,168,76,0.92) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase !important;
  margin: 18px 0 10px !important;
  padding-bottom: 6px !important;
  border-bottom: 1px solid rgba(201,168,76,0.20) !important;
}

/* Number-Inputs (Slider-Werte rechts) ohne Hover-Glanz */

/* Header-Box "Investor Deal Score" mit gold-Stern */
.set-modal-v2 .ds-pane-section-investor > .ds-pane-header,
.set-modal-v2 .ds-pane-section-investor > .ds2-pane-header {
  margin-bottom: 14px;
}

/* ═══════════════════════════════════════════════════════════════
   V63.83 — Tilgungsplan-Modal zurück auf HELL (Marcel-Wunsch)
   Überschreibt die V63.81-Dunkelversion komplett.
═══════════════════════════════════════════════════════════════ */
#tilgplan-modal .iexp-modal {
  background: #FFFFFF !important;
  color: var(--ch) !important;
  border: 1px solid rgba(42,39,39,0.10) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,0.25) !important;
}
#tilgplan-modal .iexp-header {
  background: var(--surface) !important;
  border-bottom: 1px solid rgba(42,39,39,0.08) !important;
}
#tilgplan-modal .iexp-header h2 {
  color: var(--ch) !important;
}
#tilgplan-modal .iexp-header p {
  color: rgba(42,39,39,0.65) !important;
}
#tilgplan-modal .iexp-close {
  background: rgba(42,39,39,0.06) !important;
  color: var(--ch) !important;
}
#tilgplan-modal .iexp-close:hover {
  background: rgba(42,39,39,0.12) !important;
}
#tilgplan-modal #tilgplan-statusbar {
  background: rgba(63,165,108,0.08) !important;
  border-bottom: 1px solid rgba(42,39,39,0.06) !important;
}
#tilgplan-modal #tilgplan-statusbar #tilgplan-status-text {
  color: var(--ch) !important;
}
#tilgplan-modal #tilgplan-statusbar .btn-ghost {
  background: rgba(42,39,39,0.04) !important;
  color: var(--ch) !important;
  border: 1px solid rgba(42,39,39,0.16) !important;
}
#tilgplan-modal #tilgplan-statusbar .btn-primary {
  background: var(--gold) !important;
  color: #1A1414 !important;
}
#tilgplan-modal #tilgplan-table-wrap {
  padding: 18px 28px 28px !important;
  background: #fff !important;
}
#tilgplan-modal .phase-table {
  color: var(--ch) !important;
}
#tilgplan-modal .phase-table thead th {
  background: var(--surface) !important;
  color: rgba(42,39,39,0.85) !important;
  border-bottom: 2px solid rgba(201,168,76,0.50) !important;
}
#tilgplan-modal .phase-table tbody tr {
  border-bottom: 1px solid rgba(42,39,39,0.05) !important;
}
#tilgplan-modal .phase-table tbody tr:hover {
  background: rgba(201,168,76,0.06) !important;
}
#tilgplan-modal .phase-table tbody td {
  color: var(--ch) !important;
  white-space: nowrap !important;
}
#tilgplan-modal .phase-table tbody td:nth-child(1),
#tilgplan-modal .phase-table tbody td:nth-child(2) {
  color: rgba(42,39,39,0.75) !important;
}


/* ═══════════════════════════════════════════════════════════════
   V63.84 — KOMPLETT-HELLES THEME (Marcel-Wunsch: konsistent hell)
   Fixt: Tilgungsplan-Werte unsichtbar, Cashflow-Projektion weiß-auf-weiß,
         Kennzahlen-Tab hell, KI-Tab hell, Settings hell.
═══════════════════════════════════════════════════════════════ */

/* 1) Cashflow-Projektion: ALLE Spalten lesbar — explizit dunkle Schrift */
.cft tbody td {
  color: var(--ch) !important;
  background: #fff;
}
.cft tbody td.pos { color: var(--green) !important; }
.cft tbody td.neg { color: var(--red) !important; }
.cft tbody tr:hover td { background: var(--gold-dim) !important; }
.cft tbody tr.ezb td { background: var(--gold-bg) !important; }
.cft tbody tr.proj-footer td { color: var(--ch) !important; }
.cft tbody tr.proj-footer td.pos { color: var(--green) !important; }
.cft tbody tr.proj-footer td.neg { color: var(--red) !important; }

/* 2) Tilgungsplan-Modal: Rate/Zinsen/Tilgung-Inputs sichtbar */
#tilgplan-modal .phase-table tbody td input[type="text"],
#tilgplan-modal .phase-table tbody td input[type="number"],
#tilgplan-modal .phase-table tbody td input {
  background: rgba(42,39,39,0.04) !important;
  color: var(--ch) !important;
  border: 1px solid rgba(42,39,39,0.12) !important;
  text-align: right !important;
  padding: 4px 8px !important;
  width: 95% !important;
  font-size: 13px !important;
  border-radius: 4px !important;
}
#tilgplan-modal .phase-table tbody td input::placeholder {
  color: rgba(42,39,39,0.35) !important;
}
#tilgplan-modal .phase-table tbody td input:focus {
  outline: none !important;
  border-color: var(--gold) !important;
  background: rgba(201,168,76,0.06) !important;
}
/* Für reine Text-Spalten (Datum, Restschuld) explizit dunkel */
#tilgplan-modal .phase-table tbody td {
  color: var(--ch) !important;
}

/* 3) KI-Analyse-Tab #s6 hell — alle V63.83-Dunkel-Overrides killen */
#s6 {
  background: transparent !important;
  color: var(--ch) !important;
  padding: 0 !important;
  border-radius: 0 !important;
}
#s6 .sec-title { color: var(--ch) !important; }
#s6 h3, #s6 h4 { color: var(--ch) !important; }
#s6 .ai-sub { color: var(--muted) !important; }
#s6 .hint { color: var(--muted) !important; }
#s6 .muted { color: var(--muted) !important; }
#s6 .ai-config-row,
#s6 .ai-section-card {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
}
#s6 textarea,
#s6 select,
#s6 input[type="text"] {
  background: #fff !important;
  color: var(--ch) !important;
  border: 1px solid var(--border) !important;
}

/* 4) Tab Kennzahlen #s7 explizit hell (falls irgendwo ein Override greift) */
#s7 {
  background: var(--surface) !important;
  color: var(--ch) !important;
}
#s7 .sec-title,
#s7 h3, #s7 h4 {
  color: var(--ch) !important;
}
#s7 .card { background: #fff !important; }

/* 5) Settings-Modal hell (ersetzt die set-modal-v2-Dunkel-Theme-Reste) */
.set-modal-v2,
.set-modal-v2 .pane-wrap,
.set-modal-v2 .pane,
.set-modal-v2 .pane-content {
  background: var(--surface) !important;
  color: var(--ch) !important;
}
.set-modal-v2 .pane-header,
.set-modal-v2 .pane-section,
.set-modal-v2 .ds-pane-section {
  background: #fff !important;
  color: var(--ch) !important;
  border: 1px solid var(--border) !important;
}
.set-modal-v2 label {
  color: var(--ch) !important;
}
.set-modal-v2 input[type="text"],
.set-modal-v2 input[type="email"],
.set-modal-v2 input[type="password"],
.set-modal-v2 input[type="number"],
.set-modal-v2 textarea,
.set-modal-v2 select {
  background: #fff !important;
  color: var(--ch) !important;
  border: 1px solid var(--border) !important;
}
.set-modal-v2 input::placeholder { color: rgba(42,39,39,0.40) !important; }
.set-modal-v2 .nav-btn {
  color: var(--ch) !important;
}
.set-modal-v2 .nav-btn.active {
  background: var(--gold-dim) !important;
  color: var(--ch) !important;
  border-left-color: var(--gold) !important;
}
.set-modal-v2 .nav-btn:hover:not(.active) {
  background: rgba(42,39,39,0.04) !important;
}

/* Plan-Hint-Boxen im hellen Settings */
.set-modal-v2 .plan-hint-box {
  color: var(--ch) !important;
}
.set-modal-v2 .plan-hint-investor,
.set-modal-v2 .plan-hint-pro {
  background: var(--green-dim) !important;
  border: 1px solid rgba(63,165,108,0.35) !important;
  color: var(--ch) !important;
}
.set-modal-v2 .plan-hint-investor strong,
.set-modal-v2 .plan-hint-pro strong {
  color: var(--green) !important;
}
.set-modal-v2 .plan-hint-starter {
  background: rgba(201,168,76,0.10) !important;
  border: 1px solid rgba(201,168,76,0.35) !important;
  color: var(--ch) !important;
}
.set-modal-v2 .plan-hint-starter strong {
  color: var(--gold) !important;
}
.set-modal-v2 .plan-hint-free {
  background: var(--red-bg) !important;
  border: 1px solid rgba(184,98,92,0.30) !important;
  color: var(--ch) !important;
}
.set-modal-v2 .plan-hint-free strong {
  color: var(--red) !important;
}

/* DealScore-Sections in hellem Settings */
.set-modal-v2 .ds-pane-section,
.set-modal-v2 .ds-pane-section-investor {
  background: #fff !important;
  border: 1px solid var(--border) !important;
}
.set-modal-v2 .ds-pane-section-investor::before {
  display: none;  /* gold-Akzentstreifen nur im dunklen Theme nötig */
}
.set-modal-v2 .ds-pane-section label,
.set-modal-v2 .ds-pane-section-investor label,
.set-modal-v2 .ds2-set-field label {
  color: var(--ch) !important;
}
.set-modal-v2 .ds-pane-section .ds2-section-h,
.set-modal-v2 .ds-pane-section-investor .ds2-section-h {
  color: var(--gold) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase !important;
  border-bottom: 1px solid rgba(201,168,76,0.30) !important;
}
.set-modal-v2 .ds-pane-section input[type="number"] {
  background: #fff !important;
  color: var(--ch) !important;
  border: 1px solid var(--border) !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.84 — KI-Icon: Brain-Chip Vektor-Icon in DealPilot-Gold
   Ersetzt das alte Sparkles-Buzzword-Icon mit einem cleanen
   Analytics-Style "Brain-on-Chip"-Symbol als Inline-SVG-Background.
═══════════════════════════════════════════════════════════════ */
.ai-icon-sparkles,
.ai-icon-brain {
  background: rgba(201,168,76,0.15) !important;
  border: 1.5px solid rgba(201,168,76,0.50) !important;
  border-radius: 50%;
  width: 44px;
  height: 44px;
  flex-shrink: 0;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C9A84C' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9.5 2A2.5 2.5 0 0 1 12 4.5v15a2.5 2.5 0 0 1-4.96.44 2.5 2.5 0 0 1-2.96-3.08 3 3 0 0 1-.34-5.58 2.5 2.5 0 0 1 1.32-4.24 2.5 2.5 0 0 1 1.98-3A2.5 2.5 0 0 1 9.5 2Z'/%3E%3Cpath d='M14.5 2A2.5 2.5 0 0 0 12 4.5v15a2.5 2.5 0 0 0 4.96.44 2.5 2.5 0 0 0 2.96-3.08 3 3 0 0 0 .34-5.58 2.5 2.5 0 0 0-1.32-4.24 2.5 2.5 0 0 0-1.98-3A2.5 2.5 0 0 0 14.5 2Z'/%3E%3Cpath d='M6 13a2 2 0 0 1-1.5-2.5'/%3E%3Cpath d='M18 13a2 2 0 0 0 1.5-2.5'/%3E%3Cpath d='M9 18.5a2.5 2.5 0 0 1-2-2.5'/%3E%3Cpath d='M15 18.5a2.5 2.5 0 0 0 2-2.5'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-size: 24px 24px !important;
  color: transparent !important;
  font-size: 0 !important;
}
.ai-icon-sparkles::before,
.ai-icon-sparkles::after,
.ai-icon-brain::before,
.ai-icon-brain::after {
  content: '' !important;
  display: none !important;
}

/* ═══════════════════════════════════════════════════════════════
   V63.85 — KI-Box hell + AI-Output-Sektionen lesbar
   Bug Bild 1: Überschriften "Gesamtbewertung" etc. waren auf dunkel
   unlesbar. Lösung: ai-box hell, ai-section weißer Hintergrund mit
   farbigem Akzentstreifen links (statt voller Farbfläche).
═══════════════════════════════════════════════════════════════ */
.ai-box {
  background: #fff !important;
  color: var(--ch) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow) !important;
}
.ai-box .ai-title {
  color: var(--ch) !important;
}
.ai-box .ai-sub {
  color: var(--muted) !important;
}
.ai-box .ai-body {
  color: var(--ch) !important;
}
#ai-content {
  color: var(--ch) !important;
}
.ai-section {
  margin-top: 14px;
  padding: 14px 14px 14px 18px;
  border-top: none;
  background: var(--surface);
  border-radius: 8px;
  border-left: 4px solid var(--gold);
  position: relative;
}
.ai-section .ai-section-label {
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  font-weight: 700;
  margin-bottom: 8px;
  /* Inline-Style aus renderAIResponse setzt die Farbe pro Sektion (gold/grün/rot/blau).
     Wir geben nur eine garantierte Sichtbarkeits-Mindestfarbe wenn der inline-style fehlt. */
  color: var(--ch);
}
.ai-section .ai-body {
  color: var(--ch) !important;
  font-size: 13px;
  line-height: 1.55;
}

/* ═══════════════════════════════════════════════════════════════
   V63.85 — Mobile + Tablet vollwertig
   Marcel: "vollwertige mobile Ansicht: Tabs scrollbar, Tabellen
   kompakt, Touch-Targets groß genug"
═══════════════════════════════════════════════════════════════ */

/* URL-Import-Zeile (Quick-Check) */
.qc-url-row {
  display: flex !important;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--border-g);
  border-radius: 8px;
  padding: 10px 12px;
  margin: 8px 0 12px;
}
.qc-url-row input[type="url"] {
  flex: 1 1 280px;
  min-width: 240px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #fff;
  color: var(--ch);
  font-size: 14px;
}
.qc-url-row input[type="url"]:focus {
  outline: none;
  border-color: var(--gold);
}
.qc-url-status {
  flex: 0 0 100%;
  font-size: 12.5px;
  padding-top: 6px;
}
.qc-url-status.qc-url-ok   { color: var(--green); }
.qc-url-status.qc-url-info { color: var(--muted); }
.qc-url-status.qc-url-warn { color: #B89740; }
.qc-url-status.qc-url-err  { color: var(--red); }

/* ─── TABLET (≤1024px) ─── */
@media (max-width: 1024px) {
  /* Tab-Bar: scrollbar wenn nötig */
  nav.tabs, .tabs {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    flex-wrap: nowrap !important;
    white-space: nowrap;
  }
  nav.tabs .tab, .tabs .tab {
    flex-shrink: 0 !important;
    min-width: max-content;
  }

  /* Container-Padding sparsamer */
  main, .main, .sec.active {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  /* Cashflow-Projektion-Tabelle: horizontaler Scroll */
  .cft, .phase-table, .zaer-table, .ds2-table {
    font-size: 11px !important;
  }
  .cft th, .cft td {
    padding: 5px 6px !important;
  }

  /* Workflow-Bar kompakter */
  .tabs-workflow-bar {
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
  }

  /* KPI-Grid: 2 Spalten statt 4 */
  .kpi-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* ─── MOBILE (≤640px) ─── */
@media (max-width: 640px) {
  body, html {
    font-size: 14px;
  }

  /* Sidebar wird Drawer (statt fix) */
  .sidebar {
    transform: translateX(-100%);
    transition: transform 0.25s ease;
    z-index: 1000;
    box-shadow: 4px 0 24px rgba(0,0,0,0.30);
  }
  .sidebar.mobile-open {
    transform: translateX(0);
  }

  /* Touch-Targets: alles ≥44px Höhe */
  button, .btn, .tab, input[type="text"], input[type="email"],
  input[type="password"], input[type="number"], input[type="url"],
  select {
    min-height: 44px !important;
  }
  .nav-btn, .qc-top-actions button {
    min-height: 48px !important;
    padding: 10px 14px !important;
  }

  /* Tabellen: scrollbar Container */
  .cft, .phase-table {
    font-size: 10.5px !important;
  }
  .cft th, .cft td {
    padding: 4px 5px !important;
  }
  /* Wrapper-Div des Tabellen-Containers — sicherstellen dass scroll funktioniert */
  .card > div[style*="overflow-x"] {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  /* KPI-Grid: 1 Spalte */
  .kpi-grid {
    grid-template-columns: 1fr !important;
  }

  /* Bank-Charts kompakter */
  .bc-card {
    padding: 12px !important;
  }
  .bc-head-title {
    font-size: 22px !important;
  }
  .bc-footer-grid {
    grid-template-columns: 1fr 1fr !important;
  }
  .bc-footer-cell {
    padding: 8px !important;
  }
  .bc-footer-value {
    font-size: 16px !important;
  }

  /* AI-Box mobile */
  .ai-box {
    padding: 14px !important;
  }
  .ai-section {
    padding: 10px 10px 10px 14px !important;
  }

  /* Settings-Modal mobile: full-screen */
  .set-modal-v2 {
    width: 100% !important;
    max-width: 100% !important;
    height: 100% !important;
    max-height: 100% !important;
    border-radius: 0 !important;
  }
  .set-modal-v2 .nav-pane {
    width: 100% !important;
    max-width: 100% !important;
    border-right: none !important;
    border-bottom: 1px solid var(--border) !important;
  }
  .set-modal-v2 .nav-btn {
    border-left: none !important;
    border-bottom: 2px solid transparent !important;
  }

  /* Pricing-Modal: Stack auf 1 Spalte */
  .dp-pricing-grid {
    grid-template-columns: 1fr !important;
  }
  .dp-feature-table {
    font-size: 11px !important;
  }
  .dp-feature-table thead th, .dp-feature-table tbody td {
    padding: 6px 4px !important;
  }
}

/* Hamburger-Button für Mobile (zeigt nur unter 640px) */
.mobile-hamburger {
  display: none;
  position: fixed;
  top: 12px; left: 12px;
  z-index: 1001;
  width: 44px; height: 44px;
  background: var(--gold);
  color: #1A1414;
  border: none;
  border-radius: 8px;
  font-size: 20px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
@media (max-width: 640px) {
  /* V106: Floating-Hamburger entfernt — der goldene Burger im App-Header (.hdr-mobile-menu)
     reicht aus. Doppel-Burger sah unprofessionell aus. */
  .mobile-hamburger { display: none !important; }
}

/* V63.74/.75/.86 Settings-Modal-Styles entfernt — siehe V63.89-Block am Ende der Datei */
/* ═══════════════════════════════════════════════════════════════
   V63.86 — KI-Credits-Pill im Header
═══════════════════════════════════════════════════════════════ */
.hdr-credits-pill {
  display: inline-flex !important;
  align-items: center;
  gap: 5px;
  background: rgba(201,168,76,0.14);
  border: 1px solid rgba(201,168,76,0.40);
  color: var(--gold);
  border-radius: 999px;
  padding: 5px 11px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease;
  white-space: nowrap;
}
.hdr-credits-pill:hover {
  background: rgba(201,168,76,0.22);
  border-color: rgba(201,168,76,0.55);
}
.hdr-credits-pill svg {
  flex-shrink: 0;
}
.hdr-credits-pill.low {
  background: rgba(184,98,92,0.10);
  border-color: rgba(184,98,92,0.40);
  color: var(--red);
}
.hdr-credits-pill.empty {
  background: rgba(184,98,92,0.18);
  border-color: var(--red);
  color: var(--red);
}

/* V63.86 — Settings KI-Credits-Box */
.ai-credits-box {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
  margin: 12px 0;
}
.ai-credits-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 14px;
}
.ai-credits-cell {
  background: #fff;
  border-radius: 8px;
  padding: 12px;
  text-align: center;
}
.ai-credits-label {
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 4px;
}
.ai-credits-value {
  font-size: 22px;
  font-weight: 700;
  color: var(--ch);
  line-height: 1;
}
.ai-credits-value.gn { color: var(--green); }
.ai-credits-value.rd { color: var(--red); }
.ai-credits-value.gold { color: var(--gold); }
.ai-credits-sub {
  font-size: 11px;
  color: var(--muted);
  margin-top: 4px;
}
.ai-credits-bar {
  height: 8px;
  background: var(--surface2);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 12px;
}
.ai-credits-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold), var(--gold-l));
  transition: width 0.4s ease;
}
.ai-credits-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  color: var(--muted);
  flex-wrap: wrap;
  gap: 10px;
}
@media (max-width: 640px) {
  .ai-credits-row { grid-template-columns: 1fr 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   V63.87 — KI-Tab (#s5/#s6 Investment-Analyse) komplett neu im
   Mini-AI-Box-Style: helle Karten, dunkle Schrift, gold/grün/rot
   nur als Akzent-Streifen links — wie im Tab Kennzahlen.
   Marcels Wunsch: "formatiere das wie Bild 2".
═══════════════════════════════════════════════════════════════ */
.ai-box .ai-block {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  padding: 14px 16px !important;
  margin-bottom: 12px !important;
  border-left: 3px solid var(--gold) !important;
  color: var(--ch) !important;
}
.ai-box .ai-block h3 {
  color: var(--ch) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  margin: 0 0 8px !important;
  text-transform: uppercase !important;
}
.ai-box .ai-block p,
.ai-box .ai-block li,
.ai-box .ai-block ul,
.ai-box .ai-block .ai-sub {
  color: var(--ch) !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
}
.ai-box .ai-block .ai-sub strong {
  color: var(--gold) !important;
}
.ai-box .ai-block ul {
  padding-left: 20px !important;
  margin: 0 !important;
}
.ai-box .ai-block li {
  margin-bottom: 4px !important;
}

/* Akzent-Streifen pro Sektion */
.ai-box .ai-block-green {
  border-left-color: var(--green) !important;
  background: var(--green-bg) !important;
}
.ai-box .ai-block-green h3 {
  color: var(--green) !important;
}
.ai-box .ai-block-red {
  border-left-color: var(--red) !important;
  background: var(--red-bg) !important;
}
.ai-box .ai-block-red h3 {
  color: var(--red) !important;
}
.ai-box .ai-block-empfehlung {
  border-left-color: var(--gold) !important;
  background: rgba(201,168,76,0.08) !important;
}
.ai-box .ai-block-empfehlung h3 {
  color: var(--gold) !important;
}
.ai-box .ai-block-investmentbewertung {
  border-left-color: var(--blue, #185FA5) !important;
  background: var(--blue-bg, #E8F0FA) !important;
}
.ai-box .ai-block-investmentbewertung h3 {
  color: var(--blue, #185FA5) !important;
}
.ai-box .ai-block-verhandlung {
  border-left-color: var(--gold) !important;
  background: rgba(201,168,76,0.06) !important;
}
.ai-box .ai-block-verhandlung h3 {
  color: var(--gold) !important;
}
.ai-box .ai-block-offerte {
  border-left-color: #7A5AB5 !important;
  background: rgba(122,90,181,0.06) !important;
}
.ai-box .ai-block-offerte h3 {
  color: #7A5AB5 !important;
}
.ai-box .ai-block-bankargumente {
  border-left-color: var(--green) !important;
  background: var(--green-bg) !important;
}
.ai-box .ai-block-bankargumente h3 {
  color: var(--green) !important;
}
.ai-box .ai-block-insight {
  border-left-color: var(--gold) !important;
  background: rgba(201,168,76,0.08) !important;
}
.ai-box .ai-block-insight h3 {
  color: var(--gold) !important;
}
.ai-box .ai-block-insight p {
  color: var(--ch) !important;
  font-style: italic !important;
}

/* Investor-Fit + Empfehlung-Innenboxen */
.ai-box .ai-fit-grid {
  display: grid;
  gap: 8px;
  margin-top: 6px;
}
.ai-box .ai-fit-row {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  padding: 8px 10px;
  background: rgba(255,255,255,0.5);
  border-radius: 5px;
  border: 1px solid var(--border);
}
.ai-box .ai-fit-label {
  font-weight: 600;
  color: var(--ch);
  font-size: 13px;
  flex-basis: 180px;
}
.ai-box .ai-fit-reason {
  flex: 1;
  font-size: 12.5px;
  color: var(--muted);
}
.ai-box .ai-empfehlung-row {
  display: flex;
  align-items: center;
  gap: 12px;
}
.ai-box .ai-offerte-price {
  font-size: 22px;
  font-weight: 700;
  color: var(--gold);
  margin: 8px 0 6px;
  font-family: 'Cormorant Garamond', serif;
}

/* Szenario-Sub-Boxen */
.ai-box .ai-scenario-worst {
  background: var(--red-bg) !important;
  padding: 10px 12px !important;
  border-radius: 5px !important;
  border-left: 2px solid var(--red) !important;
  margin-top: 6px !important;
}
.ai-box .ai-scenario-best {
  background: var(--green-bg) !important;
  padding: 10px 12px !important;
  border-radius: 5px !important;
  border-left: 2px solid var(--green) !important;
  margin-top: 6px !important;
}

/* V63.87 — URL-Scraper IS24-blocked Status-Box */
.qc-url-status.qc-url-blocked {
  background: var(--gold-dim) !important;
  color: var(--ch) !important;
  padding: 12px 14px !important;
  border-radius: 8px !important;
  border-left: 3px solid var(--gold) !important;
  font-size: 13px !important;
}
.qc-url-status.qc-url-blocked strong {
  color: var(--gold) !important;
}
.qc-url-status.qc-url-blocked .btn {
  display: inline-flex;
  align-items: center;
}

/* ═══════════════════════════════════════════════════════════════
   V63.87 — Plan-Gating RIGOROS: ausblenden statt ausgrauen
   Marcels Wunsch: "Funktionen die nicht im Plan sind, sollen
   gar nicht erst sichtbar sein". Das gilt für UI-Elemente, nicht
   für Settings/Plan/Hilfe (wo Upgrade-Hinweise erlaubt sind).
═══════════════════════════════════════════════════════════════ */
.feature-hidden {
  display: none !important;
}
/* Beibehaltung des alten ausgegrauten Zustands für legacy-call sites
   (Settings-Inputs zB) — neu hinzugekommene Gates nutzen feature-hidden */
body.plan-free  .feature-only-starter,
body.plan-free  .feature-only-investor,
body.plan-free  .feature-only-pro,
body.plan-starter .feature-only-investor,
body.plan-starter .feature-only-pro,
body.plan-investor .feature-only-pro {
  display: none !important;
}
body.plan-free .feature-only-paid,
body.plan-free .feature-only-investor-pro,
body.plan-starter .feature-only-investor-pro {
  display: none !important;
}

/* Settings-Tabs die nicht zum Plan passen werden ausgeblendet */
body.plan-free .st-tab[data-feature-required],
body.plan-starter .st-tab[data-feature-required] {
  /* Nur ausblenden wenn das Feature nicht erlaubt ist — wird per data-feature in JS gefiltert */
}

/* ═══════════════════════════════════════════════════════════════
   V63.89 — Settings-Modal V2 (HELL-THEME, sauberer Rewrite)
   
   Marcels V63.86/87/88-Test: weiße Schrift-Reste in Account, Sicherheit,
   Kontakt&Logo, KI, DealScore, Profil&Anzeige + Footer.
   
   Strategie: Single-Source-of-Truth-Block. Alle V63.74/.75/.86-Patches
   wurden gelöscht. Hier ist der KOMPLETTE Hell-Theme-Block.
═══════════════════════════════════════════════════════════════ */

/* ── Container ────────────────────────────────────────────── */
.set-modal-v2 {
  background: var(--surface) !important;
  color: var(--ch) !important;
  border: 1px solid var(--border-g, rgba(201,168,76,0.30)) !important;
  border-radius: 14px !important;
  box-shadow: 0 24px 70px rgba(0,0,0,0.18);
  padding: 0 !important;
  max-width: 920px !important;
  width: 92vw !important;
  max-height: 92vh !important;
}
.set-modal-v2 .pricing-close {
  position: absolute;
  top: 12px; right: 12px;
  width: 34px; height: 34px;
  background: rgba(42,39,39,0.06) !important;
  border: none !important;
  color: var(--ch) !important;
  border-radius: 8px !important;
  font-size: 22px;
  z-index: 5;
  cursor: pointer;
}
.set-modal-v2 .pricing-close:hover {
  background: rgba(42,39,39,0.14) !important;
}

/* ── Header ──────────────────────────────────────────────── */
.set-modal-v2 .set-head-v2 {
  padding: 30px 32px 18px;
  background: linear-gradient(180deg, rgba(201,168,76,0.08), transparent);
  border-bottom: 1px solid var(--border);
}
.set-modal-v2 .set-head-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.4px;
  color: var(--gold);
  margin-bottom: 8px;
}
.set-modal-v2 .set-head-v2 h2 {
  margin: 0 0 8px;
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px;
  color: var(--ch);
  display: flex;
  align-items: center;
  gap: 10px;
}
.set-modal-v2 .set-head-icon {
  display: inline-flex;
  color: var(--gold);
}
.set-modal-v2 .set-head-icon svg { display: block; }
.set-modal-v2 .set-head-sub {
  margin: 0;
  font-size: 13px;
  color: var(--muted);
  line-height: 1.5;
}

/* ── Tab-Bar ─────────────────────────────────────────────── */
.set-modal-v2 .settings-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 14px 28px 0;
  border-bottom: 1px solid var(--border);
  background: transparent;
}
.set-modal-v2 .st-tab {
  background: transparent !important;
  color: var(--muted) !important;
  border: 1px solid transparent !important;
  border-bottom: 2px solid transparent !important;
  padding: 10px 14px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  border-radius: 8px 8px 0 0 !important;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: all 0.15s ease;
  cursor: pointer;
}
.set-modal-v2 .st-tab:hover:not(.active) {
  color: var(--ch) !important;
  background: rgba(42,39,39,0.04) !important;
}
.set-modal-v2 .st-tab.active {
  color: var(--gold) !important;
  background: rgba(201,168,76,0.10) !important;
  border-color: rgba(201,168,76,0.28) !important;
  border-bottom-color: var(--gold) !important;
}
.set-modal-v2 .st-tab-ico { color: inherit; display: inline-flex; }
.set-modal-v2 .st-tab.active .st-tab-ico { color: var(--gold) !important; }
.set-modal-v2 .st-tab:not(.active) .st-tab-ico { color: var(--muted) !important; }
.set-modal-v2 .st-tab .st-tab-ico svg {
  width: 15px;
  height: 15px;
}

/* ── Panes ───────────────────────────────────────────────── */
.set-modal-v2 .st-pane {
  padding: 22px 28px 28px;
  color: var(--ch);
}

/* Generelle Schrift-Hierarchie im Pane */
.set-modal-v2 .st-pane,
.set-modal-v2 .st-pane p,
.set-modal-v2 .st-pane span:not(.st-tab-ico):not(.set-head-icon):not(.tag):not(.badge),
.set-modal-v2 .st-pane li,
.set-modal-v2 .st-pane td,
.set-modal-v2 .st-pane th {
  color: var(--ch);
}
.set-modal-v2 .st-pane h3,
.set-modal-v2 .st-pane h4,
.set-modal-v2 .st-pane h5 {
  color: var(--ch);
  font-weight: 600;
}
.set-modal-v2 .st-pane .hint,
.set-modal-v2 .st-pane .muted,
.set-modal-v2 .st-pane small {
  color: var(--muted);
  font-size: 12px;
}
.set-modal-v2 .st-pane a {
  color: var(--gold);
}
.set-modal-v2 .st-pane a:hover {
  color: var(--gold-l, #d8b74e);
}

/* Section-Header (gold uppercase eyebrow) */
.set-modal-v2 .set-section-h,
.set-modal-v2 .set-section-title {
  font-size: 11px;
  letter-spacing: 1.2px;
  color: var(--gold);
  font-weight: 700;
  text-transform: uppercase;
  margin: 18px 0 8px;
}
.set-modal-v2 hr.dvd {
  border: none;
  border-top: 1px solid var(--border);
  margin: 18px 0;
}

/* ── Form-Felder ─────────────────────────────────────────── */
.set-modal-v2 .f label,
.set-modal-v2 label {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  font-weight: 600;
  display: block;
  margin-bottom: 4px;
}
.set-modal-v2 input[type="text"],
.set-modal-v2 input[type="email"],
.set-modal-v2 input[type="number"],
.set-modal-v2 input[type="password"],
.set-modal-v2 input[type="tel"],
.set-modal-v2 input[type="url"],
.set-modal-v2 select,
.set-modal-v2 textarea {
  background: #fff;
  border: 1px solid var(--border);
  color: var(--ch);
  border-radius: 8px;
  padding: 9px 12px;
  width: 100%;
  font-size: 14px;
  box-sizing: border-box;
  font-family: inherit;
}
.set-modal-v2 input:focus,
.set-modal-v2 select:focus,
.set-modal-v2 textarea:focus {
  outline: none;
  border-color: rgba(201,168,76,0.6);
  box-shadow: 0 0 0 3px rgba(201,168,76,0.10);
}
.set-modal-v2 input::placeholder,
.set-modal-v2 textarea::placeholder {
  color: rgba(42,39,39,0.40);
}
.set-modal-v2 input[disabled],
.set-modal-v2 input[readonly] {
  background: rgba(201,168,76,0.06);
  color: rgba(42,39,39,0.65);
  cursor: not-allowed;
}

/* Checkbox-Reihen — V63.89 Marcels Wunsch: Spacing zwischen Boxen */
.set-modal-v2 .checkbox-row,
.set-modal-v2 .cb-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;  /* V63.89: vorher 0, jetzt klarer Abstand */
  padding: 8px 0;
}
.set-modal-v2 .checkbox-row + .checkbox-row,
.set-modal-v2 .cb-row + .cb-row {
  border-top: 1px solid var(--border);
}
.set-modal-v2 input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--gold);
  flex-shrink: 0;
}
.set-modal-v2 .cb-label {
  font-size: 13px;
  color: var(--ch);
  font-weight: normal;
  text-transform: none;
  letter-spacing: 0;
  margin: 0;
  cursor: pointer;
  flex: 1;
}

/* ── Buttons in Settings ─────────────────────────────────── */
.set-modal-v2 .btn-outline,
.set-modal-v2 .btn-ghost {
  background: transparent;
  color: var(--ch);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s ease;
}
.set-modal-v2 .btn-outline:hover,
.set-modal-v2 .btn-ghost:hover {
  background: rgba(201,168,76,0.08);
  color: var(--gold);
  border-color: rgba(201,168,76,0.4);
}
.set-modal-v2 .btn-primary,
.set-modal-v2 .btn-gold {
  background: var(--gold);
  color: #1A1414;
  border: none;
  border-radius: 8px;
  padding: 8px 16px;
  font-weight: 600;
  cursor: pointer;
  font-size: 13px;
}
.set-modal-v2 .btn-primary:hover,
.set-modal-v2 .btn-gold:hover { background: var(--gold-l, #d8b74e); }

/* V63.89: Kritische Buttons im Account-Pane (Logout + Account löschen) */
.set-modal-v2 .btn-logout {
  background: transparent;
  color: var(--ch);
  border: 1px solid var(--border);
  padding: 9px 16px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.set-modal-v2 .btn-logout:hover {
  background: rgba(42,39,39,0.04);
  border-color: rgba(42,39,39,0.20);
}
.set-modal-v2 .btn-danger,
.set-modal-v2 .btn-delete-account {
  background: var(--red);
  color: #fff;
  border: 1px solid var(--red);
  padding: 9px 16px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.set-modal-v2 .btn-danger:hover,
.set-modal-v2 .btn-delete-account:hover {
  background: #a85852;
  border-color: #a85852;
}

/* ── Account-Plan-Box ────────────────────────────────────── */
.set-modal-v2 .account-plan-box {
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.25);
  border-radius: 10px;
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.set-modal-v2 .account-plan-name {
  color: var(--gold);
  font-weight: 600;
  font-size: 15px;
}
.set-modal-v2 .account-plan-link {
  color: var(--ch);
  background: transparent;
  border: 1px solid var(--border);
  padding: 6px 12px;
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
}
.set-modal-v2 .account-plan-link:hover {
  color: var(--gold);
  border-color: rgba(201,168,76,0.5);
}

/* ── Cards / Info-Boxen im Pane ─────────────────────────── */
.set-modal-v2 .st-pane .card,
.set-modal-v2 .st-pane .info-box,
.set-modal-v2 .info-card {
  background: #fff;
  border: 1px solid var(--border);
  color: var(--ch);
  border-radius: 8px;
  padding: 12px 14px;
}

/* ── DealScore-Pane (DS2-Settings-Form) ─────────────────── */
.set-modal-v2 .ds2-settings-body-inline {
  background: #fff;
  border: 1px solid var(--border);
  color: var(--ch);
  border-radius: 8px;
  padding: 16px;
}
.set-modal-v2 .ds2-settings-body-inline h4 {
  color: var(--gold);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin: 0 0 10px;
}
.set-modal-v2 .ds2-settings-body-inline .ds2-set-section {
  border-bottom: 1px solid var(--border);
  padding-bottom: 14px;
  margin-bottom: 14px;
}
.set-modal-v2 .ds2-settings-body-inline .ds2-set-section:last-child {
  border-bottom: none;
  margin-bottom: 0;
}
.set-modal-v2 .ds2-settings-body-inline .ds2-set-field label {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
}
.set-modal-v2 .ds2-settings-body-inline .ds2-set-field input,
.set-modal-v2 .ds2-settings-body-inline .ds2-set-field select {
  background: #fff;
  border: 1px solid var(--border);
  color: var(--ch);
}

/* DealScore-Anzeige */
.set-modal-v2 .dealscore-card,
.set-modal-v2 .ds2-score,
.set-modal-v2 .ds2-pilot-score {
  background: rgba(201,168,76,0.06);
  color: var(--ch);
  border: 1px solid rgba(201,168,76,0.30);
  border-radius: 10px;
}
.set-modal-v2 .ds2-pilot-score-num,
.set-modal-v2 .dealscore-num {
  color: var(--gold) !important;
}

/* ── Toggles ─────────────────────────────────────────────── */
.set-modal-v2 .dp-switch-slider {
  background: var(--border);
  border: 1px solid rgba(42,39,39,0.10);
}
.set-modal-v2 input[type="checkbox"]:checked + .dp-switch-slider {
  background: var(--gold);
}

/* ── Tabellen ────────────────────────────────────────────── */
.set-modal-v2 table { color: var(--ch); }
.set-modal-v2 th { color: var(--muted); font-weight: 600; }
.set-modal-v2 td { border-color: var(--border); }

/* ── Footer (Speichern/Abbrechen) ───────────────────────── */
.set-modal-v2 .set-footer-v2 {
  background: rgba(42,39,39,0.03);
  border-top: 1px solid var(--border);
  padding: 14px 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.set-modal-v2 .set-footer-v2 .set-footer-status,
.set-modal-v2 .set-footer-v2 .footer-hint,
.set-modal-v2 .footer-changes-hint {
  color: var(--muted);
  font-size: 12px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.set-modal-v2 .set-footer-v2 .footer-changes-hint.has-changes,
.set-modal-v2 .set-footer-v2 .set-footer-status.has-changes {
  color: var(--gold);
  font-weight: 600;
}
.set-modal-v2 .set-footer-v2 .btn-ghost {
  color: var(--ch);
  background: transparent;
  border: 1px solid var(--border);
}
.set-modal-v2 .set-footer-v2 .btn-gold {
  color: #1A1414;
  background: var(--gold);
  border: none;
}

/* Section-Icons in Tab-Inhalt — V63.89 (Marcels Wunsch: Lucide statt alte Icons) */
.set-modal-v2 .st-pane-icon {
  display: inline-flex;
  align-items: center;
  margin-right: 6px;
  color: var(--gold);
  vertical-align: middle;
}
.set-modal-v2 .st-pane-icon svg {
  width: 14px;
  height: 14px;
  display: block;
}

/* Mobile */
@media (max-width: 700px) {
  .set-modal-v2 .set-head-v2 { padding: 22px 20px 14px; }
  .set-modal-v2 .settings-tabs { padding: 10px 16px 0; }
  .set-modal-v2 .st-pane { padding: 16px 20px 22px; }
  .set-modal-v2 .set-footer-v2 { padding: 12px 20px; flex-wrap: wrap; }
}

/* V63.89: Settings-Footer + dirty-hint im Hell-Theme */
.set-modal-v2 .settings-footer {
  background: rgba(42,39,39,0.03);
  border-top: 1px solid var(--border);
  padding: 14px 28px;
  margin: 0 -28px -28px;  /* Footer geht über Pane-Padding hinaus */
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
}
.set-modal-v2 .settings-dirty-hint {
  margin-right: auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--gold);
  font-style: normal;
  font-weight: 600;
}
.set-modal-v2 .settings-dirty-hint::before {
  content: '';
  width: 8px;
  height: 8px;
  background: var(--gold);
  border-radius: 50%;
  animation: dirtyPulse 1.6s ease-in-out infinite;
}
@keyframes dirtyPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

/* V63.89: KI-Pane Checkbox-Spacing Marcels Wunsch */
.set-modal-v2 [data-pane="api"] .checkbox-row,
.set-modal-v2 [data-pane="api"] .cb-row,
.set-modal-v2 [data-pane="api"] .ai-option-row {
  margin-bottom: 14px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: rgba(255,255,255,0.5);
}
.set-modal-v2 [data-pane="api"] .checkbox-row + .checkbox-row,
.set-modal-v2 [data-pane="api"] .cb-row + .cb-row {
  border-top: 1px solid var(--border);
}

/* V63.89: Settings-Row-Card (für Toggle/Action-Reihen mit Beschreibung) */
.set-modal-v2 .setting-row-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  background: #fff;
  border-radius: 8px;
  border: 1px solid var(--border);
  margin-top: 8px;
}
.set-modal-v2 .setting-row-card-gold {
  background: rgba(201,168,76,0.06);
  border-color: rgba(201,168,76,0.25);
}
.set-modal-v2 .setting-row-title {
  font-weight: 600;
  color: var(--ch);
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.set-modal-v2 .setting-row-title-gold {
  color: var(--gold);
}
.set-modal-v2 .setting-row-desc {
  font-size: 12.5px;
  color: var(--muted);
  margin-top: 4px;
  line-height: 1.4;
}

/* ═══════════════════════════════════════════════════════════════
   V63.90 — KI-Tab: Analyse-Parameter Read-Only Display
   Nach Verschiebung der 4 Parameter-Selects nach Settings → Profil
═══════════════════════════════════════════════════════════════ */
#ai-params-link-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  border-left: 3px solid var(--gold);
}
.ai-params-current {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 18px;
  margin-top: 6px;
  padding: 12px 14px;
  background: var(--surface);
  border-radius: 6px;
  border: 1px solid var(--border);
}
.ai-params-row {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.ai-params-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  font-weight: 600;
}
.ai-params-val {
  font-size: 13px;
  color: var(--ch);
  font-weight: 500;
}
@media (max-width: 720px) {
  .ai-params-current { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   V63.91 — Credit-Buy-Modal (Demo-Kauf KI-Credits)
═══════════════════════════════════════════════════════════════ */
.credit-buy-modal { max-width: 720px !important; }
.credit-buy-modal .cb-current {
  background: var(--surface);
  padding: 12px 16px;
  border-radius: 6px;
  border: 1px solid var(--border);
  margin-bottom: 18px;
  font-size: 13.5px;
  color: var(--ch);
}
.credit-buy-modal .cb-current b { color: var(--gold); font-weight: 700; }
.credit-buy-modal .cb-demo-badge {
  display: inline-block;
  background: var(--gold);
  color: var(--ch);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 2px 7px;
  border-radius: 3px;
  margin-left: 6px;
}
.credit-buy-modal .cb-packs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 18px;
}
.credit-buy-modal .cb-pack {
  position: relative;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 18px 14px 14px;
  text-align: center;
  transition: transform .18s ease, box-shadow .18s ease;
}
.credit-buy-modal .cb-pack.recommended {
  border-color: var(--gold);
  box-shadow: 0 4px 14px rgba(201,168,76,0.12);
}
.credit-buy-modal .cb-pack:hover { transform: translateY(-2px); box-shadow: 0 6px 18px rgba(0,0,0,0.08); }
.credit-buy-modal .cb-pack-badge {
  position: absolute;
  top: -10px; left: 50%;
  transform: translateX(-50%);
  background: var(--gold);
  color: var(--ch);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  padding: 3px 10px;
  border-radius: 4px;
  text-transform: uppercase;
}
.credit-buy-modal .cb-pack-amount {
  font-size: 22px;
  font-weight: 700;
  color: var(--ch);
  font-family: 'Cormorant Garamond', serif;
}
.credit-buy-modal .cb-pack-price {
  font-size: 18px;
  font-weight: 600;
  color: var(--gold);
  margin-top: 4px;
}
.credit-buy-modal .cb-pack-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: var(--muted);
  margin-top: 8px;
}
.credit-buy-modal .cb-pack-desc {
  font-size: 12px;
  color: var(--ch);
  margin: 8px 0 12px;
  min-height: 50px;
  line-height: 1.4;
}
.credit-buy-modal .cb-pack-btn {
  width: 100%;
  font-size: 12.5px;
  padding: 8px;
}
.credit-buy-modal .cb-info {
  background: rgba(201,168,76,0.06);
  border-left: 3px solid var(--gold);
  padding: 12px 14px;
  border-radius: 0 6px 6px 0;
  font-size: 12px;
  color: var(--ch);
  line-height: 1.5;
}
.credit-buy-modal .cb-info b { color: var(--gold); }
@media (max-width: 720px) {
  .credit-buy-modal .cb-packs { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   V63.91 — qc-url-status: zusätzliche Variante für Suchergebnis-Seite
═══════════════════════════════════════════════════════════════ */
.qc-url-status.qc-url-warn strong { color: var(--gold-d, #8a6d2a); }

/* ═══════════════════════════════════════════════════════════════
   V63.91 — Marktbericht-Import-Row im Tab Objekt
═══════════════════════════════════════════════════════════════ */
.market-import-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--gold);
  border-radius: 6px;
  margin: 10px 0 14px;
  flex-wrap: wrap;
}
.market-import-info {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  flex: 1;
  min-width: 250px;
}
.market-import-icon {
  font-size: 22px;
  line-height: 1;
}
.market-import-title {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--ch);
  margin-bottom: 2px;
}
.market-import-sub {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.45;
}
@media (max-width: 720px) {
  .market-import-row { flex-direction: column; align-items: stretch; }
  .market-import-row .btn { width: 100%; }
}

/* ════════════════════════════════════════════════════════════════════════
   V64.0 — PURE OBSIDIAN: Score-Header
   Goldenes Investor-Badge, animierte Gold-Border, dunkle Score-Karte,
   moderne KPI-Pills mit Lucide-Icons.
   Wirkung: nur innerhalb von #hdr-badges → bleibt isoliert vom Rest.
   ════════════════════════════════════════════════════════════════════════ */

/* V64.0: Container — überschreibt das alte 230px-Grid + den charcoal-Hintergrund.
   Das innere .scores-Element baut sein eigenes Grid auf voller Breite. */
/* V64.0: Container — überschreibt das alte 230px-Grid + den charcoal-Hintergrund.
   Das innere .scores-Element baut sein eigenes Grid auf voller Breite.
   V64.4: Nur wenn NICHT collapsed — sonst gewinnt unsere display:block über das
   display:none aus body.hdr-collapsed und der Score bleibt sichtbar trotz Toggle. */
body:not(.hdr-collapsed) #hdr-badges {
  --gold-2: #E8C964;
  --gold-3: #9a7f33;
  --green-2: #5ed992;
  display: block !important;
  grid-template-columns: none !important;
  background: transparent !important;
  border-bottom: 0 !important;
  padding: 14px 22px;
}
@media (max-width: 768px) {
  body:not(.hdr-collapsed) #hdr-badges { padding: 10px 14px; }
}

/* Container .scores — 6 Spalten (Hauptscore breit + 5 Kategorie-Pills), volle Breite */
#hdr-badges .scores {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr 1fr;
  gap: 8px;
  width: 100%;
  margin: 0;
  padding: 0;
}

/* Hauptscore-Karte mit animierter Gold-Border */
#hdr-badges .sc-main {
  padding: 1.5px;                /* die Border ist als Padding-Layer */
  border-radius: 11px;
  background: linear-gradient(135deg, var(--gold-2), var(--gold-3), var(--gold-2));
  background-size: 200% 200%;
  animation: dpV64GradMove 6s linear infinite;
  position: relative;
  overflow: visible;             /* Investor-Badge guckt oben raus */
}
@keyframes dpV64GradMove {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

/* Demo-Modus: weniger gold, mehr grau */
#hdr-badges .sc-main.sc-main-demo {
  background: linear-gradient(135deg, #6E6661, #8C7430, #6E6661);
  background-size: 200% 200%;
  animation: dpV64GradMove 8s linear infinite;
}

/* Innen-Inhalt der Score-Karte */
#hdr-badges .sc-main .si {
  display: flex;
  gap: 11px;
  align-items: center;
  padding: 13px 13px 11px;
  border-radius: 9.5px;
  /* V64.4: rein-schwarz für Kontrast gegen warmen Header */
  background: #000;
}

/* Goldenes INVESTOR-Badge oben links auf der Border (wie eine Brosche) */
#hdr-badges .sc-investor-badge {
  position: absolute;
  top: -9px;
  left: 14px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--gold-2) 0%, var(--gold) 50%, var(--gold-3) 100%);
  color: var(--ch);
  box-shadow: 0 4px 14px rgba(201,168,76,0.50),
              inset 0 1px 0 rgba(255,255,255,0.40);
  z-index: 3;
  white-space: nowrap;
  font-family: 'DM Sans', sans-serif;
}
#hdr-badges .sc-investor-badge .ic {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 10px;
  height: 10px;
  color: var(--ch);
}
#hdr-badges .sc-investor-badge .ic svg {
  width: 100%;
  height: 100%;
  display: block;
}
/* Demo-Variante: graubraun statt gold */
#hdr-badges .sc-investor-badge.sc-demo-badge {
  background: linear-gradient(135deg, #8C7430, #6E6661, #8C7430);
  color: #F5F2EA;
  box-shadow: 0 4px 12px rgba(110,102,97,0.40),
              inset 0 1px 0 rgba(255,255,255,0.20);
}

/* Donut + GUT-Badge gestapelt (NICHT überlappend) */
#hdr-badges .sc-donut-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  flex-shrink: 0;
}
#hdr-badges .sc-donut {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
#hdr-badges .sc-donut::before {
  content: "";
  position: absolute;
  inset: 4px;
  border-radius: 50%;
  /* V64.3: rein-schwarz statt warm-braun-Verlauf */
  background: radial-gradient(circle, #0a0a0a, #000);
}
#hdr-badges .sc-donut span {
  position: relative;
  font-weight: 800;
  font-size: 18px;
  color: #fff;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  font-family: 'Cormorant Garamond', serif;
}
#hdr-badges .sc-grade {
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 2px 9px;
  border-radius: 9px;
  white-space: nowrap;
  font-family: 'DM Sans', sans-serif;
}

/* Info-Block rechts vom Donut */
#hdr-badges .sc-info {
  flex: 1;
  min-width: 0;
}
#hdr-badges .sc-l {
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--gold);
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: 'DM Sans', sans-serif;
}
#hdr-badges .sc-v {
  font-size: 14px;
  color: #fff;
  font-weight: 700;
  margin-top: 4px;
  letter-spacing: -0.2px;
  font-family: 'DM Sans', sans-serif;
}
#hdr-badges .sc-sub {
  font-size: 10.5px;
  color: rgba(168,162,153,0.95);
  margin-top: 2px;
  font-family: 'DM Sans', sans-serif;
}
#hdr-badges .sc-tip {
  font-size: 10px;
  color: var(--gold-2);
  margin-top: 3px;
  display: flex;
  align-items: center;
  gap: 4px;
  font-family: 'DM Sans', sans-serif;
}
#hdr-badges .sc-tip .ic {
  display: inline-flex;
  width: 10px;
  height: 10px;
}
#hdr-badges .sc-tip .ic svg { width: 100%; height: 100%; display: block; }

/* KPI-Pills (Rendite / Finanz. / Risiko / Lage / Upside) */
#hdr-badges .sc-pill {
  border-radius: 10px;
  padding: 10px 12px;
  /* V64.6: Gold-Border deutlich sichtbar (Marcels Soll-Bild zeigt klare goldene Umrandung).
     War vorher rgba(255,255,255,0.05) = quasi unsichtbar.
     Jetzt rgba(201,168,76,0.30) = deutlich gold, aber dezent genug. */
  background: #000;
  border: 1px solid rgba(201,168,76,0.30);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02), 0 2px 8px rgba(0,0,0,0.5);
  transition: all 0.2s ease;
  cursor: default;
  font-family: 'DM Sans', sans-serif;
}
#hdr-badges .sc-pill:hover {
  background: #050505;
  border-color: rgba(201,168,76,0.55);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03), 0 0 16px rgba(201,168,76,0.25);
}
#hdr-badges .sc-pill-l {
  font-size: 9.5px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: rgba(168,162,153,0.95);
  font-weight: 600;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#hdr-badges .sc-pill-l .ic {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 12px;
  height: 12px;
  color: var(--gold);
  opacity: 0.7;
}
#hdr-badges .sc-pill-l .ic svg { width: 100%; height: 100%; display: block; }
#hdr-badges .sc-pill-v {
  font-size: 17px;
  color: #fff;
  font-weight: 700;
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.3px;
}
#hdr-badges .sc-pill-sub {
  font-size: 9.5px;
  color: rgba(168,162,153,0.95);
  margin-top: 1px;
}
#hdr-badges .sc-bar {
  height: 3px;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
  margin-top: 6px;
  overflow: hidden;
}
#hdr-badges .sc-bar i {
  display: block;
  height: 100%;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--gold-3), var(--gold-2));
  box-shadow: 0 0 6px rgba(201,168,76,0.60);
}

/* Tier-Färbung der KPI-Pills (Vorzeichen für die Mini-Bar) */
#hdr-badges .sc-pill.tier-green .sc-pill-v { color: var(--green-2); }
#hdr-badges .sc-pill.tier-green .sc-bar i  { background: linear-gradient(90deg, var(--green), var(--green-2)); box-shadow: 0 0 6px rgba(63,165,108,0.60); }
#hdr-badges .sc-pill.tier-gold .sc-pill-v  { color: var(--gold-2); }
#hdr-badges .sc-pill.tier-red .sc-pill-v   { color: #e8a09a; }
#hdr-badges .sc-pill.tier-red .sc-bar i    { background: linear-gradient(90deg, #8b3f39, #B8625C); box-shadow: 0 0 6px rgba(184,98,92,0.55); }

/* Empty-Pill (Kategorie ohne Daten) */
#hdr-badges .sc-pill-empty {
  opacity: 0.55;
}
#hdr-badges .sc-pill-empty .sc-pill-v {
  color: rgba(168,162,153,0.65);
}

/* Header-Container: dunkler Hintergrund + pulsierender Gold-Glow oben */
header.hdr.has-v64-score {
  /* V64.5: !important damit es die alte Z.13997-Regel `header.hdr { background: #2A2727 !important }`
     überschreibt. Vorher hat charcoal gewonnen weil meine Regel kein !important hatte. */
  background: linear-gradient(180deg, #0a0805 0%, #000 100%) !important;
  border-bottom: 1px solid rgba(201,168,76,0.18) !important;
  position: relative;
  overflow: visible;
}
header.hdr.has-v64-score::before {
  content: "";
  position: absolute;
  inset: 0;
  /* Original-Glow (war 0.20 in der Vorlage) */
  background: radial-gradient(ellipse 600px 200px at 50% 0%, rgba(201,168,76,0.18) 0%, transparent 70%);
  pointer-events: none;
  animation: dpV64HdrGlow 8s ease-in-out infinite;
  z-index: 0;
}
@keyframes dpV64HdrGlow {
  0%, 100% { opacity: 0.5; }
  50%      { opacity: 1.0; }
}
header.hdr.has-v64-score::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,0.60), transparent);
  z-index: 1;
}
/* Header-Inhalte über die Pseudo-Layer heben */
header.hdr.has-v64-score > * {
  position: relative;
  z-index: 2;
}
/* Adresse + Reihe-1-Texte im dunklen Header weiß färben */
header.hdr.has-v64-score #hdr-obj,
header.hdr.has-v64-score .hdr-sep,
header.hdr.has-v64-score .hdr-saved-tag {
  color: #fff;
}
header.hdr.has-v64-score #hdr-completeness {
  color: var(--green-2);
  background: rgba(63,165,108,0.12);
  border: 1px solid rgba(63,165,108,0.30);
}

/* Mobile: Pills untereinander stapeln (Desktop bleibt Grid) */
@media (max-width: 900px) {
  #hdr-badges .scores {
    grid-template-columns: 1fr 1fr;
  }
  #hdr-badges .sc-main {
    grid-column: 1 / -1;
  }
}

/* V64.0: Banner-Modus (KPI-Vollständigkeit < 70 %) — auf dunklem Pure-Obsidian-Header lesbar */
header.hdr.has-v64-score .hdr-incomplete-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-radius: 10px;
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.30);
  color: #fff;
  font-size: 12.5px;
  margin: 6px 0 12px;
}
header.hdr.has-v64-score .hdr-incomplete-banner .hdr-incomplete-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 7px;
  background: rgba(201,168,76,0.18);
  color: var(--gold-2, #E8C964);
  flex-shrink: 0;
}
header.hdr.has-v64-score .hdr-incomplete-banner strong {
  color: #fff;
  font-weight: 700;
}

/* ════════════════════════════════════════════════════════════════════════
   V64.1 — PURE OBSIDIAN: Header-Reihe-1 + Tabs
   Alles innerhalb header.hdr.has-v64-score wird auf das dunkle Pure-Obsidian-
   Look angepasst — Adresse/Icons/Buttons/Tabs sind vorher hell-charcoal,
   passen optisch nicht zum neuen Score-Header.
   ════════════════════════════════════════════════════════════════════════ */

/* Header-Reihe-1: dunkler Hintergrund, voller Padding-Reset (alte Charcoal-Regel raus) */
header.hdr.has-v64-score .hdr-v61-row1 {
  background: transparent !important;
  border-bottom: 0 !important;
  padding: 13px 22px 8px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
@media (max-width: 768px) {
  header.hdr.has-v64-score .hdr-v61-row1 { padding: 10px 14px 6px; gap: 8px; }
}

/* Objektnummer-Pill — gold mit gold-Border statt charcoal */
header.hdr.has-v64-score #hdr-obj-num {
  background: linear-gradient(135deg, rgba(201,168,76,0.20), rgba(201,168,76,0.05)) !important;
  border: 1px solid rgba(201,168,76,0.30) !important;
  color: var(--gold-2, #E8C964) !important;
  font-weight: 700;
  letter-spacing: 0.5px;
}

/* Adresse + Trenner + Auto-saved auf dunklem BG */
header.hdr.has-v64-score #hdr-obj,
header.hdr.has-v64-score .hdr-obj-name {
  color: #fff !important;
  font-weight: 600;
}
header.hdr.has-v64-score .hdr-sep {
  color: rgba(255,255,255,0.35) !important;
}
header.hdr.has-v64-score .hdr-autosave {
  color: var(--green-2, #5ed992) !important;
  background: rgba(63,165,108,0.12) !important;
  border: 1px solid rgba(63,165,108,0.30) !important;
  border-radius: 5px;
  padding: 3px 9px;
}
header.hdr.has-v64-score .hdr-autosave-dot {
  background: var(--green-2, #5ed992) !important;
  box-shadow: 0 0 7px var(--green-2, #5ed992) !important;
}

/* Mobile-Menu-Burger: weiß auf dunkel */
header.hdr.has-v64-score .hdr-mobile-menu span {
  background: var(--gold-2, #E8C964) !important;
}

/* Completeness-Indikator — auf dunklem BG */
header.hdr.has-v64-score #hdr-completeness {
  color: var(--green-2, #5ed992) !important;
  background: rgba(63,165,108,0.12) !important;
  border: 1px solid rgba(63,165,108,0.30) !important;
  border-radius: 5px;
  padding: 4px 10px;
  font-weight: 600;
}
header.hdr.has-v64-score #hdr-completeness.warn {
  color: var(--gold-2, #E8C964) !important;
  background: rgba(201,168,76,0.10) !important;
  border-color: rgba(201,168,76,0.35) !important;
}
header.hdr.has-v64-score #hdr-completeness.low {
  color: #e8a09a !important;
  background: rgba(184,98,92,0.12) !important;
  border-color: rgba(184,98,92,0.30) !important;
}

/* Header-Icon-Buttons (Hilfe / Verlauf / Teilen / Duplizieren) — Outline-Style mit Gold-Hover */
header.hdr.has-v64-score .hdr-icon-btn {
  background: transparent !important;
  border: 1px solid rgba(201,168,76,0.18) !important;
  color: rgba(168,162,153,0.95) !important;
  width: 28px;
  height: 28px;
  border-radius: 5px;
  transition: all 0.2s;
}
header.hdr.has-v64-score .hdr-icon-btn:hover {
  border-color: var(--gold, #C9A84C) !important;
  color: var(--gold-2, #E8C964) !important;
  background: rgba(201,168,76,0.06) !important;
}
header.hdr.has-v64-score .hdr-icon-btn[style*="color:var(--gold)"] {
  color: var(--gold, #C9A84C) !important;
  border-color: rgba(201,168,76,0.30) !important;
}

/* KI-Credits-Pill — gold-getönt */
header.hdr.has-v64-score .hdr-credits-pill {
  background: rgba(201,168,76,0.08) !important;
  color: var(--gold-2, #E8C964) !important;
  border: 1px solid rgba(201,168,76,0.30) !important;
  border-radius: 5px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
header.hdr.has-v64-score .hdr-credits-pill:hover {
  background: rgba(201,168,76,0.14) !important;
  box-shadow: 0 0 16px rgba(201,168,76,0.30);
}

/* PDF-Button — outlined gold */
header.hdr.has-v64-score .hdr-pdf-btn {
  background: rgba(201,168,76,0.08) !important;
  color: var(--gold-2, #E8C964) !important;
  border: 1px solid rgba(201,168,76,0.35) !important;
  font-weight: 600;
  letter-spacing: 0.3px;
  transition: all 0.2s;
}
header.hdr.has-v64-score .hdr-pdf-btn:hover {
  background: rgba(201,168,76,0.18) !important;
  box-shadow: 0 0 16px rgba(201,168,76,0.30);
}

/* Speichern-Button — gold gefüllt mit Verlauf */
header.hdr.has-v64-score .hdr-save-btn {
  background: linear-gradient(135deg, var(--gold-2, #E8C964), var(--gold-3, #9a7f33)) !important;
  color: var(--ch, #2A2727) !important;
  border: 0 !important;
  font-weight: 700;
  letter-spacing: 0.3px;
  box-shadow: 0 4px 14px rgba(201,168,76,0.40),
              inset 0 1px 0 rgba(255,255,255,0.40) !important;
  transition: all 0.2s;
}
header.hdr.has-v64-score .hdr-save-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(201,168,76,0.55),
              inset 0 1px 0 rgba(255,255,255,0.40) !important;
}

/* Toggle-Chevron-Button (Score ein-/ausblenden) — auf dunkel */
header.hdr.has-v64-score .hdr-toggle-btn {
  background: transparent !important;
  border-top: 1px solid rgba(201,168,76,0.15) !important;
  color: rgba(168,162,153,0.7) !important;
}
header.hdr.has-v64-score .hdr-toggle-btn:hover {
  color: var(--gold-2, #E8C964) !important;
}

/* ──── Tabs auf Pure-Obsidian ──── */
header.hdr.has-v64-score + nav.tabs,
body.hdr-no-score nav.tabs,
body.hdr-banner-only nav.tabs {
  /* dunkler Hintergrund nur wenn Header pure-obsidian ist */
}
header.hdr.has-v64-score + nav.tabs {
  /* V64.4: Vorlage-Farbe #0a0805 (warm-bräunlich), wie in der Original-Vorlage tabs-wrap */
  background: #0a0805 !important;
  border-top: 1px solid rgba(201,168,76,0.15) !important;
  border-bottom: 1px solid rgba(201,168,76,0.10) !important;
  padding: 0 22px;
}
header.hdr.has-v64-score + nav.tabs .tab {
  color: rgba(255,255,255,0.55) !important;
  background: transparent !important;
  border: 0 !important;
  border-bottom: 2px solid transparent !important;
  padding: 11px 12px !important;
  font-size: 12.5px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: all 0.2s;
}
header.hdr.has-v64-score + nav.tabs .tab:hover {
  color: #fff !important;
  background: rgba(201,168,76,0.04) !important;
}
header.hdr.has-v64-score + nav.tabs .tab.active {
  color: var(--gold-2, #E8C964) !important;
  border-bottom-color: var(--gold, #C9A84C) !important;
  font-weight: 600;
  text-shadow: 0 0 12px rgba(201,168,76,0.40);
  background: transparent !important;
}
header.hdr.has-v64-score + nav.tabs .tab-ico {
  color: var(--gold, #C9A84C);
  opacity: 0.85;
}
header.hdr.has-v64-score + nav.tabs .tab.active .tab-ico {
  opacity: 1;
}
header.hdr.has-v64-score + nav.tabs .tabs-version-badge {
  color: rgba(168,162,153,0.6) !important;
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  font-family: ui-monospace, monospace;
  letter-spacing: 0.5px;
}

/* Workflow-Bar (Quick-Check Steps) auf dunkel */
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar {
  background: #050505 !important;
  border-bottom: 1px solid rgba(201,168,76,0.10) !important;
}

/* ════════════════════════════════════════════════════════════════════════
   V64.2 — Workflow-Tab-Bar auf Pure Obsidian + Score-Karten-Polish
   ════════════════════════════════════════════════════════════════════════ */

/* Workflow-Bar (Quick-Check Steps) — dunkler BG mit Gold-Tönen */
header.hdr.has-v64-score ~ .tabs-workflow-bar,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar {
  background: #050505 !important;
  border-bottom: 1px solid rgba(201,168,76,0.10) !important;
  padding: 12px 22px;
  position: relative;
}
header.hdr.has-v64-score ~ .tabs-workflow-bar::after,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,0.35), transparent);
}
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-tab-title,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-tab-title {
  color: rgba(255,255,255,0.92) !important;
  font-family: 'Cormorant Garamond', serif;
}
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-tab-sub,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-tab-sub {
  color: rgba(168,162,153,0.85) !important;
}
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-tab-progress-text,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-tab-progress-text {
  color: rgba(168,162,153,0.85) !important;
}
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-tab-progress-bar,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-tab-progress-bar {
  background: rgba(255,255,255,0.10) !important;
}
/* Workflow-Steps (Pillen) auf dunklem BG */
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-step,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-step {
  background: rgba(255,255,255,0.04) !important;
  color: rgba(168,162,153,0.85) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  padding: 5px 11px !important;
  border-radius: 6px !important;
  font-weight: 600;
}
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-step:hover,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-step:hover {
  background: rgba(201,168,76,0.10) !important;
  border-color: rgba(201,168,76,0.30) !important;
  color: var(--gold-2, #E8C964) !important;
}
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-step-num,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-step-num {
  background: rgba(255,255,255,0.10) !important;
  color: rgba(255,255,255,0.85) !important;
  width: 18px !important;
  height: 18px !important;
}
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-step-name,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-step-name {
  color: inherit;
}
/* Done-Step: gold mit gold-Border + Häkchen, NICHT mehr klobig grün */
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-step-done,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-step-done {
  background: rgba(63,165,108,0.10) !important;
  border-color: rgba(94,217,146,0.35) !important;
  color: var(--green-2, #5ed992) !important;
}
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-step-done .wf-step-num,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-step-done .wf-step-num {
  background: var(--green-2, #5ed992) !important;
  color: #0a0805 !important;
  font-weight: 800;
}
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-step-done .wf-step-check,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-step-done .wf-step-check {
  color: var(--green-2, #5ed992) !important;
}
/* Current-Step: gold prominent */
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-step-current,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-step-current {
  background: rgba(201,168,76,0.15) !important;
  border-color: var(--gold, #C9A84C) !important;
  color: var(--gold-2, #E8C964) !important;
  box-shadow: 0 0 14px rgba(201,168,76,0.25);
}
header.hdr.has-v64-score ~ .tabs-workflow-bar .wf-step-current .wf-step-num,
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar .wf-step-current .wf-step-num {
  background: var(--gold, #C9A84C) !important;
  color: #0a0805 !important;
  font-weight: 800;
}

/* ──── Score-Karte: "INVESTOR DEAL SCORE"-Label größer und kursiv (wie Bild 2) ──── */
#hdr-badges .sc-l {
  font-size: 10.5px;
  letter-spacing: 1.4px;
  margin-bottom: 2px;
}
#hdr-badges .sc-v {
  font-size: 16px;
  margin-top: 5px;
  font-weight: 700;
}
#hdr-badges .sc-sub {
  font-size: 11px;
  margin-top: 3px;
}
#hdr-badges .sc-tip {
  font-size: 10.5px;
  margin-top: 5px;
  color: var(--gold-2, #E8C964);
  font-weight: 500;
}
/* Donut etwas größer, Glow stärker */
#hdr-badges .sc-donut {
  width: 60px;
  height: 60px;
}
#hdr-badges .sc-donut span {
  font-size: 21px;
}
#hdr-badges .sc-donut::before {
  inset: 5px;
}
/* Grade-Badge ("Gut" / "Sehr gut") prominenter */
#hdr-badges .sc-grade {
  font-size: 10px;
  padding: 3px 11px;
  border-radius: 11px;
  font-weight: 800;
  letter-spacing: 1.1px;
}
/* Score-Karte mehr Padding für Höhe (wie Bild 2) */
#hdr-badges .sc-main .si {
  padding: 16px 14px 14px;
  gap: 13px;
}

/* KPI-Pills: Werte größer + sub etwas mehr Abstand */
#hdr-badges .sc-pill {
  padding: 12px 14px;
}
#hdr-badges .sc-pill-l {
  font-size: 10px;
  letter-spacing: 1.1px;
  margin-bottom: 2px;
}
#hdr-badges .sc-pill-v {
  font-size: 22px;
  margin-top: 6px;
  font-weight: 800;
  letter-spacing: -0.5px;
}
#hdr-badges .sc-pill-sub {
  font-size: 10px;
  margin-top: 2px;
  color: rgba(168,162,153,0.85);
}
#hdr-badges .sc-bar {
  height: 4px;
  margin-top: 8px;
}

/* V64.2: Stern-Icon vor "INVESTOR DEAL SCORE"-Label (nur Investor-Modus) */
#hdr-badges .sc-l-star {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 12px;
  height: 12px;
  color: var(--gold-2, #E8C964);
}
#hdr-badges .sc-l-star svg { width: 100%; height: 100%; display: block; }

/* V64.2: Wenn Investor-Modus (kein Pin), dann braucht die Score-Karte etwas weniger Padding oben */
#hdr-badges .sc-main:not(.sc-main-demo) .si {
  padding-top: 14px;
}

/* ════════════════════════════════════════════════════════════════════════
   V64.4 — Bug-Fixes: Score einklappen + Workflow-Bar opak + Collapsed-Layout
   ════════════════════════════════════════════════════════════════════════ */

/* Im Collapsed-Modus: Tabs müssen DIREKT unter Reihe-1 (~48px) kleben,
   egal was --hdr-h sagt. Unsere Spezifität schlägt die Sticky-Top-Regel von Z.13975. */
body.hdr-collapsed .main-col > nav.tabs,
body.hdr-collapsed .main-col > .tabs,
body.hdr-collapsed nav.tabs,
body.hdr-collapsed .tabs {
  top: 48px !important;
}
body.hdr-collapsed .main-col > .tabs-workflow-bar,
body.hdr-collapsed .tabs-workflow-bar {
  top: calc(48px + var(--hdr-h-tabs, 44px)) !important;
}

/* Workflow-Bar ist jetzt opak schwarz (vorher rgba mit Transparenz, ließ den 
   hellen Body durchschimmern). */
header.hdr.has-v64-score + nav.tabs + .tabs-workflow-bar,
header.hdr.has-v64-score ~ .tabs-workflow-bar {
  background: #050505 !important;
}

/* Im Collapsed-Modus: V64-Header bleibt zwar dunkel (gut so), aber
   die Goldborder-Animation drumrum wirkt komisch wenn nichts dadrin ist.
   Reihe-1 bleibt sichtbar in Pure-Obsidian-Optik. */
body.hdr-collapsed header.hdr.has-v64-score #hdr-badges {
  display: none !important;     /* Score-Reihe komplett verstecken */
}

/* ════════════════════════════════════════════════════════════════════════
   V64.7 — PURE OBSIDIAN: Sidebar-Komplett-Umbau
   Particles, Logo-Shimmer, Pure-Obsidian-Karten, gold-Verlaufs-Buttons.
   Alles scoped via aside.sidebar — bleibt isoliert vom Rest.
   ════════════════════════════════════════════════════════════════════════ */

/* ─── Sidebar-Container: schwarz + Particles ─── */
aside.sidebar {
  background: #000 !important;
  border-right: 1px solid rgba(201,168,76,0.12) !important;
  position: relative;
  /* V64.8: KEIN overflow:hidden — sonst wird das Aktionen-Akkordeon abgeschnitten
     wenn es nach oben aufklappt. Particles werden über das Pseudo-Element gerendert
     (das selbst overflow:hidden hat). */
}
/* Particle-Container: clippt die Particles, aber nicht das Akkordeon */
aside.sidebar::before {
  content: "";
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
  background-image:
    radial-gradient(1px 1px at 25% 15%, rgba(201,168,76,0.6) 50%, transparent 100%),
    radial-gradient(1px 1px at 60% 8%,  rgba(201,168,76,0.4) 50%, transparent 100%),
    radial-gradient(2px 2px at 80% 25%, rgba(201,168,76,0.5) 50%, transparent 100%),
    radial-gradient(1px 1px at 15% 50%, rgba(201,168,76,0.3) 50%, transparent 100%),
    radial-gradient(1px 1px at 70% 70%, rgba(201,168,76,0.4) 50%, transparent 100%),
    radial-gradient(2px 2px at 30% 85%, rgba(201,168,76,0.55) 50%, transparent 100%),
    radial-gradient(1px 1px at 90% 60%, rgba(201,168,76,0.3) 50%, transparent 100%);
  background-size: 300px 400px;
  animation: dpV64PartFloat 25s linear infinite;
}
@keyframes dpV64PartFloat {
  0%   { background-position: 0 0, 0 0, 0 0, 0 0, 0 0, 0 0, 0 0; }
  100% { background-position: 0 -400px, 0 -400px, 0 -400px, 0 -400px, 0 -400px, 0 -400px, 0 -400px; }
}
/* Sidebar-Inhalte über die Particles heben */
aside.sidebar > * {
  position: relative;
  z-index: 1;
}

/* V65.1: CSS-Logo aus Pure-Obsidian. V65.2: deutlich größer (Marcels Wunsch).
   Frame nimmt volle Breite, Schrift ist groß und prominent. */
aside.sidebar .sb-header {
  padding: 14px 12px 14px !important;
  background: transparent !important;
  border-bottom: 0 !important;
  position: relative;
}
aside.sidebar .sb-logo-shimmer {
  position: relative;
  border-radius: 12px;
  padding: 18px 14px;             /* V66: kompakter (war 28px) — proportionaler zur Sidebar-Breite */
  text-align: center;
  background: linear-gradient(135deg, #0d0a04 0%, #1a1408 100%);
  border: 1.5px solid var(--gold);
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.5),
              inset 0 1px 0 rgba(201,168,76,0.10);
  z-index: 2;
}
aside.sidebar .sb-logo-shimmer::before {
  content: "";
  position: absolute;
  top: -100%;
  left: -100%;
  width: 300%;
  height: 300%;
  background: linear-gradient(45deg,
              transparent 30%,
              rgba(201,168,76,0.25) 50%,
              transparent 70%);
  animation: dpV65LogoShimmer 4s linear infinite;
  pointer-events: none;
  mix-blend-mode: screen;
}
@keyframes dpV65LogoShimmer {
  0%   { transform: translate(0, 0); }
  100% { transform: translate(50%, 50%); }
}
aside.sidebar .sb-logo-deal {
  font-size: 32px;                /* V66: proportionaler (war 38px) */
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.8px;
  line-height: 1;
  position: relative;
  font-family: 'DM Sans', sans-serif;
}
aside.sidebar .sb-logo-pilot {
  background: linear-gradient(135deg,
              var(--gold-2, #E8C964) 0%,
              var(--gold) 50%,
              var(--gold-3, #9a7f33) 100%);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
          color: transparent;
}
aside.sidebar .sb-logo-by {
  font-size: 11.5px;              /* V66: minim kleiner (war 13px) */
  color: var(--gold);
  margin-top: 6px;                /* V66: weniger Abstand (war 9px) */
  letter-spacing: 0.6px;
  position: relative;
  font-weight: 500;
  font-family: 'DM Sans', sans-serif;
}

/* V65.0: Shimmer raus — Logo-PNG hat selber Charakter, kein extra-Effekt nötig.
   Falls wir später wieder shimmern wollen, der Code ist im Versionshistory. */
@keyframes dpV64Shimmer {
  0%   { background-position: -50% -50%; }
  100% { background-position: 150% 150%; }
}

/* ─── Section-Titles (Portfolio / Portfolio-Übersicht) ─── */
aside.sidebar .sb-section-title {
  font-size: 11px !important;                    /* V65.0: etwas größer */
  text-transform: uppercase !important;
  letter-spacing: 1.8px !important;              /* V65.0: mehr Spacing */
  color: var(--gold-2, #E8C964) !important;     /* V65.0: gold statt grau */
  padding: 14px 16px 10px !important;            /* V65.0: mehr Atem oben/unten */
  font-weight: 700 !important;
  background: transparent !important;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
/* Emoji wurde im HTML durch <svg><use href="#i-portfolio"/></svg> ersetzt — wir
   stylen jetzt nur noch das SVG selbst gold, kein ::before-Mask-Hack mehr nötig.
   V65.2: Wrapper-Span hat eigenes flex+gap damit Abstand zwischen Icon und Text passt. */
aside.sidebar .sb-section-title > span:first-child {
  display: inline-flex !important;
  align-items: center !important;
  gap: 9px !important;          /* V65.2: Marcels "2-3 Spaces" zwischen Icon und Text */
}
aside.sidebar .sb-section-title > span:first-child svg {
  width: 13px !important;
  height: 13px !important;
  color: var(--gold) !important;
  flex-shrink: 0 !important;
}

/* Sort-Buttons (⏱ und #) */
aside.sidebar .sb-sort-toggle {
  display: flex !important;
  gap: 5px !important;
}
aside.sidebar .sb-sort-btn {
  background: transparent !important;
  border: 1px solid rgba(201,168,76,0.15) !important;
  color: rgba(168,162,153,0.95) !important;
  width: 26px !important;
  height: 22px !important;
  border-radius: 5px !important;
  cursor: pointer;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 12px !important;
  padding: 0 !important;
  transition: all 0.2s;
}
aside.sidebar .sb-sort-btn:hover {
  border-color: rgba(201,168,76,0.45) !important;
  color: var(--gold-2, #E8C964) !important;
}
aside.sidebar .sb-sort-btn.active {
  border-color: var(--gold) !important;
  color: var(--gold) !important;
  background: rgba(201,168,76,0.08) !important;
}

/* ─── Karten-Liste ─── */
aside.sidebar .sb-list {
  padding: 6px 12px 14px !important;     /* V65.0: kleines Top-Padding, größerer Bottom-Abstand */
  display: flex !important;
  flex-direction: column !important;
  gap: 18px !important;
  background: transparent !important;
}
aside.sidebar .sb-empty {
  color: rgba(168,162,153,0.7) !important;
  font-size: 12px !important;
  padding: 14px !important;
  text-align: center;
  background: transparent !important;
  border: 1px dashed rgba(201,168,76,0.20) !important;
  border-radius: 10px !important;
}

/* ─── Pure-Obsidian-Karte ─── */
aside.sidebar .sb-card {
  padding: 11px !important;
  padding-top: 16px !important;
  border-radius: 11px !important;
  background: linear-gradient(135deg, rgba(20,15,5,0.6) 0%, rgba(0,0,0,0.7) 100%) !important;
  border: 1.5px solid var(--gold) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5),
              inset 0 1px 0 rgba(201,168,76,0.15) !important;
  position: relative !important;
  overflow: visible !important;
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
aside.sidebar .sb-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(0,0,0,0.6),
              0 0 18px rgba(201,168,76,0.18),
              inset 0 1px 0 rgba(201,168,76,0.20) !important;
}
aside.sidebar .sb-card.active {
  border-color: var(--gold-2, #E8C964) !important;
  /* V106: Aktive Karte zeigt sich nur durch Goldschimmer — kein dicker Outset-Ring,
     kein AKTIV-Badge. Schmaler Border (1.5px), umlaufender warmer Glow. */
  border-width: 1.5px !important;
  box-shadow:
    0 6px 20px rgba(0,0,0,0.45),
    0 0 22px rgba(201,168,76,0.35),
    inset 0 0 0 1px rgba(232,201,100,0.20) !important;
  animation: dpV106ActiveShimmer 3s ease-in-out infinite;
}
@keyframes dpV106ActiveShimmer {
  0%, 100% { box-shadow:
    0 6px 20px rgba(0,0,0,0.45),
    0 0 22px rgba(201,168,76,0.35),
    inset 0 0 0 1px rgba(232,201,100,0.20); }
  50% { box-shadow:
    0 6px 22px rgba(0,0,0,0.50),
    0 0 36px rgba(232,201,100,0.55),
    inset 0 0 0 1px rgba(232,201,100,0.32); }
}
/* V106: AKTIV-Badge entfernt (Marcels Wunsch — nur Schimmer reicht) */
aside.sidebar .sb-card.active::before {
  content: none !important;
}

/* Investor-Pin auf der Karte — V65.0: gold-gefüllt wie im Header (Marcels Wunsch).
   Sitzt mittig oben auf der Border, Stern + "Investor" mit dunklem Text auf gold. */
aside.sidebar .sb-card .sbc-investor-ribbon {
  position: absolute !important;
  top: -9px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  background: linear-gradient(135deg, var(--gold-2, #E8C964) 0%, var(--gold) 50%, var(--gold-3, #9a7f33) 100%) !important;
  color: var(--ch, #2A2727) !important;
  border: 0 !important;
  border-radius: 10px !important;
  padding: 3px 10px !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  letter-spacing: 1.4px !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  box-shadow: 0 4px 14px rgba(201,168,76,0.50),
              inset 0 1px 0 rgba(255,255,255,0.40) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  z-index: 3 !important;
}
aside.sidebar .sb-card .sbc-investor-ribbon svg {
  width: 9px !important;
  height: 9px !important;
  color: var(--ch, #2A2727) !important;
  flex-shrink: 0 !important;
}

/* Karten-Inhalt: Foto links, Info rechts */
aside.sidebar .sb-card .sbc-top {
  display: flex !important;
  gap: 10px !important;
  align-items: flex-start !important;
  margin-bottom: 8px !important;
}
aside.sidebar .sb-card .sbc-thumb,
aside.sidebar .sb-card .sbc-photo {
  width: 64px !important;            /* V65.3: deutlich größer (war 50px) */
  height: 64px !important;
  border-radius: 9px !important;
  flex-shrink: 0 !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow: 0 4px 10px rgba(0,0,0,0.4) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: rgba(201,168,76,0.55) !important;
  border: 0 !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}
/* Leerer Thumb (kein Foto) → dunkler Verlauf */
aside.sidebar .sb-card .sbc-thumb-empty,
aside.sidebar .sb-card .sbc-thumb:not(.sbc-thumb-photo) {
  background: linear-gradient(135deg, #564a32, #3a3531) !important;
}
aside.sidebar .sb-card .sbc-thumb img,
aside.sidebar .sb-card .sbc-photo img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}
aside.sidebar .sb-card .sbc-thumb svg {
  width: 24px !important;
  height: 24px !important;
}

/* ID-Pill, Straße, Datum */
aside.sidebar .sb-card .sbc-top-line1 {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  margin-bottom: 2px !important;
  flex-wrap: wrap !important;
}
aside.sidebar .sb-card .sbc-seq,
aside.sidebar .sb-card .sbc-id {
  font-size: 9.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.4px !important;
  padding: 2px 6px !important;
  border-radius: 5px !important;
  font-variant-numeric: tabular-nums !important;
  background: rgba(201,168,76,0.12) !important;
  color: var(--gold-2, #E8C964) !important;
  border: 1px solid rgba(201,168,76,0.30) !important;
}
aside.sidebar .sb-card .sbc-street {
  font-size: 13px !important;
  color: #fff !important;
  font-weight: 700 !important;
  flex: 1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  letter-spacing: -0.1px !important;
}
aside.sidebar .sb-card .sbc-date {
  font-size: 10px !important;
  color: rgba(168,162,153,0.85) !important;
  white-space: nowrap !important;
}
aside.sidebar .sb-card .sbc-arrow {
  color: rgba(168,162,153,0.45) !important;
  font-size: 14px !important;
  margin-left: 2px !important;
}
aside.sidebar .sb-card .sbc-line2 {
  font-size: 11px !important;
  color: rgba(168,162,153,0.85) !important;
  margin-top: 2px !important;
}

/* Preis + Score-Donut */
aside.sidebar .sb-card .sbc-kp-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 9px !important;
  margin-top: 5px !important;
}
aside.sidebar .sb-card .sbc-kp {
  font-size: 16px !important;
  color: var(--gold-2, #E8C964) !important;
  font-weight: 700 !important;
  font-variant-numeric: tabular-nums !important;
  letter-spacing: -0.3px !important;
  background: transparent !important;
  padding: 0 !important;
  border: 0 !important;
}
aside.sidebar .sb-card .sbc-score-wrap {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  flex-shrink: 0 !important;
}
aside.sidebar .sb-card .sbc-mini-score {
  position: relative;
  width: 34px !important;
  height: 34px !important;
}
aside.sidebar .sb-card .sbc-mini-score svg {
  width: 34px !important;
  height: 34px !important;
}
aside.sidebar .sb-card .sbc-mini-score-num {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  font-weight: 700 !important;
  font-size: 11px !important;
  color: #fff !important;
  font-variant-numeric: tabular-nums !important;
}
aside.sidebar .sb-card .sbc-score-label {
  font-size: 10px !important;
  font-weight: 700 !important;
  padding: 2px 8px !important;
  border-radius: 7px !important;
  background: rgba(63,165,108,0.18) !important;
  color: var(--green-2, #5ed992) !important;
  border: 1px solid rgba(63,165,108,0.35) !important;
}
aside.sidebar .sb-card .sbc-score-label.tier-gold {
  background: rgba(201,168,76,0.18) !important;
  color: var(--gold-2, #E8C964) !important;
  border-color: rgba(201,168,76,0.40) !important;
}
aside.sidebar .sb-card .sbc-score-label.tier-red {
  background: rgba(184,98,92,0.18) !important;
  color: #e8a09a !important;
  border-color: rgba(184,98,92,0.40) !important;
}
/* Score-Color-Tier (fürs Donut SVG) */
aside.sidebar .sb-card .sbc-mini-score.tier-green { color: var(--green-2, #5ed992); }
aside.sidebar .sb-card .sbc-mini-score.tier-gold  { color: var(--gold-2, #E8C964); }
aside.sidebar .sb-card .sbc-mini-score.tier-red   { color: #e8a09a; }

/* Mini-Cards (DSCR, CF/J, BMR) — V65.3: kompakter (Marcels Wunsch: weniger Luft) */
aside.sidebar .sb-card .sbc-mini-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr !important;
  gap: 4px !important;
  margin-top: 4px !important;       /* V65.3: war 9px — viel zu viel Luft zwischen Kaufpreis und Mini-Cards */
}
aside.sidebar .sb-card .sbcm,
aside.sidebar .sb-card .sbc-mini {
  padding: 5px 7px !important;       /* V65.3: kompakter (war 7px 8px) */
  border-radius: 6px !important;
  background: rgba(255,255,255,0.025) !important;
  border: 1px solid rgba(201,168,76,0.12) !important;
  position: relative !important;
  overflow: hidden !important;
}
aside.sidebar .sb-card .sbcm-l,
aside.sidebar .sb-card .sbc-mini-l {
  font-size: 9px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.6px !important;
  color: rgba(168,162,153,0.95) !important;
  font-weight: 600 !important;
}
aside.sidebar .sb-card .sbcm-v,
aside.sidebar .sb-card .sbc-mini-v {
  font-size: 11.5px !important;
  font-weight: 700 !important;
  color: var(--green-2, #5ed992) !important;
  font-variant-numeric: tabular-nums !important;
  letter-spacing: -0.2px !important;
  margin-top: 2px !important;
}
aside.sidebar .sb-card .sbcm-v.gold,
aside.sidebar .sb-card .sbcm-v.is-gold,
aside.sidebar .sb-card .sbc-mini-v.gold {
  color: var(--gold-2, #E8C964) !important;
}
aside.sidebar .sb-card .sbcm-v.red,
aside.sidebar .sb-card .sbc-mini-v.red {
  color: #e8a09a !important;
}
aside.sidebar .sb-card .sbcm-bar,
aside.sidebar .sb-card .sbc-mini-bar {
  height: 3px !important;
  background: rgba(255,255,255,0.10) !important;
  border-radius: 2px !important;
  margin-top: 3px !important;
  overflow: hidden !important;
}
aside.sidebar .sb-card .sbcm-bar > i,
aside.sidebar .sb-card .sbc-mini-bar > i {
  display: block !important;
  height: 100% !important;
  border-radius: 2px !important;
  background: linear-gradient(90deg, var(--gold-3, #9a7f33), var(--gold-2, #E8C964)) !important;
  box-shadow: 0 0 6px rgba(201,168,76,0.50) !important;
}
aside.sidebar .sb-card .sbcm-scale {
  display: flex !important;
  justify-content: space-between !important;
  font-size: 7.5px !important;
  color: rgba(168,162,153,0.65) !important;
  margin-top: 2px !important;
  font-variant-numeric: tabular-nums !important;
}
/* Sparkline-SVG soll dem mini-v color folgen */
aside.sidebar .sb-card .sbcm svg,
aside.sidebar .sb-card .sbc-mini svg {
  display: block;
  width: 100%;
  height: 14px;
}

/* Quick-Action-Buttons (⎘ kopieren / × löschen) — dezent oben rechts */
aside.sidebar .sb-card .sbc-actions {
  position: absolute !important;
  /* V103: Zurück nach rechts oben (Marcels Wunsch). Score-Overlay sitzt auch rechts oben,
     aber Aktionen bekommen z-index: 7 — höher als Score (4). Damit klickbar. */
  top: 6px !important;
  right: 6px !important;
  left: auto !important;
  display: flex !important;
  gap: 4px !important;
  opacity: 0;
  transition: opacity 0.2s;
  z-index: 7 !important;     /* V103: über Score-Overlay (z-index: 4) */
}
/* V103: Score-Overlay nach unten versetzt damit Aktionen-Buttons drüber Platz haben */
aside.sidebar .sb-card .sbc-score-overlay {
  top: 38px !important;       /* war 12 — jetzt unter den Action-Buttons */
}
aside.sidebar .sb-card:hover .sbc-actions,
aside.sidebar .sb-card.active .sbc-actions {
  /* V101: Aktiv-Card zeigt Aktionen IMMER (auch ohne Hover) damit Touch-User auf Mobile löschen können */
  opacity: 1;
}
aside.sidebar .sb-card .sbc-btn {
  width: 22px !important;
  height: 22px !important;
  border-radius: 5px !important;
  background: rgba(0,0,0,0.6) !important;
  color: rgba(168,162,153,0.85) !important;
  border: 1px solid rgba(201,168,76,0.20) !important;
  font-size: 12px !important;
  cursor: pointer;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
}
aside.sidebar .sb-card .sbc-btn:hover {
  border-color: var(--gold) !important;
  color: var(--gold-2, #E8C964) !important;
}
aside.sidebar .sb-card .sbc-btn.sbc-del:hover {
  border-color: rgba(184,98,92,0.6) !important;
  color: #e8a09a !important;
}

/* Portfolio-Übersicht — V65.0: gleicher KPI-Pill-Stil wie User-Box, dezent gold + Hover-Glow */
/* V92: Alter V65.3 Portfolio-Block deaktiviert.
   Der Container .sb-portfolio bekam einen schwarzen Hintergrund mit Border und Shadow,
   und der Header darin hatte border:0 + width:100% — das machte den Portfolio-Header
   visuell schmaler/anders als den Aktionen-Trigger und überschrieb mein Investment-PDF-Styling.
   Die neuen Regeln stehen am Ende der CSS unter "V88/V92 Portfolio-Übersicht ...". */
/*
aside.sidebar .sb-portfolio {
  margin: 4px 12px 4px !important;
  border-radius: 10px !important;
  background: #000 !important;
  border: 1px solid rgba(201,168,76,0.30) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02),
              0 2px 8px rgba(0,0,0,0.5) !important;
  overflow: hidden !important;
  color: rgba(232,226,212,0.9);
  transition: all 0.2s ease;
}
aside.sidebar .sb-portfolio:hover {
  border-color: rgba(201,168,76,0.55) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03),
              0 0 16px rgba(201,168,76,0.20) !important;
}
aside.sidebar .sb-portfolio .sb-collapsible-header {
  background: transparent !important;
  border: 0 !important;
  width: 100% !important;
  padding: 10px 14px !important;
  cursor: pointer;
  color: var(--gold-2, #E8C964) !important;
  font-size: 10px !important;
  text-transform: uppercase !important;
  letter-spacing: 1.4px !important;
  font-weight: 700 !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
}
aside.sidebar .sb-portfolio .sb-collapsible-header:hover {
  background: rgba(201,168,76,0.06) !important;
}
aside.sidebar .sb-portfolio .sb-collapsible-header > span:first-child {
  display: inline-flex !important;
  align-items: center !important;
  gap: 9px !important;
}
aside.sidebar .sb-portfolio .sb-collapsible-header svg {
  color: var(--gold) !important;
  width: 13px !important;
  height: 13px !important;
}
aside.sidebar .sb-portfolio-content {
  padding: 4px 14px 12px !important;
  background: transparent !important;
}
aside.sidebar .sb-portfolio-content .port-row {
  color: rgba(232,226,212,0.85) !important;
  border-bottom: 1px solid rgba(201,168,76,0.10) !important;
  padding: 7px 0 !important;
  font-size: 11.5px !important;
  display: flex !important;
  justify-content: space-between !important;
}
aside.sidebar .sb-portfolio-content .port-row:last-child {
  border-bottom: 0 !important;
}
aside.sidebar .sb-portfolio-content .port-v {
  color: #fff !important;
  font-weight: 700 !important;
  font-variant-numeric: tabular-nums;
}
aside.sidebar .sb-portfolio-content .port-v.port-cf {
  color: var(--green-2, #5ed992) !important;
}
*/
aside.sidebar .sb-toggle-arrow {
  color: var(--gold) !important;
  transition: transform 0.2s;
}

/* ─── Aktionen-Akkordeon: Trigger + Items ───
   V89: Alter V65.3-Block hier deaktiviert — Trigger wird unten im V88/V89-Block
   im Investment-PDF-Stil definiert. Das padding hier hat den 38px-height-Block überschrieben. */
/*
aside.sidebar .sb-actions-trigger {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 9px !important;
  background: linear-gradient(135deg, rgba(201,168,76,0.18), rgba(201,168,76,0.06)) !important;
  border: 1px solid rgba(201,168,76,0.40) !important;
  color: var(--gold-2, #E8C964) !important;
  padding: 9px 13px !important;
  border-radius: 9px !important;
  font-family: inherit !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer;
  letter-spacing: 0.3px !important;
  margin: 2px 12px 2px !important;
  width: calc(100% - 24px) !important;
  transition: all 0.2s;
}
aside.sidebar .sb-actions-trigger:hover {
  background: linear-gradient(135deg, rgba(201,168,76,0.28), rgba(201,168,76,0.12)) !important;
  box-shadow: 0 0 18px rgba(201,168,76,0.25) !important;
}
aside.sidebar .sb-actions-trigger .sb-actions-icon {
  display: inline-flex !important;
  align-items: center !important;
  width: 16px !important;
  height: 16px !important;
}
aside.sidebar .sb-actions-trigger .sb-actions-arrow {
  font-size: 11px !important;
  color: var(--gold-2, #E8C964) !important;
}
*/

/* Aktionen-Akkordeon (Items) — V64.9: Klare Definition + Toggle-Verhalten respektieren */
aside.sidebar .sb-actions-accordion {
  z-index: 100 !important;
}
/* WICHTIG: Wenn nicht offen, soll's nicht sichtbar sein (display:none ist klarer als max-height) */
aside.sidebar .sb-actions-accordion:not(.sb-actions-open) .sb-actions-accordion-inner {
  display: none !important;
}
aside.sidebar .sb-actions-accordion.sb-actions-open .sb-actions-accordion-inner {
  display: block !important;       /* V65.2: block statt flex — Items stacken natürlich */
  background: linear-gradient(180deg, #0a0805 0%, #050505 100%) !important;
  border: 1.5px solid rgba(201,168,76,0.40) !important;
  border-radius: 12px !important;
  box-shadow: 0 -8px 32px rgba(0,0,0,0.7),
              0 0 24px rgba(201,168,76,0.10),
              inset 0 1px 0 rgba(201,168,76,0.12) !important;
  padding: 8px !important;
  backdrop-filter: blur(8px);
  /* V66: alle Items ohne Scroll. max-content = exakt so hoch wie Inhalt.
     Auf wirklich kleinen Bildschirmen (selten) Fallback auf Scroll mit hoher Grenze. */
  max-height: max-content !important;
  overflow-y: visible !important;
}
/* V66: Auf sehr kleinen Bildschirmen (< 750px Höhe) doch scrollbar */
@media (max-height: 749px) {
  aside.sidebar .sb-actions-accordion.sb-actions-open .sb-actions-accordion-inner {
    max-height: calc(100vh - 140px) !important;
    overflow-y: auto !important;
  }
}
aside.sidebar .sb-act-item {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 9px 14px !important;
  background: transparent !important;
  border: 0 !important;
  border-left: 3px solid transparent !important;
  color: rgba(232,226,212,0.92) !important;
  font-family: inherit !important;
  font-size: 12.5px !important;
  cursor: pointer;
  width: 100% !important;
  text-align: left !important;
  transition: background 0.15s, border-color 0.15s;
  border-radius: 6px !important;
  margin: 0 !important;        /* V64.9: Reset alle Margins damit Layout sauber ist */
  flex-shrink: 0 !important;   /* V64.9: Items nicht schrumpfen lassen */
}
aside.sidebar .sb-act-item:hover {
  background: rgba(201,168,76,0.06) !important;
  border-left-color: var(--gold) !important;
  color: #fff !important;
}
aside.sidebar .sb-act-item .sb-act-ico {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 16px !important;
  height: 16px !important;
  color: var(--gold) !important;
  flex-shrink: 0;
}
aside.sidebar .sb-act-item .sb-act-ico svg {
  width: 100% !important;
  height: 100% !important;
}
/* V65.2: Marcels Wunsch — KEINE gold-gefüllten Akzent-Items mehr.
   Alle Items haben einheitlich goldene Schrift auf dunklem Hintergrund.
   Wenn das gold-Hover-Treatment zurück soll, alte Regeln im git-history. */
aside.sidebar .sb-act-item,
aside.sidebar .sb-act-item.sb-act-accent,
aside.sidebar .sb-act-item:first-of-type {
  background: transparent !important;
  color: var(--gold-2, #E8C964) !important;
  margin: 0 !important;
  padding: 10px 14px !important;
  border: 0 !important;
  border-left: 3px solid transparent !important;
  border-radius: 6px !important;
  font-weight: 600 !important;
  letter-spacing: 0.3px !important;
  width: 100% !important;
  box-shadow: none !important;
  font-family: inherit !important;
  font-size: 12.5px !important;
  cursor: pointer;
  text-align: left !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-shrink: 0 !important;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  /* Kein ::before-Shimmer mehr */
}
aside.sidebar .sb-act-item:hover,
aside.sidebar .sb-act-item.sb-act-accent:hover,
aside.sidebar .sb-act-item:first-of-type:hover {
  background: rgba(201,168,76,0.08) !important;
  color: #fff !important;
  border-left-color: var(--gold) !important;
  transform: none !important;
  box-shadow: none !important;
}
aside.sidebar .sb-act-item .sb-act-ico,
aside.sidebar .sb-act-item.sb-act-accent .sb-act-ico,
aside.sidebar .sb-act-item:first-of-type .sb-act-ico {
  color: var(--gold) !important;
}
/* ::before pseudo komplett deaktivieren falls noch Reste da */
aside.sidebar .sb-act-item.sb-act-accent::before,
aside.sidebar .sb-act-item:first-of-type::before {
  display: none !important;
}

/* Section-Title innerhalb Akkordeon */
aside.sidebar .sb-act-section-title {
  font-size: 9.5px !important;
  text-transform: uppercase !important;
  letter-spacing: 1.5px !important;
  color: rgba(168,162,153,0.65) !important;
  padding: 12px 14px 4px !important;
  font-weight: 700 !important;
  border-top: 1px solid rgba(201,168,76,0.10) !important;
  margin-top: 6px !important;
}

/* ─── User-Box im Footer — V67: noch flacher (war zu hoch) ─── */
aside.sidebar #sb-user,
aside.sidebar .sb-user-box {
  margin: 4px 12px !important;        /* V67: Margin auf 4 (war 6) */
  padding: 4px 8px !important;        /* V67: deutlich flacher (war 6px 10px) */
  border-radius: 9px !important;
  background: #000 !important;
  border: 1px solid rgba(201,168,76,0.30) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02),
              0 2px 8px rgba(0,0,0,0.5) !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  position: relative;
  z-index: 2;
  transition: all 0.2s ease;
}
aside.sidebar #sb-user:hover,
aside.sidebar .sb-user-box:hover {
  border-color: rgba(201,168,76,0.55) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03),
              0 0 16px rgba(201,168,76,0.20) !important;
}

/* V67: User-Avatar nochmal kleiner für halbe Höhe */
aside.sidebar .sb-user-avatar {
  width: 22px !important;             /* V67: 22 (war 26) */
  height: 22px !important;
  font-size: 9.5px !important;
}

/* V67: User-Name + E-Mail noch tighter */
aside.sidebar .sb-user-name {
  font-size: 10.5px !important;
  line-height: 1.15 !important;
}
aside.sidebar .sb-user-email {
  font-size: 9px !important;
  line-height: 1.15 !important;
  margin-top: 0 !important;
}

/* V67: Action-Buttons (Plan / Abmelden) noch kleiner */
aside.sidebar .sb-user-iconbtn {
  width: 22px !important;             /* V67: 22 (war 24) */
  height: 22px !important;
}

/* V65.3: FREE-Badge sitzt jetzt INSIDE der User-Box-Actions (links vom Plan-Button).
   Sehr kompakt — nur das FREE-Pill, der Counter wird ausgeblendet weil zu viel Platz braucht. */
aside.sidebar .sb-user-actions #paywall-usage {
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
}
aside.sidebar .sb-user-actions .pw-compact {
  margin: 0 !important;
  padding: 4px 7px !important;
  border-radius: 5px !important;
  background: rgba(201,168,76,0.10) !important;
  border: 1px solid rgba(201,168,76,0.30) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  cursor: pointer;
}
aside.sidebar .sb-user-actions .pw-compact:hover {
  background: rgba(201,168,76,0.18) !important;
  border-color: rgba(201,168,76,0.50) !important;
}
aside.sidebar .sb-user-actions .pw-compact-label {
  font-size: 8.5px !important;
  font-weight: 800 !important;
  letter-spacing: 1.4px !important;
  color: var(--gold-2, #E8C964) !important;
}
/* V65.3: Counter und Arrow im User-Box-Footer ausblenden — zu wenig Platz */
aside.sidebar .sb-user-actions .pw-compact-counter,
aside.sidebar .sb-user-actions .pw-compact-arrow {
  display: none !important;
}
/* Popover bleibt funktional — wird beim Hover der pw-compact angezeigt */
aside.sidebar .sb-user-actions .pw-popover {
  /* Popover sicher links vom Badge öffnen damit es nicht außerhalb der Sidebar landet */
  left: auto !important;
  right: calc(100% + 6px) !important;
}
aside.sidebar .sb-user-main {
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  width: 100% !important;
}
aside.sidebar .sb-user-avatar {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--gold-2, #E8C964), var(--gold-3, #9a7f33)) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--ch, #2A2727) !important;
  font-weight: 800 !important;
  font-size: 12px !important;
  box-shadow: 0 4px 12px rgba(201,168,76,0.30),
              inset 0 1px 0 rgba(255,255,255,0.30) !important;
  flex-shrink: 0 !important;
}
aside.sidebar .sb-user-text {
  flex: 1 !important;
  min-width: 0 !important;
}
aside.sidebar .sb-user-name {
  font-size: 12px !important;
  color: #fff !important;
  font-weight: 600 !important;
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
aside.sidebar .sb-user-email {
  font-size: 10px !important;
  color: rgba(168,162,153,0.75) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
aside.sidebar .sb-mode-badge {
  display: inline-flex !important;
  align-items: center !important;
  width: 14px !important;
  height: 14px !important;
  color: var(--gold) !important;
}
aside.sidebar .sb-user-actions {
  display: flex !important;
  gap: 4px !important;
  flex-shrink: 0 !important;
}
aside.sidebar .sb-user-iconbtn {
  width: 28px !important;
  height: 28px !important;
  border-radius: 6px !important;
  background: rgba(201,168,76,0.06) !important;
  border: 1px solid rgba(201,168,76,0.20) !important;
  color: var(--gold-2, #E8C964) !important;
  cursor: pointer;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  transition: all 0.2s;
}
aside.sidebar .sb-user-iconbtn:hover {
  background: rgba(201,168,76,0.14) !important;
  border-color: var(--gold) !important;
  color: var(--gold) !important;
}
aside.sidebar .sb-user-iconbtn-danger:hover {
  background: rgba(184,98,92,0.14) !important;
  border-color: rgba(184,98,92,0.5) !important;
  color: #e8a09a !important;
}

/* Plan-Badge innerhalb User-Name (z. B. "Investor") */
aside.sidebar .sb-user-name .pl,
aside.sidebar .sb-user-name .plan-pill {
  font-size: 9px !important;
  background: linear-gradient(135deg, var(--gold-2, #E8C964), var(--gold-3, #9a7f33)) !important;
  color: var(--ch, #2A2727) !important;
  padding: 2px 6px !important;
  border-radius: 4px !important;
  font-weight: 800 !important;
  letter-spacing: 0.5px !important;
}

/* Free-Plan-Badge oben in der Sidebar (von demo-paywall.js gerendert) */
aside.sidebar .free-plan-badge,
aside.sidebar .demo-mode-badge {
  background: linear-gradient(135deg, rgba(201,168,76,0.15), rgba(201,168,76,0.06)) !important;
  border: 1px solid rgba(201,168,76,0.30) !important;
  color: var(--gold-2, #E8C964) !important;
}

/* sb-footer-spacer braucht nur Höhe */
aside.sidebar .sb-footer {
  background: transparent !important;
  padding: 0 !important;
}

/* ════════════════════════════════════════════════════════════════════════
   V65.0 — Scrollbar-Styling für Sidebar (gold dezent statt grau)
   ════════════════════════════════════════════════════════════════════════ */

/* Webkit (Chrome/Edge/Safari): schmale gold-Scrollbar in der Sidebar */
aside.sidebar ::-webkit-scrollbar,
aside.sidebar::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
aside.sidebar ::-webkit-scrollbar-track,
aside.sidebar::-webkit-scrollbar-track {
  background: transparent;
}
aside.sidebar ::-webkit-scrollbar-thumb,
aside.sidebar::-webkit-scrollbar-thumb {
  background: rgba(201,168,76,0.25);
  border-radius: 3px;
  transition: background 0.2s;
}
aside.sidebar ::-webkit-scrollbar-thumb:hover,
aside.sidebar::-webkit-scrollbar-thumb:hover {
  background: rgba(201,168,76,0.55);
}
aside.sidebar ::-webkit-scrollbar-corner,
aside.sidebar::-webkit-scrollbar-corner {
  background: transparent;
}

/* Firefox: thin scrollbar mit gold thumb */
aside.sidebar,
aside.sidebar * {
  scrollbar-width: thin;
  scrollbar-color: rgba(201,168,76,0.25) transparent;
}

/* Sidebar selbst KEIN overflow-y:auto — würde Akkordeon abschneiden.
   Nur die Karten-Liste sollte scrollen (.sb-list-grow ist die Liste die wachsen darf). */
aside.sidebar .sb-list,
aside.sidebar .sb-list-grow {
  overflow-y: auto;
}
/* V67: Akkordeon-Inner KEIN scroll mehr — Inhalt soll voll sichtbar sein, ohne abzuschneiden */
aside.sidebar .sb-actions-accordion-inner {
  overflow-y: visible;
}

/* ═══════════════════════════════════════════════════════════════
   V67-FINAL — Sidebar-Layout-Polish (höchste Spezifität)
   Adressiert konkret:
   - Logo groß und prominent (Marcels Screenshot 2 als Vorlage)
   - Objektkacheln: NULL Spalt zwischen Kaufpreis und Mini-Cards
   - Aktionen-Menü: voll aufklappen, kein Cut
   ═══════════════════════════════════════════════════════════════ */

/* 1) LOGO-CONTAINER: V73 — Logo höher und weiter unten, sodass PORTFOLIO
   auf gleicher Höhe wie die goldene Trennlinie zwischen Tab-Bar und
   Workflow-Bar im Header sitzt (Marcels Bild 2 als Vorlage). */
aside.sidebar .sb-header {
  padding: 28px 12px 14px !important;    /* V73: mehr top-padding (war 14px) — Logo rutscht nach unten */
  display: block !important;
  align-items: stretch !important;
}
aside.sidebar .sb-logo-shimmer {
  width: 100% !important;
  box-sizing: border-box !important;
  padding: 32px 16px !important;         /* V73: höher (war 26px) — Logo nimmt mehr Raum */
  border-width: 1.5px !important;
  border-radius: 12px !important;
}
aside.sidebar .sb-logo-deal {
  font-size: 52px !important;            /* V73: nochmal größer (war 50px) */
  letter-spacing: -1.6px !important;
  line-height: 0.95 !important;
}
aside.sidebar .sb-logo-by {
  font-size: 16px !important;            /* V73: größer (war 15px) */
  margin-top: 14px !important;           /* V73: mehr Abstand (war 12px) */
  letter-spacing: 0.8px !important;
}

/* 2) OBJEKTKACHEL: Spalt zwischen Kaufpreis und Mini-Cards entfernen */
aside.sidebar .sb-card {
  padding: 10px !important;
  padding-top: 14px !important;
  gap: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}
aside.sidebar .sb-card .sbc-top {
  margin-bottom: 0 !important;
  align-items: flex-start !important;
}
aside.sidebar .sb-card .sbc-top-body {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  gap: 1px !important;
}
aside.sidebar .sb-card .sbc-kp-row {
  margin-top: 3px !important;
}
aside.sidebar .sb-card .sbc-mini-grid {
  margin-top: 6px !important;
  margin-bottom: 0 !important;
  gap: 4px !important;
}
aside.sidebar .sb-card .sbcm,
aside.sidebar .sb-card .sbc-mini {
  padding: 5px 7px !important;
}
/* V80: Layout nach Marcels Bild —
   Foto links breiter (120×80), Body mit Adresse + Kaufpreis direkt darunter,
   Score-Donut + Bewertungs-Pille als Overlay rechts oben (darf Adresse überlappen). */
aside.sidebar .sb-card .sbc-thumb,
aside.sidebar .sb-card .sbc-photo {
  width: 130px !important;
  height: 80px !important;             /* V86: breiter als hoch — Querformat (war 100) */
  border-radius: 10px !important;
  flex-shrink: 0 !important;
}
aside.sidebar .sb-card .sbc-thumb svg {
  width: 38px !important;
  height: 38px !important;
}
aside.sidebar .sb-card .sbc-top {
  gap: 12px !important;
}
/* V80: Score-Overlay rechts oben — absolute Position, darf Adresse-Zeile überlappen */
aside.sidebar .sb-card .sbc-score-overlay {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 5px !important;
  z-index: 4 !important;
  /* Donut mit dunklem Glow damit der Text der Adresse darunter lesbar bleibt */
  filter: drop-shadow(0 0 6px rgba(0,0,0,0.85));
}
aside.sidebar .sb-card .sbc-score-overlay .sbc-mini-score {
  width: 50px !important;
  height: 50px !important;
}
aside.sidebar .sb-card .sbc-score-overlay .sbc-mini-score svg {
  width: 50px !important;
  height: 50px !important;
}
aside.sidebar .sb-card .sbc-score-overlay .sbc-mini-score-num {
  font-size: 15px !important;
}
aside.sidebar .sb-card .sbc-score-overlay .sbc-score-label {
  font-size: 11px !important;
  padding: 3px 12px !important;
}
/* V80: Adresse — bekommt rechts genug padding damit Score-Overlay nicht direkt drüber sitzt */
aside.sidebar .sb-card .sbc-address {
  padding-right: 60px !important;       /* V80: Platz für Score-Overlay rechts */
}
/* V80: Kaufpreis sitzt direkt unter der Adresse, kein Score mehr daneben */
aside.sidebar .sb-card .sbc-kp-row {
  align-items: flex-start !important;
}
aside.sidebar .sb-card .sbc-kp {
  margin-top: 2px !important;
}
/* V80: Mini-Cards (DSCR/CF/J/BMR) flacher — Marcels Wunsch: nicht so groß */
aside.sidebar .sb-card .sbc-mini-grid {
  margin-top: 8px !important;
  gap: 4px !important;
}
aside.sidebar .sb-card .sbcm,
aside.sidebar .sb-card .sbc-mini {
  padding: 4px 6px !important;          /* V80: kompakter (war 5×7) */
}
aside.sidebar .sb-card .sbcm-l,
aside.sidebar .sb-card .sbc-mini-l {
  font-size: 8.5px !important;
  margin-bottom: 1px !important;
}
aside.sidebar .sb-card .sbcm-v,
aside.sidebar .sb-card .sbc-mini-v,
aside.sidebar .sb-card .sbcm-val {
  font-size: 13px !important;           /* V80: kleiner (war 14px) */
}
aside.sidebar .sb-card .sbcm-spark {
  height: 14px !important;              /* V80: Sparkline flacher (war 18px) */
}
aside.sidebar .sb-card .sbcm-bar {
  height: 3px !important;
  margin-top: 2px !important;
}
aside.sidebar .sb-card .sbcm-scale {
  font-size: 7.5px !important;
  margin-top: 1px !important;
}
/* V76: Adresse als eigene Zeile zwischen Header und Kaufpreis — weiße Schrift */
aside.sidebar .sb-card .sbc-address {
  display: block;
  margin-top: 4px;
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ═══════════════════════════════════════════════════════════════
   V75: Tab-Bar — Häkchen direkt an Tabs + Status-Badge rechts
   ═══════════════════════════════════════════════════════════════ */
.tab .tab-wf-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  margin-left: 5px;
  color: var(--gold);
  flex-shrink: 0;
  filter: drop-shadow(0 0 3px rgba(201,168,76,0.50));
}
.tab.tab-wf-done {
  color: var(--gold);
}
.tab.tab-wf-done .tab-lbl {
  color: var(--gold);
}

/* Status-Badge in der Tab-Bar (rechts, vor Versions-Badge-Slot) */
.tabs-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-left: 8px;
  padding: 5px 11px;
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.28);
  border-radius: 7px;
  flex-shrink: 0;
  font-family: 'DM Sans', sans-serif;
  align-self: center;
}
.tabs-status-badge.tabs-status-done {
  background: rgba(63,165,108,0.10);
  border-color: rgba(63,165,108,0.35);
}
.tabs-status-text {
  font-size: 11px;
  font-weight: 600;
  color: var(--gold-2, #E8C964);
  letter-spacing: 0.3px;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.tabs-status-done .tabs-status-text {
  color: var(--green-2, #5ed992);
}
.tabs-status-bar {
  width: 60px;
  height: 4px;
  background: rgba(255,255,255,0.07);
  border-radius: 2px;
  overflow: hidden;
}
.tabs-status-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold), var(--gold-2, #E8C964));
  border-radius: 2px;
  transition: width 0.30s ease-out;
}
.tabs-status-done .tabs-status-fill {
  background: linear-gradient(90deg, #3FA56C, var(--green-2, #5ed992));
}

/* V75: Versions-Badge in User-Box (kompakt, dezent neben E-Mail) */
aside.sidebar .sb-user-ver {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 6px;
  font-size: 8.5px !important;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: rgba(201,168,76,0.85);
  background: rgba(201,168,76,0.08);
  border: 1px solid rgba(201,168,76,0.20);
  border-radius: 4px;
  vertical-align: middle;
  font-variant-numeric: tabular-nums;
}

/* 3) AKTIONEN-AKKORDEON: voll aufklappen, kein Cut, direkt über Trigger
   V71: position absolute mit !important erzwingen damit es NICHT im Flow steht.
   Outer-Container mit Padding 0 (bottom wird per JS dynamisch gesetzt),
   Inner als Vollbreite-Block mit border-box damit der goldene Rand auf ALLEN
   vier Seiten gleich sitzt. */
aside.sidebar .sb-actions-accordion {
  position: absolute !important;         /* V71: garantiert nicht im Flow */
  z-index: 100 !important;
  left: 12px !important;
  right: 12px !important;
  /* bottom wird per JS in sbActionsToggle gesetzt — fallback hier:
     Trigger ~36px + User-Box ~46px + 4px = 86px */
  bottom: 86px !important;
  padding: 0 !important;
  margin: 0 !important;
}
aside.sidebar .sb-actions-accordion:not(.sb-actions-open) .sb-actions-accordion-inner {
  display: none !important;
}
aside.sidebar .sb-actions-accordion.sb-actions-open {
  max-height: none !important;
  overflow: visible !important;
}
aside.sidebar .sb-actions-accordion.sb-actions-open .sb-actions-accordion-inner {
  display: block !important;
  box-sizing: border-box !important;     /* V69: Border + Padding bleiben in der Containerbreite */
  width: 100% !important;
  margin: 0 !important;                  /* V70: keine Margin mehr — outer regelt Position */
  max-height: none !important;
  overflow: visible !important;
  background: linear-gradient(180deg, #0a0805 0%, #050505 100%) !important;
  border: 1.5px solid rgba(201,168,76,0.40) !important;
  border-radius: 12px !important;
  box-shadow: 0 -8px 32px rgba(0,0,0,0.7),
              0 0 24px rgba(201,168,76,0.10),
              inset 0 1px 0 rgba(201,168,76,0.12) !important;
  padding: 8px !important;
}
/* Auf wirklich kleinen Bildschirmen (< 700px Höhe) → Scroll-Fallback */
@media (max-height: 699px) {
  aside.sidebar .sb-actions-accordion.sb-actions-open {
    max-height: calc(100vh - 140px) !important;
    overflow: hidden !important;
  }
  aside.sidebar .sb-actions-accordion.sb-actions-open .sb-actions-accordion-inner {
    max-height: calc(100vh - 150px) !important;
    overflow-y: auto !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   V87 — SETTINGS-MODAL CREAM-CLASSIC
   Komplettes Restyling auf Split-Layout (dunkle Sidebar links,
   cremiger Content rechts) — passend zum Pure-Obsidian-Frontend.
   Alle Regeln scoped via .set-modal-cream damit alte Settings-
   Styles im Rest der App nicht beeinflusst werden.
   ═══════════════════════════════════════════════════════════════ */

/* Backdrop hinter Modal mit Particle-Animation */
#settings-modal.global-view-overlay:has(.set-modal-cream),
#settings-modal:has(.set-modal-cream) {
  background: radial-gradient(ellipse at center, rgba(20,15,5,.55) 0%, rgba(0,0,0,.92) 70%) !important;
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
  padding: 30px;
}
#settings-modal:has(.set-modal-cream)::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    radial-gradient(1px 1px at 20% 20%, rgba(201,168,76,.4) 50%, transparent 100%),
    radial-gradient(1px 1px at 80% 60%, rgba(201,168,76,.3) 50%, transparent 100%),
    radial-gradient(2px 2px at 50% 80%, rgba(201,168,76,.4) 50%, transparent 100%);
  background-size: 300px 400px;
  animation: dpV87BgPart 25s linear infinite;
  pointer-events: none;
}
@keyframes dpV87BgPart { to { background-position: 0 -400px, 0 -400px, 0 -400px; } }

/* Modal-Container — Split-Grid */
.set-modal-cream {
  background: var(--cream, #F8F6F1) !important;
  border-radius: 16px !important;
  width: 1100px !important;
  max-width: calc(100vw - 60px) !important;
  max-height: 680px !important;
  height: 680px !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: 240px 1fr !important;
  position: relative !important;
  z-index: 1 !important;
  box-shadow: 0 30px 80px rgba(0,0,0,.5), 0 0 0 1.5px var(--gold) !important;
  padding: 0 !important;
}
.set-modal-cream .pricing-close { display: none !important; }

/* Linke Sidebar — dunkel mit Particles */
.set-modal-cream .modal-side {
  background: linear-gradient(180deg, #1a1614 0%, #0d0a04 100%);
  padding: 0;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}
.set-modal-cream .modal-side::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    radial-gradient(1px 1px at 25% 15%, rgba(201,168,76,.5) 50%, transparent 100%),
    radial-gradient(1px 1px at 70% 70%, rgba(201,168,76,.4) 50%, transparent 100%),
    radial-gradient(2px 2px at 30% 85%, rgba(201,168,76,.55) 50%, transparent 100%);
  background-size: 240px 320px;
  animation: dpV87BgPart 25s linear infinite;
  pointer-events: none;
}

/* Sidebar-Header */
.set-modal-cream .ms-h {
  padding: 22px 18px 16px;
  border-bottom: 1px solid rgba(201,168,76,.15);
  position: relative; z-index: 1;
}
.set-modal-cream .ms-title {
  font-size: 18px; color: #fff; font-weight: 700;
  letter-spacing: -.3px; display: flex; align-items: center; gap: 8px;
}
.set-modal-cream .ms-title .ic { width: 18px; height: 18px; color: var(--gold-2, #E8C964); display: inline-flex; }
.set-modal-cream .ms-title .ic svg { width: 100%; height: 100%; }
.set-modal-cream .ms-title .gold {
  background: linear-gradient(135deg, var(--gold-2, #E8C964), var(--gold));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.set-modal-cream .ms-sub {
  font-size: 11.5px; color: rgba(255,255,255,.5);
  margin-top: 3px; line-height: 1.4;
}

/* Sidebar-Tabs (Scope ms-tabs damit alte settings-tabs-Styles nicht greifen) */
.set-modal-cream .ms-tabs {
  flex: 1; overflow: auto;
  padding: 10px 10px 14px;
  position: relative; z-index: 1;
  display: flex; flex-direction: column; gap: 2px;
  background: transparent !important;
  border: 0 !important;
}
.set-modal-cream .ms-tab {
  display: flex !important;
  align-items: center; gap: 11px;
  padding: 10px 12px !important;
  border-radius: 8px !important;
  cursor: pointer;
  font-size: 12.5px !important;
  color: rgba(255,255,255,.7) !important;
  font-weight: 500 !important;
  margin-bottom: 0 !important;
  transition: all .15s;
  border: 1px solid transparent !important;
  background: transparent !important;
  font-family: inherit;
  text-align: left;
  white-space: normal;
  width: 100%;
  flex-shrink: 0;
}
.set-modal-cream .ms-tab:hover {
  background: rgba(201,168,76,.06) !important;
  color: #fff !important;
}
.set-modal-cream .ms-tab.active,
.set-modal-cream .ms-tab.act {
  background: linear-gradient(90deg, rgba(201,168,76,.18), rgba(201,168,76,.04)) !important;
  color: var(--gold-2, #E8C964) !important;
  border-color: rgba(201,168,76,.35) !important;
  box-shadow: inset 2px 0 0 var(--gold) !important;
}
.set-modal-cream .ms-tab .ic {
  width: 15px; height: 15px;
  color: var(--gold);
  opacity: .85;
  display: inline-flex;
  flex-shrink: 0;
}
.set-modal-cream .ms-tab .ic svg { width: 100%; height: 100%; }
.set-modal-cream .ms-tab.active .ic,
.set-modal-cream .ms-tab.act .ic { opacity: 1; }
/* Alte st-tab-ico-Spans verstecken (falls noch im DOM) */
.set-modal-cream .ms-tab .st-tab-ico { display: none !important; }

/* Sidebar-Footer (User-Box) */
.set-modal-cream .ms-foot {
  padding: 14px 16px;
  border-top: 1px solid rgba(201,168,76,.15);
  display: flex; align-items: center; gap: 9px;
  background: rgba(0,0,0,.3);
  position: relative; z-index: 1;
}
.set-modal-cream .ms-foot .av {
  width: 30px; height: 30px; border-radius: 50%;
  background: linear-gradient(135deg, var(--gold-2, #E8C964), var(--gold-3, #9a7f33));
  display: flex; align-items: center; justify-content: center;
  color: var(--ch); font-weight: 800; font-size: 11.5px;
  flex-shrink: 0;
}
.set-modal-cream .ms-foot .nm { font-size: 12px; color: #fff; font-weight: 600; }
.set-modal-cream .ms-foot .ml { font-size: 9.5px; color: rgba(255,255,255,.5); margin-top: 1px; }
.set-modal-cream .ms-foot .pl {
  display: inline-flex; align-items: center; gap: 3px;
  background: linear-gradient(135deg, var(--gold-2, #E8C964), var(--gold-3, #9a7f33));
  color: var(--ch);
  font-size: 8.5px; font-weight: 800; letter-spacing: .5px;
  padding: 1px 6px; border-radius: 4px;
  margin-top: 4px;
  text-transform: uppercase;
}
.set-modal-cream .ms-foot .pl .ic { width: 8px; height: 8px; }

/* Right Content-Container — Grid mit Pane oben + Save-Row als Footer */
.set-modal-cream .set-modal-content {
  display: grid !important;
  grid-template-rows: 1fr auto !important;
  height: 100% !important;
  overflow: hidden !important;
  background: var(--cream, #F8F6F1) !important;
}

/* Pane-Wrap (alle st-panes leben hier drin) */
.set-modal-cream .pane-wrap {
  padding: 24px 28px;
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 18px;
  background: var(--cream, #F8F6F1);
}
.set-modal-cream .pane-wrap .st-pane {
  padding: 0 !important;
  display: none;
}
.set-modal-cream .pane-wrap .st-pane.active {
  display: block !important;
}

/* Pane-Inhalt: Headlines, Hint-Texte, Inputs */
.set-modal-cream .pane-wrap .hint {
  font-size: 13px; color: var(--mut, #7a7570);
  margin: 0 0 14px 0;
}
.set-modal-cream .pane-wrap .set-section-h {
  font-size: 11.5px !important;
  text-transform: uppercase !important;
  letter-spacing: 1.4px !important;
  color: var(--gold-3, #9a7f33) !important;
  font-weight: 700 !important;
  margin: 18px 0 8px !important;
  display: flex; align-items: center; gap: 8px;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
}
.set-modal-cream .pane-wrap .set-section-h::after {
  content: ""; flex: 1; height: 1px;
  background: linear-gradient(90deg, var(--gold-soft, #f5ecd0), transparent);
  margin-left: 6px;
}
.set-modal-cream .pane-wrap .set-section-h:first-child { margin-top: 0 !important; }
.set-modal-cream .pane-wrap hr.dvd {
  border: 0;
  border-top: 1px solid var(--line, #e8e2d4);
  margin: 16px 0;
}

/* Inputs / Selects / Textareas im Pane */
.set-modal-cream .pane-wrap .f,
.set-modal-cream .pane-wrap .field {
  display: flex; flex-direction: column;
  margin-bottom: 0;
}
.set-modal-cream .pane-wrap .f label,
.set-modal-cream .pane-wrap .field label {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--mut, #7a7570);
  font-weight: 600;
  margin-bottom: 5px;
}
.set-modal-cream .pane-wrap .f input,
.set-modal-cream .pane-wrap .f select,
.set-modal-cream .pane-wrap .f textarea,
.set-modal-cream .pane-wrap .field input,
.set-modal-cream .pane-wrap .field select,
.set-modal-cream .pane-wrap .field textarea {
  width: 100%;
  padding: 9px 12px !important;
  border: 1px solid var(--line, #e8e2d4) !important;
  border-radius: 7px !important;
  background: #fff !important;
  font-family: inherit;
  font-size: 13px !important;
  color: var(--ch, #2a2727) !important;
  transition: all .2s;
}
.set-modal-cream .pane-wrap .f input:focus,
.set-modal-cream .pane-wrap .f select:focus,
.set-modal-cream .pane-wrap .f textarea:focus,
.set-modal-cream .pane-wrap .field input:focus,
.set-modal-cream .pane-wrap .field select:focus {
  outline: 0 !important;
  border-color: var(--gold) !important;
  box-shadow: 0 0 0 3px rgba(201,168,76,.18) !important;
}
.set-modal-cream .pane-wrap .f input[readonly],
.set-modal-cream .pane-wrap .field input[readonly] {
  background: #f4efe1 !important;
  color: var(--mut, #7a7570) !important;
  cursor: not-allowed;
}

/* Grid-Spalten g2 / g3 (bestehende Klassen) */
.set-modal-cream .pane-wrap .g2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 10px;
}
.set-modal-cream .pane-wrap .g3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
  margin-bottom: 10px;
}

/* Plan-Box im Account-Pane (Cream-Gold-Verlauf) */
.set-modal-cream .pane-wrap .plan-box,
.set-modal-cream .pane-wrap .account-plan-box {
  background: linear-gradient(135deg, #fdf9ef, #f5ecd0) !important;
  border: 1px solid var(--gold) !important;
  border-radius: 10px !important;
  padding: 14px 16px !important;
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin: 0;
}
.set-modal-cream .pane-wrap .pl-name,
.set-modal-cream .pane-wrap .account-plan-name {
  font-size: 14px !important;
  color: var(--ch) !important;
  font-weight: 700 !important;
  display: flex; align-items: center; gap: 7px;
  background: transparent !important;
  -webkit-text-fill-color: var(--ch) !important;
}
.set-modal-cream .pane-wrap .pl-name .ic,
.set-modal-cream .pane-wrap .account-plan-name .ic {
  width: 14px; height: 14px; color: var(--gold);
  display: inline-flex;
}
.set-modal-cream .pane-wrap .pl-meta,
.set-modal-cream .pane-wrap .account-plan-meta {
  font-size: 11.5px !important;
  color: var(--mut, #7a7570) !important;
  margin-top: 2px !important;
}

/* Save-Row als Grid-Footer */
.set-modal-cream .save-row,
.set-modal-cream .settings-footer {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 14px 28px !important;
  background: var(--paper, #fff) !important;
  border-top: 1px solid var(--line, #e8e2d4) !important;
  margin: 0 !important;
}
.set-modal-cream .save-row .save-info,
.set-modal-cream .settings-footer .save-info {
  font-size: 11.5px;
  color: var(--mut, #7a7570);
  display: flex; align-items: center; gap: 7px;
}
.set-modal-cream .save-row .save-info::before {
  content: "";
  width: 6px; height: 6px;
  background: var(--green, #3FA56C);
  border-radius: 50%;
  box-shadow: 0 0 8px var(--green, #3FA56C);
}
.set-modal-cream .save-row .btns {
  display: flex; gap: 9px;
}
.set-modal-cream .save-row .btn,
.set-modal-cream .settings-footer .btn {
  padding: 8px 15px !important;
  border-radius: 7px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  cursor: pointer;
  border: 1px solid !important;
  font-family: inherit;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: all .2s;
}
.set-modal-cream .save-row .btn .ic { width: 12px; height: 12px; display: inline-flex; }
.set-modal-cream .save-row .btn .ic svg { width: 100%; height: 100%; }

.set-modal-cream .save-row .btn-ghost,
.set-modal-cream .settings-footer .btn-ghost {
  background: transparent !important;
  border-color: var(--line, #e8e2d4) !important;
  color: var(--mut, #7a7570) !important;
  box-shadow: none !important;
}
.set-modal-cream .save-row .btn-ghost:hover,
.set-modal-cream .settings-footer .btn-ghost:hover {
  border-color: var(--ch) !important;
  color: var(--ch) !important;
}
.set-modal-cream .save-row .btn-gold,
.set-modal-cream .settings-footer .btn-gold {
  background: linear-gradient(135deg, var(--gold-2, #E8C964), var(--gold-3, #9a7f33)) !important;
  color: var(--ch, #2a2727) !important;
  border-color: var(--gold) !important;
  box-shadow: 0 4px 14px rgba(201,168,76,.4), inset 0 1px 0 rgba(255,255,255,.4) !important;
  font-weight: 700 !important;
}
.set-modal-cream .save-row .btn-gold:hover,
.set-modal-cream .settings-footer .btn-gold:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(201,168,76,.5), inset 0 1px 0 rgba(255,255,255,.4) !important;
}

/* Plan-Link-Button im Account-Pane (alter .account-plan-link wird Ghost-Button) */
.set-modal-cream .pane-wrap .account-plan-link {
  background: transparent !important;
  border: 1px solid var(--line, #e8e2d4) !important;
  color: var(--mut, #7a7570) !important;
  padding: 8px 15px !important;
  border-radius: 7px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  cursor: pointer;
  font-family: inherit;
  display: inline-flex; align-items: center; gap: 6px;
  transition: all .2s;
  text-decoration: none !important;
}
.set-modal-cream .pane-wrap .account-plan-link:hover {
  border-color: var(--ch) !important;
  color: var(--ch) !important;
}
.set-modal-cream .pane-wrap .account-plan-link .ic { width: 12px; height: 12px; display: inline-flex; }

/* Setting-Row-Card — bestehende Component im neuen Look */
.set-modal-cream .pane-wrap .setting-row-card {
  background: #fff !important;
  border: 1px solid var(--line, #e8e2d4) !important;
  border-radius: 8px !important;
  padding: 12px 14px !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 14px !important;
  margin: 8px 0 !important;
}
.set-modal-cream .pane-wrap .setting-row-card-gold {
  background: linear-gradient(135deg, #fdf9ef, #f5ecd0) !important;
  border-color: var(--gold) !important;
}
.set-modal-cream .pane-wrap .setting-row-title {
  font-size: 13px; font-weight: 600; color: var(--ch);
}
.set-modal-cream .pane-wrap .setting-row-title-gold { color: var(--ch); }
.set-modal-cream .pane-wrap .setting-row-desc {
  font-size: 11.5px; color: var(--mut, #7a7570); margin-top: 2px;
}

/* Mobile / kleinere Bildschirme: Sidebar collapsed → nur Tabs als Header */
@media (max-width: 768px) {
  .set-modal-cream {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto 1fr auto !important;
    height: 100vh !important;
    max-height: 100vh !important;
    width: 100vw !important;
    max-width: 100vw !important;
    border-radius: 0 !important;
  }
  .set-modal-cream .modal-side {
    flex-direction: row;
    height: auto;
    border-bottom: 1px solid rgba(201,168,76,.2);
  }
  .set-modal-cream .ms-h { padding: 14px 14px 10px; }
  .set-modal-cream .ms-tabs { flex-direction: row; flex-wrap: nowrap; overflow-x: auto; padding: 8px 12px; }
  .set-modal-cream .ms-tab { flex-shrink: 0; }
  .set-modal-cream .ms-foot { display: none; }
}

/* Dirty-Hint links in der Save-Row */
.set-modal-cream .save-row .save-info-text { display: inline; }
.set-modal-cream .save-row #settings-dirty-hint {
  color: var(--gold-3, #9a7f33);
  font-weight: 600;
  margin-right: 8px;
}

/* ═══════════════════════════════════════════════════════════════
   V88 — Portfolio-Übersicht & Aktionen-Trigger im Investment-PDF-Stil
   Gleiche Optik wie .hdr-pdf-btn: 34px Höhe, transparent, 0.5px gold,
   Hover mit Gold-Schimmer. Plus dezenteres Cream-Akzent für Portfolio-Werte.
   ═══════════════════════════════════════════════════════════════ */

/* Portfolio-Header (klickbar — wie Investment-PDF-Btn) */
aside.sidebar .sb-portfolio-collapsible .sb-collapsible-header {
  height: auto !important;
  min-height: 38px !important;
  padding: 9px 14px !important;
  margin: 4px 12px !important;
  width: calc(100% - 24px) !important;
  background: transparent !important;
  border: 0.5px solid rgba(201,168,76,0.55) !important;
  border-radius: 7px !important;
  color: var(--gold-2, #E8C964) !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.4px !important;
  text-transform: uppercase !important;
  font-family: 'DM Sans', sans-serif !important;
  transition: all 0.18s ease !important;
  position: static !important;
  top: auto !important;
}
aside.sidebar .sb-portfolio-collapsible .sb-collapsible-header:hover {
  background: rgba(201,168,76,0.10) !important;
  border-color: var(--gold) !important;
  box-shadow: 0 0 16px rgba(201,168,76,0.22) !important;
  color: var(--gold-2, #E8C964) !important;
}
aside.sidebar .sb-portfolio-collapsible .sb-collapsible-header > span:first-child {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
}
aside.sidebar .sb-portfolio-collapsible .sb-collapsible-header svg {
  color: var(--gold-2, #E8C964) !important;
}
aside.sidebar .sb-portfolio-collapsible .sb-toggle-arrow {
  font-size: 11px !important;
  color: var(--gold-2, #E8C964) !important;
  transition: transform 0.2s ease !important;
}
/* Portfolio-Container — V89: KEIN max-height/overflow mehr,
   damit der ursprüngliche flex-flow nicht überschrieben wird (war Bug in V88).
   V91: column-reverse — Header sitzt UNTEN, Inhalt klappt nach OBEN auf
   (so wie das Aktionen-Akkordeon mit seinem Trigger unten). */
aside.sidebar .sb-portfolio-collapsible {
  background: transparent !important;
  border: 0 !important;
  border-top: 1px solid rgba(201,168,76,0.10) !important;
  border-radius: 10px !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column-reverse !important;
  /* V92: max-height + overflow aus dem alten Sidebar-CSS überschreiben — sonst kommt
     eine Scrollbar im Container und der Header wirkt schmaler als der Aktionen-Trigger. */
  max-height: none !important;
  overflow: visible !important;
  flex: 0 0 auto !important;
  transition: all 0.2s ease !important;
}
/* V93: Goldener Rahmen + Hintergrund nur wenn der Inhalt aufgeklappt ist
   (also wenn das Content-Div via JS auf display:block gesetzt wurde).
   Der Container bekommt Margin nur in diesem Zustand — sonst sitzt der Header
   ohne Container-Margin direkt in der Sidebar (gleiche Position wie Aktionen-Trigger). */
aside.sidebar .sb-portfolio-collapsible:has(.sb-portfolio-content[style*="display: block"]),
aside.sidebar .sb-portfolio-collapsible:has(.sb-portfolio-content[style*="display:block"]) {
  background: rgba(0,0,0,0.45) !important;
  border: 1px solid rgba(201,168,76,0.40) !important;
  box-shadow: 0 0 18px rgba(201,168,76,0.12), inset 0 1px 0 rgba(255,255,255,0.03) !important;
  margin: 4px 12px !important;
  padding: 0 !important;
}
/* Wenn aufgeklappt: Header bekommt KEIN eigenes Margin/Border mehr — sitzt im Container drin */
aside.sidebar .sb-portfolio-collapsible:has(.sb-portfolio-content[style*="display: block"]) .sb-collapsible-header,
aside.sidebar .sb-portfolio-collapsible:has(.sb-portfolio-content[style*="display:block"]) .sb-collapsible-header {
  border: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  border-radius: 0 0 9px 9px !important;       /* nur unten gerundet, oben anschließend an content */
}
aside.sidebar .sb-portfolio-content {
  padding: 4px 14px 12px !important;
  /* V92: KEIN display:flex !important mehr — sonst gewinnt das gegen
     das inline style="display:none" aus dem HTML und togglePortfolio() greift nicht.
     Wenn der Inhalt sichtbar ist, ist Block-Display ausreichend. */
  flex-direction: column !important;
  gap: 0 !important;
  background: transparent !important;
}
/* Wenn sichtbar → flex. inline-Style display:none/block bleibt der Schalter. */
aside.sidebar .sb-portfolio-content[style*="display: block"],
aside.sidebar .sb-portfolio-content[style*="display:block"] {
  display: flex !important;
}
aside.sidebar .sb-portfolio-content .port-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 9px 12px !important;
  border-bottom: 1px solid rgba(201,168,76,0.08) !important;
  font-size: 11.5px !important;
  color: rgba(232,226,212,0.78) !important;
  font-family: 'DM Sans', sans-serif !important;
}
aside.sidebar .sb-portfolio-content .port-row:last-child {
  border-bottom: 0 !important;
}
aside.sidebar .sb-portfolio-content .port-v {
  color: #fff !important;
  font-weight: 700 !important;
  font-size: 12.5px !important;
  font-variant-numeric: tabular-nums !important;
  letter-spacing: -0.2px !important;
}
aside.sidebar .sb-portfolio-content .port-v.port-cf.positive {
  color: var(--green-2, #5ed992) !important;
}
aside.sidebar .sb-portfolio-content .port-v.port-cf.negative {
  color: #e8a09a !important;
}

/* Aktionen-Trigger im EXAKT gleichen Stil wie Portfolio-Header und Investment-PDF-Button */
aside.sidebar .sb-actions-trigger {
  /* V89: Höhe via padding (height wurde von altem padding:9px überschrieben) */
  height: auto !important;
  min-height: 38px !important;
  padding: 9px 14px !important;
  margin: 4px 12px !important;
  width: calc(100% - 24px) !important;
  background: transparent !important;
  border: 0.5px solid rgba(201,168,76,0.55) !important;
  border-radius: 7px !important;
  color: var(--gold-2, #E8C964) !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.4px !important;
  text-transform: uppercase !important;
  font-family: 'DM Sans', sans-serif !important;
  transition: all 0.18s ease !important;
  box-shadow: none !important;
}
aside.sidebar .sb-actions-trigger:hover {
  background: rgba(201,168,76,0.10) !important;
  border-color: var(--gold) !important;
  box-shadow: 0 0 16px rgba(201,168,76,0.22) !important;
}
aside.sidebar .sb-actions-trigger .sb-actions-icon {
  display: inline-flex !important;
  align-items: center !important;
  width: 16px !important;
  height: 16px !important;
  color: var(--gold-2, #E8C964) !important;
  margin-right: 4px !important;
}
aside.sidebar .sb-actions-trigger .sb-actions-l {
  flex: 1 !important;
  text-align: left !important;
}
aside.sidebar .sb-actions-trigger .sb-actions-arrow {
  font-size: 11px !important;
  color: var(--gold-2, #E8C964) !important;
}

/* ═══════════════════════════════════════════════════════════════
   V95 — Cream-Classic-Veredelung (KORRIGIERT)
   Tabs sind und bleiben Cream-hell (Body --surface #F8F6F1, Cards weiß).
   V94 hatte den Card-BG fälschlich auf dunkel geflippt — das ist hier korrigiert.
   Nur Headline-Akzente, Card-Titel mit Icons + Goldverlauflinie, und einheitliche
   gold-getönte Card-Border werden ergänzt.
   ═══════════════════════════════════════════════════════════════ */

/* Tab-Hauptüberschrift mit Goldakzent-Linie links */
#s0 > .sec-title,
#s1 > .sec-title,
#s2 > .sec-title,
#s3 > .sec-title,
#s3-tax > .sec-title,
#s4 > .sec-title,
#s5 > .sec-title,
#s6 > .sec-title {
  position: relative;
  padding-left: 14px !important;
  font-weight: 700 !important;
  letter-spacing: -0.3px !important;
}
#s0 > .sec-title::before,
#s1 > .sec-title::before,
#s2 > .sec-title::before,
#s3 > .sec-title::before,
#s3-tax > .sec-title::before,
#s4 > .sec-title::before,
#s5 > .sec-title::before,
#s6 > .sec-title::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 70%;
  background: linear-gradient(180deg, var(--gold-2, #E8C964), var(--gold-3, #9a7f33));
  border-radius: 2px;
  box-shadow: 0 0 8px rgba(201,168,76,0.4);
}

/* Card-Titel im Cream-Classic-Stil — für HELLE Cards (var(--surface)/weiß).
   Gold-3 Farbe für Schrift damit Kontrast auf cremiger Card stimmt,
   Icon in dezenter Cream-Gold-Box, Goldverlauflinie rechts fade-out. */
.ct-pro {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-size: 11.5px !important;
  text-transform: uppercase !important;
  letter-spacing: 1.4px !important;
  color: var(--gold-3, #9a7f33) !important;
  font-weight: 700 !important;
  font-family: 'DM Sans', sans-serif !important;
  margin-bottom: 14px !important;
  padding: 0 0 10px 0 !important;
  border-bottom: 0 !important;
  position: relative;
  background: transparent !important;
}
.ct-pro::after {
  content: "";
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--gold-soft, #f5ecd0), transparent);
  margin-left: 8px;
}
.ct-pro .ct-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: linear-gradient(135deg, #fdf9ef, #f5ecd0);
  border: 1px solid rgba(201,168,76,0.40);
  border-radius: 6px;
  color: var(--gold, #C9A84C);
  flex-shrink: 0;
  box-shadow: 0 1px 3px rgba(201,168,76,0.15), inset 0 1px 0 rgba(255,255,255,0.6);
}
.ct-pro .ct-ico svg {
  display: block;
  color: var(--gold, #C9A84C);
}
/* DS2-Tag im Card-Titel passend zum hellen Card */
.ct-pro .ds2-tag {
  font-size: 9px !important;
  padding: 2px 6px !important;
  letter-spacing: 0.3px !important;
  background: rgba(201,168,76,0.14) !important;
  color: var(--gold-3, #9a7f33) !important;
  border: 1px solid rgba(201,168,76,0.35) !important;
  border-radius: 4px !important;
  margin-left: 6px;
  font-weight: 700;
}

/* Cards einheitlich: gold-getönte Border, sanfter Shadow — bleiben WEISS/cremig wie immer */
#s0 .card,
#s1 .card,
#s2 .card,
#s3 .card,
#s3-tax .card,
#s4 .card,
#s5 .card,
#s6 .card {
  border-radius: 12px !important;
  border: 1px solid rgba(201,168,76,0.22) !important;
  box-shadow: 0 2px 12px rgba(42,39,39,0.06), 0 0 0 0 rgba(201,168,76,0) !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
#s0 .card:hover,
#s1 .card:hover,
#s2 .card:hover,
#s3 .card:hover,
#s3-tax .card:hover,
#s4 .card:hover,
#s5 .card:hover,
#s6 .card:hover {
  border-color: rgba(201,168,76,0.45) !important;
  box-shadow: 0 4px 18px rgba(42,39,39,0.10), 0 0 16px rgba(201,168,76,0.10) !important;
}

/* ═══════════════════════════════════════════════════════════════
   V97 — Mobile/Tablet-Defensive (prophylaktisch)
   Behebt potenzielle Probleme der V90-V96 Layout-Änderungen
   auf <900px (Tablet) und <640px (Telefon) Bildschirmen.
   ═══════════════════════════════════════════════════════════════ */

/* TABLET: 768-900px */
@media (max-width: 900px) {
  /* Sidebar mobil: schmaler — Foto + Score-Overlay würden quer schießen.
     Foto auf 100×70 verkleinern, Score-Donut etwas kleiner. */
  aside.sidebar .sb-card .sbc-thumb,
  aside.sidebar .sb-card .sbc-photo {
    width: 100px !important;
    height: 70px !important;
  }
  aside.sidebar .sb-card .sbc-score-overlay .sbc-mini-score {
    width: 40px !important;
    height: 40px !important;
  }
  aside.sidebar .sb-card .sbc-score-overlay .sbc-mini-score svg {
    width: 40px !important;
    height: 40px !important;
  }
  aside.sidebar .sb-card .sbc-score-overlay .sbc-mini-score-num {
    font-size: 12px !important;
  }
  aside.sidebar .sb-card .sbc-score-overlay .sbc-score-label {
    font-size: 9.5px !important;
    padding: 2px 8px !important;
  }
  /* Adresse mit weniger right-padding damit sie nicht zu sehr unterm Score verschwindet */
  aside.sidebar .sb-card .sbc-address {
    padding-right: 50px !important;
    font-size: 12px !important;
  }
  /* Mini-Cards (DSCR/CF/J/BMR) bei wenig Platz noch flacher */
  aside.sidebar .sb-card .sbcm,
  aside.sidebar .sb-card .sbc-mini {
    padding: 3px 5px !important;
  }
  aside.sidebar .sb-card .sbcm-v,
  aside.sidebar .sb-card .sbc-mini-v,
  aside.sidebar .sb-card .sbcm-val {
    font-size: 12px !important;
  }
  aside.sidebar .sb-card .sbcm-spark {
    height: 12px !important;
  }
}

/* TELEFON: <640px */
@media (max-width: 640px) {
  /* Portfolio-Übersicht aufgeklappt: bei sehr kleinem Bildschirm darf der Inhalt
     nicht die ganze Sidebar dominieren — max-height begrenzen + scroll. Aktionen-
     Trigger bleibt sichtbar. */
  aside.sidebar .sb-portfolio-collapsible:has(.sb-portfolio-content[style*="display: block"]),
  aside.sidebar .sb-portfolio-collapsible:has(.sb-portfolio-content[style*="display:block"]) {
    max-height: 50vh !important;
    overflow-y: auto !important;
  }
  aside.sidebar .sb-portfolio-content[style*="display: block"],
  aside.sidebar .sb-portfolio-content[style*="display:block"] {
    max-height: 42vh;
    overflow-y: auto;
  }
  /* Port-Rows kompakter */
  aside.sidebar .sb-portfolio-content .port-row {
    padding: 7px 10px !important;
    font-size: 11px !important;
  }
  aside.sidebar .sb-portfolio-content .port-v {
    font-size: 12px !important;
  }

  /* Tab-Hauptüberschrift mit Goldlinie: kompakter Padding-Left */
  #s0 > .sec-title,
  #s1 > .sec-title,
  #s2 > .sec-title,
  #s3 > .sec-title,
  #s3-tax > .sec-title,
  #s4 > .sec-title,
  #s5 > .sec-title,
  #s6 > .sec-title {
    padding-left: 10px !important;
    font-size: 18px !important;
  }
  /* Card-Titel auf Telefon kompakt halten */
  .ct-pro {
    font-size: 10.5px !important;
    letter-spacing: 1px !important;
    margin-bottom: 12px !important;
    gap: 8px !important;
  }
  .ct-pro .ct-ico {
    width: 20px !important;
    height: 20px !important;
  }
  /* Goldlinie hinter Card-Titel auf sehr schmalem Display weglassen — kein Platz */
  .ct-pro::after {
    display: none !important;
  }
  /* Cards: weniger Innen-Padding auf Telefon */
  #s0 .card,
  #s1 .card,
  #s2 .card,
  #s3 .card,
  #s3-tax .card,
  #s4 .card,
  #s5 .card,
  #s6 .card {
    padding: 14px !important;
  }
  /* Aktionen-Trigger und Portfolio-Header auf Telefon kompakter */
  aside.sidebar .sb-actions-trigger,
  aside.sidebar .sb-portfolio-collapsible .sb-collapsible-header {
    min-height: 36px !important;
    padding: 8px 12px !important;
    font-size: 11px !important;
    letter-spacing: 0.3px !important;
    margin: 4px 10px !important;
    width: calc(100% - 20px) !important;
  }
}

/* Settings-Modal auf Telefon: bestehender Cream-Classic-Mobile-Block + ergänzend */
@media (max-width: 640px) {
  /* Save-Row darf bei sehr schmalem Bildschirm umbrechen */
  .set-modal-cream .save-row {
    flex-wrap: wrap !important;
    padding: 12px 16px !important;
    gap: 10px !important;
  }
  .set-modal-cream .save-row .save-info {
    flex-basis: 100%;
    font-size: 10.5px !important;
  }
  .set-modal-cream .save-row .btns {
    flex-basis: 100%;
    justify-content: flex-end;
  }
  /* Pane-Padding kleiner */
  .set-modal-cream .pane-wrap {
    padding: 16px 18px !important;
    gap: 14px !important;
  }
  .set-modal-cream .pane-wrap .g2,
  .set-modal-cream .pane-wrap .g3 {
    grid-template-columns: 1fr !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   V99 — Mobile/Tablet-Fixes nach echten Geräte-Tests (Marcels Screenshots)
   ═══════════════════════════════════════════════════════════════ */

/* Fix 1: iOS Safe-Area — Browser-Toolbar überdeckte Header (Tablet-Bug) */
.app-wrap,
.sidebar,
header.hdr {
  padding-top: env(safe-area-inset-top, 0) !important;
}
@supports (padding-top: env(safe-area-inset-top)) {
  body {
    padding-top: 0;
  }
  .sidebar {
    padding-left: env(safe-area-inset-left, 0);
  }
  .body {
    padding-left: max(20px, env(safe-area-inset-left, 20px)) !important;
    padding-right: max(20px, env(safe-area-inset-right, 20px)) !important;
    padding-bottom: max(80px, env(safe-area-inset-bottom, 80px)) !important;
  }
}

/* Fix 2-6: Mobile <640px Optimierungen */
@media (max-width: 640px) {

  /* Inputs kompakter — 36px Höhe (war 38px), 12.5px Schrift */
  input[type=text], input[type=number], input[type=date], input[type=password], input[type=email],
  select, textarea {
    height: 36px !important;
    font-size: 12.5px !important;
    padding: 0 10px !important;
  }
  textarea {
    height: auto !important;
    min-height: 60px !important;
    padding: 8px 10px !important;
  }
  /* Labels kompakter */
  .f label, .field label {
    font-size: 10.5px !important;
    margin-bottom: 3px !important;
  }
  .f { gap: 3px !important; margin-bottom: 6px !important; }

  /* Card-Padding kleiner */
  .card {
    padding: 14px !important;
    border-radius: 10px !important;
  }
  /* Card-Titel ohne ct-pro auch kompakt */
  .ct, .card .ct:not(.ct-pro) {
    font-size: 13px !important;
    margin-bottom: 10px !important;
  }

  /* Header-Icon-Buttons (Hilfe, Verlauf, Teilen, Duplizieren) auf Handy verstecken —
     sind im Aktionen-Menü ebenfalls erreichbar */
  .hdr-actions-v61 .hdr-icon-btn {
    display: none !important;
  }
  /* KI-Credits-Pill bleibt sichtbar aber kompakter */
  .hdr-actions-v61 .hdr-credits-pill {
    padding: 6px 8px !important;
    font-size: 11px !important;
  }
  /* Investment-PDF-Btn: nur Icon, Text "Investment-PDF" raus */
  .hdr-actions-v61 .hdr-pdf-btn span {
    display: none !important;
  }
  .hdr-actions-v61 .hdr-pdf-btn,
  .hdr-actions-v61 .hdr-save-btn {
    padding: 6px 9px !important;
    min-width: 36px !important;
  }
  .hdr-actions-v61 .hdr-save-btn span {
    display: none !important;
  }
  .hdr-actions-v61 {
    gap: 6px !important;
  }

  /* Header-Row1 nicht zu sperrig */
  .hdr-v61-row1 {
    padding: 10px 12px !important;
    gap: 8px !important;
  }
  .hdr-obj-num {
    font-size: 11.5px !important;
    padding: 4px 8px !important;
  }
  .hdr-obj-name, .hdr-obj {
    font-size: 14px !important;
  }

  /* Fix 5: DealPilot-Score-Card aufgeklappt darf NICHT den ganzen Bildschirm fressen */
  .ds-score-hint,
  .dp-score-card,
  #dp-score-detail,
  .dp-score-detail-card,
  .ds-score-expanded {
    max-height: 60vh !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  /* KPI-Grid in der Score-Card auf 1 Spalte */
  .dp-score-card .kpi-grid,
  #dp-score-detail .kpi-grid,
  .ds-score-expanded .kpi-grid {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  /* Einzelne KPI-Karten (RENDITE, FINANZ, etc.) kompakter */
  .dp-score-card .kpi-card,
  #dp-score-detail .kpi-card {
    padding: 10px !important;
  }

  /* Fix 6: Body-Padding kleiner damit mehr nutzbarer Platz */
  .body {
    padding: 12px 12px 60px !important;
  }
  .sec-title {
    font-size: 17px !important;
    margin-bottom: 8px !important;
  }
  .sec-sub, .sec-title + p {
    font-size: 12px !important;
  }

  /* Tab-Bar (Objekt, Investition, Miete...): kleinere Touch-Targets aber nicht zu klein */
  .tabs button, .tab {
    padding: 8px 10px !important;
    font-size: 11px !important;
  }

  /* Workflow-Bar Top (24/24 Felder · 100%) ist schon kompakt — aber Score-Donut-Bar darüber */
  .hdr-completeness {
    font-size: 11px !important;
  }
}

/* Tablet 641-1024px: nicht so radikal wie Handy, nur leicht angepasst */
@media (min-width: 641px) and (max-width: 1024px) {
  /* Sicherheit: Header-Padding-Top respektiert Safe-Area auf iPad */
  header.hdr {
    padding-top: env(safe-area-inset-top, 0) !important;
  }
  /* Header-Buttons-Text auf Tablet zeigen wenn Platz da, sonst Icons */
  .hdr-actions-v61 .hdr-icon-btn:nth-child(n+3) {
    display: none !important;  /* Maximal 2 Icon-Buttons (Hilfe, Verlauf), Rest weg */
  }
}

/* ═══════════════════════════════════════════════════════════════
   V100 — Mobile-Fixes Runde 3 nach Marcels Detail-Tests
   ═══════════════════════════════════════════════════════════════ */

/* Fix 1: col2-stretch (Objektdaten + Qualität nebeneinander) MUSS auf Mobile auf 1 Spalte —
   sonst quetscht's die Felder und die rechten Cards ragen über den Rand */
@media (max-width: 900px) {
  .col2-stretch {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
}

/* Fix 2: Inputs sind weiterhin etwas eng — sicherstellen dass sie volle Card-Breite nutzen
   und der g2-Grid in der Card auf Mobile auch wirklich 1 Spalte ist */
@media (max-width: 640px) {
  .card .g2,
  .card .g3 {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  .card {
    padding: 12px !important;
    overflow: hidden;
  }
  /* Inputs nutzen volle Breite, kein min-width-Overflow */
  .card input, .card select, .card textarea {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
}

/* Fix 3: Investor-Score-Card auf Mobile drastisch kompakter machen
   Donut + 5 KPIs in horizontaler Scroll-Reihe (statt 6 vollbreite Karten untereinander) */
@media (max-width: 720px) {
  .hdr-v61-row2 {
    display: flex !important;
    flex-direction: row !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    scroll-snap-type: x mandatory;
    gap: 8px !important;
    padding: 10px 12px !important;
    grid-template-columns: none !important;
  }
  .hdr-v61-row2 > * {
    flex: 0 0 auto !important;
    scroll-snap-align: start;
  }
  /* Score-Donut-Karte: kompakt, Höhe begrenzt */
  .hdr-v61-row2 .hdr-score-card {
    min-width: 180px;
    padding: 4px 8px !important;
  }
  /* KPI-Badges: schmaler, lesbar bleibend */
  .hdr-v61-row2 .hdr-badge,
  .hdr-v61-row2 .hdr-badges-v39 .hdr-badge {
    min-width: 110px !important;
    padding: 6px 10px !important;
    font-size: 11px !important;
  }
  /* Scrollbar dezent */
  .hdr-v61-row2::-webkit-scrollbar {
    height: 4px;
  }
  .hdr-v61-row2::-webkit-scrollbar-thumb {
    background: rgba(201,168,76,0.4);
    border-radius: 2px;
  }
}

/* Fix 4: Sterne-Bewertung in Qualität-Card kompakt auf Mobile */
@media (max-width: 640px) {
  .qz-card .qz-rows {
    gap: 8px !important;
  }
  .qz-card .qz-row {
    flex-wrap: wrap;
    gap: 6px !important;
  }
  .qz-card .qz-row-name {
    flex: 0 0 auto;
    font-size: 12px !important;
  }
  .qz-card .qz-stars {
    font-size: 14px !important;
  }
  .qz-card .qz-label {
    font-size: 10.5px !important;
    flex-basis: 100%;
  }
  .qz-card .qz-divider {
    margin: 8px 0 !important;
  }
  .qz-card .qz-footer {
    font-size: 11.5px !important;
    flex-wrap: wrap;
    gap: 6px !important;
  }
}

/* Fix 5: Body-Container Overflow verhindern (kein Horizontal-Scroll auf Handy) */
@media (max-width: 900px) {
  html, body {
    overflow-x: hidden !important;
  }
  .body, .main-col, main {
    max-width: 100vw !important;
    overflow-x: hidden !important;
    box-sizing: border-box !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   V101 — Aktiv-Card-Highlight, Lösch-Button erreichbar, Tablet-Header-Fix
   ═══════════════════════════════════════════════════════════════ */

/* Auf Mobile: Aktionen-Buttons immer sichtbar (Hover gibt's nicht auf Touch),
   etwas größere Touch-Targets */
@media (max-width: 900px) {
  aside.sidebar .sb-card .sbc-actions {
    opacity: 1 !important;
  }
  aside.sidebar .sb-card .sbc-btn {
    width: 26px !important;
    height: 26px !important;
    font-size: 14px !important;
    background: rgba(0,0,0,0.75) !important;
  }
  /* AKTIV-Badge kleiner auf Mobile */
  aside.sidebar .sb-card.active::before {
    font-size: 7.5px;
    padding: 2px 6px;
  }
}

/* Tablet (iPad) — Browser-Toolbar-Fix endgültig:
   Das Problem in V99 war: env(safe-area-inset-top) liefert auf iPad-Browsern
   oft 0 weil Safari die Toolbar als "auto-hide" behandelt.
   Lösung: app-wrap selbst bekommt einen min-padding-top via CSS-Calc und
   die Header-Sticky-Position zieht sich nach unten. */
@media (min-width: 641px) and (max-width: 1366px) {
  /* iPad-Größen: Browser-Toolbar ist ca. 50-60px — wir geben dem App-Wrap den Platz */
  .app-wrap {
    /* Kein extra padding-top — sticky Header übernimmt das, wir scrollen drumrum */
  }
  /* Header bleibt oben sticky — aber mit zusätzlichem Top-Padding um Browser-Bar nicht zu überschneiden */
  header.hdr {
    padding-top: max(env(safe-area-inset-top, 0), 8px) !important;
  }
  /* Tab-Bar auch nach unten verschieben damit sie nicht direkt am Browser klebt */
  nav.tabs {
    top: calc(env(safe-area-inset-top, 0) + 0px) !important;
  }
}

/* iPhone/Mobile in Querformat: Browser-Toolbar kann unten sein — extra Bottom-Safe-Area */
@media (max-width: 900px) and (orientation: landscape) {
  .body {
    padding-bottom: max(80px, env(safe-area-inset-bottom, 80px) + 20px) !important;
  }
}

/* V101: Tablet/iPad Browser-Toolbar Fix — endgültiger Versuch
   Auf iPad nutzt Safari "minimal-ui" was bei viewport-fit=cover die Toolbar
   in den Inhaltsbereich zieht. Wir setzen explizit ein top-Padding auf den
   gesamten Body-Container (nicht body selbst, das würde Sidebar verschieben),
   damit der Header garantiert NICHT verdeckt wird. */
@media (min-width: 768px) and (max-width: 1366px) {
  /* iPad: Header bekommt absoluten min-height + extra Top-Margin */
  header.hdr.has-v64-score,
  header.hdr {
    padding-top: max(8px, env(safe-area-inset-top, 8px)) !important;
    /* Sicher dass Header oben bleibt und nichts ihn überschreibt */
    position: relative;
    z-index: 100;
  }
  /* App-Wrap selbst bekommt margin-top damit der Header nicht von Browser-Bar überdeckt wird */
  body {
    padding-top: env(safe-area-inset-top, 0) !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   V102 — iPad/iOS Toolbar-Fix mit visualViewport-API
   Die JS-Logik in index.html setzt --dp-toolbar-top auf die aktuelle
   Toolbar-Höhe. Hier nutzen wir's für Header und Sidebar damit nichts
   mehr von der Browser-URL-Bar überdeckt wird.
   ═══════════════════════════════════════════════════════════════ */

:root {
  --dp-toolbar-top: 0px;
}

/* Header: padding-top entspricht der erkannten Toolbar-Höhe */
header.hdr {
  padding-top: var(--dp-toolbar-top, 0) !important;
  height: auto !important;
  min-height: 64px;
  box-sizing: content-box;
}

/* Sidebar: top-padding um Logo nicht von Toolbar überdecken zu lassen */
aside.sidebar {
  padding-top: var(--dp-toolbar-top, 0) !important;
  box-sizing: border-box;
}

/* Tab-Bar (sticky unter dem Header) — bekommt das Toolbar-Padding NICHT extra,
   weil sie unter dem Header sitzt der das schon hat */
nav.tabs {
  top: var(--dp-toolbar-top, 0) !important;
}

/* Body-Container: kein extra padding-top mehr (war's für Browser-Toolbar gedacht,
   verursacht jetzt aber Doppel-Verschiebung weil Header das schon übernimmt) */
@media (min-width: 768px) and (max-width: 1366px) {
  body {
    padding-top: 0 !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   V104 — Deal-Status "Zuschlag bekommen"
   Stern-Toggle im Tab Deal-Aktion + Won-Badge in Sidebar-Cards
   + Filter-Logik in Track-Record und Bankexport
   ═══════════════════════════════════════════════════════════════ */

/* Won-Card im Tab Deal-Aktion */
.da-won-card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 22px;
  margin-bottom: 18px;
  background: linear-gradient(135deg, var(--surface, #F8F6F1) 0%, #fff 100%);
  border: 2px solid rgba(201,168,76,0.30);
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(42,39,39,0.06);
  transition: all 0.3s ease;
}
.da-won-card.da-won-active {
  background: linear-gradient(135deg, #f0fbf4 0%, #e6f7ec 100%);
  border-color: #4CAF50;
  box-shadow: 0 4px 22px rgba(76,175,80,0.20),
              0 0 0 3px rgba(76,175,80,0.10);
}
.da-won-card .da-won-star {
  flex: 0 0 auto;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(201,168,76,0.10);
  border: 2px solid rgba(201,168,76,0.40);
  color: var(--gold, #C9A84C);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.25s ease;
  padding: 0;
}
.da-won-card .da-won-star:hover {
  transform: scale(1.06) rotate(-5deg);
  background: rgba(201,168,76,0.18);
  border-color: var(--gold, #C9A84C);
  box-shadow: 0 4px 14px rgba(201,168,76,0.35);
}
.da-won-card.da-won-active .da-won-star {
  background: linear-gradient(135deg, #4CAF50, #2e7d32);
  border-color: #4CAF50;
  color: #fff;
  box-shadow: 0 6px 18px rgba(76,175,80,0.40), 0 0 22px rgba(76,175,80,0.30);
}
.da-won-card.da-won-active .da-won-star:hover {
  transform: scale(1.06);
  box-shadow: 0 8px 24px rgba(76,175,80,0.50), 0 0 28px rgba(76,175,80,0.40);
}
.da-won-card .da-won-text {
  flex: 1;
  min-width: 0;
}
.da-won-card .da-won-label {
  font-size: 17px;
  font-weight: 700;
  color: var(--ch, #2A2727);
  letter-spacing: -0.2px;
  margin-bottom: 4px;
}
.da-won-card.da-won-active .da-won-label {
  color: #2e7d32;
}
.da-won-card .da-won-sub {
  font-size: 13px;
  color: var(--muted, #7A7370);
  line-height: 1.45;
}

/* V106: Won-Ribbon links oben (wo vorher das AKTIV-Badge saß).
   Übernimmt die Position 1:1 — eckiger Schnitt unten rechts/oben links als Indikator. */
aside.sidebar .sb-card .sbc-won-ribbon {
  position: absolute;
  top: -1px;
  left: -1px;
  right: auto;
  background: linear-gradient(135deg, #4CAF50, #2e7d32);
  color: #fff;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1px;
  padding: 3px 8px 3px 6px;
  border-radius: 9px 0 9px 0;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  box-shadow: 0 2px 8px rgba(76,175,80,0.50);
  z-index: 5;
  pointer-events: none;
}
aside.sidebar .sb-card .sbc-won-ribbon svg {
  flex-shrink: 0;
}

/* V106: Investor-Ribbon bleibt mittig oben — kollidiert nicht mit Won (links) */
aside.sidebar .sb-card.has-investor-ribbon .sbc-won-ribbon {
  top: -1px;
  left: -1px;
  right: auto;
}
aside.sidebar .sb-card.deal-won.has-investor-ribbon .sbc-investor-ribbon {
  /* Investor mittig lassen (default), kein Versatz mehr nötig */
  left: 50%;
  transform: translateX(-50%);
}

/* Card-Border-Akzent wenn Won (sichtbarer Hinweis ohne Glow-Animation wie Active) */
aside.sidebar .sb-card.deal-won {
  border-color: rgba(76,175,80,0.40) !important;
}
aside.sidebar .sb-card.deal-won:not(.active) {
  box-shadow: 0 6px 20px rgba(0,0,0,0.45),
              0 0 14px rgba(76,175,80,0.18) !important;
}

/* Mobile: Won-Card kompakter */
@media (max-width: 640px) {
  .da-won-card {
    padding: 14px 16px;
    gap: 12px;
  }
  .da-won-card .da-won-star {
    width: 44px;
    height: 44px;
  }
  .da-won-card .da-won-star svg {
    width: 24px;
    height: 24px;
  }
  .da-won-card .da-won-label {
    font-size: 15px;
  }
  .da-won-card .da-won-sub {
    font-size: 11.5px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   V106 — Mobile-Score-Card kompakter (Marcels Hinweis)
   Die richtigen Selektoren sind .sc-main und .sc-pill (nicht .hdr-badge).
   Auf Mobile war der Score-Block extrem hoch — fast ganzer Bildschirm.
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 720px) {
  /* Hauptscore-Karte (Donut + Headline + Empfehlung) deutlich kompakter */
  #hdr-badges .sc-main {
    padding: 1.5px !important;
  }
  #hdr-badges .sc-main .si {
    padding: 8px 10px !important;
    gap: 10px !important;
  }
  #hdr-badges .sc-donut {
    width: 56px !important;
    height: 56px !important;
    font-size: 22px !important;
  }
  #hdr-badges .sc-donut span {
    font-size: 22px !important;
  }
  #hdr-badges .sc-grade {
    font-size: 9px !important;
    padding: 2px 8px !important;
  }
  #hdr-badges .sc-info {
    gap: 2px !important;
  }
  #hdr-badges .sc-l {
    font-size: 9.5px !important;
    letter-spacing: 0.6px !important;
  }
  #hdr-badges .sc-v {
    font-size: 16px !important;
    line-height: 1.2 !important;
  }
  #hdr-badges .sc-sub {
    font-size: 11px !important;
  }
  #hdr-badges .sc-tip {
    font-size: 11px !important;
    margin-top: 2px !important;
  }

  /* KPI-Pills (RENDITE/FINANZ/RISIKO/LAGE/UPSIDE) viel kompakter */
  #hdr-badges .sc-pill {
    padding: 8px 10px !important;
    min-height: auto !important;
  }
  #hdr-badges .sc-pill-l {
    font-size: 9.5px !important;
    letter-spacing: 0.5px !important;
  }
  #hdr-badges .sc-pill-l .ic {
    width: 11px !important;
    height: 11px !important;
  }
  #hdr-badges .sc-pill-v {
    font-size: 18px !important;
    margin: 2px 0 !important;
  }
  #hdr-badges .sc-pill-sub {
    font-size: 10px !important;
    margin-top: 1px !important;
  }
  #hdr-badges .sc-bar {
    height: 3px !important;
    margin-top: 4px !important;
  }
  /* hdr-v61-row2-Container kompakter */
  .hdr-v61-row2 {
    padding: 8px 12px !important;
  }
}

/* Sehr schmale Bildschirme <520px — Pills 2-spaltig statt 1.6fr-Grid weil sonst Sub-Text bricht */
@media (max-width: 520px) {
  #hdr-badges .scores {
    gap: 6px !important;
  }
  #hdr-badges .sc-pill {
    padding: 6px 8px !important;
  }
  #hdr-badges .sc-pill-v {
    font-size: 16px !important;
  }
  #hdr-badges .sc-donut {
    width: 50px !important;
    height: 50px !important;
  }
  #hdr-badges .sc-donut span {
    font-size: 19px !important;
  }
  #hdr-badges .sc-v {
    font-size: 14px !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   V107 — Score-Card Tier-Color-Schimmer + dickerer Won-Border
   ═══════════════════════════════════════════════════════════════ */

/* Hauptscore-Card (sc-main) bekommt einen dezenten, sanft pulsierenden
   Hintergrund-Schimmer in der Tier-Farbe. Border-Akzent passt sich an. */
#hdr-badges .sc-main.sc-tier-green {
  background:
    radial-gradient(ellipse at top left, rgba(94,217,146,0.16), transparent 60%),
    radial-gradient(ellipse at bottom right, rgba(63,165,108,0.10), transparent 65%),
    linear-gradient(135deg, rgba(15,32,22,0.95) 0%, rgba(8,18,12,0.92) 100%) !important;
  border: 1px solid rgba(94,217,146,0.30);
  animation: dpV107ScoreShimmerGreen 4s ease-in-out infinite;
}
@keyframes dpV107ScoreShimmerGreen {
  0%, 100% { box-shadow: 0 4px 18px rgba(0,0,0,0.45), 0 0 22px rgba(94,217,146,0.18), inset 0 1px 0 rgba(94,217,146,0.10); }
  50%      { box-shadow: 0 4px 20px rgba(0,0,0,0.50), 0 0 36px rgba(94,217,146,0.34), inset 0 1px 0 rgba(94,217,146,0.18); }
}

#hdr-badges .sc-main.sc-tier-gold {
  background:
    radial-gradient(ellipse at top left, rgba(232,201,100,0.16), transparent 60%),
    radial-gradient(ellipse at bottom right, rgba(201,168,76,0.10), transparent 65%),
    linear-gradient(135deg, rgba(30,24,12,0.95) 0%, rgba(18,14,8,0.92) 100%) !important;
  border: 1px solid rgba(201,168,76,0.32);
  animation: dpV107ScoreShimmerGold 4s ease-in-out infinite;
}
@keyframes dpV107ScoreShimmerGold {
  0%, 100% { box-shadow: 0 4px 18px rgba(0,0,0,0.45), 0 0 22px rgba(201,168,76,0.20), inset 0 1px 0 rgba(232,201,100,0.10); }
  50%      { box-shadow: 0 4px 20px rgba(0,0,0,0.50), 0 0 36px rgba(232,201,100,0.36), inset 0 1px 0 rgba(232,201,100,0.18); }
}

#hdr-badges .sc-main.sc-tier-red {
  background:
    radial-gradient(ellipse at top left, rgba(184,98,92,0.18), transparent 60%),
    radial-gradient(ellipse at bottom right, rgba(184,98,92,0.10), transparent 65%),
    linear-gradient(135deg, rgba(30,12,12,0.95) 0%, rgba(18,8,8,0.92) 100%) !important;
  border: 1px solid rgba(184,98,92,0.40);
  animation: dpV107ScoreShimmerRed 4s ease-in-out infinite;
}
@keyframes dpV107ScoreShimmerRed {
  0%, 100% { box-shadow: 0 4px 18px rgba(0,0,0,0.45), 0 0 22px rgba(184,98,92,0.22), inset 0 1px 0 rgba(184,98,92,0.10); }
  50%      { box-shadow: 0 4px 20px rgba(0,0,0,0.50), 0 0 38px rgba(184,98,92,0.38), inset 0 1px 0 rgba(184,98,92,0.20); }
}

/* Won-Karten in der Sidebar: dickerer grüner Border (Marcels Wunsch) */
aside.sidebar .sb-card.deal-won {
  border-color: rgba(76,175,80,0.65) !important;
  border-width: 2.5px !important;
}
aside.sidebar .sb-card.deal-won:not(.active) {
  box-shadow:
    0 6px 22px rgba(0,0,0,0.45),
    0 0 22px rgba(76,175,80,0.30),
    inset 0 0 0 1px rgba(76,175,80,0.20) !important;
}
/* Wenn aktiv UND won: Goldschimmer (active) UND dicker grüner Border bleiben — kombiniert */
aside.sidebar .sb-card.deal-won.active {
  border-color: rgba(76,175,80,0.65) !important;
  border-width: 2.5px !important;
}

/* ═══════════════════════════════════════════════════════════════
   V107 — Preset-Cards in DS2-Settings
   ═══════════════════════════════════════════════════════════════ */
.ds2-preset-section {
  margin-bottom: 20px;
}
.ds2-preset-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}
.ds2-preset-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 16px;
  background: linear-gradient(135deg, var(--surface, #F8F6F1), #fff);
  border: 1.5px solid rgba(201,168,76,0.20);
  border-radius: 12px;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  transition: all 0.2s ease;
  position: relative;
}
.ds2-preset-card:hover {
  border-color: rgba(201,168,76,0.55);
  box-shadow: 0 4px 14px rgba(201,168,76,0.18);
  transform: translateY(-1px);
}
.ds2-preset-card.ds2-preset-active {
  border-color: var(--gold, #C9A84C);
  border-width: 2px;
  background: linear-gradient(135deg, rgba(232,201,100,0.10), #fff);
  box-shadow: 0 4px 18px rgba(201,168,76,0.30), 0 0 0 3px rgba(201,168,76,0.10);
}
.ds2-preset-card.ds2-preset-active::after {
  content: "✓ AKTIV";
  position: absolute;
  top: -10px;
  right: 12px;
  background: linear-gradient(135deg, var(--gold-2, #E8C964), var(--gold-3, #9a7f33));
  color: var(--ch, #2A2727);
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.6px;
  padding: 3px 8px;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(201,168,76,0.4);
}
.ds2-preset-icon {
  font-size: 22px;
  line-height: 1;
}
.ds2-preset-label {
  font-size: 14px;
  font-weight: 700;
  color: var(--ch, #2A2727);
  letter-spacing: -0.2px;
}
.ds2-preset-desc {
  font-size: 12px;
  color: var(--muted, #7A7370);
  line-height: 1.45;
}

/* Mobile: Preset-Cards untereinander */
@media (max-width: 640px) {
  .ds2-preset-grid {
    grid-template-columns: 1fr !important;
  }
  .ds2-preset-card {
    padding: 12px 14px;
  }
  .ds2-preset-label {
    font-size: 13px;
  }
  .ds2-preset-desc {
    font-size: 11px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   V108 — Settings-Modal X-Schließen-Button
   ═══════════════════════════════════════════════════════════════ */
.set-modal-cream .set-modal-close {
  position: absolute;
  top: 12px;
  right: 14px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(42,39,39,0.06);
  border: 1px solid rgba(42,39,39,0.10);
  color: var(--ch, #2A2727);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: all 0.18s ease;
  padding: 0;
}
.set-modal-cream .set-modal-close:hover {
  background: rgba(201,168,76,0.12);
  border-color: rgba(201,168,76,0.40);
  color: var(--gold, #C9A84C);
  transform: rotate(90deg);
}
.set-modal-cream .set-modal-close svg {
  display: block;
}
/* Position des Content-Containers braucht position:relative für absoluten X */
.set-modal-cream .set-modal-content {
  position: relative;
}

/* Mobile: kleiner und etwas reingerückt */
@media (max-width: 640px) {
  .set-modal-cream .set-modal-close {
    width: 32px;
    height: 32px;
    top: 10px;
    right: 10px;
  }
  .set-modal-cream .set-modal-close svg {
    width: 16px;
    height: 16px;
  }
}
