/* PropAnalytics Pro — 3-Panel Premium Layout */
#pa-root { font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif; -webkit-font-smoothing: antialiased; }
.pa-app {
  --blue:#2563eb;--bdk:#1d4ed8;--bpale:#eff6ff;
  --grn:#059669;--red:#dc2626;--gold:#d97706;
  --ink:#0f172a;--ink2:#334155;
  --g50:#f8fafc;--g100:#f1f5f9;--g200:#e2e8f0;--g400:#94a3b8;--g500:#64748b;
  --sb:260px;--rp:268px;
  font-size:14px;line-height:1.65;color:var(--ink);background:var(--g50);min-height:100vh;
}
.pa-app * { box-sizing:border-box;margin:0;padding:0; }

/* APP BAR */
.pa-appbar{background:#fff;border-bottom:1px solid var(--g200);display:flex;align-items:center;gap:24px;padding:0 28px;height:64px;position:sticky;top:0;z-index:200}
.pa-appbar-logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.pa-appbar-mark{width:38px;height:38px;border-radius:10px;background:var(--blue);color:#fff;font-weight:900;font-size:17px;display:flex;align-items:center;justify-content:center}
.pa-appbar-name{font-size:15px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.pa-appbar-name strong{color:var(--blue);font-weight:900}
.pa-appbar-sub{font-size:9px;font-weight:800;color:var(--g400);text-transform:uppercase;letter-spacing:.14em;margin-top:1px}
.pa-appbar-steps{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}
.pa-appbar-step{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;color:var(--g400);padding:8px 14px;border-radius:8px;transition:all .15s;white-space:nowrap}
.pa-appbar-step:hover{color:var(--ink);background:var(--g50)}
.pa-appbar-step.active{color:var(--blue);font-weight:800;background:var(--bpale)}
.pa-appbar-step.done{color:var(--g500)}
.pa-appbar-step-num{width:22px;height:22px;border-radius:50%;flex-shrink:0;background:var(--g200);color:var(--g500);font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center}
.pa-appbar-step.active .pa-appbar-step-num{background:var(--blue);color:#fff}
.pa-appbar-step.done .pa-appbar-step-num{background:var(--grn);color:#fff}
.pa-appbar-dot{color:var(--g200);font-size:18px;margin:0 2px}
.pa-appbar-page-title{font-size:16px;font-weight:800;color:var(--ink)}
.pa-appbar-saved{font-size:11px;font-weight:700;color:var(--grn)}
.pa-appbar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.pa-appbar-btn{font-family:inherit;font-size:13px;font-weight:700;border-radius:8px;cursor:pointer;padding:8px 16px;display:inline-flex;align-items:center;gap:6px;transition:all .15s}
.pa-appbar-btn.outline{background:#fff;border:1.5px solid var(--g200);color:var(--ink2)}
.pa-appbar-btn.outline:hover{border-color:var(--blue);color:var(--blue)}
.pa-appbar-btn.solid{background:var(--blue);border:none;color:#fff;box-shadow:0 2px 8px rgba(37,99,235,.25)}
.pa-appbar-btn.solid:hover{background:var(--bdk)}
.pa-appbar-btn.icon{background:none;border:1.5px solid var(--g200);color:var(--g400);padding:8px 10px}
.pa-appbar-btn.icon:hover{border-color:var(--g400);color:var(--ink)}

/* LAYOUT */
.pa-layout{display:flex;max-width:1480px;margin:0 auto;min-height:calc(100vh - 64px)}

/* LEFT STEP SIDEBAR */
.pa-step-sidebar{width:var(--sb);flex-shrink:0;background:#fff;border-right:1px solid var(--g200);padding:24px 0;display:flex;flex-direction:column}
.pa-step-sb-section{padding:0 16px 24px}
.pa-step-sb-label{font-size:10px;font-weight:800;color:var(--g400);text-transform:uppercase;letter-spacing:.12em;margin-bottom:10px;padding:0 4px}
.pa-step-sb-nav{display:flex;flex-direction:column;gap:3px}
.pa-step-sb-item{display:flex;align-items:flex-start;gap:12px;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;padding:10px 12px;border-radius:10px;transition:all .15s;width:100%}
.pa-step-sb-item:hover{background:var(--g50)}
.pa-step-sb-item.active{background:var(--bpale)}
.pa-step-sb-num{width:24px;height:24px;border-radius:50%;flex-shrink:0;background:var(--g200);color:var(--g500);font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;margin-top:1px}
.pa-step-sb-item.active .pa-step-sb-num{background:var(--blue);color:#fff}
.pa-step-sb-item.done .pa-step-sb-num{background:var(--grn);color:#fff}
.pa-step-sb-name{font-size:13px;font-weight:700;color:var(--ink2);margin-bottom:2px}
.pa-step-sb-item.active .pa-step-sb-name{color:var(--blue);font-weight:800}
.pa-step-sb-sub{font-size:11px;color:var(--g400)}
.pa-step-sb-empty{font-size:12px;color:var(--g400);padding:6px 4px;font-style:italic}
.pa-step-sb-source{font-size:11px;color:var(--g500);padding:4px}
.pa-step-sb-draft{display:flex;align-items:center;justify-content:space-between;padding:8px 4px}
.pa-step-sb-draft-time{font-size:11px;color:var(--grn);font-weight:700}
.pa-step-sb-draft-del{background:none;border:none;cursor:pointer;font-size:11px;color:var(--g400);font-family:inherit}
.pa-step-sb-draft-del:hover{color:var(--red)}

/* MAIN & RIGHT */
.pa-main-content{flex:1;min-width:0;padding:36px 40px}
.pa-live{width:var(--rp);flex-shrink:0;background:#fff;border-left:1px solid var(--g200);display:flex;flex-direction:column}
.pa-dash,.pa-account,.pa-results{flex:1}

/* BANNERS */
.pa-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 28px;font-size:13px;font-weight:600;flex-wrap:wrap}
.pa-banner-red{background:#fef2f2;color:#991b1b;border-bottom:1px solid #fecaca}
.pa-banner-amber{background:#fffbeb;color:#78350f;border-bottom:1px solid #fde68a}
.pa-banner-blue{background:#eff6ff;color:#1d4ed8;border-bottom:1px solid #bfdbfe}

/* ── TYPOGRAPHY ──────────────────────── */
.pa-h1{font-size:38px;font-weight:900;color:var(--ink);letter-spacing:-.06em;line-height:1.08;margin-bottom:8px}
.pa-sub{font-size:15px;color:var(--g500);line-height:1.65}
.pa-step-hd{margin-bottom:28px}
.pa-step-tag{font-size:11px;font-weight:800;color:var(--blue);letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px}

/* ── STEPS BAR ───────────────────────── */
.pa-steps{display:flex;align-items:center;margin-bottom:32px;gap:0}
.pa-step{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--g400);cursor:pointer}
.pa-step.active{color:var(--blue)}.pa-step.done{color:var(--grn)}
.pa-step-dot{width:26px;height:26px;border-radius:50%;background:var(--g100);border:2px solid var(--g200);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:var(--g400);flex-shrink:0}
.pa-step.active .pa-step-dot{background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:0 0 0 4px rgba(37,99,235,.15)}
.pa-step.done .pa-step-dot{background:var(--grn);border-color:var(--grn);color:#fff}
.pa-step-line{flex:1;height:2px;background:var(--g200);margin:0 10px;max-width:52px}
.pa-mode-back-btn{background:none;border:1px solid var(--g200);border-radius:6px;padding:4px 10px;font-size:11px;font-weight:700;color:var(--g500);cursor:pointer;margin-right:10px;font-family:inherit;transition:all .15s}
.pa-mode-back-btn:hover{border-color:var(--blue);color:var(--blue)}

/* ── CARDS (frameless) ───────────────── */
.pa-card{background:#fff;border-radius:16px;box-shadow:0 1px 3px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.05);overflow:hidden}
.pa-card-hd{padding:16px 22px;border-bottom:1px solid rgba(0,0,0,.05);font-size:11px;font-weight:800;color:var(--g400);text-transform:uppercase;letter-spacing:.1em}
.pa-card-body{padding:22px}
.pa-rs{background:#fff;border-radius:14px;box-shadow:0 1px 3px rgba(0,0,0,.06),0 4px 14px rgba(0,0,0,.05);overflow:hidden}
.pa-rs-hd{padding:14px 22px;border-bottom:1px solid rgba(0,0,0,.05);font-size:10px;font-weight:800;color:var(--ink);letter-spacing:.1em;text-transform:uppercase}
.pa-rgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}

/* ── KPI CARDS ───────────────────────── */
.pa-kgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.pa-kpi{background:#fff;border-radius:16px;padding:22px 20px;border-top:3px solid;box-shadow:0 1px 3px rgba(0,0,0,.05),0 4px 12px rgba(0,0,0,.05);transition:transform .15s,box-shadow .15s;animation:pa-fade-up .5s ease both}
.pa-kpi:hover{transform:translateY(-3px);box-shadow:0 6px 24px rgba(0,0,0,.1)}
.pa-kpi:nth-child(1){animation-delay:.05s}.pa-kpi:nth-child(2){animation-delay:.1s}.pa-kpi:nth-child(3){animation-delay:.15s}.pa-kpi:nth-child(4){animation-delay:.2s}.pa-kpi:nth-child(5){animation-delay:.25s}.pa-kpi:nth-child(6){animation-delay:.3s}.pa-kpi:nth-child(7){animation-delay:.35s}.pa-kpi:nth-child(8){animation-delay:.4s}
.pa-kpi.kg{border-top-color:var(--grn)}.pa-kpi.kr{border-top-color:var(--red)}.pa-kpi.ka{border-top-color:var(--gold)}.pa-kpi.kn{border-top-color:var(--ink)}.pa-kpi.kb{border-top-color:var(--blue)}
.pa-kpi.kg .pa-kv{color:var(--grn)}.pa-kpi.kr .pa-kv{color:var(--red)}.pa-kpi.ka .pa-kv{color:var(--gold)}.pa-kpi.kn .pa-kv{color:var(--ink)}.pa-kpi.kb .pa-kv{color:var(--blue)}
.pa-kl{font-size:10px;font-weight:800;color:var(--g400);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px}
.pa-kv{font-size:24px;font-weight:900;letter-spacing:-.05em}

/* ── TABLES ──────────────────────────── */
.pa-t{width:100%;border-collapse:collapse;font-size:12px}
.pa-t td{padding:8px 18px;border-bottom:1px solid var(--g100);color:var(--g500);font-weight:500}
.pa-t td.mid{color:var(--g400);font-size:11px;font-family:'DM Mono',monospace;text-align:right}
.pa-t td.r{text-align:right;font-family:'DM Mono',monospace;font-weight:700;color:var(--ink)}
.pa-t tr:last-child td{border-bottom:none}
.pa-cta{background:var(--blue);border-radius:14px;padding:22px 28px;display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:18px}
.pa-cta-t{font-size:16px;font-weight:900;color:#fff}
.pa-cta-s{font-size:12px;color:rgba(255,255,255,.55)}

/* ── FORM INPUTS ─────────────────────── */
.pa-g1{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:14px}
.pa-g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pa-f{display:flex;flex-direction:column;gap:5px}
.pa-lbl{font-size:11px;font-weight:800;color:#475569;letter-spacing:.04em;text-transform:uppercase}
.pa-inp{background:#fff;border:1.5px solid var(--g200);border-radius:10px;color:var(--ink);font-family:inherit;font-size:14px;font-weight:500;padding:11px 14px;outline:none;width:100%;transition:border-color .15s;-webkit-appearance:none}
.pa-inp:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.pa-sfx{position:relative}.pa-sfx .pa-inp{padding-right:48px}
.pa-sfx span{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--g400);font-family:'DM Mono',monospace;font-weight:600;pointer-events:none;white-space:nowrap}

/* ── OPTION CARDS ────────────────────── */
.pa-og{display:grid;gap:8px}.pa-og4{grid-template-columns:repeat(4,1fr)}.pa-og3{grid-template-columns:repeat(3,1fr)}.pa-og2{grid-template-columns:repeat(2,1fr)}
.pa-oc{cursor:pointer;position:relative}.pa-oc input{position:absolute;opacity:0;pointer-events:none}
.pa-ob{border:1.5px solid var(--g200);border-radius:12px;padding:13px 10px;text-align:center;background:var(--g50);transition:all .15s}
.pa-oc:hover .pa-ob,.pa-oc.active .pa-ob{border-color:var(--blue);background:#eff6ff}
.pa-ob-i{font-size:20px;margin-bottom:4px}.pa-ob-l{font-size:12px;font-weight:800;color:#475569}.pa-ob-s{font-size:10px;color:var(--g400);margin-top:2px}

/* ── EURIBOR WIDGET ──────────────────── */
.pa-eur{background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border:1.5px solid #86efac;border-radius:14px;padding:18px 22px;margin-bottom:18px}
.pa-eur-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.pa-eur-title{font-size:13px;font-weight:900;color:#166534;display:flex;align-items:center;gap:8px}
.pa-eur-badge{font-size:9px;font-weight:900;padding:2px 9px;background:#dcfce7;border:1px solid #86efac;border-radius:100px;color:var(--grn);text-transform:uppercase}
.pa-eur-refresh{background:transparent;border:1.5px solid #86efac;border-radius:6px;color:var(--grn);font-size:11px;font-family:inherit;font-weight:700;padding:5px 10px;cursor:pointer}
.pa-eur-sec{font-size:10px;font-weight:800;color:var(--g400);text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px}
.pa-eur-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.pa-eur-item{background:#fff;border:1.5px solid var(--g200);border-radius:10px;padding:9px 10px;cursor:pointer;transition:all .15s;text-align:center}
.pa-eur-item:hover,.pa-eur-item.selected{border-color:var(--blue);background:#eff6ff}
.pa-eur-item.em{border-color:#fed7aa;background:#fffbeb}.pa-eur-item.em:hover{border-color:var(--gold)}
.pa-ei-lbl{font-size:9px;font-weight:700;color:var(--g400);text-transform:uppercase;margin-bottom:3px}
.pa-ei-rate{font-size:15px;font-weight:900;color:var(--grn);font-family:'DM Mono',monospace}
.pa-eur-item.em .pa-ei-rate{color:var(--gold)}
.pa-ei-use{font-size:8px;font-weight:800;color:var(--blue);margin-top:2px;opacity:0}
.pa-eur-item:hover .pa-ei-use{opacity:1}
.pa-eur-note{font-size:10px;color:var(--g500);line-height:1.55;margin-top:10px;padding:8px 10px;background:rgba(0,0,0,.02);border-radius:6px}

/* ── AfA WIDGET ──────────────────────── */
.pa-afa{background:linear-gradient(135deg,#eff6ff,#f5f8ff);border:1.5px solid #bfdbfe;border-radius:14px;padding:20px 24px;margin-bottom:18px}
.pa-afa-hd{font-size:14px;font-weight:900;color:var(--blue);margin-bottom:4px;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.pa-afa-sub{font-size:10px;font-weight:700;color:var(--g400);text-transform:uppercase;letter-spacing:.08em}
.pa-afa-section{margin-top:16px;padding-top:16px;border-top:1.5px solid #bfdbfe}
.pa-afa-section:first-of-type{border-top:none;margin-top:8px;padding-top:0}
.pa-afa-row-label{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:#475569;font-weight:600;margin-bottom:8px}
.pa-afa-pct-val{font-size:16px;font-weight:900;color:var(--blue)}
.pa-afa-slider-wrap{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.pa-afa-slider-lb,.pa-afa-slider-rb{font-size:10px;font-weight:700;color:var(--g400);white-space:nowrap}
.pa-range-slider{flex:1;height:6px;-webkit-appearance:none;appearance:none;border-radius:3px;background:linear-gradient(90deg,var(--blue) 0%,var(--g200) 0%);outline:none;cursor:pointer;accent-color:var(--blue)}
.pa-range-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--blue);border:3px solid #fff;box-shadow:0 2px 6px rgba(37,99,235,.35);cursor:pointer}
.pa-afa-split-vis{margin:10px 0}
.pa-afa-split-bar{display:flex;height:32px;border-radius:8px;overflow:hidden}
.pa-afa-split-land{background:linear-gradient(135deg,#fecaca,#f87171);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#991b1b;transition:width .3s;min-width:40px;overflow:hidden}
.pa-afa-split-bldg{background:linear-gradient(135deg,#86efac,#4ade80);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#166534;transition:width .3s;flex:1;overflow:hidden}
.pa-afa-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}
.pa-afa-kpi{background:#fff;border:1.5px solid var(--g200);border-radius:10px;padding:10px 12px}
.pa-afa-kpi.red{border-color:#fecaca;background:#fef2f2}.pa-afa-kpi.grn{border-color:#86efac;background:#f0fdf4}
.pa-afa-kpi-l{font-size:9px;font-weight:800;color:var(--g400);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.pa-afa-kpi-v{font-size:14px;font-weight:900;color:var(--ink)}
.pa-afa-kpi.red .pa-afa-kpi-v{color:var(--red)}.pa-afa-kpi.grn .pa-afa-kpi-v{color:var(--grn)}
.pa-afa-method-toggle{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pa-method-btn{background:#fff;border:1.5px solid var(--g200);border-radius:12px;padding:14px;cursor:pointer;font-family:inherit;text-align:left;transition:all .2s;display:flex;flex-direction:column;gap:3px}
.pa-method-btn:hover{border-color:var(--blue)}.pa-method-btn.active{border-color:var(--blue);background:#eff6ff;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.pa-method-btn.rnd.active{border-color:var(--grn);background:#f0fdf4;box-shadow:0 0 0 3px rgba(5,150,105,.1)}
.pa-method-icon{font-size:20px;margin-bottom:4px}
.pa-method-btn span:nth-child(2){font-size:12px;font-weight:900;color:var(--ink)}.pa-method-sub{font-size:10px;color:var(--g400);font-weight:600}
.pa-rnd-info{display:flex;gap:12px;background:#fff;border:1.5px solid #bfdbfe;border-radius:10px;padding:12px 14px;margin-bottom:14px;font-size:12px;color:#1e40af;line-height:1.6}
.pa-rnd-info-icon{font-size:18px;flex-shrink:0}
.pa-rnd-source-tabs{display:flex;gap:6px;margin-bottom:14px}
.pa-src-tab{background:#fff;border:1.5px solid var(--g200);border-radius:8px;padding:8px 14px;font-size:12px;font-weight:700;color:var(--g500);cursor:pointer;font-family:inherit;transition:all .15s}
.pa-src-tab.active{border-color:var(--blue);background:#eff6ff;color:var(--blue)}
.pa-rnd-auto{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1.5px solid #86efac;border-radius:10px;padding:12px 16px;margin-bottom:12px;gap:10px;flex-wrap:wrap}
.pa-rnd-auto-result{font-size:12px;color:#475569}.pa-rnd-auto-val{font-size:14px;font-weight:800;color:var(--ink);margin-top:3px}
.pa-rnd-scale{position:relative;height:20px;margin:4px 12px 0}
.pa-rnd-scale span{position:absolute;font-size:9px;transform:translateX(-50%);transition:all .2s;font-family:'DM Mono',monospace}
.pa-afa-result-section{margin-top:16px;padding-top:16px;border-top:1.5px solid #bfdbfe}
.pa-afa-res3{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}
.pa-afa-r{background:#fff;border:1.5px solid var(--g200);border-radius:10px;padding:10px 12px;text-align:center}
.pa-afa-r.highlight{border-color:#86efac;background:#f0fdf4}.pa-afa-r.blue{border-color:#bfdbfe;background:#eff6ff}
.pa-afa-rl2{font-size:9px;font-weight:800;color:var(--g400);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.pa-afa-rv2{font-size:14px;font-weight:900;color:var(--ink)}.pa-afa-rv2.grn{color:var(--grn)}.pa-afa-rv2.blue{color:var(--blue)}
.pa-afa-rate-btns{display:flex;gap:8px}
.pa-rate-btn{flex:1;background:#fff;border:1.5px solid var(--g200);border-radius:10px;padding:12px;cursor:pointer;font-family:inherit;text-align:center;transition:all .15s}
.pa-rate-btn.active{border-color:var(--blue);background:#eff6ff}
.pa-rate-pct{font-size:18px;font-weight:900;color:var(--ink);margin-bottom:3px}.pa-rate-btn.active .pa-rate-pct{color:var(--blue)}
.pa-rate-desc{font-size:10px;color:var(--g400);font-weight:600}
.pa-rnd-compare{background:rgba(37,99,235,.04);border:1.5px solid #bfdbfe;border-radius:12px;padding:16px}
.pa-rnd-compare-hd{font-size:11px;font-weight:900;color:var(--blue);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.pa-rnd-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.pa-rnd-bar-lbl{min-width:90px;font-size:11px;font-weight:700;color:#475569}
.pa-rnd-bar-bg{flex:1;background:var(--g200);border-radius:6px;height:28px;overflow:hidden}
.pa-rnd-bar{height:100%;border-radius:6px;display:flex;align-items:center;justify-content:flex-end;padding-right:10px;font-size:11px;font-weight:800;color:#fff;transition:width .9s cubic-bezier(.4,0,.2,1);min-width:60px}
.pa-rnd-advantage{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
.pa-rnd-adv-item{background:#fff;border-radius:8px;padding:10px;text-align:center}
.pa-rnd-adv-item span{display:block;font-size:9px;font-weight:700;color:var(--g400);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.pa-rnd-adv-item strong{font-size:13px;font-weight:900}

/* ── BUTTONS ─────────────────────────── */
.pa-btn-primary{background:var(--blue);border:none;border-radius:10px;color:#fff;font-family:inherit;font-size:13px;font-weight:800;padding:11px 22px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:7px;box-shadow:0 2px 8px rgba(37,99,235,.2)}
.pa-btn-primary:hover{background:var(--bdk);transform:translateY(-1px);box-shadow:0 4px 14px rgba(37,99,235,.35)}
.pa-btn-secondary{background:#fff;border:1.5px solid var(--g200);border-radius:10px;color:var(--g500);font-family:inherit;font-size:13px;font-weight:700;padding:10px 20px;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:7px}
.pa-btn-secondary:hover{border-color:var(--ink);color:var(--ink)}
.pa-btn-calc{background:var(--blue);border:none;border-radius:12px;color:#fff;font-family:inherit;font-size:15px;font-weight:900;padding:14px 32px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px;box-shadow:0 4px 16px rgba(37,99,235,.3)}
.pa-btn-calc:hover{background:var(--bdk);transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,99,235,.4)}
.pa-btn-upgrade{background:var(--blue);border:none;border-radius:8px;color:#fff;font-family:inherit;font-size:12px;font-weight:800;padding:8px 16px;cursor:pointer;white-space:nowrap}
.pa-btn-upgrade:hover{background:var(--bdk)}
.pa-nav-btns{display:flex;justify-content:space-between;align-items:center;padding-top:32px;margin-top:32px;border-top:1px solid var(--g100)}

/* ── LIVE PANEL ──────────────────────── */
.pa-live-hd{padding:14px 18px 12px;border-bottom:1px solid var(--g100);background:var(--g50);font-size:10px;font-weight:900;color:var(--g500);text-transform:uppercase;letter-spacing:.12em;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0}
.pa-live-badge{font-size:9px;background:#dcfce7;color:var(--grn);border:1px solid #86efac;padding:2px 9px;border-radius:100px;font-weight:900;text-transform:uppercase}
.pa-live-row{padding:12px 18px;border-bottom:1px solid var(--g50)}
.pa-live-lbl{font-size:9px;font-weight:800;color:var(--g400);text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px}
.pa-live-val{font-size:17px;font-weight:900;color:var(--ink);letter-spacing:-.03em}
.pa-live-val.big{font-size:20px}
.pa-live-empty{padding:40px 18px;text-align:center;color:var(--g400);font-size:13px}
.pa-live-foot{padding:12px 16px;font-size:10px;color:var(--g400);line-height:1.65;border-top:1px solid var(--g100);margin-top:auto}

/* ── LOADING ─────────────────────────── */
.pa-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;flex:1;text-align:center;min-height:400px}
.pa-spinner{width:52px;height:52px;position:relative;margin:0 auto 20px}
.pa-spin{position:absolute;inset:0;border-radius:50%;border:3px solid var(--g200);border-top-color:var(--blue);animation:paspin .9s linear infinite}
.pa-spin2{position:absolute;inset:8px;border-radius:50%;border:2px solid var(--g100);border-top-color:var(--gold);animation:paspin .6s linear infinite reverse}
@keyframes paspin{to{transform:rotate(360deg)}}

/* ── CALC LOADING ────────────────────── */
.pa-calc-loading{display:flex;align-items:center;justify-content:center;min-height:520px;padding:40px}
.pa-cl-inner{max-width:480px;width:100%;text-align:center}
.pa-cl-rings{position:relative;width:100px;height:100px;margin:0 auto 32px}
@keyframes cl-spin1{to{transform:rotate(360deg)}}
@keyframes cl-spin2{to{transform:rotate(-360deg)}}
@keyframes cl-spin3{to{transform:rotate(360deg)}}
.pa-cl-ring{position:absolute;border-radius:50%;border:3px solid transparent}
.r1{inset:0;border-top-color:#6366f1;animation:cl-spin1 1.2s linear infinite}
.r2{inset:8px;border-top-color:#38bdf8;animation:cl-spin2 .9s linear infinite}
.r3{inset:18px;border-top-color:#34d399;animation:cl-spin3 .6s linear infinite}
.pa-cl-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:26px}
.pa-cl-title{font-size:26px;font-weight:900;color:var(--ink);letter-spacing:-.04em;margin-bottom:24px}
.pa-cl-steps{display:flex;flex-direction:column;gap:6px;margin-bottom:24px;text-align:left}
.pa-cl-step{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:10px;background:var(--g50);border:1.5px solid var(--g200);opacity:.4;transition:all .4s cubic-bezier(.4,0,.2,1)}
.pa-cl-step.done{opacity:1;background:#f0fdf4;border-color:#86efac;transform:translateX(4px)}
.pa-cls-icon{font-size:16px;width:22px;text-align:center;flex-shrink:0}.pa-cls-label{flex:1;font-size:13px;font-weight:700;color:var(--ink)}
.pa-cls-check{font-size:14px;color:var(--grn);font-weight:900;opacity:0;transition:opacity .3s}.pa-cl-step.done .pa-cls-check{opacity:1}
.pa-cl-bar-wrap{background:var(--g200);border-radius:4px;height:6px;margin-bottom:20px;overflow:hidden}
.pa-cl-bar{height:100%;background:linear-gradient(90deg,#6366f1,#38bdf8);border-radius:4px;width:0;transition:width .4s cubic-bezier(.4,0,.2,1)}
.pa-cl-sub{font-size:12px;color:var(--g400);line-height:1.65}
.pa-cl-skip{margin-top:16px;background:#fff;border:1.5px solid var(--g200);border-radius:8px;padding:8px 20px;font-size:12px;font-weight:800;color:var(--blue);cursor:pointer;font-family:inherit;transition:all .15s}
.pa-cl-skip:hover{border-color:var(--blue);background:#eff6ff}

/* ── DASHBOARD ───────────────────────── */
.pa-dash-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.pa-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.pa-dash-empty{text-align:center;padding:80px 40px}
.pa-empty-icon{font-size:52px;margin-bottom:16px;opacity:.3}
.pa-acard{background:#fff;border-radius:16px;box-shadow:0 1px 3px rgba(0,0,0,.06),0 4px 14px rgba(0,0,0,.05);overflow:hidden;transition:box-shadow .15s,transform .15s}
.pa-acard:hover{box-shadow:0 4px 20px rgba(0,0,0,.1);transform:translateY(-2px)}
.pa-acard-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:16px 18px 10px}
.pa-acard-addr{font-size:13px;font-weight:800;color:var(--ink)}.pa-acard-date{font-size:11px;color:var(--g400);margin-top:2px}
.pa-verdict-badge{font-size:10px;font-weight:800;padding:3px 10px;border-radius:100px;flex-shrink:0}
.pa-acard-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:0 18px 14px}
.pa-kpi-lbl{font-size:9px;font-weight:700;color:var(--g400);text-transform:uppercase;display:block;margin-bottom:3px}.pa-kpi-val{font-size:14px;font-weight:900;color:var(--ink)}
.pa-acard-ft{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-top:1px solid var(--g50);background:var(--g50)}
.pa-acard-btn{background:none;border:none;color:var(--blue);font-size:12px;font-weight:800;cursor:pointer;font-family:inherit}.pa-acard-del{background:none;border:none;font-size:14px;cursor:pointer;opacity:.4}.pa-acard-del:hover{opacity:1}

/* ── ACCOUNT ─────────────────────────── */
.pa-account-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pa-plan-current{border:2px solid currentColor;border-radius:12px;padding:18px;margin-bottom:14px}
.pa-plan-name{font-size:18px;font-weight:900;margin-bottom:4px}
.pa-plan-price{font-size:28px;font-weight:900;color:var(--ink)}.pa-plan-limit{font-size:12px;color:var(--g500);margin-top:4px}
.pa-usage-bar-bg{background:var(--g100);border-radius:4px;height:8px;overflow:hidden;margin-bottom:6px}
.pa-usage-bar{height:100%;border-radius:4px;transition:width .6s}
.pa-plan-usage span{font-size:12px;color:var(--g500)}
.pa-plan-option{border:1.5px solid var(--g200);border-radius:10px;padding:14px;margin-bottom:10px}
.pa-plan-option.active{border-color:var(--blue);background:#eff6ff}

/* ── RESULTS ─────────────────────────── */
.pa-verdict{border-radius:16px;padding:24px 28px;margin-bottom:22px;border:1.5px solid}
.pa-verdict-label{font-size:22px;font-weight:900;letter-spacing:-.04em;margin-bottom:6px}
.pa-res-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}

/* ── GATE MODAL ──────────────────────── */
.pa-gate{position:fixed;inset:0;background:rgba(15,23,42,.55);backdrop-filter:blur(8px);display:flex;align-items:flex-end;justify-content:center;z-index:9999;padding:0}
.pa-gate-card{background:#fff;border-radius:24px 24px 0 0;padding:36px 40px;width:100%;max-width:480px;text-align:center;animation:slideup .35s ease}
@keyframes slideup{from{transform:translateY(100%)}to{transform:translateY(0)}}
.pa-gate-title{font-size:22px;font-weight:900;color:var(--ink);letter-spacing:-.04em;margin-bottom:10px}
.pa-gate-badge{display:inline-block;background:#dcfce7;border:1px solid #86efac;border-radius:100px;padding:4px 14px;font-size:10px;font-weight:900;color:var(--grn);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}
.pa-gate-desc{font-size:13px;color:var(--g500);line-height:1.65;margin-bottom:20px}
.pa-gate-fields{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;text-align:left}
.pa-guest-save-note{background:#fffbeb;border:1.5px solid #fde68a;border-radius:8px;padding:9px 14px;font-size:12px;color:#78350f;margin-top:10px}

/* ── PROMO CODE ──────────────────────── */
.pa-promo-input-row{display:flex;gap:8px;align-items:center}
.pa-promo-inp{flex:1;letter-spacing:.1em;font-weight:800 !important;text-transform:uppercase}
.pa-promo-used{display:flex;align-items:center;gap:10px;background:#f0fdf4;border:1.5px solid #86efac;border-radius:10px;padding:12px 16px;font-size:13px;color:#166534}
.pa-promo-used strong{font-size:15px;letter-spacing:.12em;font-family:'DM Mono',monospace}

/* ── ANIMATIONS ──────────────────────── */
@keyframes pa-fade-up{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes pa-fade-in{from{opacity:0}to{opacity:1}}
@keyframes pa-scale-in{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
@keyframes pa-pulse{0%,100%{box-shadow:0 0 0 0 rgba(37,99,235,.3)}50%{box-shadow:0 0 0 8px rgba(37,99,235,0)}}
.pa-rs{animation:pa-fade-up .4s ease both}
.pa-verdict{animation:pa-scale-in .35s ease both}
.pa-score-bar-fill{transition:width 1s cubic-bezier(.4,0,.2,1)}

/* ── SCORE GAUGE ─────────────────────── */
.pa-score-layout{display:grid;grid-template-columns:1fr 1fr;gap:0}
.pa-gauge-wrap{padding:18px 16px;border-right:1px solid var(--g100)}
.pa-gauge-svg{width:180px;height:120px;display:block;margin:0 auto 12px}
.pa-score-bars{display:flex;flex-direction:column;gap:8px;padding-top:4px}
.pa-score-bar-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--g500)}
.pa-score-bar-row span:first-child{min-width:62px;font-weight:600}
.pa-score-bar-bg{flex:1;background:var(--g100);border-radius:5px;height:8px;overflow:hidden}
.pa-yield-chart{padding:18px 16px}
.pa-chart-title{font-size:10px;font-weight:800;color:var(--g500);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}
.pa-yield-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.pa-yield-lbl{min-width:120px;font-size:11px;color:var(--g500);font-weight:600}
.pa-yield-bar-wrap{flex:1;background:var(--g100);border-radius:5px;height:22px;overflow:hidden;position:relative}
.pa-yield-bar{height:100%;border-radius:5px;min-width:2px;display:flex;align-items:center;justify-content:flex-end;padding-right:8px;font-size:11px;font-weight:800;color:#fff;transition:width .8s ease}
.pa-yield-bar.ref{opacity:.7}
.pa-yield-note{font-size:9px;color:var(--g400);margin-top:6px}

/* ── VERMIETUNG / MFH ────────────────── */
.pa-vermietet-box{background:#f0fdf4;border:1.5px solid #86efac;border-radius:12px;padding:16px 18px;margin-bottom:14px}
.pa-vm-hd{font-size:11px;font-weight:900;color:#166534;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.pa-vm-analyse{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px;padding-top:12px;border-top:1.5px solid #86efac}
.pa-vm-row{background:#fff;border:1.5px solid var(--g200);border-radius:8px;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#475569}
.pa-vm-row.warn{border-color:#fde68a;background:#fffbeb}.pa-vm-row.ok{border-color:#86efac}
.pa-vm-row.pot{border-color:#bfdbfe;background:#eff6ff;grid-column:1/-1}.pa-vm-row.info{border-color:#fde68a;background:#fffbeb;grid-column:1/-1;font-size:11px}
.pa-vm-row strong{font-weight:800;color:var(--ink)}
.pa-info-box{background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:10px;padding:12px 16px;font-size:12px;color:#1d4ed8;margin-bottom:14px}
.pa-mfh-manager{background:#fff;border-radius:14px;box-shadow:0 1px 3px rgba(0,0,0,.06),0 4px 14px rgba(0,0,0,.05);margin-bottom:20px;overflow:hidden}
.pa-mfh-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:18px 20px;border-bottom:1px solid var(--g100);background:var(--g50)}
.pa-mfh-title{font-size:14px;font-weight:900;color:var(--ink)}.pa-mfh-sub{font-size:11px;color:var(--g400);margin-top:3px}
.pa-mfh-sqm-box{padding:14px 20px;border-bottom:1px solid var(--g100);background:linear-gradient(135deg,#eff6ff,#f8fafc)}
.pa-mfh-sqm-lbl{font-size:11px;font-weight:800;color:var(--blue);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.pa-mfh-sqm-total{font-size:12px;color:var(--ink);text-transform:none;letter-spacing:0}
.pa-mfh-sqm-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.pa-mfh-sqm-current{font-size:11px;color:var(--g500);margin-top:7px}
.pa-mfh-table{padding:0 16px 8px}
.pa-mfh-thead{display:grid;grid-template-columns:1fr 65px 45px 100px 90px 52px 100px 28px;gap:5px;padding:10px 4px 6px;font-size:9px;font-weight:800;color:var(--g400);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--g100)}
.pa-mfh-row{display:grid;grid-template-columns:1fr 65px 45px 100px 90px 52px 100px 28px;gap:5px;padding:7px 4px;border-bottom:1px solid var(--g50);align-items:center}
.pa-mfh-inp{background:var(--g50);border:1.5px solid var(--g200);border-radius:7px;padding:7px 9px;font-size:12px;font-family:inherit;font-weight:600;color:var(--ink);width:100%;outline:none}
.pa-mfh-inp:focus{border-color:var(--blue)}.pa-mfh-inp.dim{opacity:.5}
.pa-mfh-sel{-webkit-appearance:none;cursor:pointer}
.pa-sfx-sm{position:relative}.pa-sfx-sm .pa-mfh-inp{padding-right:24px}
.pa-sfx-sm span{position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:9px;color:var(--g400);font-weight:700;pointer-events:none}
.pa-mfh-sqm-val{font-size:11px;font-weight:800;color:var(--ink);font-family:'DM Mono',monospace}.pa-mfh-sqm-val.below{color:var(--gold)}
.pa-mfh-soll{font-size:11px;font-weight:700;color:var(--g500)}.pa-mfh-soll .up{color:var(--grn);font-size:10px}.pa-mfh-soll .down{color:var(--red);font-size:10px}
.pa-mfh-del{background:none;border:none;cursor:pointer;font-size:14px;opacity:.4;padding:2px}.pa-mfh-del:hover{opacity:1}
.pa-mfh-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:14px 16px;border-top:1px solid var(--g100);background:var(--g50)}
.pa-mfh-sum-row{background:#fff;border:1.5px solid var(--g200);border-radius:8px;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--g500)}
.pa-mfh-sum-row.pot{border-color:#bfdbfe;background:#eff6ff}.pa-mfh-sum-row strong{font-weight:900;color:var(--ink)}

/* ── DRAFT INDICATOR ─────────────────── */
.pa-draft-indicator{font-size:11px;font-weight:700;padding:3px 10px;border-radius:100px;transition:all .3s}
.pa-draft-saved{background:#f0fdf4;border:1px solid #86efac;color:#166534}
.pa-draft-saving{background:#fffbeb;border:1px solid #fde68a;color:#78350f}
.pa-draft-none{display:none}
.pa-draft-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:10px;padding:10px 16px;margin-top:12px;animation:pa-fade-up .3s ease}
.pa-draft-bar span{font-size:12px;font-weight:700;color:#1d4ed8}
.pa-draft-bar-btn{background:#fff;border:1.5px solid #bfdbfe;border-radius:6px;color:var(--blue);font-size:11px;font-weight:700;padding:4px 10px;cursor:pointer;font-family:inherit}
.pa-draft-bar-btn:hover{border-color:#fecaca;color:var(--red)}

/* ── URL CARD ────────────────────────── */
.pa-url-card{background:#0f172a;border-radius:16px;padding:22px 26px;margin-bottom:18px}
.pa-url-ttl{font-size:16px;font-weight:900;color:#fff;display:flex;align-items:center;gap:10px;margin-bottom:4px}
.pa-url-icon{font-size:18px}.pa-url-badge{font-size:10px;font-weight:800;padding:2px 9px;background:rgba(37,99,235,.3);border:1px solid rgba(37,99,235,.4);border-radius:100px;color:#a5b4fc;text-transform:uppercase}
.pa-url-sub{font-size:12px;color:rgba(255,255,255,.4);margin-bottom:14px}
.pa-url-row{display:flex;gap:8px}
.pa-url-inp{flex:1;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.15);border-radius:10px;color:#fff;font-family:inherit;font-size:13px;padding:10px 14px;outline:none}
.pa-url-inp:focus{border-color:var(--blue)}.pa-url-inp::placeholder{color:rgba(255,255,255,.3)}
.pa-url-btn{background:var(--blue);border:none;border-radius:10px;color:#fff;font-family:inherit;font-size:12px;font-weight:800;padding:10px 18px;cursor:pointer;flex-shrink:0}
.pa-url-btn:hover{background:var(--bdk)}
.pa-url-msg{font-size:12px;color:rgba(255,255,255,.5);margin-top:8px}.pa-url-msg.ok{color:#4ade80}.pa-url-msg.err{color:#f87171}

/* ── MODE SELECTOR ───────────────────── */
.pa-mode-select{max-width:720px;margin:0 auto;padding:0 0 40px}
.pa-ms-hero{text-align:center;padding:48px 24px 40px;background:linear-gradient(135deg,#0f172a 0%,#1e1b4b 50%,#0f172a 100%);border-radius:20px;margin-bottom:24px;position:relative;overflow:hidden}
.pa-ms-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(99,102,241,.25) 0%,transparent 60%),radial-gradient(ellipse at 70% 20%,rgba(37,99,235,.2) 0%,transparent 50%);pointer-events:none}
.pa-ms-hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(99,102,241,.2);border:1px solid rgba(99,102,241,.4);border-radius:100px;padding:5px 16px;font-size:11px;font-weight:800;color:#a5b4fc;text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px}
.pa-ms-hero-title{font-size:42px;font-weight:900;color:#fff;letter-spacing:-.05em;line-height:1.1;margin-bottom:14px}
.pa-ms-hero-title span{background:linear-gradient(90deg,#818cf8,#38bdf8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.pa-ms-hero-sub{font-size:14px;color:rgba(255,255,255,.5);line-height:1.7;max-width:500px;margin:0 auto}
.pa-ms-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:14px}
.pa-ms-card{background:#fff;border:1.5px solid var(--g200);border-radius:20px;padding:28px 24px;cursor:pointer;text-align:left;font-family:inherit;transition:all .25s;display:flex;flex-direction:column;gap:10px}
.pa-ms-card:hover{transform:translateY(-5px);box-shadow:0 12px 32px rgba(0,0,0,.1)}
.pa-ms-card.wizard{border-color:#c7d2fe}.pa-ms-card.wizard:hover{border-color:#6366f1;box-shadow:0 16px 40px rgba(99,102,241,.15)}
.pa-ms-card.pro:hover{border-color:#34d399;box-shadow:0 16px 40px rgba(5,150,105,.1)}
.pa-ms-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:4px}
.pa-ms-card-icon-wrap{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px}
.pa-ms-card-icon-wrap.wizard{background:linear-gradient(135deg,#eff6ff,#e0e7ff)}.pa-ms-card-icon-wrap.pro{background:linear-gradient(135deg,#f0fdf4,#dcfce7)}
.pa-ms-recommended{background:linear-gradient(90deg,#6366f1,#8b5cf6);color:#fff;font-size:10px;font-weight:900;padding:3px 10px;border-radius:100px;letter-spacing:.08em;text-transform:uppercase}
.pa-ms-pro-badge{background:#f0fdf4;border:1px solid #86efac;color:#166534;font-size:10px;font-weight:800;padding:3px 10px;border-radius:100px;text-transform:uppercase;letter-spacing:.06em}
.pa-ms-card-label{font-size:20px;font-weight:900;color:var(--ink);letter-spacing:-.03em}
.pa-ms-card-desc{font-size:13px;color:var(--g500);line-height:1.7;flex:1}
.pa-ms-list{list-style:none;padding:0;margin:4px 0 0;display:flex;flex-direction:column;gap:5px}.pa-ms-list li{font-size:12px;color:#475569;font-weight:600}
.pa-ms-card-cta{font-size:14px;font-weight:900;margin-top:6px;display:flex;align-items:center;gap:6px;transition:gap .2s}
.pa-ms-card-cta.wizard{color:#6366f1}.pa-ms-card-cta.pro{color:var(--grn)}
.pa-ms-card:hover .pa-ms-card-cta{gap:10px}
.pa-ms-draft{background:#fff;border:1.5px solid var(--g200);border-radius:14px;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;margin-bottom:14px;transition:all .15s}
.pa-ms-draft:hover{border-color:#6366f1;background:#fafbff}
.pa-ms-draft-left{display:flex;align-items:center;gap:12px}
.pa-ms-draft-dot{width:10px;height:10px;border-radius:50%;background:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.2);animation:pa-pulse 2s infinite}
.pa-ms-draft-label{font-size:13px;font-weight:800;color:var(--ink)}.pa-ms-draft-meta{font-size:11px;color:var(--g400);margin-top:2px}.pa-ms-draft-cta{font-size:13px;font-weight:900;color:#6366f1}
.pa-ms-features{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.pa-ms-feat{background:var(--g50);border-radius:10px;padding:10px 12px;display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:#475569}
.pa-ms-feat span:first-child{font-size:16px;flex-shrink:0}

/* ── WIZARD ──────────────────────────── */
.pa-wizard{display:flex;flex-direction:column;max-width:900px;padding:0}
.pa-wz-header{margin-bottom:20px}
.pa-wz-prog-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.pa-wz-back-chip,.pa-wz-pro-chip{background:#fff;border:1.5px solid var(--g200);border-radius:8px;padding:6px 12px;font-size:12px;font-weight:800;color:var(--g500);cursor:pointer;font-family:inherit;flex-shrink:0;transition:all .15s}
.pa-wz-back-chip:hover{border-color:#6366f1;color:#6366f1}.pa-wz-pro-chip:hover{border-color:var(--grn);color:var(--grn)}
.pa-wz-prog-track{flex:1;height:8px;background:var(--g200);border-radius:4px;overflow:hidden;position:relative}
.pa-wz-prog-fill{height:100%;background:linear-gradient(90deg,#6366f1,#38bdf8);border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.pa-wz-step-label{font-size:11px;color:var(--g400);font-weight:700;text-align:center;letter-spacing:.06em;text-transform:uppercase}
.pa-wz-body-grid{display:grid;grid-template-columns:1fr 280px;gap:18px}
@keyframes wz-in{from{opacity:0;transform:translateX(40px) scale(.97)}to{opacity:1;transform:translateX(0) scale(1)}}
@keyframes wz-out{from{opacity:1}to{opacity:0;transform:translateX(-30px)}}
.pa-wz-in{animation:wz-in .3s cubic-bezier(.4,0,.2,1)}.pa-wz-out{animation:wz-out .2s ease}
.pa-wz-card{background:#fff;border-radius:20px;padding:36px 40px;display:flex;flex-direction:column;min-height:400px;box-shadow:0 1px 3px rgba(0,0,0,.05),0 8px 24px rgba(0,0,0,.07)}
.pa-wz-q-wrap{margin-bottom:28px}
.pa-wz-step-num{font-size:11px;font-weight:900;color:var(--g400);letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px}
.pa-wz-q{font-size:28px;font-weight:900;color:var(--ink);letter-spacing:-.04em;line-height:1.2;margin:0 0 10px}
.pa-wz-hint{font-size:13px;color:var(--g500);line-height:1.65;background:var(--g50);border-left:3px solid #6366f1;padding:8px 14px;border-radius:0 8px 8px 0}
.pa-wz-answer{flex:1}
.pa-wz-nav{display:flex;align-items:center;justify-content:space-between;margin-top:28px;padding-top:20px;border-top:1px solid var(--g100)}
.pa-wz-nav-back{background:#fff;border:1.5px solid var(--g200);border-radius:10px;padding:11px 20px;font-size:13px;font-weight:800;color:var(--g500);cursor:pointer;font-family:inherit;transition:all .15s}
.pa-wz-nav-back:hover{border-color:var(--ink);color:var(--ink)}
.pa-wz-nav-next{background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:12px;padding:13px 28px;font-size:14px;font-weight:900;color:#fff;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:8px;transition:all .2s;box-shadow:0 4px 14px rgba(99,102,241,.35)}
.pa-wz-nav-next:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(99,102,241,.45)}
.pa-wz-nav-next.last{background:linear-gradient(135deg,var(--grn),#047857);box-shadow:0 4px 14px rgba(5,150,105,.35)}
.pa-wz-nav-next.last:hover{box-shadow:0 8px 24px rgba(5,150,105,.45)}
.pa-wz-nav-arrow{font-size:16px;transition:transform .2s}.pa-wz-nav-next:hover .pa-wz-nav-arrow{transform:translateX(4px)}
.pa-wz-nav-hint{font-size:12px;color:var(--g400);font-weight:600;font-style:italic}
.pa-wz-options{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:8px}
.pa-wz-opt{background:var(--g50);border:1.5px solid var(--g200);border-radius:14px;padding:16px 18px;cursor:pointer;text-align:left;font-family:inherit;transition:all .18s;display:flex;flex-direction:column;gap:5px}
.pa-wz-opt:hover{border-color:#818cf8;transform:translateY(-2px);box-shadow:0 6px 16px rgba(99,102,241,.1)}
.pa-wz-opt.selected{border-color:#6366f1;background:#eff6ff;box-shadow:0 0 0 3px rgba(99,102,241,.12)}
.pa-wz-opt-icon{font-size:26px;line-height:1;margin-bottom:4px}.pa-wz-opt-label{font-size:14px;font-weight:900;color:var(--ink)}.pa-wz-opt.selected .pa-wz-opt-label{color:#4f46e5}.pa-wz-opt-desc{font-size:11px;color:var(--g400);line-height:1.45}
.pa-wz-tax-opts,.pa-wz-goal-opts{grid-template-columns:repeat(3,1fr)}.pa-wz-taxgoal .pa-lbl{display:block;margin-bottom:8px}
.pa-wz-custom{margin-top:14px;padding-top:14px;border-top:1.5px dashed var(--g200)}
.pa-wz-select{width:100%;max-width:420px;font-size:15px;padding:14px 16px;border:1.5px solid var(--g200);border-radius:12px;background:var(--g50);font-family:inherit;outline:none;transition:border-color .15s}
.pa-wz-select:focus{border-color:#6366f1}
.pa-wz-text{font-size:16px;padding:14px 18px;border:1.5px solid var(--g200);border-radius:12px;width:100%;max-width:480px;background:var(--g50);font-family:inherit;font-weight:600;outline:none;transition:border-color .15s}
.pa-wz-text:focus{border-color:#6366f1}.pa-wz-optional{font-size:11px;color:var(--g400);margin-top:7px}
.pa-wz-num{font-size:22px;font-weight:900;padding:14px 60px 14px 18px;border:1.5px solid var(--g200);border-radius:12px;background:var(--g50);max-width:240px;outline:none;font-family:inherit;transition:border-color .15s}
.pa-wz-num:focus{border-color:#6366f1}.pa-wz-num-hint{font-size:12px;color:#6366f1;font-weight:700;margin-top:10px;padding:6px 12px;background:#eff6ff;border-radius:6px;display:inline-block}
.pa-wz-number-wrap{display:flex;flex-direction:column;align-items:flex-start;gap:4px}
.pa-wz-summary{background:#fff;border-radius:16px;overflow:hidden;height:fit-content;position:sticky;top:80px;box-shadow:0 1px 3px rgba(0,0,0,.06),0 4px 14px rgba(0,0,0,.05)}
.pa-wz-sum-empty{padding:28px 18px;text-align:center;color:var(--g400);background:var(--g50);height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.pa-wz-sum-icon{font-size:32px;opacity:.3}.pa-wz-sum-empty p{font-size:12px;line-height:1.65}
.pa-wz-sum-hd{padding:12px 16px;background:linear-gradient(135deg,var(--g50),#eff6ff);border-bottom:1px solid var(--g100);font-size:10px;font-weight:900;color:#6366f1;text-transform:uppercase;letter-spacing:.12em}
.pa-wz-sum-row{display:flex;justify-content:space-between;align-items:center;padding:9px 16px;border-bottom:1px solid var(--g50)}
.pa-wz-sum-lbl{font-size:11px;color:var(--g500);font-weight:600}.pa-wz-sum-val{font-size:12px;font-weight:900;color:var(--ink);font-family:'DM Mono',monospace}
.pa-wz-sum-val.grn{color:var(--grn)}.pa-wz-sum-val.red{color:var(--red)}

/* ── GATE PAGE (login) ───────────────── */
.pa-gate-page{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:24px;font-family:inherit}
.pa-gp-card{background:#fff;border-radius:20px;padding:40px 44px;width:100%;max-width:440px;box-shadow:0 4px 24px rgba(0,0,0,.08)}
.pa-gp-logo{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.pa-gp-logo-icon{width:36px;height:36px;background:var(--blue);border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:16px}
.pa-gp-logo-txt{font-size:17px;font-weight:900;color:var(--ink);letter-spacing:-.03em}
.pa-gp-logo-txt b{color:var(--blue)}
.pa-gp-h2{font-size:26px;font-weight:900;color:var(--ink);letter-spacing:-.04em;margin:0 0 6px}
.pa-gp-sub{font-size:13px;color:var(--g500);margin:0 0 22px;line-height:1.65}
.pa-gp-code-box{display:flex;gap:8px;margin-bottom:8px}
.pa-gp-code-inp{flex:1;background:var(--g50);border:2px solid #bfdbfe;border-radius:10px;padding:13px 14px;font-size:15px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);outline:none;font-family:inherit;transition:border-color .15s}
.pa-gp-code-inp:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}.pa-gp-code-inp::placeholder{opacity:.4;font-weight:600;letter-spacing:.06em}
.pa-gp-code-btn{background:var(--blue);border:none;border-radius:10px;color:#fff;font-family:inherit;font-size:13px;font-weight:900;padding:13px 20px;cursor:pointer;white-space:nowrap;transition:all .15s}
.pa-gp-code-btn:hover{background:var(--bdk)}.pa-gp-code-btn:disabled{opacity:.6;cursor:not-allowed}
.pa-gp-msg{padding:10px 14px;border-radius:8px;font-size:12px;font-weight:700;margin-bottom:6px}
.pa-gp-msg.err{background:#fef2f2;border:1.5px solid #fecaca;color:#991b1b}.pa-gp-msg.ok{background:#f0fdf4;border:1.5px solid #86efac;color:#166534}
.pa-gp-success{align-items:center;gap:12px;background:#f0fdf4;border:1.5px solid #86efac;border-radius:12px;padding:16px 20px;margin-bottom:8px}
.pa-gp-success-icon{width:32px;height:32px;background:var(--grn);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:900;flex-shrink:0}
.pa-gp-success-txt{font-size:13px;font-weight:800;color:#166534}
.pa-gp-divider{text-align:center;margin:18px 0;position:relative}
.pa-gp-divider::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--g200)}
.pa-gp-divider span{background:#fff;padding:0 12px;position:relative;font-size:11px;color:var(--g400);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.pa-gp-login-row{display:flex;gap:10px}
.pa-gp-login-btn{flex:1;display:block;text-align:center;background:#fff;border:1.5px solid var(--blue);border-radius:10px;color:var(--blue);font-weight:900;text-decoration:none;padding:11px 16px;font-size:13px;transition:all .15s}
.pa-gp-login-btn:hover{background:#eff6ff}
.pa-gp-register-btn{flex:1;display:block;text-align:center;background:var(--g50);border:1.5px solid var(--g200);border-radius:10px;color:var(--g500);font-weight:700;text-decoration:none;padding:11px 16px;font-size:13px;transition:all .15s}
.pa-gp-register-btn:hover{border-color:var(--g400);color:var(--ink)}
.pa-gp-note{font-size:11px;color:var(--g400);text-align:center;margin-top:16px;line-height:1.65}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   RESPONSIVE — Mobile First
   Breakpoints: 480 / 640 / 768 / 1024 / 1200
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* ── Bottom Navigation (mobile only) ─────────────────── */
.pa-bottom-nav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  height:64px;
  background:#fff;
  border-top:1px solid var(--g200);
  z-index:300;
  padding:0 8px;
  padding-bottom:env(safe-area-inset-bottom); /* iPhone notch */
}
.pa-bottom-nav-item{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:3px;
  background:none;border:none;cursor:pointer;
  font-family:inherit;font-size:10px;font-weight:600;
  color:var(--g400);padding:8px 4px;border-radius:10px;
  transition:all .15s;min-height:44px;
}
.pa-bottom-nav-item.active{color:var(--blue)}
.pa-bottom-nav-item.highlight{
  background:var(--blue);color:#fff;
  border-radius:14px;margin:8px 4px;
  flex:0 0 auto;padding:8px 20px;
  box-shadow:0 4px 12px rgba(37,99,235,.3);
  flex-direction:row;gap:6px;font-size:13px;font-weight:800;
}
.pa-bottom-nav-icon{line-height:1;display:flex;align-items:center;justify-content:center}
.pa-bottom-nav-label{font-size:10px;line-height:1}
.pa-bottom-nav-item.highlight .pa-bottom-nav-label{font-size:13px}

/* ── Hamburger ────────────────────────────────────────── */
.pa-hamburger{
  display:none;
  flex-direction:column;gap:5px;
  background:none;border:1.5px solid var(--g200);
  border-radius:8px;padding:8px 10px;cursor:pointer;
  flex-shrink:0;
}
.pa-hamburger span{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:all .2s}

/* ── Mobile Drawer (step sidebar) ────────────────────── */
.pa-mob-overlay{
  display:none;
  position:fixed;inset:0;background:rgba(0,0,0,.4);
  z-index:400;backdrop-filter:blur(2px);
}
.pa-mob-drawer{
  display:none;
  position:fixed;top:0;left:0;bottom:0;width:80vw;max-width:300px;
  background:#fff;z-index:401;overflow-y:auto;
  padding-top:env(safe-area-inset-top);
  box-shadow:4px 0 24px rgba(0,0,0,.12);
  transform:translateX(-100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
}
.pa-mob-drawer.open{transform:translateX(0)}
.pa-mob-drawer-close{
  display:block;width:100%;padding:14px 20px;
  background:none;border:none;border-top:1px solid var(--g200);
  font-family:inherit;font-size:13px;font-weight:700;color:var(--g500);
  cursor:pointer;text-align:center;margin-top:8px;
}

/* ─────────────────────────────────────────────────────────
   768px — Tablet & Mobile
───────────────────────────────────────────────────────── */
@media(max-width:768px){

  /* Appbar */
  .pa-appbar{padding:0 14px;gap:10px;height:56px}
  .pa-appbar-sub{display:none}
  .pa-appbar-name{font-size:13px}
  .pa-appbar-mark{width:32px;height:32px;font-size:14px}
  .pa-appbar-steps{gap:0}
  .pa-appbar-dot{display:none}
  .pa-step-label-text{display:none} /* just show numbers on mobile */
  .pa-appbar-step{padding:6px 8px;font-size:12px}
  .pa-appbar-saved{display:none}
  .pa-appbar-btn.outline span:not(:first-child){display:none} /* icon only */
  .pa-hamburger{display:flex}

  /* Layout */
  .pa-layout{display:block!important}
  .pa-step-sidebar{display:none} /* replaced by drawer */
  .pa-live{display:none}
  .pa-main-content{padding:16px 14px 80px} /* 80px for bottom nav */

  /* Bottom nav visible */
  .pa-bottom-nav{display:flex}

  /* Mobile drawer visible */
  .pa-mob-drawer{display:block}
  .pa-mob-overlay{display:block}

  /* Dashboard */
  .pa-dash,.pa-account,.pa-results{padding:16px 0 80px}
  .pa-dash-hd{flex-direction:column;align-items:flex-start;gap:12px}
  .pa-h1{font-size:22px}
  .pa-sub{font-size:13px}
  .pa-cards{grid-template-columns:1fr}

  /* Analysis cards */
  .pa-acard-ft{flex-wrap:wrap;gap:6px}
  .pa-acard-btn-edit,.pa-acard-btn{flex:1;justify-content:center;min-height:40px}

  /* KPI Grid */
  .pa-kgrid{grid-template-columns:1fr 1fr!important;gap:8px!important}
  .pa-kv{font-size:18px!important}
  .pa-kl{font-size:9px!important}

  /* 2-col grids → 1 col */
  .pa-rgrid{grid-template-columns:1fr!important}
  .pa-g2{grid-template-columns:1fr}
  .pa-cols-2,.cols-2{grid-template-columns:1fr}
  .pa-account-grid{grid-template-columns:1fr}

  /* Option cards */
  .pa-og4{grid-template-columns:1fr 1fr}
  .pa-og3{grid-template-columns:1fr 1fr}

  /* Verdict card */
  .pa-verdict{padding:16px}
  .pa-res-actions{flex-direction:column;gap:8px}
  .pa-res-actions button,.pa-res-actions a{width:100%;justify-content:center}

  /* Mode selector */
  .pa-mode-select{padding:16px 12px 80px}
  .pa-ms-hero{padding:24px 16px 20px}
  .pa-ms-hero-title{font-size:22px}
  .pa-ms-cards{grid-template-columns:1fr;gap:12px}
  .pa-ms-features{grid-template-columns:1fr 1fr}

  /* Wizard */
  .pa-wizard{padding:12px 12px 80px}
  .pa-wz-body-grid{grid-template-columns:1fr}
  .pa-wz-summary{display:none}
  .pa-wz-card{padding:20px 16px;min-height:auto}
  .pa-wz-q{font-size:19px}
  .pa-wz-options{grid-template-columns:1fr 1fr}
  .pa-wz-nav-next{width:100%;justify-content:center;padding:14px}
  .pa-wz-nav-back{padding:10px 16px}
  .pa-wz-nav{flex-wrap:wrap;gap:8px}
  .pa-wz-header{padding:0 2px}
  .pa-wz-prog-row{gap:8px}

  /* Forms */
  .pa-geo-row{flex-direction:column;gap:8px}
  .pa-geo-btn{width:100%;justify-content:center}
  .pa-geo-body{grid-template-columns:1fr}
  .pa-geo-info{border-left:none;border-top:1px solid var(--g100)}
  .pa-leaflet-map{height:180px}

  /* URL card */
  .pa-url-row{flex-direction:column;gap:8px}
  .pa-url-btn{width:100%}

  /* AfA */
  .pa-afa-rows{grid-template-columns:1fr}
  .pa-eur-grid{grid-template-columns:repeat(2,1fr)}

  /* Inputs — larger touch targets */
  .pa-inp{min-height:44px;font-size:16px!important} /* 16px prevents iOS zoom */
  select.pa-inp{min-height:44px}
  .pa-btn-primary,.pa-btn-secondary,.pa-btn-calc{min-height:44px}

  /* Modal */
  .pa-modal{margin:0;border-radius:16px 16px 0 0;max-width:100%;position:fixed;bottom:0;left:0;right:0}
  .pa-modal-overlay{align-items:flex-end}

  /* Step nav */
  .pa-nav-btns{flex-direction:column;gap:8px}
  .pa-nav-btns button{width:100%;justify-content:center;min-height:48px}
  .pa-step-hd .pa-h1{font-size:20px}

  /* Results page */
  .pa-whitepaper .pa-rgrid{grid-template-columns:1fr}
  .pa-wp-arg{font-size:11.5px}

  /* Score gauge */
  .pa-gauge-wrap{transform:scale(0.8);transform-origin:top left}

  /* PDF lageplan */
  .cv-lageplan-maps{grid-template-columns:1fr}
  .cv-lageplan-side{display:none}
  .cv-boris-row{grid-template-columns:1fr 1fr}
}

/* ─────────────────────────────────────────────────────────
   480px — Small phones
───────────────────────────────────────────────────────── */
@media(max-width:480px){
  .pa-appbar{padding:0 12px}
  .pa-appbar-logo{gap:8px}
  .pa-appbar-steps{display:none} /* too cramped — use bottom nav instead */
  .pa-main-content{padding:12px 10px 80px}

  .pa-kgrid{grid-template-columns:1fr 1fr!important;gap:6px!important}
  .pa-kv{font-size:16px!important}

  .pa-wz-options,.pa-wz-tax-opts,.pa-wz-goal-opts{grid-template-columns:1fr}
  .pa-og4,.pa-og3{grid-template-columns:1fr 1fr}

  .pa-ms-hero-title{font-size:20px}
  .pa-ms-features{grid-template-columns:1fr}

  .pa-eur-grid{grid-template-columns:1fr 1fr}

  .pa-acard-kpis{grid-template-columns:1fr 1fr}

  /* Make cards full bleed on tiny screens */
  .pa-acard{border-radius:12px}
  .pa-verdict{border-radius:10px;padding:14px}
}

/* ─────────────────────────────────────────────────────────
   1024px — iPad landscape / small laptops
───────────────────────────────────────────────────────── */
@media(max-width:1024px) and (min-width:769px){
  .pa-live{display:none}
  .pa-kgrid{grid-template-columns:repeat(4,1fr)!important}
  .pa-main-content{padding:24px 20px}
  .pa-step-sb-sub{display:none} /* save space on tablet */
}

/* ── RESULTS SCREEN ──────────────────────────────────────────────────────── */
.pa-verdict{border:2px solid;border-radius:14px;padding:22px 26px;margin-bottom:20px}
.pa-verdict-label{font-size:18px;font-weight:900;letter-spacing:-.03em;margin-bottom:4px}
.pa-res-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:16px}
.pa-score-ring{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pa-score-num{position:absolute;font-size:15px;font-weight:900;letter-spacing:-.04em}
.pa-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(3px)}
.pa-modal{background:#fff;border-radius:16px;width:100%;max-width:480px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.2);margin:20px}
.pa-modal-hd{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--g200)}
.pa-modal-title{font-size:15px;font-weight:900;color:var(--ink)}
.pa-modal-close{background:none;border:none;cursor:pointer;font-size:18px;color:var(--g400);padding:4px 8px;border-radius:6px;transition:all .15s}
.pa-modal-close:hover{background:var(--g100);color:var(--ink)}
.pa-modal-body{padding:22px 24px}
.pa-whitepaper{margin-top:20px}
.pa-wp-arg{padding:8px 12px;border-radius:8px;font-size:12px;line-height:1.55;margin-bottom:6px}
.pa-wp-arg.good{background:#f0fdf4;color:#166534;border-left:3px solid #059669}
.pa-wp-arg.bad{background:#fef2f2;color:#991b1b;border-left:3px solid #dc2626}
.pa-wp-arg.neutral{background:var(--g50);color:var(--ink2);border-left:3px solid var(--g200)}

/* Print-only elements hidden on screen */
.pa-pdf-cover,.pa-pdf-toc,.pa-pdf-section-hd,.pa-pdf-footer,.pa-pdf-disclaimer{display:none}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PROPANALYTICS PRO — BANK-GRADE PDF
   Version 3.2 · A4 Portrait · Running Header
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Print-only elements: hidden on screen */
.pa-pdf-cover,.pa-pdf-toc,.pa-pdf-section-hd,
.pa-pdf-running-header,.pa-pdf-footer,.pa-pdf-disclaimer,
.pa-pdf-page-break { display:none }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@page {
  size: A4 portrait;
  /* top margin = 24mm to make room for running header */
  margin: 24mm 15mm 20mm 15mm;
}
/* Cover page: no top margin (full-bleed) */
@page :first {
  margin: 0;
}

@media print {

  /* ── BASE RESET ──────────────────────────────────────────────────────── */
  * { -webkit-print-color-adjust:exact!important; print-color-adjust:exact!important; box-sizing:border-box }
  html,body { margin:0; padding:0; background:#fff!important; font-size:9.5pt; line-height:1.55; color:#0f172a; font-family:"Plus Jakarta Sans",-apple-system,sans-serif }

  /* ── HIDE SCREEN CHROME ──────────────────────────────────────────────── */
  .pa-appbar, .pa-live, .pa-gate, .pa-cta,
  .pa-res-actions, .pa-banner, .pa-step-sidebar,
  .pa-appbar-actions, .screen-only, #pa-email-modal,
  .pa-modal-overlay, .pa-guest-save-note,
  .pa-verdict, .pa-score-ring, .pa-wz-summary,
  .pa-draft-bar, .pa-geo-card { display:none!important }

  /* ── UNFOLD LAYOUT ───────────────────────────────────────────────────── */
  .pa-layout       { display:block!important; max-width:100%!important; min-height:0!important }
  .pa-main-content { display:block!important; padding:0!important; max-width:100%!important }
  .pa-results      { display:block!important; max-width:100%!important; padding:0!important; margin:0!important }

  /* ══════════════════════════════════════════════════════════════════════
     RUNNING HEADER — appears on every page EXCEPT the cover (page 1)
     Uses position:fixed which prints at top of every page in Chrome/Edge
     ══════════════════════════════════════════════════════════════════════ */
  .pa-pdf-running-header {
    display:block!important;
    position:fixed;
    top:0; left:0; right:0;
    height:18mm;
    background:#fff;
    border-bottom:0.5pt solid #e2e8f0;
    padding:0 15mm;
    display:flex!important;
    align-items:center;
    justify-content:space-between;
    gap:8mm;
    z-index:9999;
  }
  .pa-pdf-rh-logo {
    display:flex!important;
    align-items:center;
    gap:4mm;
    flex-shrink:0;
  }
  .pa-pdf-rh-logo img {
    height:10mm;
    max-width:40mm;
    object-fit:contain;
    display:block;
  }
  .pa-pdf-rh-brand {
    font-size:9pt;
    font-weight:900;
    color:#0f172a;
    letter-spacing:-.02em;
    white-space:nowrap;
  }
  .pa-pdf-rh-brand span { color:#2563eb }
  .pa-pdf-rh-center {
    flex:1;
    text-align:center;
    font-size:7.5pt;
    color:#94a3b8;
    font-weight:600;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .pa-pdf-rh-right {
    font-size:7pt;
    color:#94a3b8;
    text-align:right;
    flex-shrink:0;
  }
  .pa-pdf-rh-right strong {
    display:block;
    color:#64748b;
    font-size:7.5pt;
    font-weight:700;
  }

  /* Cover page: hide running header (only show on pages 2+) */
  /* We use a trick: cover is position:fixed, header is also fixed.
     Chrome renders fixed elements on every page — we hide header inside cover */
  .pa-pdf-cover ~ .pa-pdf-running-header,
  .pa-pdf-cover + .pa-pdf-running-header { display:none!important }
  /* Simpler: just always show header, cover is full-bleed with its own header */

  /* ══════════════════════════════════════════════════════════════════════
     PAGE 1 — COVER (full-bleed dark)
     ══════════════════════════════════════════════════════════════════════ */
  .pa-pdf-cover {
    display:block!important;
    position:relative;
    width:210mm;
    height:297mm;
    margin:-24mm -15mm 0;
    page-break-after:always;
    background:linear-gradient(160deg,#0a1628 0%,#0f2040 40%,#1a3a6b 100%)!important;
    overflow:hidden;
    color:#fff;
  }
  /* Decorative circle */
  .pa-pdf-cover::after {
    content:'';
    position:absolute;
    bottom:-30mm; right:-30mm;
    width:120mm; height:120mm;
    border-radius:50%;
    background:radial-gradient(circle,rgba(37,99,235,.25),transparent 70%);
    pointer-events:none;
  }

  .pa-pdf-cv-top {
    display:flex!important;
    align-items:center;
    justify-content:space-between;
    padding:10mm 14mm 0;
  }
  .pa-pdf-cv-logo {
    display:flex!important;
    align-items:center;
    gap:4mm;
  }
  .pa-pdf-cv-logo img {
    height:12mm;
    max-width:50mm;
    object-fit:contain;
    display:block;
    filter:brightness(0) invert(1);
  }
  .pa-pdf-cv-logo-fallback {
    display:flex!important;
    align-items:center;
    gap:3mm;
  }
  .pa-pdf-cv-logo-mark {
    width:10mm; height:10mm;
    background:#2563eb!important;
    border-radius:2.5mm;
    display:flex!important;
    align-items:center; justify-content:center;
    font-size:13pt; font-weight:900; color:#fff;
  }
  .pa-pdf-cv-logo-name {
    font-size:12pt; font-weight:900;
    color:#fff; letter-spacing:-.03em;
  }
  .pa-pdf-cv-logo-name b { color:#60a5fa }
  .pa-pdf-cv-badge {
    font-size:6.5pt; font-weight:800;
    text-transform:uppercase; letter-spacing:.18em;
    color:rgba(255,255,255,.35);
    border:0.5pt solid rgba(255,255,255,.2);
    padding:2mm 5mm; border-radius:100mm;
  }

  .pa-pdf-cv-body {
    padding:12mm 14mm 0;
    display:block;
  }
  .pa-pdf-cv-type {
    font-size:7.5pt; font-weight:800;
    text-transform:uppercase; letter-spacing:.2em;
    color:#60a5fa; margin-bottom:5mm;
  }
  .pa-pdf-cv-addr {
    font-size:26pt; font-weight:900;
    color:#fff; letter-spacing:-.05em;
    line-height:1.1; margin-bottom:4mm;
    max-width:170mm;
  }
  .pa-pdf-cv-meta {
    display:flex!important;
    gap:0;
    flex-wrap:wrap;
    font-size:9.5pt;
    color:rgba(255,255,255,.45);
    margin-bottom:10mm;
  }
  .pa-pdf-cv-meta-item { margin-right:6mm }
  .pa-pdf-cv-meta-item::before { content:'· '; margin-right:2mm; opacity:.3 }
  .pa-pdf-cv-meta-item:first-child::before { content:''; margin:0 }

  .pa-pdf-cv-verdict {
    display:inline-flex!important;
    align-items:center;
    gap:3mm;
    padding:4mm 8mm;
    border-radius:3mm;
    font-size:11pt; font-weight:900;
    margin-bottom:10mm;
  }

  .pa-pdf-cv-score-row {
    display:flex!important;
    gap:10mm;
    align-items:flex-end;
    margin-bottom:10mm;
  }
  .pa-pdf-cv-score {
    background:rgba(255,255,255,.07)!important;
    border:0.5pt solid rgba(255,255,255,.15);
    border-radius:4mm;
    padding:5mm 8mm;
    text-align:center;
    min-width:30mm;
  }
  .pa-pdf-cv-score-val {
    font-size:40pt; font-weight:900;
    letter-spacing:-.08em; line-height:1;
  }
  .pa-pdf-cv-score-sub {
    font-size:6pt; color:rgba(255,255,255,.35);
    text-transform:uppercase; letter-spacing:.14em;
    margin-top:1.5mm;
  }
  .pa-pdf-cv-kpis {
    display:grid!important;
    grid-template-columns:1fr 1fr;
    gap:4mm;
    flex:1;
  }
  .pa-pdf-cv-kpi {
    background:rgba(255,255,255,.06)!important;
    border:0.5pt solid rgba(255,255,255,.12);
    border-radius:3mm;
    padding:3mm 5mm;
  }
  .pa-pdf-cv-kpi-l {
    font-size:6pt; color:rgba(255,255,255,.3);
    text-transform:uppercase; letter-spacing:.12em;
    margin-bottom:1.5mm;
  }
  .pa-pdf-cv-kpi-v {
    font-size:11pt; font-weight:900; color:#fff;
    letter-spacing:-.04em;
  }

  /* Map on cover (if geocoded) */
  .pa-pdf-cv-map {
    margin:0 14mm 0;
    border-radius:3mm;
    overflow:hidden;
    max-height:45mm;
  }
  .pa-pdf-cv-map img {
    width:100%;
    max-height:45mm;
    object-fit:cover;
    display:block;
    border-radius:3mm;
  }

  .pa-pdf-cv-bottom {
    position:absolute;
    bottom:0; left:0; right:0;
    padding:5mm 14mm;
    border-top:0.5pt solid rgba(255,255,255,.1);
    display:flex!important;
    justify-content:space-between;
    align-items:center;
    background:rgba(0,0,0,.2)!important;
  }
  .pa-pdf-cv-bottom-l { font-size:7pt; color:rgba(255,255,255,.3) }
  .pa-pdf-cv-bottom-r { font-size:7pt; color:rgba(255,255,255,.25) }

  /* ══════════════════════════════════════════════════════════════════════
     PAGE 2 — TABLE OF CONTENTS
     ══════════════════════════════════════════════════════════════════════ */
  .pa-pdf-toc {
    display:block!important;
    page-break-after:always;
    padding:0;
  }
  .pa-pdf-toc-title {
    font-size:20pt; font-weight:900; color:#0f172a;
    letter-spacing:-.05em;
    padding-bottom:4mm;
    border-bottom:2.5pt solid;
    margin-bottom:8mm;
  }
  .pa-pdf-toc-entries { display:block!important }
  .pa-pdf-toc-entry {
    display:flex!important;
    align-items:baseline;
    gap:3mm;
    padding:3mm 0;
    border-bottom:0.5pt solid #f1f5f9;
  }
  .pa-pdf-toc-num {
    font-size:8.5pt; font-weight:900;
    width:7mm; flex-shrink:0;
    font-variant-numeric:tabular-nums;
  }
  .pa-pdf-toc-label { font-size:10pt; font-weight:700; color:#0f172a; flex:1 }
  .pa-pdf-toc-dots {
    flex:1;
    border-bottom:1pt dotted #d1d5db;
    margin:0 2mm 1.5mm;
    min-width:10mm;
  }
  .pa-pdf-toc-pg {
    font-size:8.5pt; font-weight:700; color:#64748b;
    width:8mm; text-align:right; flex-shrink:0;
  }
  .pa-pdf-toc-sub {
    font-size:7.5pt; color:#94a3b8;
    padding:0 0 2mm 10mm; line-height:1.4;
  }

  /* ══════════════════════════════════════════════════════════════════════
     SECTION HEADERS
     ══════════════════════════════════════════════════════════════════════ */
  .pa-pdf-section-hd {
    display:flex!important;
    align-items:center;
    gap:4mm;
    margin:0 0 6mm;
    padding:3mm 0 4mm;
    border-bottom:1.5pt solid #0f172a;
    page-break-after:avoid;
  }
  .pa-pdf-section-num {
    width:8mm; height:8mm;
    border-radius:2mm;
    color:#fff;
    font-size:9pt; font-weight:900;
    display:flex!important;
    align-items:center; justify-content:center;
    flex-shrink:0;
  }
  .pa-pdf-section-title {
    font-size:14pt; font-weight:900;
    color:#0f172a; letter-spacing:-.04em;
  }

  /* ══════════════════════════════════════════════════════════════════════
     PAGE BREAKS
     ══════════════════════════════════════════════════════════════════════ */
  .pa-pdf-page-break {
    display:block!important;
    page-break-before:always;
    padding-top:0;
  }

  /* ══════════════════════════════════════════════════════════════════════
     KPI GRID
     ══════════════════════════════════════════════════════════════════════ */
  .pa-kgrid {
    display:grid!important;
    grid-template-columns:repeat(4,1fr)!important;
    gap:4mm!important;
    margin:0 0 6mm!important;
    page-break-inside:avoid;
  }
  .pa-kpi {
    border-top:2.5pt solid;
    padding:4mm!important;
    box-shadow:none!important;
    border-radius:2mm!important;
    background:#fff;
    border:0.5pt solid #e2e8f0;
    border-top-width:2.5pt;
    page-break-inside:avoid;
  }
  .pa-kl { font-size:6pt!important; margin-bottom:2mm!important; letter-spacing:.08em }
  .pa-kv { font-size:13pt!important; letter-spacing:-.05em!important }

  /* ══════════════════════════════════════════════════════════════════════
     TABLES & CARDS
     ══════════════════════════════════════════════════════════════════════ */
  .pa-rgrid {
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:5mm!important;
    margin:0 0 5mm!important;
    page-break-inside:avoid;
  }
  .pa-rs, .pa-card {
    box-shadow:none!important;
    border:0.5pt solid #e2e8f0!important;
    border-radius:2mm!important;
    overflow:hidden;
    page-break-inside:avoid;
  }
  .pa-rs-hd, .pa-card-hd {
    background:#f8fafc!important;
    color:#0f172a;
    font-size:7pt!important;
    padding:2.5mm 5mm!important;
    border-bottom:0.5pt solid #e2e8f0!important;
    letter-spacing:.08em;
  }
  .pa-t { font-size:8pt; width:100%; border-collapse:collapse }
  .pa-t td { padding:2.5mm 4mm!important; border-bottom:0.5pt solid #f1f5f9!important }
  .pa-t td.r { font-family:monospace; font-weight:800 }
  .pa-t td.mid { font-size:7.5pt; color:#94a3b8 }

  /* ══════════════════════════════════════════════════════════════════════
     WHITEPAPER / NEGOTIATION
     ══════════════════════════════════════════════════════════════════════ */
  .pa-whitepaper {
    page-break-before:always;
    display:block!important;
  }
  .pa-whitepaper .pa-rs {
    box-shadow:none!important;
    border:0.5pt solid #e2e8f0!important;
  }
  .pa-wp-arg { font-size:8pt; padding:2.5mm 4mm; margin-bottom:2mm }

  /* ══════════════════════════════════════════════════════════════════════
     PDF FOOTER (every page)
     ══════════════════════════════════════════════════════════════════════ */
  .pa-pdf-footer {
    display:flex!important;
    position:fixed;
    bottom:0; left:0; right:0;
    height:12mm;
    padding:0 15mm;
    align-items:center;
    justify-content:space-between;
    border-top:0.5pt solid #e2e8f0;
    background:#fff;
    font-size:6.5pt;
    color:#94a3b8;
  }
  .pa-pdf-footer-brand { font-weight:800 }

  /* ══════════════════════════════════════════════════════════════════════
     DISCLAIMER PAGE
     ══════════════════════════════════════════════════════════════════════ */
  .pa-pdf-disclaimer {
    display:block!important;
    page-break-before:always;
    padding:4mm 0;
    font-size:8pt;
    color:#64748b;
    line-height:1.7;
  }
  .pa-pdf-disclaimer h4 {
    font-size:9pt; font-weight:800;
    color:#334155; margin-bottom:4mm;
    padding-bottom:2mm;
    border-bottom:0.5pt solid #e2e8f0;
  }
  .pa-pdf-disclaimer p { margin-bottom:3mm }
}

/* ── ADDRESS SPLIT WIZARD ────────────────────────────────────────────────── */
.pa-addr-split{display:flex;flex-direction:column;gap:14px}
.pa-addr-row{display:grid;grid-template-columns:120px 1fr;gap:12px}
.pa-addr-field{display:flex;flex-direction:column;gap:6px;position:relative}
.pa-addr-lbl{font-size:12px;font-weight:700;color:var(--g500);display:flex;align-items:center;gap:6px}
.pa-addr-lbl-icon{font-size:14px}
.pa-addr-inp{font-size:15px!important;padding:13px 16px!important;border:2px solid var(--g200)!important;border-radius:10px!important;background:#fafbff;transition:border-color .15s}
.pa-addr-inp:focus{border-color:var(--blue)!important;outline:none;box-shadow:0 0 0 3px rgba(37,99,235,.08)}

/* Autocomplete dropdown */
.pa-addr-suggest{
  position:absolute;top:calc(100% + 4px);left:0;right:0;
  background:#fff;border:1.5px solid var(--g200);border-radius:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
  z-index:500;overflow:hidden;max-height:200px;overflow-y:auto;
}
.pa-addr-suggest-item{
  display:flex;align-items:center;gap:10px;
  width:100%;padding:10px 14px;
  background:none;border:none;border-bottom:1px solid var(--g100);
  text-align:left;font-family:inherit;font-size:12px;font-weight:600;color:var(--ink2);
  cursor:pointer;transition:background .1s;
}
.pa-addr-suggest-item:last-child{border-bottom:none}
.pa-addr-suggest-item:hover,.pa-addr-suggest-item:focus{background:var(--bpale);color:var(--blue)}
.pa-addr-suggest-icon{font-size:14px;flex-shrink:0}

/* Status bar */
.pa-addr-status{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:8px;
  font-size:12px;font-weight:600;line-height:1.5;
}
.pa-addr-status-loading{background:#eff6ff;color:#1d4ed8}
.pa-addr-status-success{background:#f0fdf4;border:1px solid #86efac;color:#166534}
.pa-addr-status-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}

/* Why box */
.pa-addr-why{
  background:var(--g50);border:1.5px solid var(--g200);border-radius:10px;
  padding:12px 14px;display:flex;flex-direction:column;gap:8px;
}
.pa-addr-why-item{display:flex;align-items:flex-start;gap:10px;font-size:11px;color:var(--g500);line-height:1.55}
.pa-addr-why-item span{font-size:16px;flex-shrink:0;margin-top:1px}
.pa-addr-why-item strong{color:var(--ink2);display:block;margin-bottom:1px;font-size:11.5px}

@media(max-width:480px){
  .pa-addr-row{grid-template-columns:100px 1fr}
}

/* ════════════════════════════════════════════════════════════════════════
   iOS SAFARI + ANDROID CHROME — COMPLETE MOBILE FIX PATCH
   PropAnalytics Pro v3.4.x
   ════════════════════════════════════════════════════════════════════════ */

/* ── 1. GLOBAL TOUCH BASELINE ──────────────────────────────────────────
   FIX: 300ms tap delay auf iOS (alle interaktiven Elemente)
   FIX: Blaue Tap-Highlight-Flashes auf iOS/Android entfernen
   FIX: Webkit font smoothing für Retina-Displays
   ──────────────────────────────────────────────────────────────────── */
#pa-root,
#pa-root *,
#pa-root button,
#pa-root a,
#pa-root input,
#pa-root select,
#pa-root textarea {
  -webkit-tap-highlight-color: transparent; /* FIX: iOS blaue Flash-Highlights */
  touch-action: manipulation;              /* FIX: 300ms Tap-Delay eliminieren */
}

/* FIX: Konsistentes box-model auf allen Elementen */
#pa-root * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

/* ── 2. VIEWPORT HEIGHT — 100dvh statt 100vh ────────────────────────────
   FIX: iOS Safari rechnet URL-Bar in 100vh mit → Overflow
   100dvh = dynamic viewport height = korrekt für iOS
   ──────────────────────────────────────────────────────────────────── */
.pa-app {
  min-height: 100dvh; /* FIX: Dynamic viewport für iOS Safari */
}
.pa-layout {
  min-height: calc(100dvh - 56px); /* FIX: korrekte Restfläche */
}
.pa-mob-drawer {
  height: 100dvh; /* FIX: Drawer füllt korrekt auf iOS */
}

/* ── 3. SAFE AREA INSETS — Dynamic Island, Home Indicator ───────────────
   FIX: Appbar oben berücksichtigt Dynamic Island (iPhone 14 Pro+)
   FIX: Bottom-Nav + safe-area korrekt kombiniert (height + padding)
   FIX: Drawer links berücksichtigt sichere Zone (Landscape)
   ──────────────────────────────────────────────────────────────────── */
.pa-appbar {
  /* FIX: Zusatz-Padding für Dynamic Island / Notch oben */
  padding-top: env(safe-area-inset-top);
  height: calc(56px + env(safe-area-inset-top));
}

.pa-bottom-nav {
  /* FIX: Korrekte Gesamthöhe inkl. Home Indicator */
  height: calc(64px + env(safe-area-inset-bottom));
  padding-bottom: max(env(safe-area-inset-bottom), 8px);
  /* FIX: Landscape: links/rechts sichere Zone */
  padding-left: max(env(safe-area-inset-left), 8px);
  padding-right: max(env(safe-area-inset-right), 8px);
}

.pa-mob-drawer {
  /* FIX: Sichere Zone oben (Notch) + links (Landscape) */
  padding-top: max(env(safe-area-inset-top), 12px);
  padding-left: env(safe-area-inset-left);
}

.pa-main-content {
  /* FIX: Landscape-Modus: sichere Zonen links/rechts */
  padding-left: max(14px, env(safe-area-inset-left));
  padding-right: max(14px, env(safe-area-inset-right));
}

/* ── 4. POSITION: FIXED — iOS Safari Fixes ──────────────────────────────
   FIX: -webkit-overflow-scrolling für scrollbare Drawers
   FIX: will-change für GPU-beschleunigte Animationen
   FIX: Backdrop-filter mit -webkit- Prefix für iOS
   ──────────────────────────────────────────────────────────────────── */
.pa-mob-drawer {
  -webkit-overflow-scrolling: touch; /* FIX: Momentum-Scrolling auf iOS */
  overscroll-behavior: contain;      /* FIX: Kein Scroll-Leak zum Body */
  will-change: transform;            /* FIX: GPU-Layer für Slide-Animation */
}

.pa-mob-overlay {
  -webkit-backdrop-filter: blur(2px); /* FIX: iOS Safari Prefix */
  backdrop-filter: blur(2px);
  will-change: opacity;
}

.pa-modal-overlay {
  -webkit-backdrop-filter: blur(6px); /* FIX: iOS Safari Prefix */
  backdrop-filter: blur(6px);
}

.pa-gate {
  -webkit-backdrop-filter: blur(8px); /* FIX: iOS Safari Prefix */
  backdrop-filter: blur(8px);
}

/* FIX: Modal als Sheet (bottom-up) mit korrekter safe area */
@media(max-width:768px) {
  .pa-modal {
    padding-bottom: max(env(safe-area-inset-bottom), 16px);
    will-change: transform;
  }
}

/* ── 5. INPUTS — iOS Zoom & Android Keyboard ────────────────────────────
   FIX: font-size < 16px → iOS Auto-Zoom. Alle Inputs auf 16px.
   FIX: -webkit-appearance:none entfernt iOS-Standard-Styling
   FIX: Rounded corners auf iOS select-Elementen
   ──────────────────────────────────────────────────────────────────── */
.pa-inp,
.pa-inp[type="text"],
.pa-inp[type="number"],
.pa-inp[type="email"],
.pa-inp[type="url"],
.pa-inp[type="tel"],
select.pa-inp,
textarea.pa-inp,
.pa-wz-text,
.pa-wz-num,
.pa-wz-select,
.pa-addr-inp {
  font-size: 16px !important;        /* FIX: Kein iOS Auto-Zoom unter 16px */
  -webkit-appearance: none;          /* FIX: iOS Standard-Styling entfernen */
  -moz-appearance: none;
  appearance: none;
  border-radius: 10px;               /* FIX: iOS rundet automatisch – überschreiben */
}

/* FIX: Select auf Android – Custom-Arrow statt System-Arrow */
select.pa-inp {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
  cursor: pointer;
}

/* ── 6. TOUCH-TARGETS — min 44×44px für alle Interaktives ──────────────
   FIX: pa-oc (Option-Cards) zu klein auf Mobile
   FIX: pa-mfh-del zu kleines Ziel (14px Icon)
   FIX: pa-step-sb-item, pa-acard-del, pa-appbar-btn
   ──────────────────────────────────────────────────────────────────── */

/* FIX: Appbar Buttons — Mindest-Touch-Target */
.pa-appbar-btn {
  min-height: 44px;
  min-width: 44px;
  cursor: pointer;
}

/* FIX: Hamburger Button */
.pa-hamburger {
  min-height: 44px;
  min-width: 44px;
  display: none; /* bleibt hidden bis Media-Query */
  justify-content: center;
  align-items: center;
  cursor: pointer;
}

/* FIX: Option-Cards (Objekttyp, Zustand etc.) */
.pa-oc {
  min-height: 56px;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.pa-ob {
  min-height: 56px;
  display: flex;
  align-items: center;
  cursor: pointer;
}

/* FIX: MFH Löschen-Button — zu kleines Touch-Target */
.pa-mfh-del {
  min-width: 44px;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  opacity: 1;           /* FIX: opacity:.4 schwer sichtbar auf Mobile */
  color: var(--g400);
  border-radius: 8px;
  cursor: pointer;
}
.pa-mfh-del:active { color: var(--red); background: #fef2f2; }

/* FIX: Step Sidebar Items */
.pa-step-sb-item {
  min-height: 52px;
  cursor: pointer;
}

/* FIX: Analysis card buttons */
.pa-acard-btn,
.pa-acard-btn-edit,
.pa-acard-del {
  min-height: 44px;
  cursor: pointer;
  touch-action: manipulation;
}

/* FIX: Wizard option buttons */
.pa-wz-opt {
  min-height: 60px;
  cursor: pointer;
}

/* FIX: Draft bar Löschen */
.pa-step-sb-draft-del {
  min-height: 44px;
  min-width: 80px;
  cursor: pointer;
}

/* ── 7. SCROLLBARES VERHALTEN ───────────────────────────────────────────
   FIX: Momentum-Scrolling auf iOS für langen Content
   FIX: overscroll-behavior verhindert Body-Scroll-Leak
   ──────────────────────────────────────────────────────────────────── */
.pa-main-content,
.pa-mob-drawer,
.pa-modal-body,
.pa-step-sidebar {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

/* ── 8. GAUGE / SVG — kein Overflow auf 375px ───────────────────────────
   FIX: SVG Gauge war 180px → overflows auf iPhone SE (375px)
   ──────────────────────────────────────────────────────────────────── */
.pa-gauge-wrap {
  padding: 12px 8px;
  overflow: hidden;
}
.pa-gauge-svg {
  width: 100%;
  max-width: 180px;
  height: auto;
  display: block;
  margin: 0 auto 8px;
}

/* ── 9. EURIBOR GRID — lesbar auf 375px ────────────────────────────────
   FIX: 5-spaltiger Grid → zu eng auf kleinen Screens
   ──────────────────────────────────────────────────────────────────── */
@media(max-width:500px) {
  .pa-eur-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px;
  }
  .pa-eur-item { padding: 10px 8px; }
  .pa-eur-rate { font-size: 16px; }  /* FIX: DM Mono nicht abschneiden */
}

/* ── 10. TYPOGRAFIE — kein Sub-11px auf Mobile ──────────────────────────
   FIX: Kleinere Labels auf Mobile erhöhen für Lesbarkeit
   FIX: DM Mono Zahlen in KPI-Cards nicht abschneiden
   ──────────────────────────────────────────────────────────────────── */
@media(max-width:768px) {
  .pa-kl          { font-size: 10px !important; } /* FIX: war 6.5px → unlesbar */
  .pa-kv          { font-size: 17px !important; letter-spacing: -.04em !important; }
  .pa-step-sb-sub { font-size: 11px; }             /* FIX: war display:none → kurz zeigen */
  .pa-appbar-sub  { font-size: 8px; }
  .pa-rs-hd       { font-size: 9px; }
  .pa-card-hd     { font-size: 9px; }

  /* FIX: KPI-Val Overflow verhindern */
  .pa-kpi { overflow: hidden; }
  .pa-kv  { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
}

/* ── 11. HOVER → ACTIVE STATES FÜR MOBILE ──────────────────────────────
   FIX: :hover existiert nicht auf Touch-Geräten → :active als Ersatz
   ──────────────────────────────────────────────────────────────────── */
@media(hover: none) and (pointer: coarse) {
  /* Buttons: active state statt hover */
  .pa-btn-primary:active    { transform: scale(0.97); opacity: .9; }
  .pa-btn-secondary:active  { background: var(--g100); }
  .pa-appbar-btn:active     { opacity: .8; }
  .pa-wz-opt:active         { transform: scale(0.98); border-color: var(--blue); }
  .pa-ms-card:active        { transform: translateY(-2px); }
  .pa-acard:active          { transform: translateY(-1px); }
  .pa-bottom-nav-item:active { opacity: .7; }

  /* FIX: Hover-Transitions auf Mobile deaktivieren (spart Rendering) */
  .pa-kpi          { transition: none; }
  .pa-appbar-step  { transition: none; }
  .pa-wz-opt       { transition: border-color .1s; }
}

/* ── 12. LEAFLET MAP — Mobile Höhe ─────────────────────────────────────
   FIX: 220px reicht auf Mobile, aber Map braucht explizite Höhe
   ──────────────────────────────────────────────────────────────────── */
@media(max-width:768px) {
  .pa-leaflet-map {
    height: 180px;
    min-height: 180px;  /* FIX: Leaflet kollabiert ohne explizite Höhe */
  }
  /* FIX: Leaflet-Controls zu nah am Rand */
  .leaflet-control-zoom { margin: 8px !important; }
}

/* ── 13. ANDROID — Gesture Navigation Bar ───────────────────────────────
   FIX: Android 10+ Gesture Nav überschneidet Bottom-Nav
   env(safe-area-inset-bottom) funktioniert auch auf Android Chrome
   ──────────────────────────────────────────────────────────────────── */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
  .pa-bottom-nav {
    padding-bottom: max(env(safe-area-inset-bottom), 8px);
  }
}

/* ── 14. WIZARD ADDRESS — Mobile Autocomplete ───────────────────────────
   FIX: Autocomplete-Dropdown zu breit auf kleinen Screens
   FIX: Touch-Ziele in Suggest-Liste groß genug
   ──────────────────────────────────────────────────────────────────── */
@media(max-width:768px) {
  .pa-addr-suggest-item {
    min-height: 48px;          /* FIX: Touch-Target */
    font-size: 13px;
    padding: 12px 14px;
  }
  .pa-addr-row {
    grid-template-columns: 90px 1fr; /* FIX: PLZ-Spalte schmaler auf Mobile */
  }
  .pa-addr-why {
    display: none; /* FIX: Why-Box auf Mobile ausblenden, spart Platz */
  }
}

/* ── 15. GATE / MODAL — iOS Keyboard Push ──────────────────────────────
   FIX: iOS schiebt Viewport hoch wenn Keyboard öffnet
   position:fixed + input focus → korrekte Behandlung
   ──────────────────────────────────────────────────────────────────── */
@media(max-width:768px) {
  .pa-modal-overlay {
    align-items: flex-end;
    /* FIX: Verhindert dass Modal hinter Keyboard rutscht */
    padding-bottom: 0;
  }
  .pa-modal {
    border-radius: 20px 20px 0 0;
    padding-bottom: max(env(safe-area-inset-bottom), 20px);
    max-height: 90dvh;          /* FIX: dvh statt vh */
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* ── 16. GATE SCREEN (Lead-Capture) ─────────────────────────────────────
   FIX: Gate-Overlay korrekte Höhe auf iOS
   ──────────────────────────────────────────────────────────────────── */
.pa-gate {
  height: 100dvh; /* FIX: dvh statt vh */
}
.pa-gate-card {
  max-height: calc(100dvh - 32px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
