*{box-sizing:border-box}
:root{
  --bg:#f3f6fb;
  --panel:#ffffff;
  --ink:#0f172a;
  --muted:#64748b;
  --line:#e2e8f0;
  --brand:#2563eb;
  --brand2:#4f46e5;
  --dark:#0b1220;
  --dark2:#111827;
  --green:#16a34a;
  --yellow:#ca8a04;
  --red:#dc2626;
}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:
    radial-gradient(circle at top right,rgba(37,99,235,.15),transparent 30%),
    linear-gradient(135deg,#f8fafc,#eef2ff);
  color:var(--ink);
}
a{text-decoration:none;color:inherit}
.layout{display:grid;grid-template-columns:292px 1fr;min-height:100vh}
.sidebar{
  background:linear-gradient(180deg,#08111f,#111827);
  color:#fff;
  padding:28px;
  position:sticky;
  top:0;
  height:100vh;
  box-shadow:24px 0 70px rgba(15,23,42,.18);
}
.brand{display:flex;gap:14px;align-items:center;margin-bottom:34px}
.brand span,.logo,.invoice-logo{
  width:52px;height:52px;border-radius:18px;
  background:linear-gradient(135deg,var(--brand),var(--brand2));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:900;box-shadow:0 18px 34px rgba(37,99,235,.32)
}
.brand b{font-size:18px;letter-spacing:-.03em}
.brand small{display:block;color:#94a3b8;margin-top:3px}
.sidebar nav{display:grid;gap:10px}
.sidebar nav a{
  padding:14px 16px;border-radius:16px;
  color:#cbd5e1;font-weight:750;transition:.18s ease;
  border:1px solid transparent;
}
.sidebar nav a:hover,.sidebar nav a.active{
  background:rgba(255,255,255,.1);
  color:#fff;
  border-color:rgba(255,255,255,.12);
  transform:translateX(2px);
}
.main{padding:34px;overflow:auto}
.topbar{
  display:flex;justify-content:space-between;align-items:center;margin-bottom:26px;
  background:rgba(255,255,255,.68);
  border:1px solid rgba(255,255,255,.75);
  border-radius:30px;
  padding:24px;
  box-shadow:0 24px 70px rgba(15,23,42,.08);
  backdrop-filter:blur(14px);
}
.topbar p{margin:0;color:var(--muted);font-weight:700}
.topbar h1{margin:4px 0 0;font-size:42px;letter-spacing:-.055em;line-height:1}
.btn{
  border:0;border-radius:16px;padding:13px 18px;font-weight:850;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  cursor:pointer;transition:.18s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn.primary{
  background:linear-gradient(135deg,var(--brand),var(--brand2));
  color:#fff;box-shadow:0 18px 32px rgba(37,99,235,.26)
}
.btn.light{background:#e8eef8;color:#0f172a;border:1px solid #dbe4f0}
.btn.full{width:100%;margin-top:16px}
.cards{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px
}
.card,.panel,.auth-card{
  background:rgba(255,255,255,.9);
  border:1px solid rgba(226,232,240,.85);
  border-radius:30px;
  box-shadow:0 24px 70px rgba(15,23,42,.08);
}
.card{padding:24px;position:relative;overflow:hidden}
.card:before{
  content:"";position:absolute;inset:auto -40px -55px auto;
  width:140px;height:140px;background:rgba(37,99,235,.09);
  border-radius:999px
}
.card span{display:block;color:var(--muted);font-size:14px;font-weight:800}
.card strong{display:block;margin-top:12px;font-size:30px;letter-spacing:-.04em}
.card.danger strong{color:var(--red)}
.panel{padding:26px}
.panel-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:22px}
.panel h2{margin:0;font-size:24px;letter-spacing:-.035em}
.panel p{color:var(--muted);margin:7px 0 0;font-weight:500}
.filters{display:flex;gap:10px;flex-wrap:wrap}
input,select,textarea{
  width:100%;border:1px solid #dbe4f0;background:#f8fafc;border-radius:16px;
  padding:14px 15px;font:inherit;outline:none;transition:.16s ease;
}
input:focus,select:focus,textarea:focus{
  border-color:rgba(37,99,235,.55);
  box-shadow:0 0 0 4px rgba(37,99,235,.10);
  background:#fff;
}
textarea{min-height:112px;resize:vertical}
label{display:block;font-size:13px;font-weight:850;color:#334155;margin:14px 0 8px}
.table-wrap{overflow:auto;border-radius:22px;border:1px solid var(--line)}
table{width:100%;border-collapse:collapse;background:#fff}
th{
  text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.09em;
  color:#64748b;background:#f1f5f9;font-weight:900
}
th,td{padding:16px;border-bottom:1px solid #eef2f7;white-space:nowrap}
tbody tr{transition:.14s ease}
tbody tr:hover{background:#f8fbff}
.badge{
  display:inline-flex;border-radius:999px;padding:7px 12px;font-size:12px;font-weight:900;
  background:#e0e7ff;color:#3730a3;border:1px solid #c7d2fe
}
.badge.bezahlt{background:#dcfce7;color:#166534;border-color:#bbf7d0}
.badge.offen{background:#fef3c7;color:#92400e;border-color:#fde68a}
.badge.ueberfaellig{background:#fee2e2;color:#991b1b;border-color:#fecaca}
.badge.entwurf{background:#e2e8f0;color:#334155;border-color:#cbd5e1}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.actions a{
  font-size:13px;font-weight:850;background:#eef2ff;color:#1e40af;
  border-radius:13px;padding:8px 11px;border:1px solid #dbeafe
}
.actions a:hover{background:#dbeafe}
.actions a.delete{color:#991b1b;background:#fee2e2;border-color:#fecaca}
.grid-two{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form.wide{max-width:980px}
.auth-bg{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at top left,#dbeafe,transparent 36%),#f6f7fb
}
.auth-card{width:min(440px,92vw);padding:34px}
.auth-card h1{letter-spacing:-.045em;margin-bottom:6px}
.auth-card p,.auth-card small{color:var(--muted)}
.alert.error{background:#fee2e2;color:#991b1b;border-radius:16px;padding:14px;margin:14px 0;font-weight:800}
.alert.success{background:#dcfce7;color:#166534;border-radius:16px;padding:14px 16px;margin-bottom:18px;font-weight:800}
.hint{background:#f1f5f9;padding:16px;border-radius:16px;line-height:1.8}
.warning{color:#b45309!important}

/* Position editor */
.positions-head{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;margin:30px 0 14px}
.positions-head h2{margin:0}
.positions-head p{margin:6px 0 0;color:var(--muted)}
.positions-table{border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#fff}
.pos-row{display:grid;grid-template-columns:2fr .7fr .8fr .9fr .9fr 44px;gap:10px;align-items:center;padding:12px;border-bottom:1px solid #eef2f7}
.pos-row:last-child{border-bottom:0}
.pos-header{background:#f1f5f9;color:#64748b;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}
.pos-row input{padding:11px;border-radius:13px}
.row-total{font-weight:900;text-align:right}
.mini{border:0;border-radius:12px;width:34px;height:34px;font-weight:900;cursor:pointer}
.mini.danger{background:#fee2e2;color:#991b1b}
.sum-box{
  margin:18px 0 24px;margin-left:auto;max-width:340px;
  background:linear-gradient(135deg,#0f172a,#1e3a8a);color:#fff;border-radius:24px;
  padding:20px;display:flex;justify-content:space-between;align-items:center;
  box-shadow:0 20px 44px rgba(30,58,138,.22)
}
.sum-box span{color:#cbd5e1;font-weight:850}
.sum-box strong{font-size:26px}

/* Company settings */
.company-logo-box{display:flex;align-items:center;justify-content:space-between;gap:22px;background:#f8fafc;border:1px solid var(--line);border-radius:24px;padding:20px;margin-bottom:20px}
.company-logo-preview{max-width:170px;max-height:86px;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:18px;padding:10px}
.company-logo-placeholder{width:150px;height:78px;border-radius:18px;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900}
.small-muted{font-size:13px;color:var(--muted);margin:8px 0 0}

/* Invoice / PDF page */
.invoice-page{background:#e8edf5}
.invoice-actions{
  max-width:920px;margin:28px auto 14px;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap
}
.mail-alert{max-width:920px;margin:0 auto 14px;border-radius:16px;padding:14px 18px;font-weight:850}
.mail-alert.success{background:#dcfce7;color:#166534}
.mail-alert.error{background:#fee2e2;color:#991b1b}
.invoice-sheet{
  max-width:920px;margin:0 auto 42px;background:#fff;border-radius:32px;padding:58px;
  box-shadow:0 28px 90px rgba(15,23,42,.18)
}
.invoice-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);padding-bottom:32px}
.invoice-header.premium{align-items:flex-start}
.company-block{display:flex;gap:18px;align-items:flex-start}
.company-block h2{margin:0 0 6px;font-size:23px;letter-spacing:-.035em}
.company-block p{margin:0;color:var(--muted);line-height:1.55}
.document-title{text-align:right}
.document-title h1,.invoice-header h1{font-size:44px;margin:0;letter-spacing:-.055em}
.invoice-company-logo{width:104px;height:68px;object-fit:contain;border-radius:16px;background:#fff}
.invoice-meta{display:grid;grid-template-columns:1fr 1fr;gap:50px;margin:42px 0}
.invoice-meta p{line-height:1.7;color:#475569}
.invoice-table th,.invoice-table td{white-space:normal}
.invoice-table tfoot td{font-size:20px;font-weight:950;background:#f8fafc}
.invoice-note{margin-top:30px;background:#f8fafc;border-radius:20px;padding:18px}
.invoice-note p{color:#475569;line-height:1.6}
.invoice-footer{margin-top:40px;border-top:1px solid var(--line);padding-top:18px;display:flex;justify-content:space-between;gap:24px;color:#475569;font-size:13px;line-height:1.6}
.thanks{margin-top:42px;color:var(--muted);font-weight:700}

@media(max-width:1100px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){
  .layout{grid-template-columns:1fr}
  .sidebar{height:auto;position:relative}
  .cards,.grid-two,.invoice-meta{grid-template-columns:1fr}
  .panel-head,.topbar{flex-direction:column;align-items:stretch}
  .main{padding:18px}
  .pos-header{display:none}
  .pos-row{grid-template-columns:1fr;gap:8px}
  .row-total{text-align:left;background:#f8fafc;border-radius:12px;padding:10px}
  .company-logo-box,.invoice-footer,.invoice-header.premium,.company-block{flex-direction:column}
  .document-title{text-align:left}
  .invoice-sheet{padding:28px;border-radius:0}
}
@media print{
  .no-print,.invoice-actions,.mail-alert{display:none!important}
  .invoice-page{background:#fff}
  .invoice-sheet{box-shadow:none;margin:0;max-width:none;border-radius:0}
  .invoice-footer{break-inside:avoid}
}


@page { size: A4; margin: 12mm; }
@media print {
  html, body {
    background: #fff !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .invoice-page { background: #fff !important; }
  .invoice-sheet {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
  }
  .invoice-header { padding-bottom: 24px !important; }
  .invoice-meta { margin: 32px 0 !important; }
  .invoice-table th { background: #f1f5f9 !important; }
  .invoice-table tfoot td { background: #f8fafc !important; }
  .invoice-note { background: #f8fafc !important; }
}


.tax-summary-box{
  margin:18px 0 24px;
  margin-left:auto;
  max-width:380px;
  background:linear-gradient(135deg,#0f172a,#1e3a8a);
  color:#fff;
  border-radius:24px;
  padding:18px 20px;
  box-shadow:0 20px 44px rgba(30,58,138,.22);
  display:grid;
  gap:10px;
}
.tax-summary-box div{
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.tax-summary-box span{
  color:#cbd5e1;
  font-weight:850;
}
.tax-summary-box strong{
  font-size:18px;
}
.tax-summary-box .grand{
  border-top:1px solid rgba(255,255,255,.18);
  padding-top:10px;
}
.tax-summary-box .grand strong{
  font-size:26px;
}


.invoice-form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.mwst-field select{
  border:2px solid rgba(37,99,235,.55);
  background:#fff;
  font-weight:850;
}
.mwst-banner{
  margin:18px 0 6px;
  background:linear-gradient(135deg,#2563eb,#4f46e5);
  color:#fff;
  border-radius:20px;
  padding:15px 18px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  box-shadow:0 18px 34px rgba(37,99,235,.22);
}
.mwst-banner strong{font-weight:900}
.mwst-banner span{font-size:22px;font-weight:950}
.tax-summary-box{
  margin:18px 0 24px;
  margin-left:auto;
  max-width:380px;
  background:linear-gradient(135deg,#0f172a,#1e3a8a);
  color:#fff;
  border-radius:24px;
  padding:18px 20px;
  box-shadow:0 20px 44px rgba(30,58,138,.22);
  display:grid;
  gap:10px;
}
.tax-summary-box div{
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.tax-summary-box span{
  color:#cbd5e1;
  font-weight:850;
}
.tax-summary-box strong{font-size:18px}
.tax-summary-box .grand{
  border-top:1px solid rgba(255,255,255,.18);
  padding-top:10px;
}
.tax-summary-box .grand strong{font-size:26px}
@media(max-width:900px){
  .invoice-form-grid{grid-template-columns:1fr}
}



/* ===========================
   V3 PREMIUM SAAS DESIGN
   =========================== */
:root{
  --v3-bg:#eef4fb;
  --v3-card:#ffffff;
  --v3-ink:#0f172a;
  --v3-muted:#64748b;
  --v3-line:#e2e8f0;
  --v3-blue:#2563eb;
  --v3-indigo:#4f46e5;
  --v3-dark:#07111f;
  --v3-shadow:0 24px 70px rgba(15,23,42,.10);
  --v3-soft-shadow:0 12px 34px rgba(15,23,42,.07);
}

body{
  background:
    radial-gradient(circle at 78% 0%,rgba(37,99,235,.16),transparent 32%),
    radial-gradient(circle at 18% 16%,rgba(14,165,233,.10),transparent 30%),
    linear-gradient(135deg,#f8fafc,#eaf1fb)!important;
}

.layout{
  grid-template-columns:310px minmax(0,1fr)!important;
}

.sidebar{
  background:
    radial-gradient(circle at top left,rgba(37,99,235,.34),transparent 34%),
    linear-gradient(180deg,#06101f,#0b1322 60%,#050b14)!important;
  padding:30px 26px!important;
}

.brand span{
  background:linear-gradient(135deg,#2563eb,#7c3aed)!important;
}

.sidebar nav a{
  border-radius:18px!important;
  padding:16px 17px!important;
  font-size:15px!important;
}

.sidebar nav a.active,
.sidebar nav a:hover{
  background:linear-gradient(135deg,#2563eb,#4f46e5)!important;
  box-shadow:0 18px 38px rgba(37,99,235,.28)!important;
}

.main{
  max-width:1280px!important;
  padding:38px!important;
}

.topbar{
  border-radius:34px!important;
  padding:30px 34px!important;
  background:rgba(255,255,255,.82)!important;
  border:1px solid rgba(255,255,255,.85)!important;
  box-shadow:var(--v3-shadow)!important;
}

.topbar h1{
  font-size:46px!important;
  letter-spacing:-.065em!important;
}

.topbar p{
  color:#64748b!important;
  font-weight:850!important;
}

/* Premium panels */
.panel,
.card,
.auth-card{
  border-radius:34px!important;
  border:1px solid rgba(226,232,240,.9)!important;
  background:rgba(255,255,255,.94)!important;
  box-shadow:var(--v3-shadow)!important;
}

.panel{
  padding:30px!important;
}

.form.wide{
  max-width:1040px!important;
}

/* Form field polish */
label{
  color:#334155!important;
  font-size:12px!important;
  text-transform:none!important;
  letter-spacing:0!important;
  font-weight:900!important;
}

input,select,textarea{
  border-radius:18px!important;
  border:1px solid #dbe4f0!important;
  background:#f8fafc!important;
  padding:15px 16px!important;
  min-height:52px!important;
}

input:focus,select:focus,textarea:focus{
  background:#fff!important;
  border-color:rgba(37,99,235,.62)!important;
  box-shadow:0 0 0 4px rgba(37,99,235,.11)!important;
}

/* Invoice form layout */
.grid-two{
  grid-template-columns:1fr 1fr!important;
  gap:20px!important;
}

.mwst-final-box,
.mwst-pro-box{
  margin:24px 0!important;
  padding:0!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  color:var(--v3-ink)!important;
}

.mwst-final-box h2,
.mwst-pro-box h2{
  font-size:20px!important;
  margin:0 0 6px!important;
  letter-spacing:-.035em!important;
}

.mwst-final-box p,
.mwst-pro-box p{
  color:var(--v3-muted)!important;
  margin:0 0 14px!important;
  font-weight:650!important;
}

.mwst-final-options,
.mwst-pro-options{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:14px!important;
}

.mwst-radio,
.mwst-pro-radio{
  display:flex!important;
  align-items:center!important;
  gap:12px!important;
  background:#f8fafc!important;
  border:1px solid #e2e8f0!important;
  color:#0f172a!important;
  padding:15px 17px!important;
  border-radius:18px!important;
  font-weight:900!important;
  box-shadow:none!important;
}

.mwst-radio input,
.mwst-pro-radio input{
  width:auto!important;
  min-height:auto!important;
  accent-color:#2563eb!important;
  transform:scale(1.16)!important;
}

.mwst-radio:has(input:checked),
.mwst-pro-radio:has(input:checked){
  background:#ffffff!important;
  border-color:#2563eb!important;
  box-shadow:0 0 0 4px rgba(37,99,235,.10)!important;
}

/* Position section */
.positions-head{
  margin-top:28px!important;
  align-items:center!important;
}

.positions-head h2{
  font-size:30px!important;
  letter-spacing:-.05em!important;
}

.positions-head p{
  max-width:580px!important;
  line-height:1.45!important;
}

.positions-table{
  border-radius:26px!important;
  overflow:hidden!important;
  border:1px solid #e2e8f0!important;
  background:#fff!important;
  box-shadow:var(--v3-soft-shadow)!important;
}

.pos-header{
  background:#f1f5f9!important;
  color:#64748b!important;
  font-size:11px!important;
}

.pos-row{
  grid-template-columns:2.2fr .72fr .82fr .95fr .95fr 44px!important;
  padding:14px!important;
  gap:11px!important;
}

.pos-row input{
  min-height:46px!important;
  border-radius:15px!important;
}

.row-total{
  font-weight:950!important;
  color:#0f172a!important;
}

.mini.danger{
  background:#fee2e2!important;
  color:#991b1b!important;
}

/* Totals: clean hero */
.tax-summary-box,
.sum-box{
  background:#ffffff!important;
  color:#0f172a!important;
  border:1px solid #e2e8f0!important;
  box-shadow:var(--v3-soft-shadow)!important;
  border-radius:26px!important;
  padding:20px 22px!important;
  max-width:420px!important;
}

.tax-summary-box span,
.sum-box span{
  color:#64748b!important;
  font-weight:850!important;
}

.tax-summary-box strong,
.sum-box strong{
  color:#0f172a!important;
}

.tax-summary-box .grand,
.sum-box .grand{
  border-top:1px solid #e5e7eb!important;
  padding-top:12px!important;
}

.tax-summary-box .grand strong,
.sum-box strong:last-child{
  color:#2563eb!important;
  font-size:30px!important;
}

/* Buttons */
.btn{
  border-radius:17px!important;
  padding:14px 19px!important;
  font-weight:950!important;
}

.btn.primary{
  background:linear-gradient(135deg,#2563eb,#4f46e5)!important;
  box-shadow:0 18px 34px rgba(37,99,235,.26)!important;
}

.btn.light{
  background:#eef4fb!important;
  border:1px solid #dbe4f0!important;
}

/* Tables / dashboard */
.table-wrap{
  border-radius:26px!important;
}

th{
  background:#f1f5f9!important;
  font-size:11px!important;
}

td,th{
  padding:17px!important;
}

/* Invoice screen */
.invoice-sheet{
  border-radius:36px!important;
  padding:62px!important;
  max-width:980px!important;
  box-shadow:0 30px 90px rgba(15,23,42,.18)!important;
}

.invoice-header.premium{
  padding-bottom:34px!important;
}

.document-title h1{
  font-size:48px!important;
  letter-spacing:-.065em!important;
}

.invoice-meta{
  margin:38px 0!important;
}

.invoice-table th{
  font-size:10px!important;
  padding:14px 12px!important;
}

.invoice-table td{
  padding:15px 12px!important;
}

/* Mobile */
@media(max-width:900px){
  .layout{grid-template-columns:1fr!important}
  .main{padding:18px!important}
  .topbar{padding:24px!important}
  .topbar h1{font-size:36px!important}
  .grid-two{grid-template-columns:1fr!important}
  .mwst-final-options,.mwst-pro-options{grid-template-columns:1fr!important}
  .pos-header{display:none!important}
  .pos-row{grid-template-columns:1fr!important}
  .tax-summary-box,.sum-box{max-width:none!important}
  .invoice-sheet{padding:30px!important;border-radius:0!important}
}

/* Print stays compact */
@media print{
  .invoice-sheet{
    padding:0!important;
    box-shadow:none!important;
    border-radius:0!important;
  }
}



/* ===========================
   V4 PREMIUM INVOICE SYSTEM
   =========================== */
:root{
  --v4-ink:#0b1220;
  --v4-muted:#667085;
  --v4-line:#e6ebf2;
  --v4-card:#ffffff;
  --v4-bg:#f3f7fc;
  --v4-blue:#1d4ed8;
  --v4-indigo:#4338ca;
  --v4-green:#16a34a;
  --v4-red:#dc2626;
  --v4-shadow:0 28px 80px rgba(15,23,42,.11);
  --v4-shadow-soft:0 14px 34px rgba(15,23,42,.07);
}

body{
  color:var(--v4-ink)!important;
  background:
    radial-gradient(circle at 82% -6%,rgba(37,99,235,.18),transparent 30%),
    radial-gradient(circle at 18% 20%,rgba(14,165,233,.10),transparent 28%),
    linear-gradient(135deg,#fbfdff,#eaf1fb)!important;
}

.sidebar{
  background:
    radial-gradient(circle at 25% 2%,rgba(99,102,241,.42),transparent 24%),
    linear-gradient(180deg,#050b14,#09111f 58%,#030712)!important;
}

.main{
  max-width:1340px!important;
}

.topbar{
  position:relative;
  overflow:hidden;
  background:rgba(255,255,255,.88)!important;
}
.topbar:after{
  content:"";
  position:absolute;
  right:-90px;
  top:-90px;
  width:230px;
  height:230px;
  border-radius:999px;
  background:linear-gradient(135deg,rgba(37,99,235,.18),rgba(67,56,202,.10));
}
.topbar h1{
  max-width:760px;
}

/* Better app cards */
.panel{
  background:rgba(255,255,255,.96)!important;
  border:1px solid rgba(230,235,242,.95)!important;
}

/* V4 invoice form premium */
.form.wide{
  max-width:1080px!important;
}

.grid-two{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:18px 22px!important;
}

.form label{
  margin-top:18px!important;
  margin-bottom:8px!important;
}

input,select,textarea{
  background:#fbfcfe!important;
  border-color:#dce5ef!important;
}

/* Make VAT feel integrated, not loud */
.mwst-final-box,
.mwst-pro-box{
  background:#f8fafc!important;
  border:1px solid #e5e7eb!important;
  border-radius:24px!important;
  padding:20px!important;
  margin:24px 0!important;
  box-shadow:var(--v4-shadow-soft)!important;
}

.mwst-final-box h2,
.mwst-pro-box h2{
  font-size:18px!important;
  margin:0 0 4px!important;
}

.mwst-final-box p,
.mwst-pro-box p{
  font-size:14px!important;
  margin-bottom:14px!important;
}

.mwst-radio,
.mwst-pro-radio{
  background:#fff!important;
  border:1px solid #e3eaf3!important;
  border-radius:18px!important;
}

.mwst-radio:has(input:checked),
.mwst-pro-radio:has(input:checked){
  border-color:#1d4ed8!important;
  background:#f7faff!important;
}

/* Position table V4 */
.positions-head{
  border-top:1px solid #eef2f7;
  padding-top:28px;
}

.positions-table{
  box-shadow:none!important;
  border:1px solid #e6ebf2!important;
}

.pos-header{
  background:#f8fafc!important;
}

.pos-row{
  border-bottom:1px solid #edf2f7!important;
}

.item-row:hover{
  background:#fbfdff!important;
}

/* V4 totals - this becomes the hero */
.tax-summary-box,
.sum-box{
  max-width:460px!important;
  background:linear-gradient(180deg,#ffffff,#f8fafc)!important;
  color:#0b1220!important;
  border:1px solid #e5eaf1!important;
  box-shadow:0 18px 42px rgba(15,23,42,.08)!important;
  border-radius:28px!important;
  padding:22px 24px!important;
}

.tax-summary-box div,
.sum-box div{
  padding:2px 0!important;
}

.tax-summary-box span{
  color:#667085!important;
  font-size:14px!important;
}

.tax-summary-box strong{
  font-size:19px!important;
}

.tax-summary-box .grand{
  margin-top:6px!important;
}

.tax-summary-box .grand span{
  color:#0b1220!important;
  font-weight:950!important;
}

.tax-summary-box .grand strong{
  font-size:34px!important;
  letter-spacing:-.04em!important;
  color:#1d4ed8!important;
}

/* Premium invoice screen */
.invoice-page{
  background:
    radial-gradient(circle at top right,rgba(37,99,235,.14),transparent 32%),
    linear-gradient(135deg,#eef4fb,#e7edf6)!important;
}

.invoice-actions{
  max-width:1020px!important;
}

.invoice-sheet{
  max-width:1020px!important;
  border-radius:40px!important;
  padding:64px!important;
  background:#fff!important;
  border:1px solid rgba(255,255,255,.8);
  box-shadow:0 34px 100px rgba(15,23,42,.20)!important;
}

.invoice-header.premium{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:28px!important;
  align-items:start!important;
  border-bottom:1px solid #e6ebf2!important;
}

.company-block{
  align-items:flex-start!important;
}

.invoice-company-logo{
  width:112px!important;
  height:76px!important;
}

.company-block h2{
  font-size:24px!important;
}

.document-title h1{
  font-size:56px!important;
  line-height:.95!important;
}

.document-title p{
  color:#667085!important;
  font-weight:850!important;
  margin-top:12px!important;
}

.invoice-meta{
  gap:70px!important;
}

.invoice-meta b{
  font-size:13px!important;
}

.invoice-meta p{
  font-size:14px!important;
}

.invoice-table{
  border-collapse:collapse!important;
}

.invoice-table th{
  background:#f8fafc!important;
  color:#667085!important;
  border-bottom:1px solid #e6ebf2!important;
}

.invoice-table td{
  border-bottom:1px solid #edf2f7!important;
}

.invoice-table tfoot td{
  background:#fff!important;
  border-bottom:0!important;
}

.invoice-table tfoot tr:first-child td{
  border-top:1px solid #e6ebf2!important;
  padding-top:18px!important;
}

.invoice-table tfoot tr:last-child td{
  font-size:24px!important;
  color:#1d4ed8!important;
  background:#f8fafc!important;
}

.invoice-footer{
  color:#667085!important;
}

.thanks{
  color:#344054!important;
}

/* Add premium status badges if present */
.badge{
  font-weight:950!important;
}

/* Mobile polish */
@media(max-width:900px){
  .invoice-header.premium{
    grid-template-columns:1fr!important;
  }
  .document-title{
    text-align:left!important;
  }
  .document-title h1{
    font-size:42px!important;
  }
  .invoice-sheet{
    padding:28px!important;
  }
}


/* Mail Tracking PRO */
.sent-badge{
  display:inline-block;
  margin-top:8px;
  padding:6px 10px;
  background:#ecfdf5;
  color:#065f46;
  border:1px solid #bbf7d0;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
}
.mail-tracking-card{
  margin-top:28px;
  border:1px solid #e5e7eb;
  background:#f8fafc;
  border-radius:24px;
  padding:20px;
}
.mail-tracking-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:14px;
}
.mail-tracking-head b{
  font-size:16px;
}
.mail-tracking-head p{
  margin:5px 0 0;
  color:#64748b;
  font-size:13px;
}
.sent-pill{
  background:#dcfce7;
  color:#166534;
  border:1px solid #bbf7d0;
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  white-space:nowrap;
}
.mail-log-list{
  display:grid;
  gap:10px;
}
.mail-log-row{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:center;
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:13px 14px;
}
.mail-log-row strong{
  display:block;
  font-size:13px;
}
.mail-log-row small{
  display:block;
  margin-top:3px;
  color:#64748b;
}
.mail-log-row.sent{
  border-color:#bbf7d0;
}
.mail-log-row.error{
  border-color:#fecaca;
}
.mail-log-meta{
  text-align:right;
}
.mail-log-meta span{
  display:inline-block;
  padding:5px 9px;
  border-radius:999px;
  background:#e2e8f0;
  color:#334155;
  font-size:11px;
  font-weight:900;
}
.mail-log-row.sent .mail-log-meta span{
  background:#dcfce7;
  color:#166534;
}
.mail-log-row.error .mail-log-meta span{
  background:#fee2e2;
  color:#991b1b;
}
@media(max-width:700px){
  .mail-tracking-head,
  .mail-log-row{
    flex-direction:column;
    align-items:stretch;
  }
  .mail-log-meta{
    text-align:left;
  }
}
@media print{
  .mail-tracking-card{display:none!important}
}


/* Mail Dashboard */
.muted-cell{
  color:#64748b;
  max-width:260px;
  white-space:normal;
}
.empty-state{
  text-align:center;
  padding:36px!important;
  color:#64748b;
}
.empty-state b{
  color:#0f172a;
}
small{
  color:#64748b;
  font-weight:700;
}
@media(max-width:900px){
  .filters{
    display:grid!important;
    grid-template-columns:1fr!important;
    width:100%;
  }
}


/* Reminder PRO */
.reminder-level,
.reminder-mini{
  display:inline-block;
  padding:6px 10px;
  background:#eef2ff;
  color:#3730a3;
  border:1px solid #c7d2fe;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  margin-top:6px;
}


/* Reminder Mail Stufen */
.reminder-level{
  background:#eef2ff;
  color:#3730a3;
}
.reminder-level.level-1{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}
.reminder-level.level-2{background:#fffbeb;color:#92400e;border-color:#fde68a}
.reminder-level.level-3{background:#fef2f2;color:#991b1b;border-color:#fecaca}


/* Dashboard PRO */
.dashboard-hero{
  display:flex;
  justify-content:space-between;
  gap:24px;
  align-items:flex-end;
}
.hero-subline{
  display:block;
  color:#64748b;
  font-weight:750;
  margin-top:8px;
}
.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.kpi-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
  margin:24px 0;
}
.kpi-card{
  background:rgba(255,255,255,.95);
  border:1px solid #e5e7eb;
  border-radius:30px;
  padding:24px;
  box-shadow:0 18px 46px rgba(15,23,42,.08);
  position:relative;
  overflow:hidden;
}
.kpi-card:after{
  content:"";
  position:absolute;
  right:-35px;
  top:-35px;
  width:105px;
  height:105px;
  border-radius:999px;
  background:rgba(37,99,235,.10);
}
.kpi-card span{
  display:block;
  color:#64748b;
  font-weight:900;
  font-size:13px;
}
.kpi-card strong{
  display:block;
  font-size:34px;
  letter-spacing:-.05em;
  margin-top:10px;
  color:#0f172a;
}
.kpi-card small{
  display:block;
  color:#64748b;
  font-weight:700;
  margin-top:6px;
}
.kpi-card.primary strong{color:#2563eb}
.kpi-card.danger strong{color:#dc2626}
.kpi-card.success strong{color:#16a34a}
.dashboard-grid{
  display:grid;
  grid-template-columns:minmax(0,1.75fr) minmax(320px,.8fr);
  gap:22px;
  align-items:start;
}
.side-stack{
  display:grid;
  gap:22px;
}
.panel-head.compact{
  margin-bottom:14px;
}
.panel-head.compact h2{
  font-size:22px;
}
.mini-list{
  display:grid;
  gap:10px;
}
.mini-item{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:center;
  text-decoration:none;
  color:#0f172a;
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:14px;
}
.mini-item small{
  display:block;
  margin-top:4px;
}
.mini-item strong{
  white-space:nowrap;
  color:#2563eb;
}
.mini-item.danger strong{
  color:#dc2626;
}
.empty-mini{
  padding:18px;
  color:#64748b;
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  font-weight:800;
}
.quick-actions{
  display:grid;
  gap:10px;
}
.quick-actions a{
  padding:14px 15px;
  border-radius:18px;
  background:#f8fafc;
  border:1px solid #e5e7eb;
  color:#0f172a;
  text-decoration:none;
  font-weight:900;
}
.quick-actions a:hover{
  background:#eef2ff;
  border-color:#c7d2fe;
}
.empty-state{
  text-align:center;
  padding:36px!important;
  color:#64748b;
}
.empty-state b{
  color:#0f172a;
}
@media(max-width:1100px){
  .kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dashboard-grid{grid-template-columns:1fr}
}
@media(max-width:760px){
  .dashboard-hero{align-items:flex-start;flex-direction:column}
  .kpi-grid{grid-template-columns:1fr}
}


/* Delete + Nummer PRO */
.btn.danger,
button.danger{
  background:#dc2626!important;
  color:#fff!important;
  border:1px solid #dc2626!important;
  box-shadow:0 16px 32px rgba(220,38,38,.20)!important;
}
.btn.danger:hover,
button.danger:hover{
  background:#b91c1c!important;
}
.manual-number-hint{
  display:block;
  margin-top:7px;
  color:#64748b;
  font-size:12px;
  font-weight:750;
}
.delete-card h1{
  color:#991b1b;
}
.danger-summary{
  margin:18px 0;
  padding:16px;
  border-radius:18px;
  background:#fef2f2;
  border:1px solid #fecaca;
}
.danger-summary b{
  display:block;
  color:#7f1d1d;
  font-size:18px;
}
.danger-summary span{
  display:block;
  color:#991b1b;
  margin-top:5px;
}
.warning{
  color:#92400e;
  background:#fffbeb;
  border:1px solid #fde68a;
  border-radius:14px;
  padding:12px;
}


/* Position AutoGrow + Brutto/Netto PRO */
.pos-desc{
  width:100%;
  min-height:52px!important;
  max-height:220px;
  resize:none;
  overflow:hidden;
  line-height:1.45;
  font-family:inherit;
  border-radius:18px!important;
  border:1px solid #dbe4f0!important;
  background:#fbfcfe!important;
  padding:15px 16px!important;
}
.pos-desc:focus{
  background:#fff!important;
  border-color:rgba(37,99,235,.62)!important;
  box-shadow:0 0 0 4px rgba(37,99,235,.11)!important;
  outline:none;
}
.price-mode-box{
  margin:24px 0;
  padding:20px;
  border-radius:24px;
  background:#f8fafc;
  border:1px solid #e5e7eb;
  display:flex;
  justify-content:space-between;
  gap:20px;
  align-items:center;
}
.price-mode-box h2{
  margin:0 0 4px;
  font-size:20px;
  letter-spacing:-.035em;
}
.price-mode-box p{
  margin:0;
  color:#64748b;
  font-weight:750;
}
.price-mode-options{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.price-mode-options label{
  display:flex;
  align-items:center;
  gap:9px;
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:18px;
  padding:14px 16px;
  font-weight:950!important;
  white-space:nowrap;
}
.price-mode-options label:has(input:checked){
  border-color:#2563eb;
  background:#f7faff;
  box-shadow:0 0 0 4px rgba(37,99,235,.10);
}
.price-mode-options input{
  width:auto!important;
  min-height:auto!important;
  accent-color:#2563eb;
}
.price-mode-label{
  display:inline-block;
  margin-left:4px;
  color:#2563eb;
  font-weight:950;
}
@media(max-width:900px){
  .price-mode-box{
    flex-direction:column;
    align-items:stretch;
  }
  .price-mode-options{
    display:grid;
    grid-template-columns:1fr;
  }
}


/* Paid Flow + Customer Profile PRO */
.btn.success{
  background:#16a34a!important;
  color:#fff!important;
  border:1px solid #16a34a!important;
  box-shadow:0 16px 32px rgba(22,163,74,.20)!important;
}
.paid-badge{
  display:inline-block;
  margin-top:8px;
  padding:6px 10px;
  background:#dcfce7;
  color:#166534;
  border:1px solid #bbf7d0;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
}
.kpi-card.success strong{
  color:#16a34a!important;
}


/* Angebot zu Rechnung PRO */
.badge.umgewandelt{
  background:#eef2ff;
  color:#3730a3;
  border-color:#c7d2fe;
}


/* Dashboard PRO+ Analytics */
.dashboard-plus-hero{
  display:flex;
  justify-content:space-between;
  gap:24px;
  align-items:flex-end;
}
.smart-alerts{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin:22px 0 0;
}
.smart-alert{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:13px 16px;
  border-radius:999px;
  font-weight:950;
  text-decoration:none;
  border:1px solid #e5e7eb;
  background:#fff;
  box-shadow:0 10px 24px rgba(15,23,42,.06);
}
.smart-alert.danger{background:#fef2f2;color:#991b1b;border-color:#fecaca}
.smart-alert.warning{background:#fffbeb;color:#92400e;border-color:#fde68a}
.smart-alert.info{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}

.analytics-grid{
  display:grid;
  grid-template-columns:1.35fr 1fr 1fr 1fr;
  gap:18px;
  margin:24px 0;
}
.analytics-card{
  background:rgba(255,255,255,.94);
  border:1px solid #e6ebf2;
  border-radius:32px;
  padding:25px;
  box-shadow:0 20px 48px rgba(15,23,42,.08);
  position:relative;
  overflow:hidden;
}
.analytics-card:after{
  content:"";
  position:absolute;
  right:-42px;
  top:-42px;
  width:128px;
  height:128px;
  border-radius:999px;
  background:rgba(37,99,235,.09);
}
.analytics-card span{
  color:#667085;
  font-weight:950;
  font-size:13px;
}
.analytics-card strong{
  display:block;
  margin-top:12px;
  font-size:34px;
  letter-spacing:-.055em;
  color:#0b1220;
}
.analytics-card small{
  display:block;
  margin-top:7px;
  color:#667085;
  font-weight:750;
}
.analytics-card.hero-money{
  background:linear-gradient(135deg,#0f172a,#1e3a8a);
  color:#fff;
}
.analytics-card.hero-money span,
.analytics-card.hero-money small{
  color:#cbd5e1;
}
.analytics-card.hero-money strong{
  color:#fff;
  font-size:40px;
}
.analytics-card.danger strong{color:#dc2626}
.analytics-card.success strong{color:#16a34a}

.proplus-grid{
  display:grid;
  grid-template-columns:1.35fr .85fr;
  gap:22px;
  margin-bottom:24px;
}
.analytics-panel{
  min-height:315px;
}
.bar-chart-lite{
  height:210px;
  display:grid;
  grid-template-columns:repeat(7,1fr);
  align-items:end;
  gap:14px;
  padding-top:12px;
}
.bar-col{
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  align-items:center;
  gap:8px;
  min-width:0;
}
.bar-value{
  font-size:11px;
  color:#64748b;
  font-weight:850;
  min-height:16px;
  white-space:nowrap;
}
.bar-track{
  width:100%;
  max-width:42px;
  height:145px;
  background:#eef2f7;
  border-radius:999px;
  position:relative;
  overflow:hidden;
}
.bar-fill{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  border-radius:999px;
  background:linear-gradient(180deg,#2563eb,#4f46e5);
  min-height:8px;
}
.bar-col small{
  color:#64748b;
  font-weight:850;
}
.top-customer-list{
  display:grid;
  gap:12px;
}
.top-customer-item{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:center;
  padding:15px;
  border-radius:20px;
  border:1px solid #e5e7eb;
  background:#f8fafc;
}
.top-customer-item b{
  display:block;
}
.top-customer-item small{
  display:block;
  margin-top:4px;
}
.top-customer-item strong{
  color:#2563eb;
  white-space:nowrap;
}
.dashboard-grid{
  display:grid;
  grid-template-columns:minmax(0,1.75fr) minmax(320px,.8fr);
  gap:22px;
  align-items:start;
}
.side-stack{display:grid;gap:22px}
.mini-list{display:grid;gap:10px}
.mini-item{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:center;
  text-decoration:none;
  color:#0f172a;
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  padding:14px;
}
.mini-item small{display:block;margin-top:4px}
.mini-item strong{white-space:nowrap;color:#2563eb}
.mini-item.danger strong{color:#dc2626}
.empty-mini{
  padding:18px;
  color:#64748b;
  background:#f8fafc;
  border:1px solid #e5e7eb;
  border-radius:18px;
  font-weight:850;
}
.quick-actions{display:grid;gap:10px}
.quick-actions a{
  padding:14px 15px;
  border-radius:18px;
  background:#f8fafc;
  border:1px solid #e5e7eb;
  color:#0f172a;
  text-decoration:none;
  font-weight:950;
}
.quick-actions a:hover{
  background:#eef2ff;
  border-color:#c7d2fe;
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-subline{display:block;color:#64748b;font-weight:750;margin-top:8px}
@media(max-width:1180px){
  .analytics-grid{grid-template-columns:repeat(2,1fr)}
  .proplus-grid,.dashboard-grid{grid-template-columns:1fr}
}
@media(max-width:760px){
  .dashboard-plus-hero{flex-direction:column;align-items:flex-start}
  .analytics-grid{grid-template-columns:1fr}
  .bar-chart-lite{gap:8px}
  .bar-value{display:none}
}



/* DASHBOARD PRO+ LAYOUT FIX */
.main{
  width:100%!important;
  box-sizing:border-box!important;
  overflow-x:hidden!important;
}

.dashboard-plus-hero{
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-end!important;
  gap:24px!important;
  width:100%!important;
}

.smart-alerts{
  display:flex!important;
  gap:12px!important;
  flex-wrap:wrap!important;
  margin:22px 0!important;
}

.analytics-grid{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:18px!important;
  margin:24px 0!important;
  width:100%!important;
}

.analytics-card{
  display:block!important;
  min-width:0!important;
  background:rgba(255,255,255,.96)!important;
  border:1px solid #e6ebf2!important;
  border-radius:32px!important;
  padding:24px!important;
  box-shadow:0 20px 48px rgba(15,23,42,.08)!important;
  overflow:hidden!important;
}

.analytics-card span,
.analytics-card small{
  display:block!important;
}

.analytics-card strong{
  display:block!important;
  margin-top:10px!important;
  font-size:32px!important;
  line-height:1.05!important;
  white-space:nowrap!important;
}

.analytics-card.hero-money{
  background:linear-gradient(135deg,#0f172a,#1e3a8a)!important;
}

.proplus-grid{
  display:grid!important;
  grid-template-columns:minmax(0,1.35fr) minmax(280px,.85fr)!important;
  gap:22px!important;
  margin-bottom:24px!important;
  width:100%!important;
}

.analytics-panel{
  min-width:0!important;
}

.bar-chart-lite{
  height:230px!important;
  display:grid!important;
  grid-template-columns:repeat(7,minmax(0,1fr))!important;
  gap:14px!important;
  align-items:end!important;
  padding:16px 4px 0!important;
}

.bar-col{
  height:100%!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:flex-end!important;
  align-items:center!important;
  gap:8px!important;
  min-width:0!important;
}

.bar-value{
  font-size:11px!important;
  color:#64748b!important;
  font-weight:850!important;
  min-height:16px!important;
  white-space:nowrap!important;
}

.bar-track{
  width:100%!important;
  max-width:42px!important;
  height:150px!important;
  background:#eef2f7!important;
  border-radius:999px!important;
  position:relative!important;
  overflow:hidden!important;
}

.bar-fill{
  position:absolute!important;
  left:0!important;
  right:0!important;
  bottom:0!important;
  border-radius:999px!important;
  background:linear-gradient(180deg,#2563eb,#4f46e5)!important;
  min-height:8px!important;
}

.top-customer-list{
  display:grid!important;
  gap:12px!important;
}

.top-customer-item{
  display:flex!important;
  justify-content:space-between!important;
  align-items:center!important;
  gap:14px!important;
  padding:15px!important;
  border-radius:20px!important;
  background:#f8fafc!important;
  border:1px solid #e5e7eb!important;
}

.dashboard-grid{
  display:grid!important;
  grid-template-columns:minmax(0,1.65fr) minmax(300px,.85fr)!important;
  gap:22px!important;
  align-items:start!important;
}

.side-stack{
  display:grid!important;
  gap:22px!important;
}

/* Prevent tables from blowing out on tablet/mobile */
.table-wrap{
  width:100%!important;
  overflow-x:auto!important;
}

.table-wrap table{
  min-width:720px!important;
}

/* Tablet, like your screenshot */
@media(max-width:1180px){
  .main{
    padding:26px!important;
  }
  .analytics-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .proplus-grid,
  .dashboard-grid{
    grid-template-columns:1fr!important;
  }
}

/* Narrow mobile */
@media(max-width:760px){
  .main{
    padding:18px!important;
  }
  .dashboard-plus-hero{
    flex-direction:column!important;
    align-items:flex-start!important;
  }
  .analytics-grid{
    grid-template-columns:1fr!important;
  }
  .analytics-card strong{
    font-size:30px!important;
  }
  .bar-chart-lite{
    gap:8px!important;
  }
  .bar-value{
    display:none!important;
  }
}

/* If sidebar is still visible on narrow tablets, keep content usable */
@media(max-width:980px){
  .layout{
    grid-template-columns:220px minmax(0,1fr)!important;
  }
  .sidebar{
    width:220px!important;
    padding:20px!important;
  }
}

@media(max-width:720px){
  .layout{
    grid-template-columns:1fr!important;
  }
  .sidebar{
    position:relative!important;
    width:auto!important;
    min-height:auto!important;
  }
}


/* Save UX PRO */
.save-success-box{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  margin:0 auto 18px;
  max-width:1020px;
  padding:16px 18px;
  border-radius:22px;
  background:#ecfdf5;
  border:1px solid #bbf7d0;
  color:#065f46;
  box-shadow:0 18px 38px rgba(22,163,74,.10);
}
.save-success-box b{
  display:block;
  font-size:16px;
}
.save-success-box span{
  display:block;
  margin-top:3px;
  color:#047857;
  font-weight:750;
}
.pulse-send{
  animation:pulseSend 1.4s ease-in-out 0s 3;
}
@keyframes pulseSend{
  0%{transform:scale(1); box-shadow:0 0 0 0 rgba(37,99,235,.38);}
  50%{transform:scale(1.025); box-shadow:0 0 0 9px rgba(37,99,235,.09);}
  100%{transform:scale(1); box-shadow:0 0 0 0 rgba(37,99,235,0);}
}
@media(max-width:760px){
  .save-success-box{
    flex-direction:column;
    align-items:stretch;
  }
}



/* ===========================
   STRIPE STYLE INVOICE VIEW
   =========================== */

.stripe-style-page{
  background:
    radial-gradient(circle at 80% -10%, rgba(99,102,241,.16), transparent 32%),
    radial-gradient(circle at 15% 8%, rgba(14,165,233,.10), transparent 30%),
    linear-gradient(180deg,#f8fafc 0%,#eef4fb 100%)!important;
}

.stripe-actions,
.invoice-actions{
  max-width:1080px!important;
  margin:22px auto 18px!important;
  padding:10px!important;
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
  flex-wrap:wrap!important;
  background:rgba(255,255,255,.82)!important;
  border:1px solid rgba(226,232,240,.95)!important;
  border-radius:24px!important;
  box-shadow:0 18px 45px rgba(15,23,42,.08)!important;
  backdrop-filter:blur(14px)!important;
}

.stripe-actions .btn,
.invoice-actions .btn{
  min-height:42px!important;
  border-radius:15px!important;
  padding:11px 15px!important;
  font-size:13px!important;
  font-weight:900!important;
  box-shadow:none!important;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease!important;
}

.stripe-actions .btn:hover,
.invoice-actions .btn:hover{
  transform:translateY(-1px)!important;
}

.stripe-actions .btn.primary,
.invoice-actions .btn.primary{
  background:#635bff!important;
  border-color:#635bff!important;
  color:#fff!important;
  box-shadow:0 10px 24px rgba(99,91,255,.24)!important;
}

.stripe-actions .btn.success,
.invoice-actions .btn.success{
  background:#00a76f!important;
  border-color:#00a76f!important;
  color:#fff!important;
}

.stripe-actions .btn.danger,
.invoice-actions .btn.danger{
  background:#fff!important;
  border-color:#fecaca!important;
  color:#b91c1c!important;
  box-shadow:none!important;
}

.stripe-actions .btn.light,
.invoice-actions .btn.light{
  background:#f8fafc!important;
  border:1px solid #e2e8f0!important;
  color:#0f172a!important;
}

.stripe-invoice-sheet,
.invoice-sheet{
  max-width:1080px!important;
  margin:0 auto 52px!important;
  border-radius:34px!important;
  padding:58px 64px!important;
  background:#ffffff!important;
  border:1px solid rgba(226,232,240,.92)!important;
  box-shadow:0 35px 95px rgba(15,23,42,.16)!important;
}

.invoice-header.premium{
  border-bottom:1px solid #edf2f7!important;
  padding-bottom:34px!important;
  margin-bottom:30px!important;
}

.company-block{
  gap:18px!important;
}

.company-block h2{
  font-size:22px!important;
  letter-spacing:-.035em!important;
  color:#0f172a!important;
}

.company-block p,
.document-title p{
  color:#64748b!important;
  font-weight:750!important;
}

.document-title h1{
  font-size:52px!important;
  line-height:1!important;
  letter-spacing:-.065em!important;
  color:#0f172a!important;
}

.invoice-meta{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:20px!important;
  margin:32px 0 34px!important;
}

.invoice-meta > div{
  background:#f8fafc!important;
  border:1px solid #edf2f7!important;
  border-radius:24px!important;
  padding:20px!important;
}

.invoice-meta b{
  display:block!important;
  margin-bottom:11px!important;
  font-size:12px!important;
  color:#0f172a!important;
}

.invoice-meta p{
  color:#475569!important;
  font-size:14px!important;
  line-height:1.65!important;
}

.sent-badge,
.paid-badge,
.reminder-mini{
  border-radius:999px!important;
  padding:7px 10px!important;
  font-size:11px!important;
  font-weight:950!important;
}

.invoice-table{
  margin-top:16px!important;
  border-collapse:separate!important;
  border-spacing:0!important;
  overflow:hidden!important;
  border:1px solid #edf2f7!important;
  border-radius:24px!important;
}

.invoice-table th{
  background:#f8fafc!important;
  color:#64748b!important;
  font-size:10px!important;
  letter-spacing:.09em!important;
  padding:15px 14px!important;
  border-bottom:1px solid #edf2f7!important;
}

.invoice-table td{
  padding:17px 14px!important;
  border-bottom:1px solid #f1f5f9!important;
  color:#1e293b!important;
}

.invoice-table tbody tr:hover td{
  background:#fbfdff!important;
}

.invoice-table tfoot td{
  border:0!important;
  background:#fff!important;
  padding:12px 14px!important;
}

.invoice-table tfoot tr:first-child td{
  padding-top:24px!important;
}

.invoice-table tfoot tr td:first-child,
.invoice-table tfoot tr td:last-child{
  font-size:18px!important;
  color:#0f172a!important;
  font-weight:950!important;
}

.invoice-table tfoot tr:last-child td{
  background:#f6f9ff!important;
  border-top:1px solid #edf2f7!important;
  color:#635bff!important;
  font-size:28px!important;
  padding-top:18px!important;
  padding-bottom:18px!important;
}

.stripe-mail-tracking,
.mail-tracking-card{
  margin-top:28px!important;
  border-radius:26px!important;
  background:#fbfdff!important;
  border:1px solid #edf2f7!important;
  padding:18px!important;
  box-shadow:none!important;
}

.mail-tracking-head{
  margin-bottom:12px!important;
}

.mail-tracking-head b{
  font-size:15px!important;
}

.mail-tracking-head p{
  font-size:12px!important;
}

.mail-log-list{
  display:grid!important;
  gap:8px!important;
}

.mail-log-row{
  border-radius:18px!important;
  padding:11px 12px!important;
  background:#fff!important;
}

.mail-log-row:nth-child(n+4){
  display:none!important;
}

.mail-log-row strong{
  font-size:12px!important;
}

.mail-log-row small{
  font-size:11px!important;
}

.invoice-footer{
  margin-top:30px!important;
  border-top:1px solid #edf2f7!important;
  padding-top:22px!important;
  color:#64748b!important;
}

.thanks{
  margin-top:28px!important;
  font-size:15px!important;
  font-weight:950!important;
  color:#334155!important;
}

.save-success-box{
  max-width:1080px!important;
  border-radius:24px!important;
}

@media(max-width:900px){
  .stripe-actions,
  .invoice-actions{
    margin:16px 10px!important;
    overflow-x:auto!important;
    flex-wrap:nowrap!important;
    justify-content:flex-start!important;
  }
  .stripe-actions .btn,
  .invoice-actions .btn{
    white-space:nowrap!important;
  }
  .stripe-invoice-sheet,
  .invoice-sheet{
    border-radius:26px!important;
    padding:32px 24px!important;
    margin:0 10px 36px!important;
  }
  .invoice-header.premium{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:24px!important;
  }
  .document-title{
    text-align:left!important;
  }
  .document-title h1{
    font-size:42px!important;
  }
  .invoice-meta{
    grid-template-columns:1fr!important;
  }
}



/* ===========================
   V5 ULTRA STRIPE UI
   =========================== */
:root{
  --stripe-purple:#635bff;
  --stripe-dark:#0a2540;
  --stripe-muted:#697386;
  --stripe-line:#e6ebf1;
  --stripe-bg:#f6f9fc;
  --stripe-green:#00a76f;
  --stripe-red:#e11d48;
}

/* Global invoice page */
.v5-ultra-page{
  background:
    radial-gradient(circle at 84% -8%, rgba(99,91,255,.20), transparent 31%),
    radial-gradient(circle at 10% 4%, rgba(0,167,111,.09), transparent 28%),
    linear-gradient(180deg,#f6f9fc 0%,#eef4fb 100%)!important;
  color:var(--stripe-dark)!important;
}

/* Ultra action bar */
.v5-actions,
.invoice-actions{
  max-width:1120px!important;
  margin:18px auto 18px!important;
  padding:8px!important;
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
  flex-wrap:wrap!important;
  background:rgba(255,255,255,.88)!important;
  border:1px solid rgba(230,235,241,.95)!important;
  border-radius:22px!important;
  box-shadow:0 18px 48px rgba(10,37,64,.10)!important;
  backdrop-filter:blur(16px)!important;
}

/* Buttons: less chaos */
.v5-actions .btn,
.invoice-actions .btn{
  min-height:40px!important;
  border-radius:13px!important;
  padding:10px 14px!important;
  font-size:12px!important;
  font-weight:850!important;
  letter-spacing:-.01em!important;
  box-shadow:none!important;
  border:1px solid transparent!important;
}

.v5-actions .btn.primary,
.invoice-actions .btn.primary{
  order:1!important;
  background:var(--stripe-purple)!important;
  color:#fff!important;
  border-color:var(--stripe-purple)!important;
  box-shadow:0 10px 24px rgba(99,91,255,.24)!important;
}

.v5-actions .btn.success,
.invoice-actions .btn.success{
  order:2!important;
  background:var(--stripe-green)!important;
  color:#fff!important;
  border-color:var(--stripe-green)!important;
}

.v5-actions .btn.light,
.invoice-actions .btn.light{
  background:#fff!important;
  color:var(--stripe-dark)!important;
  border-color:#e6ebf1!important;
}

.v5-actions .btn.danger,
.invoice-actions .btn.danger{
  margin-left:auto!important;
  background:#fff!important;
  color:#be123c!important;
  border-color:#ffe4e6!important;
}

.v5-actions .btn:hover,
.invoice-actions .btn:hover{
  transform:translateY(-1px)!important;
  box-shadow:0 12px 24px rgba(10,37,64,.08)!important;
}

/* Invoice paper */
.v5-sheet,
.invoice-sheet{
  max-width:1120px!important;
  margin:0 auto 64px!important;
  padding:64px 72px!important;
  border-radius:36px!important;
  background:#fff!important;
  border:1px solid rgba(230,235,241,.95)!important;
  box-shadow:0 38px 110px rgba(10,37,64,.16)!important;
  position:relative!important;
  overflow:hidden!important;
}

.v5-sheet:before,
.invoice-sheet:before{
  content:""!important;
  position:absolute!important;
  left:0!important;
  right:0!important;
  top:0!important;
  height:7px!important;
  background:linear-gradient(90deg,#635bff,#00d4ff,#00a76f)!important;
}

/* Header: Stripe-like hierarchy */
.invoice-header.premium{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(260px,.6fr)!important;
  gap:40px!important;
  align-items:start!important;
  border-bottom:1px solid var(--stripe-line)!important;
  padding-bottom:38px!important;
  margin-bottom:34px!important;
}

.company-block{
  display:flex!important;
  align-items:flex-start!important;
  gap:18px!important;
}

.company-block h2{
  color:var(--stripe-dark)!important;
  font-size:23px!important;
  line-height:1.1!important;
  letter-spacing:-.04em!important;
  margin-bottom:8px!important;
}

.company-block p{
  color:var(--stripe-muted)!important;
  line-height:1.55!important;
  font-size:14px!important;
  font-weight:650!important;
}

.invoice-company-logo{
  width:96px!important;
  max-height:72px!important;
  object-fit:contain!important;
}

.document-title{
  text-align:right!important;
}

.document-title h1{
  color:var(--stripe-dark)!important;
  font-size:58px!important;
  line-height:.95!important;
  letter-spacing:-.075em!important;
  margin:0!important;
}

.document-title p{
  color:var(--stripe-muted)!important;
  font-weight:850!important;
  margin-top:14px!important;
}

/* Meta cards */
.invoice-meta{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:18px!important;
  margin:34px 0!important;
}

.invoice-meta > div{
  background:#f6f9fc!important;
  border:1px solid #edf2f7!important;
  border-radius:24px!important;
  padding:22px!important;
}

.invoice-meta b{
  display:block!important;
  color:var(--stripe-dark)!important;
  font-size:12px!important;
  font-weight:950!important;
  margin-bottom:12px!important;
  letter-spacing:-.01em!important;
}

.invoice-meta p{
  color:#425466!important;
  font-size:14px!important;
  line-height:1.65!important;
}

/* Status chips */
.sent-badge,
.paid-badge,
.reminder-mini{
  display:inline-flex!important;
  align-items:center!important;
  width:max-content!important;
  border-radius:999px!important;
  padding:6px 10px!important;
  font-size:11px!important;
  font-weight:900!important;
  margin-top:7px!important;
}

/* Table */
.invoice-table{
  width:100%!important;
  border-collapse:separate!important;
  border-spacing:0!important;
  overflow:hidden!important;
  border:1px solid var(--stripe-line)!important;
  border-radius:24px!important;
  margin-top:28px!important;
}

.invoice-table thead th{
  background:#f6f9fc!important;
  color:#697386!important;
  font-size:10px!important;
  letter-spacing:.095em!important;
  text-transform:uppercase!important;
  padding:15px 14px!important;
  border-bottom:1px solid var(--stripe-line)!important;
}

.invoice-table tbody td{
  padding:18px 14px!important;
  border-bottom:1px solid #edf2f7!important;
  color:#0a2540!important;
}

.invoice-table tbody tr:last-child td{
  border-bottom:1px solid var(--stripe-line)!important;
}

/* Premium total block */
.invoice-table tfoot td{
  background:#fff!important;
  border:0!important;
  padding:13px 16px!important;
}

.invoice-table tfoot tr:first-child td{
  padding-top:26px!important;
}

.invoice-table tfoot tr td:first-child{
  color:#425466!important;
  font-weight:850!important;
  font-size:16px!important;
}

.invoice-table tfoot tr td:last-child{
  color:var(--stripe-dark)!important;
  font-weight:950!important;
  font-size:18px!important;
}

.invoice-table tfoot tr:last-child td{
  background:linear-gradient(135deg,#f6f9ff,#ffffff)!important;
  border-top:1px solid var(--stripe-line)!important;
  color:var(--stripe-purple)!important;
  font-size:32px!important;
  font-weight:950!important;
  padding-top:20px!important;
  padding-bottom:20px!important;
}

/* Compact tracking */
.v5-mail-tracking,
.mail-tracking-card{
  margin-top:30px!important;
  padding:16px!important;
  border-radius:24px!important;
  background:#fbfdff!important;
  border:1px solid var(--stripe-line)!important;
  box-shadow:none!important;
}

.mail-tracking-head{
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-start!important;
  gap:12px!important;
  margin-bottom:10px!important;
}

.mail-tracking-head b{
  font-size:14px!important;
  color:var(--stripe-dark)!important;
}

.mail-tracking-head p{
  margin-top:3px!important;
  font-size:11px!important;
  color:var(--stripe-muted)!important;
}

.sent-pill{
  background:#e6fcf5!important;
  color:#007a5a!important;
  border-color:#c4f1e4!important;
  font-size:10px!important;
  padding:6px 9px!important;
}

.mail-log-list{
  display:grid!important;
  gap:7px!important;
}

.mail-log-row{
  display:flex!important;
  justify-content:space-between!important;
  align-items:center!important;
  gap:12px!important;
  padding:10px 12px!important;
  border-radius:16px!important;
  background:#fff!important;
  border:1px solid #edf2f7!important;
}

.mail-log-row:nth-child(n+4){
  display:none!important;
}

.mail-log-row strong{
  font-size:12px!important;
}

.mail-log-row small{
  font-size:11px!important;
}

/* Footer */
.invoice-footer{
  margin-top:34px!important;
  padding-top:24px!important;
  border-top:1px solid var(--stripe-line)!important;
  color:var(--stripe-muted)!important;
}

.thanks{
  margin-top:30px!important;
  color:#425466!important;
  font-size:15px!important;
  font-weight:900!important;
}

/* Mobile */
@media(max-width:900px){
  .v5-actions,
  .invoice-actions{
    margin:14px 10px!important;
    overflow-x:auto!important;
    flex-wrap:nowrap!important;
    justify-content:flex-start!important;
    border-radius:18px!important;
  }

  .v5-actions .btn,
  .invoice-actions .btn{
    white-space:nowrap!important;
  }

  .v5-actions .btn.danger,
  .invoice-actions .btn.danger{
    margin-left:0!important;
  }

  .v5-sheet,
  .invoice-sheet{
    margin:0 10px 38px!important;
    padding:34px 24px!important;
    border-radius:28px!important;
  }

  .invoice-header.premium{
    grid-template-columns:1fr!important;
    gap:26px!important;
  }

  .document-title{
    text-align:left!important;
  }

  .document-title h1{
    font-size:44px!important;
  }

  .invoice-meta{
    grid-template-columns:1fr!important;
  }

  .invoice-table{
    display:block!important;
    overflow-x:auto!important;
  }

  .invoice-table table,
  .invoice-table{
    min-width:640px!important;
  }
}



/* Kundenportal PRO+ */
.portal-public-page{
  margin:0;
  min-height:100vh;
  background:
    radial-gradient(circle at 82% -10%, rgba(99,91,255,.18), transparent 32%),
    linear-gradient(180deg,#f6f9fc,#eef4fb);
  color:#0a2540;
}
.portal-shell{
  width:min(980px, calc(100% - 28px));
  margin:32px auto;
}
.portal-hero{
  background:#fff;
  border:1px solid #e6ebf1;
  border-radius:34px;
  padding:34px;
  box-shadow:0 30px 85px rgba(10,37,64,.13);
  display:flex;
  justify-content:space-between;
  gap:28px;
  align-items:flex-start;
  position:relative;
  overflow:hidden;
}
.portal-hero:before{
  content:"";
  position:absolute;
  left:0;right:0;top:0;height:7px;
  background:linear-gradient(90deg,#635bff,#00d4ff,#00a76f);
}
.portal-company{
  display:flex;
  gap:14px;
  align-items:center;
}
.portal-company b{
  display:block;
  font-size:18px;
}
.portal-company span,
.portal-customer span{
  display:block;
  color:#697386;
  font-weight:800;
  font-size:13px;
  margin-top:4px;
}
.portal-logo{
  width:76px;
  max-height:58px;
  object-fit:contain;
}
.portal-logo-fallback{
  width:54px;
  height:54px;
  border-radius:16px;
  background:#0a2540;
  color:white;
  display:grid;
  place-items:center;
  font-weight:950;
}
.portal-customer{
  text-align:right;
}
.portal-customer h1{
  margin:6px 0 4px;
  font-size:38px;
  letter-spacing:-.06em;
}
.portal-customer p{
  margin:0;
  color:#697386;
  font-weight:700;
}
.portal-kpis{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  margin:18px 0;
}
.portal-kpis article{
  background:#fff;
  border:1px solid #e6ebf1;
  border-radius:24px;
  padding:22px;
  box-shadow:0 14px 36px rgba(10,37,64,.07);
}
.portal-kpis span{
  display:block;
  color:#697386;
  font-size:13px;
  font-weight:900;
}
.portal-kpis strong{
  display:block;
  margin-top:8px;
  font-size:30px;
  letter-spacing:-.05em;
}
.portal-card{
  background:#fff;
  border:1px solid #e6ebf1;
  border-radius:30px;
  padding:28px;
  box-shadow:0 24px 65px rgba(10,37,64,.10);
}
.portal-card-head h2{
  margin:0;
  font-size:26px;
  letter-spacing:-.05em;
}
.portal-card-head p{
  margin:6px 0 0;
  color:#697386;
  font-weight:700;
}
.portal-doc-list{
  display:grid;
  gap:12px;
  margin-top:22px;
}
.portal-doc{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
  padding:18px;
  border-radius:22px;
  border:1px solid #edf2f7;
  background:#fbfdff;
}
.portal-doc b{
  display:block;
  font-size:16px;
}
.portal-doc span{
  display:block;
  margin-top:4px;
  color:#697386;
  font-weight:700;
}
.portal-doc-right{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.portal-doc-right strong{
  font-size:18px;
  white-space:nowrap;
}
.portal-doc-right a{
  text-decoration:none;
  background:#635bff;
  color:#fff;
  padding:10px 13px;
  border-radius:13px;
  font-size:13px;
  font-weight:950;
}
.portal-status{
  display:inline-flex!important;
  align-items:center;
  width:max-content;
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:950;
}
.portal-status.open{background:#fffbeb;color:#92400e}
.portal-status.paid{background:#e6fcf5;color:#007a5a}
.portal-status.late{background:#fef2f2;color:#991b1b}
.portal-status.converted{background:#eef2ff;color:#3730a3}
.portal-empty{
  padding:26px;
  border-radius:20px;
  background:#f8fafc;
  color:#697386;
}
.portal-empty b{
  display:block;
  color:#0a2540;
}
.portal-empty span{
  display:block;
  margin-top:6px;
}
.portal-footer{
  margin:20px 0 0;
  text-align:center;
  color:#697386;
  font-weight:700;
}
.portal-footer b{
  display:block;
  color:#0a2540;
}
.portal-link-cell{
  max-width:420px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
@media(max-width:760px){
  .portal-hero{
    flex-direction:column;
  }
  .portal-customer{
    text-align:left;
  }
  .portal-kpis{
    grid-template-columns:1fr;
  }
  .portal-doc{
    align-items:flex-start;
    flex-direction:column;
  }
  .portal-doc-right{
    justify-content:flex-start;
  }
}



/* Passwort PRO */
.password-panel{
  max-width:620px;
}
.password-form{
  max-width:520px;
}
.password-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:22px;
}
@media(max-width:760px){
  .password-actions{
    flex-direction:column;
  }
}



/* ===========================
   MOBILE PHASE 2 - INVOICE POWER
   =========================== */

.mobile-invoice-hero{
  display:none;
}

.mobile-sticky-actions{
  display:none;
}

@media(max-width:900px){
  body.mobile-phase2-invoice{
    background:
      radial-gradient(circle at 80% -12%, rgba(99,91,255,.20), transparent 32%),
      linear-gradient(180deg,#f6f9fc,#eef4fb)!important;
    padding-bottom:92px!important;
  }

  .mobile-invoice-hero{
    display:block!important;
    margin:14px 12px 14px!important;
    padding:22px!important;
    border-radius:30px!important;
    background:linear-gradient(135deg,#0a2540,#172b4d)!important;
    color:#fff!important;
    box-shadow:0 26px 70px rgba(10,37,64,.26)!important;
    position:relative!important;
    overflow:hidden!important;
  }

  .mobile-invoice-hero:after{
    content:"";
    position:absolute;
    right:-52px;
    top:-52px;
    width:150px;
    height:150px;
    border-radius:999px;
    background:rgba(99,91,255,.34);
  }

  .mobile-hero-top{
    position:relative;
    z-index:1;
    display:flex;
    justify-content:space-between;
    gap:16px;
    align-items:center;
    margin-bottom:18px;
  }

  .mobile-hero-top span{
    color:#cbd5e1;
    font-weight:850;
    font-size:13px;
  }

  .mobile-hero-top b{
    color:#fff;
    font-size:13px;
    font-weight:950;
  }

  .mobile-hero-amount{
    position:relative;
    z-index:1;
    display:block;
    font-size:44px;
    line-height:1;
    letter-spacing:-.07em;
    margin-bottom:16px;
  }

  .mobile-hero-meta{
    position:relative;
    z-index:1;
    display:flex;
    gap:9px;
    align-items:center;
    flex-wrap:wrap;
  }

  .mobile-hero-meta > span{
    display:inline-flex;
    align-items:center;
    padding:8px 11px;
    border-radius:999px;
    background:rgba(255,255,255,.12);
    color:#e5e7eb;
    font-size:12px;
    font-weight:900;
  }

  .mobile-status.open{background:#fffbeb!important;color:#92400e!important}
  .mobile-status.paid{background:#dcfce7!important;color:#166534!important}
  .mobile-status.late{background:#fee2e2!important;color:#991b1b!important}
  .mobile-status.converted{background:#eef2ff!important;color:#3730a3!important}

  .mobile-hero-fun{
    position:relative;
    z-index:1;
    margin:16px 0 0;
    color:#cbd5e1;
    font-weight:800;
  }

  /* Hide noisy desktop paper header on mobile, hero now owns focus */
  .mobile-phase2-invoice .invoice-header.premium .document-title{
    display:none!important;
  }

  .mobile-phase2-invoice .invoice-header.premium{
    padding-bottom:22px!important;
    margin-bottom:18px!important;
  }

  .mobile-phase2-invoice .company-block{
    gap:12px!important;
  }

  .mobile-phase2-invoice .company-block h2{
    font-size:19px!important;
  }

  .mobile-phase2-invoice .company-block p{
    font-size:12px!important;
  }

  /* Make invoice sheet feel like app card */
  .mobile-phase2-invoice .invoice-sheet,
  .mobile-phase2-invoice .stripe-invoice-sheet,
  .mobile-phase2-invoice .v5-sheet{
    margin:0 12px 110px!important;
    padding:24px 18px!important;
    border-radius:30px!important;
    box-shadow:0 20px 55px rgba(10,37,64,.13)!important;
  }

  /* Meta: cards stacked */
  .mobile-phase2-invoice .invoice-meta{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:12px!important;
    margin:18px 0!important;
  }

  .mobile-phase2-invoice .invoice-meta > div{
    padding:16px!important;
    border-radius:22px!important;
  }

  /* Table to cards on mobile */
  .mobile-phase2-invoice .invoice-table,
  .mobile-phase2-invoice .mobile-card-table{
    display:block!important;
    min-width:0!important;
    border:0!important;
    border-radius:0!important;
    overflow:visible!important;
    margin-top:18px!important;
  }

  .mobile-phase2-invoice .invoice-table thead{
    display:none!important;
  }

  .mobile-phase2-invoice .invoice-table tbody{
    display:grid!important;
    gap:12px!important;
  }

  .mobile-phase2-invoice .invoice-table tbody tr{
    display:grid!important;
    gap:8px!important;
    padding:16px!important;
    border:1px solid #edf2f7!important;
    border-radius:22px!important;
    background:#fbfdff!important;
    box-shadow:0 8px 22px rgba(10,37,64,.05)!important;
  }

  .mobile-phase2-invoice .invoice-table tbody td{
    display:flex!important;
    justify-content:space-between!important;
    gap:14px!important;
    align-items:flex-start!important;
    border:0!important;
    padding:0!important;
    background:transparent!important;
    font-size:14px!important;
  }

  .mobile-phase2-invoice .invoice-table tbody td:nth-child(1)::before{content:"Pos."; color:#697386; font-weight:850;}
  .mobile-phase2-invoice .invoice-table tbody td:nth-child(2)::before{content:"Beschreibung"; color:#697386; font-weight:850;}
  .mobile-phase2-invoice .invoice-table tbody td:nth-child(3)::before{content:"Menge"; color:#697386; font-weight:850;}
  .mobile-phase2-invoice .invoice-table tbody td:nth-child(4)::before{content:"Einheit"; color:#697386; font-weight:850;}
  .mobile-phase2-invoice .invoice-table tbody td:nth-child(5)::before{content:"Preis"; color:#697386; font-weight:850;}
  .mobile-phase2-invoice .invoice-table tbody td:nth-child(6)::before{content:"Gesamt"; color:#697386; font-weight:850;}

  .mobile-phase2-invoice .invoice-table tbody td:nth-child(2){
    display:block!important;
  }

  .mobile-phase2-invoice .invoice-table tbody td:nth-child(2)::before{
    display:block!important;
    margin-bottom:5px!important;
  }

  .mobile-phase2-invoice .invoice-table tbody td:last-child{
    font-size:18px!important;
    font-weight:950!important;
    color:#635bff!important;
    padding-top:6px!important;
    border-top:1px solid #edf2f7!important;
  }

  /* Totals: big card */
  .mobile-phase2-invoice .invoice-table tfoot{
    display:block!important;
    margin-top:14px!important;
    padding:16px!important;
    border-radius:24px!important;
    background:linear-gradient(135deg,#f6f9ff,#ffffff)!important;
    border:1px solid #edf2f7!important;
  }

  .mobile-phase2-invoice .invoice-table tfoot tr{
    display:flex!important;
    justify-content:space-between!important;
    gap:16px!important;
    padding:7px 0!important;
  }

  .mobile-phase2-invoice .invoice-table tfoot td{
    display:block!important;
    padding:0!important;
    background:transparent!important;
    border:0!important;
  }

  .mobile-phase2-invoice .invoice-table tfoot tr:last-child{
    margin-top:6px!important;
    padding-top:12px!important;
    border-top:1px solid #e6ebf1!important;
  }

  .mobile-phase2-invoice .invoice-table tfoot tr:last-child td{
    font-size:26px!important;
    color:#635bff!important;
    font-weight:950!important;
  }

  /* Compact tracking */
  .mobile-phase2-invoice .mail-tracking-card{
    padding:14px!important;
    border-radius:22px!important;
  }

  .mobile-phase2-invoice .mail-log-row{
    flex-direction:column!important;
    align-items:stretch!important;
    gap:7px!important;
  }

  .mobile-phase2-invoice .mail-log-meta{
    text-align:left!important;
  }

  /* Sticky mobile actions */
  .mobile-sticky-actions{
    position:fixed!important;
    left:12px!important;
    right:12px!important;
    bottom:12px!important;
    z-index:9999!important;
    display:grid!important;
    grid-template-columns:1fr 1.25fr 1fr!important;
    gap:8px!important;
    padding:8px!important;
    border-radius:24px!important;
    background:rgba(255,255,255,.92)!important;
    border:1px solid #e6ebf1!important;
    box-shadow:0 20px 60px rgba(10,37,64,.20)!important;
    backdrop-filter:blur(16px)!important;
  }

  .mobile-sticky-actions a{
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    min-height:48px!important;
    border-radius:17px!important;
    background:#f6f9fc!important;
    color:#0a2540!important;
    text-decoration:none!important;
    font-size:13px!important;
    font-weight:950!important;
  }

  .mobile-sticky-actions a.primary{
    background:#635bff!important;
    color:#fff!important;
    box-shadow:0 12px 28px rgba(99,91,255,.28)!important;
  }

  /* Desktop action bar becomes horizontal scroll on mobile and less important */
  .mobile-phase2-invoice .invoice-actions{
    margin:12px 12px!important;
    opacity:.94!important;
  }

  .mobile-phase2-invoice .invoice-actions .btn.primary{
    display:none!important;
  }
}

@media(min-width:901px){
  .mobile-invoice-hero,
  .mobile-sticky-actions{
    display:none!important;
  }
}



/* ==========================================================
   PHASE 4 HARD MOBILE OVERRIDE
   No subtlety. Real mobile app look.
   ========================================================== */

.hard-mobile-dashboard,
.hard-invoice-hero,
.hard-bottom-nav,
.hard-fab-button,
.hard-fab-menu,
.hard-fab-backdrop,
.hard-fab-toggle,
.hard-sticky-actions{
  display:none;
}

@media(max-width:900px){
  html, body{
    overflow-x:hidden!important;
  }

  body.phase4-hard-mobile{
    margin:0!important;
    min-height:100vh!important;
    padding-bottom:108px!important;
    background:
      radial-gradient(circle at 82% -10%, rgba(99,91,255,.26), transparent 34%),
      radial-gradient(circle at 0% 18%, rgba(0,167,111,.13), transparent 30%),
      linear-gradient(180deg,#f5f7fb 0%,#eaf1fb 100%)!important;
    color:#0a2540!important;
    -webkit-tap-highlight-color:transparent!important;
  }

  body.phase4-hard-mobile .layout{
    display:block!important;
    min-height:100vh!important;
  }

  body.phase4-hard-mobile .sidebar{
    display:none!important;
  }

  body.phase4-hard-mobile .main{
    padding:12px 12px 120px!important;
    width:100%!important;
    max-width:none!important;
    box-sizing:border-box!important;
  }

  body.phase4-hard-mobile .hard-desktop-only,
  body.phase4-hard-mobile .topbar:not(:has(+ .hard-mobile-dashboard)){
    display:none!important;
  }

  body.phase4-hard-mobile .kpi-grid,
  body.phase4-hard-mobile .analytics-grid,
  body.phase4-hard-mobile .proplus-grid,
  body.phase4-hard-mobile .dashboard-grid,
  body.phase4-hard-mobile .cards{
    display:none!important;
  }

  .hard-mobile-dashboard{
    display:block!important;
  }

  .hard-hero-card{
    position:relative!important;
    overflow:hidden!important;
    padding:24px!important;
    border-radius:34px!important;
    color:white!important;
    background:linear-gradient(135deg,#061226 0%,#172b4d 58%,#635bff 130%)!important;
    box-shadow:0 28px 80px rgba(10,37,64,.28)!important;
    margin-bottom:14px!important;
  }

  .hard-hero-card:after{
    content:""!important;
    position:absolute!important;
    width:180px!important;
    height:180px!important;
    right:-68px!important;
    top:-68px!important;
    border-radius:999px!important;
    background:rgba(255,255,255,.13)!important;
  }

  .hard-hero-mini{
    position:relative!important;
    z-index:1!important;
    color:#cbd5e1!important;
    font-size:12px!important;
    font-weight:950!important;
    text-transform:uppercase!important;
    letter-spacing:.08em!important;
  }

  .hard-hero-card h2{
    position:relative!important;
    z-index:1!important;
    margin:10px 0 8px!important;
    color:#fff!important;
    font-size:39px!important;
    line-height:.96!important;
    letter-spacing:-.08em!important;
  }

  .hard-hero-card p{
    position:relative!important;
    z-index:1!important;
    color:#dbeafe!important;
    font-weight:800!important;
    margin:0!important;
  }

  .hard-money-card{
    padding:22px!important;
    border-radius:30px!important;
    background:#fff!important;
    border:1px solid #e6ebf1!important;
    box-shadow:0 20px 55px rgba(10,37,64,.12)!important;
    margin-bottom:12px!important;
  }

  .hard-money-card span{
    display:block!important;
    color:#697386!important;
    font-size:12px!important;
    font-weight:950!important;
  }

  .hard-money-card strong{
    display:block!important;
    margin-top:8px!important;
    color:#0a2540!important;
    font-size:42px!important;
    line-height:1!important;
    letter-spacing:-.075em!important;
  }

  .hard-money-card em{
    display:block!important;
    margin-top:8px!important;
    color:#697386!important;
    font-style:normal!important;
    font-weight:800!important;
  }

  .hard-quick-grid{
    display:grid!important;
    grid-template-columns:repeat(3,1fr)!important;
    gap:10px!important;
    margin-bottom:18px!important;
  }

  .hard-quick-grid a{
    min-height:84px!important;
    padding:14px 8px!important;
    border-radius:26px!important;
    background:#fff!important;
    border:1px solid #e6ebf1!important;
    box-shadow:0 15px 36px rgba(10,37,64,.09)!important;
    text-decoration:none!important;
    color:#0a2540!important;
    display:flex!important;
    flex-direction:column!important;
    justify-content:center!important;
    align-items:center!important;
    gap:8px!important;
    font-weight:950!important;
  }

  .hard-quick-grid a:active,
  .hard-doc-card:active{
    transform:scale(.975)!important;
  }

  .hard-quick-grid b{
    font-size:25px!important;
  }

  .hard-quick-grid span{
    font-size:12px!important;
  }

  .hard-section-title{
    display:flex!important;
    justify-content:space-between!important;
    align-items:end!important;
    margin:18px 4px 10px!important;
  }

  .hard-section-title h3{
    margin:0!important;
    color:#0a2540!important;
    font-size:22px!important;
    letter-spacing:-.055em!important;
  }

  .hard-section-title span{
    color:#697386!important;
    font-weight:850!important;
    font-size:12px!important;
  }

  .hard-doc-feed{
    display:grid!important;
    gap:10px!important;
  }

  .hard-doc-card{
    display:flex!important;
    justify-content:space-between!important;
    align-items:center!important;
    gap:14px!important;
    min-height:76px!important;
    padding:16px!important;
    border-radius:27px!important;
    background:rgba(255,255,255,.96)!important;
    border:1px solid #e6ebf1!important;
    box-shadow:0 15px 42px rgba(10,37,64,.10)!important;
    text-decoration:none!important;
    color:#0a2540!important;
  }

  .hard-doc-card b,
  .hard-doc-card strong{
    display:block!important;
  }

  .hard-doc-card small{
    display:block!important;
    margin-top:4px!important;
    color:#697386!important;
    font-weight:800!important;
    max-width:180px!important;
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
  }

  .hard-doc-card strong{
    font-size:17px!important;
    text-align:right!important;
    white-space:nowrap!important;
  }

  .hard-doc-card em{
    display:inline-flex!important;
    float:right!important;
    margin-top:6px!important;
    padding:5px 9px!important;
    border-radius:999px!important;
    font-size:10px!important;
    font-style:normal!important;
    font-weight:950!important;
  }

  .hard-doc-card em.open{background:#fffbeb!important;color:#92400e!important}
  .hard-doc-card em.paid{background:#dcfce7!important;color:#166534!important}
  .hard-doc-card em.late{background:#fee2e2!important;color:#991b1b!important}
  .hard-doc-card em.converted{background:#eef2ff!important;color:#3730a3!important}

  .hard-empty{
    padding:24px!important;
    border-radius:28px!important;
    background:#fff!important;
    border:1px solid #e6ebf1!important;
    box-shadow:0 15px 42px rgba(10,37,64,.10)!important;
  }

  .hard-empty b,
  .hard-empty span{
    display:block!important;
  }

  .hard-empty b{
    color:#0a2540!important;
    font-size:19px!important;
  }

  .hard-empty span{
    margin-top:6px!important;
    color:#697386!important;
    font-weight:800!important;
  }

  /* Bottom navigation */
  .hard-fab-toggle{display:none!important}

  .hard-bottom-nav{
    display:grid!important;
    grid-template-columns:1fr 1fr 86px 1fr 1fr!important;
    position:fixed!important;
    left:10px!important;
    right:10px!important;
    bottom:10px!important;
    height:72px!important;
    z-index:9998!important;
    align-items:center!important;
    padding:0 8px!important;
    border-radius:30px!important;
    background:rgba(255,255,255,.92)!important;
    border:1px solid rgba(230,235,241,.96)!important;
    box-shadow:0 26px 76px rgba(10,37,64,.26)!important;
    backdrop-filter:blur(18px)!important;
  }

  .hard-bottom-nav a{
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    gap:3px!important;
    height:58px!important;
    border-radius:20px!important;
    color:#697386!important;
    text-decoration:none!important;
    font-size:10px!important;
    font-weight:900!important;
  }

  .hard-bottom-nav a b{
    font-size:21px!important;
    line-height:1!important;
  }

  .hard-bottom-nav a.active{
    color:#635bff!important;
    background:#f3f1ff!important;
  }

  .hard-bottom-nav a:nth-child(3){grid-column:4!important}
  .hard-bottom-nav a:nth-child(4){grid-column:5!important}

  .hard-fab-button{
    display:grid!important;
    place-items:center!important;
    position:fixed!important;
    left:50%!important;
    bottom:34px!important;
    transform:translateX(-50%)!important;
    width:66px!important;
    height:66px!important;
    border-radius:25px!important;
    z-index:10000!important;
    color:#fff!important;
    font-size:36px!important;
    font-weight:850!important;
    background:linear-gradient(135deg,#635bff,#8b5cf6)!important;
    box-shadow:0 20px 48px rgba(99,91,255,.42)!important;
  }

  .hard-fab-button:active{
    transform:translateX(-50%) scale(.94)!important;
  }

  .hard-fab-backdrop{
    display:none!important;
    position:fixed!important;
    inset:0!important;
    z-index:9996!important;
    background:rgba(10,37,64,.24)!important;
    backdrop-filter:blur(4px)!important;
  }

  .hard-fab-menu{
    display:grid!important;
    position:fixed!important;
    left:14px!important;
    right:14px!important;
    bottom:98px!important;
    z-index:9999!important;
    gap:10px!important;
    padding:14px!important;
    border-radius:30px!important;
    background:rgba(255,255,255,.96)!important;
    border:1px solid #e6ebf1!important;
    box-shadow:0 30px 90px rgba(10,37,64,.28)!important;
    opacity:0!important;
    pointer-events:none!important;
    transform:translateY(18px) scale(.98)!important;
    transition:.18s ease!important;
  }

  .hard-fab-menu a{
    min-height:62px!important;
    display:grid!important;
    grid-template-columns:42px 1fr!important;
    align-items:center!important;
    column-gap:10px!important;
    padding:12px 14px!important;
    border-radius:22px!important;
    background:#f6f9fc!important;
    color:#0a2540!important;
    text-decoration:none!important;
  }

  .hard-fab-menu a span{
    grid-row:1 / span 2!important;
    font-size:25px!important;
  }

  .hard-fab-menu a b{
    display:block!important;
    font-size:15px!important;
  }

  .hard-fab-menu a small{
    display:block!important;
    color:#697386!important;
    font-weight:800!important;
  }

  .hard-fab-toggle:checked ~ .hard-fab-backdrop{
    display:block!important;
  }

  .hard-fab-toggle:checked ~ .hard-fab-menu{
    opacity:1!important;
    pointer-events:auto!important;
    transform:translateY(0) scale(1)!important;
  }

  /* Invoice hard visual */
  .hard-invoice-hero{
    display:block!important;
    margin:12px 0 12px!important;
    padding:24px!important;
    border-radius:34px!important;
    color:#fff!important;
    background:linear-gradient(135deg,#061226 0%,#172b4d 58%,#635bff 130%)!important;
    box-shadow:0 28px 80px rgba(10,37,64,.28)!important;
    position:relative!important;
    overflow:hidden!important;
  }

  .hard-invoice-hero:after{
    content:""!important;
    position:absolute!important;
    right:-65px!important;
    top:-65px!important;
    width:170px!important;
    height:170px!important;
    border-radius:999px!important;
    background:rgba(255,255,255,.13)!important;
  }

  .hard-invoice-top{
    position:relative!important;
    z-index:1!important;
    display:flex!important;
    justify-content:space-between!important;
    align-items:center!important;
    gap:16px!important;
    margin-bottom:18px!important;
  }

  .hard-invoice-top span{
    color:#cbd5e1!important;
    font-weight:950!important;
    font-size:12px!important;
    text-transform:uppercase!important;
    letter-spacing:.08em!important;
  }

  .hard-invoice-top b{
    color:#fff!important;
    font-size:13px!important;
    font-weight:950!important;
  }

  .hard-invoice-hero > strong{
    position:relative!important;
    z-index:1!important;
    display:block!important;
    color:#fff!important;
    font-size:48px!important;
    line-height:.95!important;
    letter-spacing:-.085em!important;
  }

  .hard-invoice-pills{
    position:relative!important;
    z-index:1!important;
    display:flex!important;
    gap:8px!important;
    flex-wrap:wrap!important;
    margin-top:16px!important;
  }

  .hard-invoice-pills em{
    display:inline-flex!important;
    padding:8px 11px!important;
    border-radius:999px!important;
    font-style:normal!important;
    font-size:12px!important;
    font-weight:950!important;
    background:rgba(255,255,255,.13)!important;
    color:#e5e7eb!important;
  }

  .hard-invoice-pills em.open{background:#fffbeb!important;color:#92400e!important}
  .hard-invoice-pills em.paid{background:#dcfce7!important;color:#166534!important}
  .hard-invoice-pills em.late{background:#fee2e2!important;color:#991b1b!important}
  .hard-invoice-pills em.converted{background:#eef2ff!important;color:#3730a3!important}

  .hard-invoice-hero p{
    position:relative!important;
    z-index:1!important;
    color:#dbeafe!important;
    margin:16px 0 0!important;
    font-weight:850!important;
  }

  body.phase4-hard-mobile .invoice-actions{
    display:none!important;
  }

  body.phase4-hard-mobile .invoice-sheet,
  body.phase4-hard-mobile .stripe-invoice-sheet,
  body.phase4-hard-mobile .v5-sheet{
    margin:0!important;
    padding:20px 16px 24px!important;
    border-radius:30px!important;
    background:#fff!important;
    box-shadow:0 18px 54px rgba(10,37,64,.12)!important;
  }

  body.phase4-hard-mobile .invoice-header.premium .document-title{
    display:none!important;
  }

  body.phase4-hard-mobile .invoice-header.premium{
    border:0!important;
    padding-bottom:10px!important;
    margin-bottom:8px!important;
  }

  body.phase4-hard-mobile .invoice-meta{
    grid-template-columns:1fr!important;
    gap:10px!important;
    margin:14px 0!important;
  }

  body.phase4-hard-mobile .invoice-meta > div{
    border-radius:24px!important;
    padding:16px!important;
    background:#f6f9fc!important;
  }

  body.phase4-hard-mobile .invoice-table{
    display:block!important;
    border:0!important;
    min-width:0!important;
    overflow:visible!important;
    margin-top:16px!important;
  }

  body.phase4-hard-mobile .invoice-table thead{
    display:none!important;
  }

  body.phase4-hard-mobile .invoice-table tbody{
    display:grid!important;
    gap:10px!important;
  }

  body.phase4-hard-mobile .invoice-table tbody tr{
    display:grid!important;
    gap:8px!important;
    padding:16px!important;
    border-radius:24px!important;
    background:#fbfdff!important;
    border:1px solid #e6ebf1!important;
    box-shadow:0 10px 28px rgba(10,37,64,.06)!important;
  }

  body.phase4-hard-mobile .invoice-table tbody td{
    display:flex!important;
    justify-content:space-between!important;
    gap:12px!important;
    border:0!important;
    padding:0!important;
    background:transparent!important;
  }

  body.phase4-hard-mobile .invoice-table tbody td:nth-child(1)::before{content:"Pos."; color:#697386; font-weight:900}
  body.phase4-hard-mobile .invoice-table tbody td:nth-child(2)::before{content:"Beschreibung"; color:#697386; font-weight:900}
  body.phase4-hard-mobile .invoice-table tbody td:nth-child(3)::before{content:"Menge"; color:#697386; font-weight:900}
  body.phase4-hard-mobile .invoice-table tbody td:nth-child(4)::before{content:"Einheit"; color:#697386; font-weight:900}
  body.phase4-hard-mobile .invoice-table tbody td:nth-child(5)::before{content:"Preis"; color:#697386; font-weight:900}
  body.phase4-hard-mobile .invoice-table tbody td:nth-child(6)::before{content:"Gesamt"; color:#697386; font-weight:900}

  body.phase4-hard-mobile .invoice-table tbody td:nth-child(2){
    display:block!important;
  }

  body.phase4-hard-mobile .invoice-table tbody td:nth-child(2)::before{
    display:block!important;
    margin-bottom:6px!important;
  }

  body.phase4-hard-mobile .invoice-table tbody td:last-child{
    border-top:1px solid #e6ebf1!important;
    padding-top:8px!important;
    color:#635bff!important;
    font-size:18px!important;
    font-weight:950!important;
  }

  body.phase4-hard-mobile .invoice-table tfoot{
    display:block!important;
    margin-top:12px!important;
    padding:16px!important;
    border-radius:26px!important;
    background:linear-gradient(135deg,#f6f9ff,#fff)!important;
    border:1px solid #e6ebf1!important;
  }

  body.phase4-hard-mobile .invoice-table tfoot tr{
    display:flex!important;
    justify-content:space-between!important;
    padding:6px 0!important;
  }

  body.phase4-hard-mobile .invoice-table tfoot td{
    display:block!important;
    padding:0!important;
    border:0!important;
    background:transparent!important;
  }

  body.phase4-hard-mobile .invoice-table tfoot tr:last-child{
    border-top:1px solid #e6ebf1!important;
    margin-top:8px!important;
    padding-top:14px!important;
  }

  body.phase4-hard-mobile .invoice-table tfoot tr:last-child td{
    color:#635bff!important;
    font-size:28px!important;
    font-weight:950!important;
  }

  .hard-sticky-actions{
    position:fixed!important;
    left:12px!important;
    right:12px!important;
    bottom:92px!important;
    z-index:9995!important;
    display:grid!important;
    grid-template-columns:1fr 1.28fr 1fr!important;
    gap:8px!important;
    padding:8px!important;
    border-radius:25px!important;
    background:rgba(255,255,255,.92)!important;
    border:1px solid #e6ebf1!important;
    box-shadow:0 22px 65px rgba(10,37,64,.22)!important;
    backdrop-filter:blur(16px)!important;
  }

  .hard-sticky-actions a{
    min-height:48px!important;
    display:grid!important;
    place-items:center!important;
    border-radius:17px!important;
    background:#f6f9fc!important;
    color:#0a2540!important;
    text-decoration:none!important;
    font-weight:950!important;
    font-size:13px!important;
  }

  .hard-sticky-actions a.primary{
    background:#635bff!important;
    color:#fff!important;
  }

  body.phase4-hard-mobile .panel{
    border-radius:28px!important;
    padding:18px!important;
    box-shadow:0 16px 46px rgba(10,37,64,.10)!important;
  }

  body.phase4-hard-mobile input,
  body.phase4-hard-mobile select,
  body.phase4-hard-mobile textarea{
    font-size:16px!important;
    min-height:54px!important;
    border-radius:19px!important;
  }

  body.phase4-hard-mobile .btn{
    min-height:46px!important;
    border-radius:17px!important;
  }
}

@media(min-width:901px){
  .hard-mobile-dashboard,
  .hard-invoice-hero,
  .hard-bottom-nav,
  .hard-fab-button,
  .hard-fab-menu,
  .hard-fab-backdrop,
  .hard-sticky-actions{
    display:none!important;
  }
}



/* ==========================================================
   PHASE 5 SMART UX
   ========================================================== */

.smart-ux-assistant{
  margin:24px 0 14px;
  padding:22px;
  border-radius:28px;
  background:linear-gradient(135deg,#0a2540,#172b4d);
  color:#fff;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  box-shadow:0 22px 58px rgba(10,37,64,.18);
  position:relative;
  overflow:hidden;
}

.smart-ux-assistant:after{
  content:"";
  position:absolute;
  right:-42px;
  top:-42px;
  width:130px;
  height:130px;
  border-radius:999px;
  background:rgba(99,91,255,.34);
}

.smart-ux-assistant > *{
  position:relative;
  z-index:1;
}

.smart-ux-assistant span{
  display:block;
  color:#cbd5e1;
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.smart-ux-assistant h2{
  margin:7px 0 5px;
  color:#fff;
  font-size:24px;
  letter-spacing:-.055em;
}

.smart-ux-assistant p{
  margin:0;
  color:#dbeafe;
  font-weight:750;
  line-height:1.45;
}

.smart-reset{
  border:1px solid rgba(255,255,255,.20);
  background:rgba(255,255,255,.12);
  color:#fff;
  border-radius:16px;
  padding:12px 14px;
  font-weight:950;
  cursor:pointer;
}

.smart-suggestions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:0 0 20px;
}

.smart-suggestions button{
  border:1px solid #e6ebf1;
  background:#fff;
  color:#0a2540;
  border-radius:999px;
  padding:12px 15px;
  font-weight:950;
  box-shadow:0 10px 24px rgba(10,37,64,.06);
  cursor:pointer;
}

.duplicate-position-btn{
  width:34px!important;
  height:34px!important;
  min-height:34px!important;
  border-radius:999px!important;
  border:1px solid #dbeafe!important;
  background:#eff6ff!important;
  color:#1d4ed8!important;
  font-weight:950!important;
  display:inline-grid!important;
  place-items:center!important;
  cursor:pointer!important;
  margin-right:6px!important;
}

.smart-pop{
  animation:smartPop .42s ease-out both;
}

@keyframes smartPop{
  0%{transform:scale(.985); box-shadow:0 0 0 0 rgba(99,91,255,.28);}
  55%{transform:scale(1.01); box-shadow:0 0 0 9px rgba(99,91,255,.08);}
  100%{transform:scale(1); box-shadow:0 0 0 0 rgba(99,91,255,0);}
}

@media(max-width:900px){
  body.phase5-smart-ux .smart-ux-assistant{
    margin:16px 0 12px!important;
    padding:20px!important;
    border-radius:30px!important;
    display:block!important;
  }

  body.phase5-smart-ux .smart-ux-assistant h2{
    font-size:27px!important;
  }

  body.phase5-smart-ux .smart-reset{
    margin-top:15px!important;
    width:100%!important;
  }

  body.phase5-smart-ux .smart-suggestions{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:9px!important;
  }

  body.phase5-smart-ux .smart-suggestions button{
    min-height:52px!important;
    border-radius:20px!important;
    text-align:left!important;
    padding:0 16px!important;
  }

  body.phase5-smart-ux .duplicate-position-btn{
    width:38px!important;
    height:38px!important;
    min-height:38px!important;
  }
}



/* ==========================================================
   FULL APP REBUILD - Apple/Stripe Level UX Layer
   ========================================================== */
:root{
  --fa-bg:#f6f9fc;
  --fa-card:#ffffff;
  --fa-dark:#0a2540;
  --fa-muted:#697386;
  --fa-line:#e6ebf1;
  --fa-primary:#635bff;
  --fa-green:#00a76f;
  --fa-red:#e11d48;
  --fa-shadow:0 24px 70px rgba(10,37,64,.12);
}

.full-app-rebuild{
  margin:0!important;
  background:
    radial-gradient(circle at 84% -10%, rgba(99,91,255,.20), transparent 34%),
    radial-gradient(circle at 3% 20%, rgba(0,167,111,.10), transparent 30%),
    linear-gradient(180deg,#f6f9fc,#eef4fb)!important;
  color:var(--fa-dark)!important;
}

.fullapp-layout{
  display:grid;
  grid-template-columns:260px minmax(0,1fr);
  min-height:100vh;
}

.fullapp-sidebar{
  padding:26px;
  border-right:1px solid var(--fa-line);
  background:rgba(255,255,255,.70);
  backdrop-filter:blur(18px);
}

.fullapp-brand{
  display:flex;
  gap:12px;
  align-items:center;
  margin-bottom:26px;
}
.fullapp-brand span{
  width:44px;height:44px;border-radius:16px;background:var(--fa-dark);color:#fff;display:grid;place-items:center;font-weight:950;
}
.fullapp-brand b{display:block}
.fullapp-brand small{display:block;color:var(--fa-muted);font-weight:800}

.fullapp-sidebar nav{display:grid;gap:8px}
.fullapp-sidebar nav a{
  padding:13px 14px;border-radius:16px;color:var(--fa-muted);text-decoration:none;font-weight:900;
}
.fullapp-sidebar nav a.active,
.fullapp-sidebar nav a:hover{background:#f3f1ff;color:var(--fa-primary)}

.fullapp-main{
  padding:34px;
  max-width:1320px;
  width:100%;
  box-sizing:border-box;
}

.fullapp-hero{
  display:flex;
  justify-content:space-between;
  gap:24px;
  align-items:flex-end;
  padding:34px;
  border-radius:36px;
  color:#fff;
  background:linear-gradient(135deg,#061226,#172b4d 62%,#635bff 140%);
  box-shadow:0 34px 90px rgba(10,37,64,.23);
  position:relative;
  overflow:hidden;
}
.fullapp-hero:after{
  content:"";position:absolute;right:-80px;top:-80px;width:230px;height:230px;border-radius:999px;background:rgba(255,255,255,.12);
}
.fullapp-hero > *{position:relative;z-index:1}
.fullapp-hero span{color:#cbd5e1;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.09em}
.fullapp-hero h1{margin:10px 0 8px;font-size:48px;line-height:.98;letter-spacing:-.08em;color:#fff}
.fullapp-hero p{margin:0;color:#dbeafe;font-weight:800}
.fullapp-hero a{
  color:#fff;background:var(--fa-primary);text-decoration:none;border-radius:18px;padding:14px 18px;font-weight:950;box-shadow:0 14px 34px rgba(99,91,255,.32);white-space:nowrap;
}

.fullapp-kpis{
  display:grid;
  grid-template-columns:1.4fr 1fr .8fr .8fr;
  gap:16px;
  margin:20px 0;
}
.fullapp-kpis article{
  padding:24px;border-radius:30px;background:#fff;border:1px solid var(--fa-line);box-shadow:0 16px 42px rgba(10,37,64,.08);
}
.fullapp-kpis span{display:block;color:var(--fa-muted);font-size:12px;font-weight:950}
.fullapp-kpis strong{display:block;margin-top:10px;font-size:34px;line-height:1;letter-spacing:-.065em;color:var(--fa-dark)}
.fullapp-kpis small{display:block;margin-top:8px;color:var(--fa-muted);font-weight:800}
.fullapp-kpis .money strong{color:var(--fa-primary)}
.fullapp-kpis .danger strong{color:var(--fa-red)}

.fullapp-grid{
  display:grid;
  grid-template-columns:minmax(0,1.7fr) minmax(320px,.8fr);
  gap:20px;
  align-items:start;
}
.fullapp-panel{
  background:#fff;border:1px solid var(--fa-line);border-radius:32px;padding:24px;box-shadow:var(--fa-shadow);
}
.fullapp-panel-head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:18px;
}
.fullapp-panel-head h2{margin:0;font-size:26px;letter-spacing:-.055em;color:var(--fa-dark)}
.fullapp-panel-head p{margin:5px 0 0;color:var(--fa-muted);font-weight:800}
.fullapp-panel-head a{color:var(--fa-primary);font-weight:950;text-decoration:none}

.fullapp-doc-list{display:grid;gap:10px}
.fullapp-doc{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:16px;border-radius:24px;background:#fbfdff;border:1px solid #edf2f7;text-decoration:none;color:var(--fa-dark);
  transition:.16s ease;
}
.fullapp-doc:hover{transform:translateY(-1px);box-shadow:0 14px 34px rgba(10,37,64,.08)}
.fullapp-doc b,.fullapp-doc strong{display:block}
.fullapp-doc span{display:block;margin-top:4px;color:var(--fa-muted);font-weight:800}
.doc-side{text-align:right}
.doc-side strong{font-size:18px;white-space:nowrap}
.doc-side em{
  display:inline-flex;margin-top:6px;padding:5px 9px;border-radius:999px;font-style:normal;font-size:11px;font-weight:950;
}
.doc-side em.open{background:#fffbeb;color:#92400e}
.doc-side em.paid{background:#dcfce7;color:#166534}
.doc-side em.late{background:#fee2e2;color:#991b1b}
.doc-side em.converted{background:#eef2ff;color:#3730a3}

.fullapp-side{display:grid;gap:20px}
.fullapp-mini-list{display:grid;gap:10px}
.fullapp-mini{
  display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px;border-radius:20px;background:#f8fafc;border:1px solid #edf2f7;
}
.fullapp-mini b,.fullapp-mini span{display:block}
.fullapp-mini span{margin-top:4px;color:var(--fa-muted);font-weight:800}
.fullapp-mini strong{color:var(--fa-primary);white-space:nowrap}

.fullapp-actions{display:grid;gap:10px}
.fullapp-actions a{
  text-decoration:none;color:var(--fa-dark);padding:15px;border-radius:20px;background:#f8fafc;border:1px solid #edf2f7;font-weight:950;
}
.fullapp-empty{
  padding:24px;border-radius:24px;background:#f8fafc;color:var(--fa-muted);font-weight:800;
}
.fullapp-empty b{display:block;color:var(--fa-dark);font-size:18px}
.fullapp-empty span{display:block;margin-top:6px}

/* Full app mobile nav */
.fullapp-bottom-nav,.fullapp-fab,.fullapp-fab-menu,.fullapp-backdrop,.fullapp-fab-toggle{display:none}

.fullapp-customers-intro{
  display:none;
}

@media(max-width:900px){
  .fullapp-layout{display:block}
  .fullapp-sidebar{display:none}
  .fullapp-main{padding:12px 12px 116px}
  .fullapp-hero{padding:24px;border-radius:34px;display:block}
  .fullapp-hero h1{font-size:39px}
  .fullapp-hero a{display:inline-flex;margin-top:18px}
  .fullapp-kpis{grid-template-columns:1.4fr .8fr;gap:10px}
  .fullapp-kpis article{padding:17px;border-radius:25px}
  .fullapp-kpis strong{font-size:25px}
  .fullapp-grid{grid-template-columns:1fr;gap:14px}
  .fullapp-panel{padding:18px;border-radius:30px}
  .fullapp-panel-head h2{font-size:23px}
  .fullapp-doc{border-radius:25px;min-height:72px}
  .fullapp-side{gap:14px}

  /* Hide old layout parts where present */
  body.full-app-rebuild .sidebar{display:none!important}
  body.full-app-rebuild .layout{display:block!important}
  body.full-app-rebuild .main{padding:12px 12px 116px!important}
  body.full-app-rebuild .topbar{border-radius:28px!important}

  .fullapp-customers-intro{
    display:block;
    padding:24px;
    border-radius:34px;
    background:linear-gradient(135deg,#061226,#172b4d 62%,#635bff 140%);
    color:#fff;
    box-shadow:0 28px 80px rgba(10,37,64,.26);
    margin-bottom:14px;
  }
  .fullapp-customers-intro span{color:#cbd5e1;font-weight:950;font-size:12px;text-transform:uppercase;letter-spacing:.08em}
  .fullapp-customers-intro h1{margin:9px 0 7px;color:#fff;font-size:34px;line-height:1;letter-spacing:-.075em}
  .fullapp-customers-intro p{margin:0 0 16px;color:#dbeafe;font-weight:800}
  .fullapp-customers-intro a{display:inline-flex;color:#fff;background:var(--fa-primary);text-decoration:none;border-radius:16px;padding:12px 15px;font-weight:950}

  .fullapp-bottom-nav{
    display:grid!important;
    grid-template-columns:1fr 1fr 86px 1fr 1fr;
    position:fixed;left:10px;right:10px;bottom:10px;z-index:9998;height:72px;
    align-items:center;padding:0 8px;border-radius:30px;background:rgba(255,255,255,.92);
    border:1px solid rgba(230,235,241,.96);box-shadow:0 26px 76px rgba(10,37,64,.26);backdrop-filter:blur(18px);
  }
  .fullapp-bottom-nav a{
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;height:58px;border-radius:20px;
    color:var(--fa-muted);text-decoration:none;font-size:10px;font-weight:900;
  }
  .fullapp-bottom-nav a b{font-size:21px;line-height:1}
  .fullapp-bottom-nav a.active{color:var(--fa-primary);background:#f3f1ff}
  .fullapp-bottom-nav a:nth-child(3){grid-column:4}
  .fullapp-bottom-nav a:nth-child(4){grid-column:5}
  .fullapp-fab{
    display:grid!important;place-items:center;position:fixed;left:50%;bottom:34px;transform:translateX(-50%);
    width:66px;height:66px;border-radius:25px;z-index:10000;color:#fff;font-size:36px;font-weight:850;
    background:linear-gradient(135deg,#635bff,#8b5cf6);box-shadow:0 20px 48px rgba(99,91,255,.42);
  }
  .fullapp-fab-toggle{display:none}
  .fullapp-backdrop{display:none;position:fixed;inset:0;z-index:9996;background:rgba(10,37,64,.24);backdrop-filter:blur(4px)}
  .fullapp-fab-menu{
    display:grid;position:fixed;left:14px;right:14px;bottom:98px;z-index:9999;gap:10px;padding:14px;border-radius:30px;
    background:rgba(255,255,255,.96);border:1px solid var(--fa-line);box-shadow:0 30px 90px rgba(10,37,64,.28);
    opacity:0;pointer-events:none;transform:translateY(18px) scale(.98);transition:.18s ease;
  }
  .fullapp-fab-menu a{
    min-height:62px;display:grid;grid-template-columns:42px 1fr;align-items:center;column-gap:10px;padding:12px 14px;border-radius:22px;
    background:#f6f9fc;color:var(--fa-dark);text-decoration:none;
  }
  .fullapp-fab-menu a span{grid-row:1 / span 2;font-size:25px}
  .fullapp-fab-menu a b{display:block;font-size:15px}
  .fullapp-fab-menu a small{display:block;color:var(--fa-muted);font-weight:800}
  .fullapp-fab-toggle:checked ~ .fullapp-backdrop{display:block}
  .fullapp-fab-toggle:checked ~ .fullapp-fab-menu{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}
}



/* ==========================================================
   UI 2026 FULL REDESIGN
   Modern fresh Apple/Stripe inspired design system
   ========================================================== */

:root{
  --ui26-bg:#f5f7fb;
  --ui26-surface:rgba(255,255,255,.82);
  --ui26-card:#ffffff;
  --ui26-dark:#071429;
  --ui26-text:#0f2742;
  --ui26-muted:#718096;
  --ui26-line:rgba(226,232,240,.9);
  --ui26-primary:#635bff;
  --ui26-primary2:#8b5cf6;
  --ui26-green:#00a76f;
  --ui26-red:#e11d48;
  --ui26-yellow:#f59e0b;
  --ui26-radius:30px;
  --ui26-shadow:0 24px 70px rgba(7,20,41,.12);
  --ui26-soft:0 14px 36px rgba(7,20,41,.08);
}

*{
  box-sizing:border-box;
}

body.ui26-page,
body.full-app-rebuild,
body.phase4-hard-mobile,
body.phase5-smart-ux{
  margin:0!important;
  min-height:100vh!important;
  background:
    radial-gradient(circle at 82% -10%, rgba(99,91,255,.20), transparent 34%),
    radial-gradient(circle at 4% 20%, rgba(0,167,111,.10), transparent 30%),
    linear-gradient(180deg,#f6f8fc 0%,#eef4fb 100%)!important;
  color:var(--ui26-text)!important;
  font-family:Inter, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif!important;
  -webkit-font-smoothing:antialiased;
}

.ui26-noise{
  pointer-events:none;
  position:fixed;
  inset:0;
  z-index:-1;
  opacity:.18;
  background-image:linear-gradient(rgba(255,255,255,.35) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.35) 1px, transparent 1px);
  background-size:44px 44px;
}

/* Generic layout overrides */
.layout,
.fullapp-layout,
.ui26-app{
  display:grid!important;
  grid-template-columns:280px minmax(0,1fr)!important;
  min-height:100vh!important;
}

.sidebar,
.fullapp-sidebar,
.ui26-sidebar{
  position:sticky!important;
  top:0!important;
  height:100vh!important;
  padding:26px!important;
  border-right:1px solid var(--ui26-line)!important;
  background:rgba(255,255,255,.68)!important;
  backdrop-filter:blur(22px)!important;
}

.brand,
.fullapp-brand,
.ui26-brand{
  display:flex!important;
  gap:13px!important;
  align-items:center!important;
  margin-bottom:28px!important;
}

.brand span,
.fullapp-brand span,
.ui26-brand span{
  width:48px!important;
  height:48px!important;
  border-radius:18px!important;
  display:grid!important;
  place-items:center!important;
  color:#fff!important;
  background:linear-gradient(135deg,var(--ui26-dark),#1e2f55)!important;
  box-shadow:0 12px 28px rgba(7,20,41,.18)!important;
  font-weight:950!important;
}

.brand b,
.fullapp-brand b,
.ui26-brand b{
  display:block!important;
  color:var(--ui26-dark)!important;
  font-size:16px!important;
}

.brand small,
.fullapp-brand small,
.ui26-brand small{
  display:block!important;
  color:var(--ui26-muted)!important;
  font-weight:850!important;
}

.sidebar nav,
.fullapp-sidebar nav,
.ui26-sidebar nav{
  display:grid!important;
  gap:8px!important;
}

.sidebar nav a,
.fullapp-sidebar nav a,
.ui26-sidebar nav a{
  padding:14px 15px!important;
  border-radius:18px!important;
  color:var(--ui26-muted)!important;
  text-decoration:none!important;
  font-weight:900!important;
  transition:.16s ease!important;
}

.sidebar nav a.active,
.sidebar nav a:hover,
.fullapp-sidebar nav a.active,
.fullapp-sidebar nav a:hover,
.ui26-sidebar nav a.active,
.ui26-sidebar nav a:hover{
  color:var(--ui26-primary)!important;
  background:#f1efff!important;
}

.main,
.fullapp-main,
.ui26-main{
  padding:34px!important;
  width:100%!important;
  max-width:1360px!important;
  box-sizing:border-box!important;
}

/* Page hero */
.ui26-hero,
.fullapp-hero,
.ui26-page-hero{
  position:relative!important;
  overflow:hidden!important;
  padding:34px!important;
  border-radius:38px!important;
  color:#fff!important;
  background:linear-gradient(135deg,#061226 0%,#172b4d 62%,#635bff 142%)!important;
  box-shadow:0 34px 90px rgba(7,20,41,.22)!important;
  margin-bottom:22px!important;
}

.ui26-hero:after,
.fullapp-hero:after,
.ui26-page-hero:after{
  content:""!important;
  position:absolute!important;
  right:-80px!important;
  top:-80px!important;
  width:240px!important;
  height:240px!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.12)!important;
}

.ui26-hero > *,
.fullapp-hero > *,
.ui26-page-hero > *{
  position:relative!important;
  z-index:1!important;
}

.ui26-hero{
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-end!important;
  gap:24px!important;
}

.ui26-eyebrow,
.fullapp-hero span,
.ui26-page-hero .ui26-eyebrow{
  display:block!important;
  color:#cbd5e1!important;
  font-size:12px!important;
  font-weight:950!important;
  text-transform:uppercase!important;
  letter-spacing:.095em!important;
}

.ui26-hero h1,
.fullapp-hero h1,
.ui26-page-hero h1{
  margin:10px 0 8px!important;
  color:#fff!important;
  font-size:52px!important;
  line-height:.96!important;
  letter-spacing:-.085em!important;
}

.ui26-hero p,
.fullapp-hero p,
.ui26-page-hero p{
  margin:0!important;
  color:#dbeafe!important;
  font-weight:800!important;
}

.ui26-hero-actions{
  display:flex!important;
  gap:10px!important;
  flex-wrap:wrap!important;
}

.ui26-hero-actions a,
.fullapp-hero a{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:48px!important;
  padding:0 18px!important;
  border-radius:18px!important;
  background:var(--ui26-primary)!important;
  color:#fff!important;
  text-decoration:none!important;
  font-weight:950!important;
  box-shadow:0 14px 34px rgba(99,91,255,.32)!important;
}

.ui26-hero-actions a.ghost{
  background:rgba(255,255,255,.12)!important;
  border:1px solid rgba(255,255,255,.20)!important;
  box-shadow:none!important;
}

/* Cards, panels */
.card,
.panel,
.auth-card,
.fullapp-panel,
.ui26-card{
  background:rgba(255,255,255,.92)!important;
  border:1px solid var(--ui26-line)!important;
  border-radius:var(--ui26-radius)!important;
  box-shadow:var(--ui26-shadow)!important;
  backdrop-filter:blur(16px)!important;
}

.panel,
.fullapp-panel,
.ui26-card{
  padding:24px!important;
}

.panel-head,
.fullapp-panel-head,
.ui26-card-head{
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-start!important;
  gap:20px!important;
  margin-bottom:18px!important;
}

.panel-head h2,
.fullapp-panel-head h2,
.ui26-card-head h2{
  margin:0!important;
  color:var(--ui26-dark)!important;
  font-size:27px!important;
  letter-spacing:-.06em!important;
  line-height:1.05!important;
}

.panel-head p,
.fullapp-panel-head p,
.ui26-card-head p{
  margin:6px 0 0!important;
  color:var(--ui26-muted)!important;
  font-weight:800!important;
}

.panel-head a,
.ui26-card-head a{
  color:var(--ui26-primary)!important;
  text-decoration:none!important;
  font-weight:950!important;
}

/* KPIs */
.kpi-grid,
.analytics-grid,
.fullapp-kpis,
.ui26-kpi-grid{
  display:grid!important;
  grid-template-columns:1.35fr 1fr .85fr .85fr!important;
  gap:16px!important;
  margin:20px 0!important;
}

.kpi-card,
.analytics-card,
.fullapp-kpis article,
.ui26-kpi{
  min-width:0!important;
  padding:24px!important;
  border-radius:30px!important;
  background:#fff!important;
  border:1px solid var(--ui26-line)!important;
  box-shadow:var(--ui26-soft)!important;
}

.kpi-card span,
.analytics-card span,
.fullapp-kpis span,
.ui26-kpi span{
  display:block!important;
  color:var(--ui26-muted)!important;
  font-size:12px!important;
  font-weight:950!important;
  text-transform:none!important;
}

.kpi-card strong,
.analytics-card strong,
.fullapp-kpis strong,
.ui26-kpi strong{
  display:block!important;
  margin-top:10px!important;
  color:var(--ui26-dark)!important;
  font-size:35px!important;
  line-height:1!important;
  letter-spacing:-.07em!important;
  white-space:nowrap!important;
}

.kpi-card small,
.analytics-card small,
.fullapp-kpis small,
.ui26-kpi small{
  display:block!important;
  margin-top:8px!important;
  color:var(--ui26-muted)!important;
  font-weight:800!important;
}

.ui26-kpi.primary strong,
.fullapp-kpis .money strong,
.analytics-card.hero-money strong{
  color:var(--ui26-primary)!important;
}

.ui26-kpi.danger strong,
.kpi-card.danger strong{
  color:var(--ui26-red)!important;
}

.ui26-kpi.success strong{
  color:var(--ui26-green)!important;
}

/* Content grid */
.dashboard-grid,
.proplus-grid,
.fullapp-grid,
.ui26-content-grid{
  display:grid!important;
  grid-template-columns:minmax(0,1.7fr) minmax(320px,.82fr)!important;
  gap:20px!important;
  align-items:start!important;
}

.side-stack,
.fullapp-side,
.ui26-stack{
  display:grid!important;
  gap:20px!important;
}

/* Documents as cards */
.ui26-doc-list,
.fullapp-doc-list,
.mini-list{
  display:grid!important;
  gap:10px!important;
}

.ui26-doc-card,
.fullapp-doc,
.mini-item{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:16px!important;
  min-height:78px!important;
  padding:16px!important;
  border-radius:25px!important;
  background:#fbfdff!important;
  border:1px solid #edf2f7!important;
  color:var(--ui26-dark)!important;
  text-decoration:none!important;
  box-shadow:0 10px 28px rgba(7,20,41,.05)!important;
  transition:.16s ease!important;
}

.ui26-doc-card:hover,
.fullapp-doc:hover,
.mini-item:hover{
  transform:translateY(-2px)!important;
  box-shadow:0 18px 42px rgba(7,20,41,.10)!important;
}

.ui26-doc-icon{
  width:44px!important;
  height:44px!important;
  border-radius:16px!important;
  background:#f1efff!important;
  display:grid!important;
  place-items:center!important;
  font-size:22px!important;
  flex:0 0 auto!important;
}

.ui26-doc-main,
.doc-main{
  flex:1!important;
  min-width:0!important;
}

.ui26-doc-main b,
.doc-main b,
.ui26-doc-side strong,
.doc-side strong{
  display:block!important;
}

.ui26-doc-main span,
.doc-main span{
  display:block!important;
  color:var(--ui26-muted)!important;
  font-weight:800!important;
  margin-top:4px!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}

.ui26-doc-side,
.doc-side{
  text-align:right!important;
  flex:0 0 auto!important;
}

.ui26-doc-side strong,
.doc-side strong{
  font-size:18px!important;
  color:var(--ui26-dark)!important;
  white-space:nowrap!important;
}

.ui26-doc-side em,
.doc-side em,
.badge{
  display:inline-flex!important;
  align-items:center!important;
  width:max-content!important;
  margin-top:6px!important;
  padding:6px 10px!important;
  border-radius:999px!important;
  font-style:normal!important;
  font-size:11px!important;
  font-weight:950!important;
  border:1px solid transparent!important;
}

.ui26-doc-side em.open,
.doc-side em.open,
.badge.offen{background:#fffbeb!important;color:#92400e!important;border-color:#fde68a!important}
.ui26-doc-side em.paid,
.doc-side em.paid,
.badge.bezahlt{background:#dcfce7!important;color:#166534!important;border-color:#bbf7d0!important}
.ui26-doc-side em.late,
.doc-side em.late,
.badge.ueberfaellig{background:#fee2e2!important;color:#991b1b!important;border-color:#fecaca!important}
.ui26-doc-side em.converted,
.doc-side em.converted,
.badge.umgewandelt{background:#eef2ff!important;color:#3730a3!important;border-color:#c7d2fe!important}

/* Mini rows */
.ui26-mini-list,
.fullapp-mini-list{
  display:grid!important;
  gap:10px!important;
}

.ui26-mini-row,
.fullapp-mini,
.top-customer-item{
  display:flex!important;
  justify-content:space-between!important;
  align-items:center!important;
  gap:14px!important;
  padding:15px!important;
  border-radius:22px!important;
  background:#f8fafc!important;
  border:1px solid #edf2f7!important;
}

.ui26-mini-row b,
.ui26-mini-row span,
.fullapp-mini b,
.fullapp-mini span{
  display:block!important;
}

.ui26-mini-row span,
.fullapp-mini span{
  margin-top:4px!important;
  color:var(--ui26-muted)!important;
  font-weight:800!important;
}

.ui26-mini-row strong,
.fullapp-mini strong{
  color:var(--ui26-primary)!important;
  white-space:nowrap!important;
}

/* Shortcuts */
.ui26-shortcuts,
.fullapp-actions,
.quick-actions{
  display:grid!important;
  gap:10px!important;
}

.ui26-shortcuts a,
.fullapp-actions a,
.quick-actions a{
  display:flex!important;
  align-items:center!important;
  min-height:52px!important;
  padding:0 16px!important;
  border-radius:20px!important;
  background:#f8fafc!important;
  border:1px solid #edf2f7!important;
  color:var(--ui26-dark)!important;
  text-decoration:none!important;
  font-weight:950!important;
}

/* Forms */
.form label,
label{
  color:var(--ui26-dark)!important;
  font-weight:900!important;
  font-size:13px!important;
}

input,
select,
textarea{
  width:100%;
  min-height:52px!important;
  border-radius:19px!important;
  border:1px solid #dce5f2!important;
  background:rgba(255,255,255,.92)!important;
  padding:0 15px!important;
  color:var(--ui26-dark)!important;
  font-size:15px!important;
  outline:none!important;
  transition:.16s ease!important;
}

textarea{
  padding:14px 15px!important;
}

input:focus,
select:focus,
textarea:focus{
  border-color:rgba(99,91,255,.65)!important;
  box-shadow:0 0 0 5px rgba(99,91,255,.10)!important;
}

/* Buttons */
.btn,
button,
.fullapp-hero a,
.ui26-hero-actions a{
  border-radius:18px!important;
  font-weight:950!important;
  transition:.16s ease!important;
}

.btn:hover,
button:hover{
  transform:translateY(-1px);
}

.btn.primary,
button.primary,
button[type="submit"]{
  background:linear-gradient(135deg,var(--ui26-primary),var(--ui26-primary2))!important;
  color:#fff!important;
  border-color:transparent!important;
  box-shadow:0 14px 32px rgba(99,91,255,.26)!important;
}

.btn.light{
  background:#fff!important;
  border:1px solid var(--ui26-line)!important;
  color:var(--ui26-dark)!important;
}

.btn.danger{
  background:#fff!important;
  border:1px solid #fecaca!important;
  color:#be123c!important;
}

.btn.success{
  background:var(--ui26-green)!important;
  color:#fff!important;
}

/* Tables still modernized */
.table-wrap{
  border-radius:24px!important;
  overflow:auto!important;
  border:1px solid var(--ui26-line)!important;
  background:#fff!important;
}

table{
  width:100%;
  border-collapse:separate!important;
  border-spacing:0!important;
}

th{
  background:#f8fafc!important;
  color:var(--ui26-muted)!important;
  font-size:11px!important;
  text-transform:uppercase!important;
  letter-spacing:.08em!important;
  padding:15px!important;
  border-bottom:1px solid var(--ui26-line)!important;
}

td{
  padding:15px!important;
  border-bottom:1px solid #edf2f7!important;
}

/* Invoice 2026 */
.ui26-invoice-hero{
  margin:0 auto 16px!important;
  max-width:1120px!important;
  padding:30px!important;
  border-radius:38px!important;
  color:#fff!important;
  background:linear-gradient(135deg,#061226 0%,#172b4d 60%,#635bff 140%)!important;
  box-shadow:0 34px 90px rgba(7,20,41,.25)!important;
  position:relative!important;
  overflow:hidden!important;
}

.ui26-invoice-hero:after{
  content:""!important;
  position:absolute!important;
  right:-75px!important;
  top:-75px!important;
  width:220px!important;
  height:220px!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.12)!important;
}

.ui26-invoice-hero > *{
  position:relative!important;
  z-index:1!important;
}

.ui26-invoice-top{
  display:flex!important;
  justify-content:space-between!important;
  gap:16px!important;
  align-items:center!important;
  margin-bottom:16px!important;
}

.ui26-invoice-top span{
  color:#cbd5e1!important;
  font-size:12px!important;
  font-weight:950!important;
  text-transform:uppercase!important;
  letter-spacing:.09em!important;
}

.ui26-invoice-top b{
  color:#fff!important;
  font-weight:950!important;
}

.ui26-invoice-hero > strong{
  display:block!important;
  color:#fff!important;
  font-size:56px!important;
  line-height:.95!important;
  letter-spacing:-.085em!important;
}

.ui26-invoice-pills{
  display:flex!important;
  gap:8px!important;
  flex-wrap:wrap!important;
  margin-top:18px!important;
}

.ui26-invoice-pills em{
  display:inline-flex!important;
  padding:8px 12px!important;
  border-radius:999px!important;
  font-style:normal!important;
  font-size:12px!important;
  font-weight:950!important;
  background:rgba(255,255,255,.13)!important;
  color:#e5e7eb!important;
}

.ui26-invoice-pills em.open{background:#fffbeb!important;color:#92400e!important}
.ui26-invoice-pills em.paid{background:#dcfce7!important;color:#166534!important}
.ui26-invoice-pills em.late{background:#fee2e2!important;color:#991b1b!important}
.ui26-invoice-pills em.converted{background:#eef2ff!important;color:#3730a3!important}

.ui26-invoice-hero p{
  margin:16px 0 0!important;
  color:#dbeafe!important;
  font-weight:850!important;
}

.invoice-actions{
  max-width:1120px!important;
  margin:18px auto!important;
  border-radius:24px!important;
  padding:10px!important;
  background:rgba(255,255,255,.88)!important;
  border:1px solid var(--ui26-line)!important;
  box-shadow:var(--ui26-soft)!important;
}

.invoice-sheet,
.stripe-invoice-sheet,
.v5-sheet{
  max-width:1120px!important;
  border-radius:38px!important;
  border:1px solid var(--ui26-line)!important;
  box-shadow:0 34px 95px rgba(7,20,41,.16)!important;
}

/* Sticky mobile invoice actions */
.ui26-sticky-actions{
  display:none;
}

/* Empty states */
.ui26-empty,
.empty-state,
.empty-mini{
  padding:24px!important;
  border-radius:24px!important;
  background:#f8fafc!important;
  color:var(--ui26-muted)!important;
  font-weight:800!important;
}

.ui26-empty b,
.empty-state b{
  display:block!important;
  color:var(--ui26-dark)!important;
  font-size:18px!important;
}

/* Mobile app nav */
.ui26-mobile-nav,
.ui26-fab,
.ui26-fab-sheet,
.ui26-backdrop,
.ui26-fab-toggle{
  display:none;
}

/* Customer portal public redesign */
.portal-public-page{
  background:
    radial-gradient(circle at 82% -10%, rgba(99,91,255,.20), transparent 34%),
    linear-gradient(180deg,#f6f8fc,#eef4fb)!important;
}

.portal-hero,
.portal-card,
.portal-kpis article{
  border-radius:34px!important;
  border:1px solid var(--ui26-line)!important;
  box-shadow:var(--ui26-shadow)!important;
}

.portal-doc{
  border-radius:25px!important;
}

/* Mobile */
@media(max-width:900px){
  body.ui26-page,
  body.full-app-rebuild,
  body.phase4-hard-mobile,
  body.phase5-smart-ux{
    padding-bottom:104px!important;
    -webkit-tap-highlight-color:transparent!important;
  }

  .layout,
  .fullapp-layout,
  .ui26-app{
    display:block!important;
  }

  .sidebar,
  .fullapp-sidebar,
  .ui26-sidebar{
    display:none!important;
  }

  .main,
  .fullapp-main,
  .ui26-main{
    padding:12px 12px 118px!important;
    max-width:none!important;
  }

  .topbar{
    border-radius:30px!important;
    padding:22px!important;
    background:rgba(255,255,255,.9)!important;
    border:1px solid var(--ui26-line)!important;
    box-shadow:var(--ui26-soft)!important;
  }

  .ui26-hero,
  .fullapp-hero,
  .ui26-page-hero{
    display:block!important;
    padding:25px!important;
    border-radius:34px!important;
    margin-bottom:14px!important;
  }

  .ui26-hero h1,
  .fullapp-hero h1,
  .ui26-page-hero h1{
    font-size:39px!important;
    line-height:.98!important;
  }

  .ui26-hero-actions{
    margin-top:18px!important;
  }

  .ui26-kpi-grid,
  .kpi-grid,
  .analytics-grid,
  .fullapp-kpis{
    grid-template-columns:1.4fr .8fr!important;
    gap:10px!important;
    margin:14px 0!important;
  }

  .ui26-kpi,
  .kpi-card,
  .analytics-card,
  .fullapp-kpis article{
    padding:17px!important;
    border-radius:26px!important;
  }

  .ui26-kpi strong,
  .kpi-card strong,
  .analytics-card strong,
  .fullapp-kpis strong{
    font-size:25px!important;
  }

  .ui26-content-grid,
  .dashboard-grid,
  .proplus-grid,
  .fullapp-grid{
    grid-template-columns:1fr!important;
    gap:14px!important;
  }

  .ui26-card,
  .panel,
  .fullapp-panel{
    padding:18px!important;
    border-radius:30px!important;
  }

  .ui26-card-head h2,
  .panel-head h2,
  .fullapp-panel-head h2{
    font-size:23px!important;
  }

  .ui26-doc-card,
  .fullapp-doc,
  .mini-item{
    min-height:76px!important;
    border-radius:26px!important;
    padding:15px!important;
  }

  .ui26-doc-icon{
    width:42px!important;
    height:42px!important;
  }

  .ui26-doc-side strong,
  .doc-side strong{
    font-size:16px!important;
  }

  .table-wrap table{
    min-width:720px!important;
  }

  /* Invoice mobile */
  .invoice-actions{
    display:none!important;
  }

  .ui26-invoice-hero{
    margin:0 0 12px!important;
    padding:24px!important;
    border-radius:34px!important;
  }

  .ui26-invoice-hero > strong{
    font-size:48px!important;
  }

  .invoice-sheet,
  .stripe-invoice-sheet,
  .v5-sheet{
    margin:0!important;
    padding:20px 16px!important;
    border-radius:30px!important;
  }

  .invoice-header.premium .document-title{
    display:none!important;
  }

  .invoice-meta{
    grid-template-columns:1fr!important;
    gap:10px!important;
  }

  .invoice-table{
    display:block!important;
    min-width:0!important;
    border:0!important;
    overflow:visible!important;
  }

  .invoice-table thead{
    display:none!important;
  }

  .invoice-table tbody{
    display:grid!important;
    gap:10px!important;
  }

  .invoice-table tbody tr{
    display:grid!important;
    gap:8px!important;
    padding:16px!important;
    border-radius:24px!important;
    background:#fbfdff!important;
    border:1px solid var(--ui26-line)!important;
  }

  .invoice-table tbody td{
    display:flex!important;
    justify-content:space-between!important;
    gap:12px!important;
    border:0!important;
    padding:0!important;
    background:transparent!important;
  }

  .invoice-table tbody td:nth-child(1)::before{content:"Pos."; color:var(--ui26-muted); font-weight:900}
  .invoice-table tbody td:nth-child(2)::before{content:"Beschreibung"; color:var(--ui26-muted); font-weight:900}
  .invoice-table tbody td:nth-child(3)::before{content:"Menge"; color:var(--ui26-muted); font-weight:900}
  .invoice-table tbody td:nth-child(4)::before{content:"Einheit"; color:var(--ui26-muted); font-weight:900}
  .invoice-table tbody td:nth-child(5)::before{content:"Preis"; color:var(--ui26-muted); font-weight:900}
  .invoice-table tbody td:nth-child(6)::before{content:"Gesamt"; color:var(--ui26-muted); font-weight:900}

  .invoice-table tbody td:nth-child(2){
    display:block!important;
  }

  .invoice-table tbody td:nth-child(2)::before{
    display:block!important;
    margin-bottom:6px!important;
  }

  .invoice-table tbody td:last-child{
    border-top:1px solid var(--ui26-line)!important;
    padding-top:8px!important;
    color:var(--ui26-primary)!important;
    font-size:18px!important;
    font-weight:950!important;
  }

  .invoice-table tfoot{
    display:block!important;
    margin-top:12px!important;
    padding:16px!important;
    border-radius:26px!important;
    background:linear-gradient(135deg,#f6f9ff,#fff)!important;
    border:1px solid var(--ui26-line)!important;
  }

  .invoice-table tfoot tr{
    display:flex!important;
    justify-content:space-between!important;
    padding:6px 0!important;
  }

  .invoice-table tfoot td{
    display:block!important;
    padding:0!important;
    border:0!important;
    background:transparent!important;
  }

  .invoice-table tfoot tr:last-child{
    border-top:1px solid var(--ui26-line)!important;
    margin-top:8px!important;
    padding-top:14px!important;
  }

  .invoice-table tfoot tr:last-child td{
    color:var(--ui26-primary)!important;
    font-size:28px!important;
    font-weight:950!important;
  }

  .ui26-sticky-actions{
    position:fixed!important;
    left:12px!important;
    right:12px!important;
    bottom:92px!important;
    z-index:9996!important;
    display:grid!important;
    grid-template-columns:1fr 1.28fr 1fr!important;
    gap:8px!important;
    padding:8px!important;
    border-radius:25px!important;
    background:rgba(255,255,255,.92)!important;
    border:1px solid var(--ui26-line)!important;
    box-shadow:0 22px 65px rgba(7,20,41,.22)!important;
    backdrop-filter:blur(16px)!important;
  }

  .ui26-sticky-actions a{
    min-height:48px!important;
    display:grid!important;
    place-items:center!important;
    border-radius:17px!important;
    background:#f6f9fc!important;
    color:var(--ui26-dark)!important;
    text-decoration:none!important;
    font-weight:950!important;
    font-size:13px!important;
  }

  .ui26-sticky-actions a.primary{
    background:linear-gradient(135deg,var(--ui26-primary),var(--ui26-primary2))!important;
    color:#fff!important;
  }

  /* Mobile nav */
  .ui26-mobile-nav{
    display:grid!important;
    grid-template-columns:1fr 1fr 86px 1fr 1fr!important;
    position:fixed!important;
    left:10px!important;
    right:10px!important;
    bottom:10px!important;
    z-index:9998!important;
    height:72px!important;
    align-items:center!important;
    padding:0 8px!important;
    border-radius:30px!important;
    background:rgba(255,255,255,.92)!important;
    border:1px solid rgba(226,232,240,.95)!important;
    box-shadow:0 26px 76px rgba(7,20,41,.25)!important;
    backdrop-filter:blur(18px)!important;
  }

  .ui26-mobile-nav a{
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    gap:3px!important;
    height:58px!important;
    border-radius:20px!important;
    color:var(--ui26-muted)!important;
    text-decoration:none!important;
    font-size:10px!important;
    font-weight:900!important;
  }

  .ui26-mobile-nav a b{
    font-size:21px!important;
    line-height:1!important;
  }

  .ui26-mobile-nav a.active{
    color:var(--ui26-primary)!important;
    background:#f3f1ff!important;
  }

  .ui26-fab{
    display:grid!important;
    place-items:center!important;
    position:fixed!important;
    left:50%!important;
    bottom:34px!important;
    transform:translateX(-50%)!important;
    width:66px!important;
    height:66px!important;
    border-radius:25px!important;
    z-index:10000!important;
    color:#fff!important;
    font-size:36px!important;
    font-weight:850!important;
    background:linear-gradient(135deg,var(--ui26-primary),var(--ui26-primary2))!important;
    box-shadow:0 20px 48px rgba(99,91,255,.42)!important;
  }

  .ui26-fab-toggle{
    display:none!important;
  }

  .ui26-backdrop{
    display:none!important;
    position:fixed!important;
    inset:0!important;
    z-index:9996!important;
    background:rgba(7,20,41,.24)!important;
    backdrop-filter:blur(4px)!important;
  }

  .ui26-fab-sheet{
    display:grid!important;
    position:fixed!important;
    left:14px!important;
    right:14px!important;
    bottom:98px!important;
    z-index:9999!important;
    gap:10px!important;
    padding:14px!important;
    border-radius:30px!important;
    background:rgba(255,255,255,.96)!important;
    border:1px solid var(--ui26-line)!important;
    box-shadow:0 30px 90px rgba(7,20,41,.28)!important;
    opacity:0!important;
    pointer-events:none!important;
    transform:translateY(18px) scale(.98)!important;
    transition:.18s ease!important;
  }

  .ui26-fab-head{
    padding:8px 6px 4px!important;
  }

  .ui26-fab-head b,
  .ui26-fab-head span{
    display:block!important;
  }

  .ui26-fab-head span{
    color:var(--ui26-muted)!important;
    font-weight:800!important;
    margin-top:3px!important;
  }

  .ui26-fab-sheet a{
    min-height:62px!important;
    display:grid!important;
    grid-template-columns:42px 1fr!important;
    align-items:center!important;
    column-gap:10px!important;
    padding:12px 14px!important;
    border-radius:22px!important;
    background:#f6f9fc!important;
    color:var(--ui26-dark)!important;
    text-decoration:none!important;
  }

  .ui26-fab-sheet a span{
    grid-row:1 / span 2!important;
    font-size:25px!important;
  }

  .ui26-fab-sheet a b{
    display:block!important;
    font-size:15px!important;
  }

  .ui26-fab-sheet a small{
    display:block!important;
    color:var(--ui26-muted)!important;
    font-weight:800!important;
  }

  .ui26-fab-toggle:checked ~ .ui26-backdrop{
    display:block!important;
  }

  .ui26-fab-toggle:checked ~ .ui26-fab-sheet{
    opacity:1!important;
    pointer-events:auto!important;
    transform:translateY(0) scale(1)!important;
  }

  /* Auth mobile */
  .auth-bg{
    padding:14px!important;
  }

  .auth-card{
    border-radius:32px!important;
  }
}

@media(min-width:901px){
  .ui26-mobile-nav,
  .ui26-fab,
  .ui26-fab-sheet,
  .ui26-backdrop,
  .ui26-sticky-actions{
    display:none!important;
  }
}



/* =========================================================
   V2 STRIPE MOBILE REBUILD
   Clean 2026 mobile-first UI, no sidebar chaos.
   ========================================================= */

:root{
  --v2-bg:#f7f8fc;
  --v2-card:#ffffff;
  --v2-ink:#081427;
  --v2-text:#13233a;
  --v2-muted:#768399;
  --v2-line:#e7edf5;
  --v2-primary:#635bff;
  --v2-purple:#8b5cf6;
  --v2-green:#16a34a;
  --v2-red:#dc2626;
  --v2-yellow:#f59e0b;
  --v2-shadow:0 22px 60px rgba(8,20,39,.12);
  --v2-soft:0 12px 30px rgba(8,20,39,.08);
}

body.v2-page{
  margin:0!important;
  min-height:100vh!important;
  background:
    radial-gradient(circle at 88% -12%, rgba(99,91,255,.20), transparent 34%),
    radial-gradient(circle at 0% 22%, rgba(22,163,74,.10), transparent 30%),
    linear-gradient(180deg,#f7f8fc,#edf4fb)!important;
  color:var(--v2-text)!important;
  font-family:Inter, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif!important;
  -webkit-font-smoothing:antialiased;
}

/* Desktop shell but cleaner */
.v2-desktop-shell{
  display:grid;
  grid-template-columns:270px minmax(0,1fr);
  min-height:100vh;
}

.v2-desktop-nav{
  padding:26px;
  background:rgba(255,255,255,.70);
  border-right:1px solid var(--v2-line);
  backdrop-filter:blur(18px);
}

.v2-brand{
  display:flex;
  gap:12px;
  align-items:center;
  margin-bottom:28px;
}
.v2-brand span{
  width:48px;height:48px;border-radius:18px;background:#081427;color:#fff;display:grid;place-items:center;font-weight:950;
}
.v2-brand b,.v2-brand small{display:block}
.v2-brand small{color:var(--v2-muted);font-weight:800}

.v2-desktop-nav nav{display:grid;gap:8px}
.v2-desktop-nav nav a{
  padding:14px 15px;border-radius:18px;text-decoration:none;color:var(--v2-muted);font-weight:900;
}
.v2-desktop-nav nav a.active,.v2-desktop-nav nav a:hover{
  background:#f1efff;color:var(--v2-primary);
}

.v2-main{
  padding:32px;
  max-width:1180px;
  width:100%;
}

.v2-top{
  display:flex;
  justify-content:space-between;
  gap:22px;
  align-items:flex-end;
  padding:32px;
  border-radius:34px;
  color:#fff;
  background:linear-gradient(135deg,#081427,#152a4a 60%,#635bff 140%);
  box-shadow:0 30px 85px rgba(8,20,39,.24);
  position:relative;
  overflow:hidden;
}
.v2-top:after,.v2-hero-balance:after,.v2-invoice-hero:after{
  content:"";position:absolute;right:-70px;top:-70px;width:210px;height:210px;border-radius:999px;background:rgba(255,255,255,.12);
}
.v2-top > *{position:relative;z-index:1}
.v2-top span{
  color:#cbd5e1;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.09em;
}
.v2-top h1{
  margin:10px 0 8px;color:#fff;font-size:48px;line-height:.96;letter-spacing:-.085em;
}
.v2-top p{margin:0;color:#dbeafe;font-weight:800}
.v2-top a{
  background:var(--v2-primary);color:#fff;text-decoration:none;padding:14px 18px;border-radius:18px;font-weight:950;box-shadow:0 14px 32px rgba(99,91,255,.32);white-space:nowrap;
}

.v2-hero-balance{
  position:relative;
  overflow:hidden;
  margin:18px 0 0;
  padding:26px;
  border-radius:30px;
  background:#fff;
  border:1px solid var(--v2-line);
  box-shadow:var(--v2-shadow);
}
.v2-hero-balance span,.v2-metrics span{
  display:block;color:var(--v2-muted);font-size:12px;font-weight:950;
}
.v2-hero-balance strong{
  display:block;margin-top:10px;color:var(--v2-primary);font-size:52px;line-height:.95;letter-spacing:-.085em;
}
.v2-hero-balance p{margin:9px 0 0;color:var(--v2-muted);font-weight:800}

.v2-metrics{
  display:grid;
  grid-template-columns:1.3fr .8fr .8fr;
  gap:14px;
  margin:16px 0;
}
.v2-metrics article{
  padding:20px;
  border-radius:26px;
  background:#fff;
  border:1px solid var(--v2-line);
  box-shadow:var(--v2-soft);
}
.v2-metrics strong{
  display:block;margin-top:8px;font-size:28px;line-height:1;letter-spacing:-.06em;color:var(--v2-ink);
}
.v2-metrics small{display:block;margin-top:8px;color:var(--v2-muted);font-weight:800}
.v2-metrics .danger strong{color:var(--v2-red)}
.v2-metrics .ok strong{color:var(--v2-green)}

.v2-alert-card{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:18px;
  border-radius:26px;
  background:#fff7ed;
  border:1px solid #fed7aa;
  box-shadow:var(--v2-soft);
  margin-bottom:16px;
}
.v2-alert-card b,.v2-alert-card span{display:block}
.v2-alert-card span{margin-top:4px;color:#9a3412;font-weight:800}
.v2-alert-card a{color:#fff;background:#ea580c;padding:11px 14px;border-radius:15px;text-decoration:none;font-weight:950}

.v2-quick{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-bottom:20px;
}
.v2-quick a{
  min-height:92px;padding:16px;border-radius:26px;background:#fff;border:1px solid var(--v2-line);box-shadow:var(--v2-soft);
  text-decoration:none;color:var(--v2-ink);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;font-weight:950;
}
.v2-quick b{font-size:26px}

.v2-section{
  padding:24px;
  border-radius:32px;
  background:rgba(255,255,255,.92);
  border:1px solid var(--v2-line);
  box-shadow:var(--v2-shadow);
}
.v2-section-head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;
}
.v2-section-head h2{margin:0;color:var(--v2-ink);font-size:28px;letter-spacing:-.06em}
.v2-section-head p{margin:6px 0 0;color:var(--v2-muted);font-weight:800}
.v2-section-head a{color:var(--v2-primary);text-decoration:none;font-weight:950}

.v2-doc-feed{display:grid;gap:10px}
.v2-doc-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  min-height:82px;
  padding:16px;
  border-radius:25px;
  background:#fbfdff;
  border:1px solid #edf2f7;
  color:var(--v2-ink);
  text-decoration:none;
  box-shadow:0 10px 26px rgba(8,20,39,.05);
}
.v2-doc-icon{
  width:46px;height:46px;border-radius:17px;background:#f1efff;display:grid;place-items:center;font-size:22px;flex:0 0 auto;
}
.v2-doc-body{flex:1;min-width:0}
.v2-doc-body b,.v2-doc-body span{display:block}
.v2-doc-body span{margin-top:4px;color:var(--v2-muted);font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.v2-doc-money{text-align:right;flex:0 0 auto}
.v2-doc-money strong{display:block;color:var(--v2-ink);font-size:18px;white-space:nowrap}
.v2-doc-money em,.v2-invoice-meta em{
  display:inline-flex;margin-top:6px;padding:6px 10px;border-radius:999px;font-size:11px;font-style:normal;font-weight:950;
}
.v2-doc-money em.open,.v2-invoice-meta em.open{background:#fffbeb;color:#92400e}
.v2-doc-money em.paid,.v2-invoice-meta em.paid{background:#dcfce7;color:#166534}
.v2-doc-money em.late,.v2-invoice-meta em.late{background:#fee2e2;color:#991b1b}
.v2-doc-money em.converted,.v2-invoice-meta em.converted{background:#eef2ff;color:#3730a3}

.v2-empty{
  padding:24px;border-radius:24px;background:#f8fafc;color:var(--v2-muted);font-weight:800;
}
.v2-empty b{display:block;color:var(--v2-ink);font-size:18px}
.v2-empty span{display:block;margin-top:6px}

/* Mobile shell */
.v2-bottom-nav,.v2-fab,.v2-action-sheet,.v2-backdrop,.v2-fab-toggle{display:none}

/* Hard mobile reset */
@media(max-width:900px){
  body.v2-page{
    padding-bottom:104px!important;
    overflow-x:hidden!important;
  }

  /* Hide old sidebars/layouts on every page */
  body.v2-page .sidebar,
  body.v2-page .fullapp-sidebar,
  body.v2-page .ui26-sidebar,
  body.v2-page .v2-desktop-nav{
    display:none!important;
  }

  body.v2-page .layout,
  body.v2-page .fullapp-layout,
  body.v2-page .ui26-app,
  .v2-desktop-shell{
    display:block!important;
    min-height:100vh!important;
  }

  body.v2-page .main,
  body.v2-page .fullapp-main,
  body.v2-page .ui26-main,
  .v2-main{
    width:100%!important;
    max-width:none!important;
    padding:12px 12px 118px!important;
  }

  .v2-top{
    display:block;
    padding:24px;
    border-radius:34px;
  }
  .v2-top h1{font-size:39px}
  .v2-top a{display:inline-flex;margin-top:18px}

  .v2-hero-balance{
    padding:22px;
    border-radius:30px;
  }
  .v2-hero-balance strong{
    font-size:46px;
  }

  .v2-metrics{
    grid-template-columns:1.25fr .75fr;
    gap:10px;
  }
  .v2-metrics article{
    padding:16px;
    border-radius:24px;
  }
  .v2-metrics strong{
    font-size:24px;
  }

  .v2-quick{
    grid-template-columns:repeat(3,1fr);
    gap:10px;
  }
  .v2-quick a{
    min-height:84px;
    border-radius:24px;
    padding:14px 8px;
  }

  .v2-section{
    padding:18px;
    border-radius:30px;
  }
  .v2-section-head h2{
    font-size:24px;
  }
  .v2-doc-row{
    border-radius:25px;
    min-height:78px;
    padding:15px;
  }

  /* Make legacy pages less ugly */
  body.v2-page .topbar,
  body.v2-page .panel,
  body.v2-page .card,
  body.v2-page .auth-card{
    border-radius:30px!important;
    background:rgba(255,255,255,.92)!important;
    border:1px solid var(--v2-line)!important;
    box-shadow:var(--v2-shadow)!important;
  }
  body.v2-page .topbar{
    padding:22px!important;
  }
  body.v2-page .topbar h1{
    font-size:34px!important;
    line-height:1!important;
    letter-spacing:-.075em!important;
  }

  input,select,textarea{
    min-height:54px!important;
    border-radius:18px!important;
    font-size:16px!important;
  }
  .btn,button{
    min-height:46px!important;
    border-radius:16px!important;
  }

  /* Invoice detail mobile */
  .v2-invoice-hero{
    display:block!important;
    margin:0 0 12px!important;
    padding:24px!important;
    border-radius:34px!important;
    color:#fff!important;
    background:linear-gradient(135deg,#081427,#152a4a 60%,#635bff 140%)!important;
    box-shadow:0 30px 85px rgba(8,20,39,.25)!important;
    position:relative!important;
    overflow:hidden!important;
  }
  .v2-invoice-hero > *{position:relative;z-index:1}
  .v2-invoice-kicker{
    display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:16px;
  }
  .v2-invoice-kicker span{color:#cbd5e1;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.09em}
  .v2-invoice-kicker b{color:#fff;font-weight:950}
  .v2-invoice-hero > strong{
    display:block;color:#fff;font-size:48px;line-height:.95;letter-spacing:-.085em;
  }
  .v2-invoice-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
  .v2-invoice-meta em:not(.open):not(.paid):not(.late):not(.converted){background:rgba(255,255,255,.13);color:#e5e7eb}
  .v2-invoice-hero p{margin:16px 0 0;color:#dbeafe;font-weight:850}

  body.v2-page .invoice-actions{display:none!important}
  body.v2-page .invoice-sheet,
  body.v2-page .stripe-invoice-sheet,
  body.v2-page .v5-sheet{
    margin:0!important;
    padding:20px 16px!important;
    border-radius:30px!important;
    background:#fff!important;
    box-shadow:var(--v2-shadow)!important;
  }
  body.v2-page .invoice-header.premium .document-title{display:none!important}
  body.v2-page .invoice-table{
    display:block!important;
    border:0!important;
    min-width:0!important;
    overflow:visible!important;
  }
  body.v2-page .invoice-table thead{display:none!important}
  body.v2-page .invoice-table tbody{display:grid!important;gap:10px!important}
  body.v2-page .invoice-table tbody tr{
    display:grid!important;gap:8px!important;padding:16px!important;border-radius:24px!important;background:#fbfdff!important;border:1px solid var(--v2-line)!important;
  }
  body.v2-page .invoice-table tbody td{
    display:flex!important;justify-content:space-between!important;gap:12px!important;border:0!important;padding:0!important;background:transparent!important;
  }
  body.v2-page .invoice-table tbody td:nth-child(1)::before{content:"Pos.";color:var(--v2-muted);font-weight:900}
  body.v2-page .invoice-table tbody td:nth-child(2)::before{content:"Beschreibung";color:var(--v2-muted);font-weight:900}
  body.v2-page .invoice-table tbody td:nth-child(3)::before{content:"Menge";color:var(--v2-muted);font-weight:900}
  body.v2-page .invoice-table tbody td:nth-child(4)::before{content:"Einheit";color:var(--v2-muted);font-weight:900}
  body.v2-page .invoice-table tbody td:nth-child(5)::before{content:"Preis";color:var(--v2-muted);font-weight:900}
  body.v2-page .invoice-table tbody td:nth-child(6)::before{content:"Gesamt";color:var(--v2-muted);font-weight:900}
  body.v2-page .invoice-table tbody td:nth-child(2){display:block!important}
  body.v2-page .invoice-table tbody td:nth-child(2)::before{display:block!important;margin-bottom:6px!important}
  body.v2-page .invoice-table tbody td:last-child{border-top:1px solid var(--v2-line)!important;padding-top:8px!important;color:var(--v2-primary)!important;font-size:18px!important;font-weight:950!important}
  body.v2-page .invoice-table tfoot{
    display:block!important;margin-top:12px!important;padding:16px!important;border-radius:26px!important;background:linear-gradient(135deg,#f6f9ff,#fff)!important;border:1px solid var(--v2-line)!important;
  }
  body.v2-page .invoice-table tfoot tr{display:flex!important;justify-content:space-between!important;padding:6px 0!important}
  body.v2-page .invoice-table tfoot td{display:block!important;padding:0!important;border:0!important;background:transparent!important}
  body.v2-page .invoice-table tfoot tr:last-child{border-top:1px solid var(--v2-line)!important;margin-top:8px!important;padding-top:14px!important}
  body.v2-page .invoice-table tfoot tr:last-child td{color:var(--v2-primary)!important;font-size:28px!important;font-weight:950!important}

  .v2-sticky-actions{
    display:grid!important;
    position:fixed!important;
    left:12px!important;
    right:12px!important;
    bottom:92px!important;
    z-index:9996!important;
    grid-template-columns:1fr 1.3fr 1fr!important;
    gap:8px!important;
    padding:8px!important;
    border-radius:25px!important;
    background:rgba(255,255,255,.92)!important;
    border:1px solid var(--v2-line)!important;
    box-shadow:0 22px 65px rgba(8,20,39,.22)!important;
    backdrop-filter:blur(16px)!important;
  }
  .v2-sticky-actions a{
    min-height:48px;display:grid;place-items:center;border-radius:17px;background:#f6f9fc;color:var(--v2-ink);text-decoration:none;font-weight:950;font-size:13px;
  }
  .v2-sticky-actions a.primary{
    color:#fff;background:linear-gradient(135deg,var(--v2-primary),var(--v2-purple));
  }

  /* Bottom nav */
  .v2-bottom-nav{
    display:grid!important;
    grid-template-columns:1fr 1fr 86px 1fr 1fr!important;
    position:fixed!important;
    left:10px!important;
    right:10px!important;
    bottom:10px!important;
    z-index:9998!important;
    height:72px!important;
    align-items:center!important;
    padding:0 8px!important;
    border-radius:30px!important;
    background:rgba(255,255,255,.92)!important;
    border:1px solid rgba(231,237,245,.95)!important;
    box-shadow:0 26px 76px rgba(8,20,39,.25)!important;
    backdrop-filter:blur(18px)!important;
  }
  .v2-bottom-nav a{
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;height:58px;border-radius:20px;color:var(--v2-muted);text-decoration:none;font-size:10px;font-weight:900;
  }
  .v2-bottom-nav a b{font-size:21px;line-height:1}
  .v2-bottom-nav a.active{color:var(--v2-primary);background:#f1efff}
  .v2-fab{
    display:grid!important;place-items:center!important;position:fixed!important;left:50%!important;bottom:34px!important;transform:translateX(-50%)!important;
    width:66px!important;height:66px!important;border-radius:25px!important;z-index:10000!important;color:#fff!important;font-size:36px!important;font-weight:850!important;
    background:linear-gradient(135deg,var(--v2-primary),var(--v2-purple))!important;box-shadow:0 20px 48px rgba(99,91,255,.42)!important;
  }
  .v2-fab-toggle{display:none!important}
  .v2-backdrop{display:none!important;position:fixed!important;inset:0!important;z-index:9996!important;background:rgba(8,20,39,.24)!important;backdrop-filter:blur(4px)!important}
  .v2-action-sheet{
    display:grid!important;position:fixed!important;left:14px!important;right:14px!important;bottom:98px!important;z-index:9999!important;gap:10px!important;
    padding:14px!important;border-radius:30px!important;background:rgba(255,255,255,.96)!important;border:1px solid var(--v2-line)!important;box-shadow:0 30px 90px rgba(8,20,39,.28)!important;
    opacity:0!important;pointer-events:none!important;transform:translateY(18px) scale(.98)!important;transition:.18s ease!important;
  }
  .v2-action-head{padding:8px 6px 4px}
  .v2-action-head b,.v2-action-head span{display:block}
  .v2-action-head span{color:var(--v2-muted);font-weight:800;margin-top:3px}
  .v2-action-sheet a{
    display:grid;grid-template-columns:44px 1fr;gap:10px;align-items:center;min-height:64px;padding:12px 14px;border-radius:22px;background:#f6f9fc;color:var(--v2-ink);text-decoration:none;
  }
  .v2-action-sheet i{font-style:normal;font-size:25px}
  .v2-action-sheet b,.v2-action-sheet span{display:block}
  .v2-action-sheet span{color:var(--v2-muted);font-weight:800;margin-top:3px}
  .v2-fab-toggle:checked ~ .v2-backdrop{display:block!important}
  .v2-fab-toggle:checked ~ .v2-action-sheet{opacity:1!important;pointer-events:auto!important;transform:translateY(0) scale(1)!important}
}

@media(min-width:901px){
  .v2-bottom-nav,.v2-fab,.v2-action-sheet,.v2-backdrop,.v2-sticky-actions{display:none!important}
}



/* =========================================================
   V2 PAGES FIX: Customers + Invoice Form
   ========================================================= */

/* Customers */
.v2-customer-feed{
  display:grid;
  gap:10px;
}

.v2-customer-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  min-height:82px;
  padding:16px;
  border-radius:25px;
  background:#fbfdff;
  border:1px solid #edf2f7;
  color:var(--v2-ink);
  text-decoration:none;
  box-shadow:0 10px 26px rgba(8,20,39,.05);
}

.v2-customer-card:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 36px rgba(8,20,39,.10);
}

.v2-customer-avatar{
  width:48px;
  height:48px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#635bff,#8b5cf6);
  color:#fff;
  font-weight:950;
  flex:0 0 auto;
}

.v2-customer-main{
  flex:1;
  min-width:0;
}

.v2-customer-main b,
.v2-customer-main span{
  display:block;
}

.v2-customer-main b{
  color:var(--v2-ink);
}

.v2-customer-main span{
  margin-top:4px;
  color:var(--v2-muted);
  font-weight:800;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.v2-customer-side{
  text-align:right;
  flex:0 0 auto;
}

.v2-customer-side strong{
  display:block;
  color:var(--v2-primary);
  white-space:nowrap;
}

.v2-customer-side em{
  display:inline-flex;
  margin-top:6px;
  padding:6px 10px;
  border-radius:999px;
  font-size:11px;
  font-style:normal;
  font-weight:950;
  color:#475569;
  background:#f1f5f9;
}

/* Invoice form V2 hard restyle */
.v2-form-hero{
  position:relative;
  overflow:hidden;
  padding:32px;
  border-radius:34px;
  color:#fff;
  background:linear-gradient(135deg,#081427,#152a4a 60%,#635bff 140%);
  box-shadow:0 30px 85px rgba(8,20,39,.24);
  margin-bottom:18px;
}

.v2-form-hero:after{
  content:"";
  position:absolute;
  right:-70px;
  top:-70px;
  width:210px;
  height:210px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
}

.v2-form-hero > *{
  position:relative;
  z-index:1;
}

.v2-form-hero span{
  color:#cbd5e1;
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.09em;
}

.v2-form-hero h1{
  margin:10px 0 8px;
  color:#fff;
  font-size:44px;
  line-height:.96;
  letter-spacing:-.085em;
}

.v2-form-hero p{
  margin:0;
  color:#dbeafe;
  font-weight:800;
}

body.v2-invoice-form-page .topbar{
  display:none!important;
}

body.v2-invoice-form-page .main{
  max-width:980px!important;
}

body.v2-invoice-form-page .panel,
body.v2-invoice-form-page .form-card,
body.v2-invoice-form-page form > .card,
body.v2-invoice-form-page .invoice-form-card{
  border-radius:32px!important;
  background:rgba(255,255,255,.94)!important;
  border:1px solid var(--v2-line)!important;
  box-shadow:var(--v2-shadow)!important;
}

body.v2-invoice-form-page input,
body.v2-invoice-form-page select,
body.v2-invoice-form-page textarea{
  min-height:56px!important;
  border-radius:20px!important;
  border:1px solid #dce5f2!important;
  background:#fff!important;
  font-size:16px!important;
}

body.v2-invoice-form-page input:focus,
body.v2-invoice-form-page select:focus,
body.v2-invoice-form-page textarea:focus{
  border-color:rgba(99,91,255,.65)!important;
  box-shadow:0 0 0 5px rgba(99,91,255,.10)!important;
}

body.v2-invoice-form-page label{
  color:var(--v2-ink)!important;
  font-weight:950!important;
}

body.v2-invoice-form-page .tax-box,
body.v2-invoice-form-page .price-mode-box,
body.v2-invoice-form-page .smart-ux-assistant{
  border-radius:28px!important;
  border:1px solid var(--v2-line)!important;
}

body.v2-invoice-form-page .positions-head h2,
body.v2-invoice-form-page h2{
  letter-spacing:-.06em!important;
}

body.v2-invoice-form-page .summary-box,
body.v2-invoice-form-page .totals-box,
body.v2-invoice-form-page .total-card{
  border-radius:28px!important;
  background:linear-gradient(135deg,#f6f9ff,#fff)!important;
  border:1px solid var(--v2-line)!important;
  box-shadow:var(--v2-soft)!important;
}

/* Hide duplicated old mobile shells if multiple versions exist */
@media(max-width:900px){
  body.v2-page .fullapp-bottom-nav,
  body.v2-page .ui26-mobile-nav,
  body.v2-page .hard-bottom-nav,
  body.v2-page .mobile-bottom-nav,
  body.v2-page .fullapp-fab,
  body.v2-page .ui26-fab,
  body.v2-page .hard-fab,
  body.v2-page .mobile-fab{
    display:none!important;
  }

  body.v2-customers-page .v2-desktop-shell,
  body.v2-invoice-form-page .v2-desktop-shell{
    display:block!important;
  }

  .v2-page-top,
  .v2-form-hero{
    padding:24px!important;
    border-radius:34px!important;
  }

  .v2-page-top h1,
  .v2-form-hero h1{
    font-size:38px!important;
  }

  .v2-customer-card{
    min-height:78px;
    border-radius:25px;
    padding:15px;
  }

  body.v2-invoice-form-page .main{
    padding:12px 12px 118px!important;
  }

  body.v2-invoice-form-page .form-grid,
  body.v2-invoice-form-page .grid,
  body.v2-invoice-form-page .two-col{
    grid-template-columns:1fr!important;
  }

  body.v2-invoice-form-page .item-row{
    border-radius:24px!important;
    background:#fbfdff!important;
    border:1px solid var(--v2-line)!important;
    box-shadow:0 10px 26px rgba(8,20,39,.05)!important;
  }
}



/* =========================================================
   V2 ADMIN PAGES - Settings, Mail, Reminder, Invoice Form
   ========================================================= */

.v2-admin-hero{
  position:relative;
  overflow:hidden;
  padding:32px;
  border-radius:34px;
  color:#fff;
  background:linear-gradient(135deg,#081427,#152a4a 60%,#635bff 140%);
  box-shadow:0 30px 85px rgba(8,20,39,.24);
  margin-bottom:18px;
}

.v2-admin-hero:after{
  content:"";
  position:absolute;
  right:-70px;
  top:-70px;
  width:210px;
  height:210px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
}

.v2-admin-hero > *{
  position:relative;
  z-index:1;
}

.v2-admin-hero span{
  color:#cbd5e1;
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.09em;
}

.v2-admin-hero h1{
  margin:10px 0 8px;
  color:#fff;
  font-size:44px;
  line-height:.96;
  letter-spacing:-.085em;
}

.v2-admin-hero p{
  margin:0;
  color:#dbeafe;
  font-weight:800;
}

/* Make legacy admin pages feel like V2 */
body.v2-admin-page .topbar{
  display:none!important;
}

body.v2-admin-page .main,
body.v2-admin-page .fullapp-main,
body.v2-admin-page .ui26-main{
  max-width:1080px!important;
}

body.v2-admin-page .panel,
body.v2-admin-page .card,
body.v2-admin-page .settings-card,
body.v2-admin-page .mail-card,
body.v2-admin-page .reminder-card,
body.v2-admin-page .form-card,
body.v2-admin-page form,
body.v2-admin-page .table-wrap{
  border-radius:32px!important;
  background:rgba(255,255,255,.94)!important;
  border:1px solid var(--v2-line)!important;
  box-shadow:var(--v2-shadow)!important;
}

body.v2-admin-page .panel,
body.v2-admin-page .card,
body.v2-admin-page .settings-card,
body.v2-admin-page .mail-card,
body.v2-admin-page .reminder-card,
body.v2-admin-page .form-card{
  padding:24px!important;
}

body.v2-admin-page .panel-head h2,
body.v2-admin-page h2{
  color:var(--v2-ink)!important;
  font-size:28px!important;
  letter-spacing:-.06em!important;
}

body.v2-admin-page .panel-head p,
body.v2-admin-page .muted,
body.v2-admin-page small{
  color:var(--v2-muted)!important;
  font-weight:800!important;
}

body.v2-admin-page input,
body.v2-admin-page select,
body.v2-admin-page textarea{
  min-height:56px!important;
  border-radius:20px!important;
  border:1px solid #dce5f2!important;
  background:#fff!important;
  font-size:16px!important;
}

body.v2-admin-page input:focus,
body.v2-admin-page select:focus,
body.v2-admin-page textarea:focus{
  border-color:rgba(99,91,255,.65)!important;
  box-shadow:0 0 0 5px rgba(99,91,255,.10)!important;
}

body.v2-admin-page label{
  color:var(--v2-ink)!important;
  font-weight:950!important;
}

body.v2-admin-page .btn,
body.v2-admin-page button,
body.v2-admin-page input[type="submit"]{
  min-height:46px!important;
  border-radius:17px!important;
  font-weight:950!important;
}

body.v2-admin-page .btn.primary,
body.v2-admin-page button[type="submit"],
body.v2-admin-page input[type="submit"]{
  background:linear-gradient(135deg,var(--v2-primary),var(--v2-purple))!important;
  color:#fff!important;
  border-color:transparent!important;
  box-shadow:0 14px 32px rgba(99,91,255,.26)!important;
}

body.v2-admin-page table{
  border-collapse:separate!important;
  border-spacing:0!important;
  width:100%;
}

body.v2-admin-page th{
  background:#f8fafc!important;
  color:var(--v2-muted)!important;
  font-size:11px!important;
  text-transform:uppercase!important;
  letter-spacing:.08em!important;
  padding:15px!important;
  border-bottom:1px solid var(--v2-line)!important;
}

body.v2-admin-page td{
  padding:15px!important;
  border-bottom:1px solid #edf2f7!important;
}

/* Mail + Reminder log rows if they use div/cards */
body.v2-admin-page .mail-log-row,
body.v2-admin-page .reminder-row,
body.v2-admin-page .log-row{
  border-radius:22px!important;
  background:#fbfdff!important;
  border:1px solid #edf2f7!important;
  box-shadow:0 10px 26px rgba(8,20,39,.05)!important;
}

/* Invoice form: stronger app form */
body.v2-invoice-form-page .v2-form-hero{
  display:none!important;
}

body.v2-invoice-form-page .panel,
body.v2-invoice-form-page form > .card,
body.v2-invoice-form-page .form-card{
  padding:26px!important;
}

body.v2-invoice-form-page .tax-box,
body.v2-invoice-form-page .price-mode-box,
body.v2-invoice-form-page .smart-ux-assistant,
body.v2-invoice-form-page .positions-box,
body.v2-invoice-form-page .total-box,
body.v2-invoice-form-page .summary-box{
  border-radius:30px!important;
  background:#fff!important;
  border:1px solid var(--v2-line)!important;
  box-shadow:var(--v2-soft)!important;
}

body.v2-invoice-form-page .item-row{
  border-radius:25px!important;
  background:#fbfdff!important;
  border:1px solid #edf2f7!important;
  box-shadow:0 10px 26px rgba(8,20,39,.05)!important;
}

body.v2-invoice-form-page .smart-suggestions button{
  border-radius:999px!important;
  background:#fff!important;
  border:1px solid var(--v2-line)!important;
  box-shadow:var(--v2-soft)!important;
}

/* Mobile */
@media(max-width:900px){
  body.v2-admin-page .main,
  body.v2-admin-page .fullapp-main,
  body.v2-admin-page .ui26-main{
    padding:12px 12px 118px!important;
    max-width:none!important;
  }

  .v2-admin-hero{
    padding:24px!important;
    border-radius:34px!important;
    margin-bottom:14px!important;
  }

  .v2-admin-hero h1{
    font-size:38px!important;
  }

  body.v2-admin-page .panel,
  body.v2-admin-page .card,
  body.v2-admin-page form,
  body.v2-admin-page .table-wrap{
    border-radius:30px!important;
    padding:18px!important;
  }

  body.v2-admin-page .table-wrap{
    overflow-x:auto!important;
  }

  body.v2-admin-page .table-wrap table,
  body.v2-admin-page table{
    min-width:720px;
  }

  body.v2-invoice-form-page .form-grid,
  body.v2-invoice-form-page .grid,
  body.v2-invoice-form-page .two-col,
  body.v2-invoice-form-page .row{
    grid-template-columns:1fr!important;
  }
}



/* =========================================================
   INVOICE FORM V2 REAL REWRITE
   ========================================================= */

.invoice-form-v2-main{
  max-width:1180px!important;
}

.ifv2-hero{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:24px;
  padding:32px;
  border-radius:34px;
  color:#fff;
  background:linear-gradient(135deg,#081427,#152a4a 60%,#635bff 140%);
  box-shadow:0 30px 85px rgba(8,20,39,.24);
  position:relative;
  overflow:hidden;
  margin-bottom:18px;
}

.ifv2-hero:after{
  content:"";
  position:absolute;
  right:-70px;
  top:-70px;
  width:210px;
  height:210px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
}

.ifv2-hero > *{
  position:relative;
  z-index:1;
}

.ifv2-hero span,
.ifv2-card-head span{
  display:block;
  color:#cbd5e1;
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.09em;
}

.ifv2-hero h1{
  margin:10px 0 8px;
  color:#fff;
  font-size:48px;
  line-height:.96;
  letter-spacing:-.085em;
}

.ifv2-hero p{
  margin:0;
  color:#dbeafe;
  font-weight:800;
}

.ifv2-live-total{
  text-align:right;
  min-width:220px;
}

.ifv2-live-total small{
  display:block;
  color:#cbd5e1;
  font-weight:900;
}

.ifv2-live-total strong{
  display:block;
  margin-top:8px;
  color:#fff;
  font-size:38px;
  line-height:1;
  letter-spacing:-.075em;
}

.ifv2-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:18px;
  align-items:start;
}

.ifv2-main-col{
  display:grid;
  gap:18px;
}

.ifv2-card{
  padding:24px;
  border-radius:32px;
  background:rgba(255,255,255,.94);
  border:1px solid var(--v2-line);
  box-shadow:var(--v2-shadow);
}

.ifv2-sticky{
  position:sticky;
  top:20px;
}

.ifv2-card-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:18px;
}

.ifv2-card-head span{
  color:var(--v2-primary);
}

.ifv2-card-head h2{
  margin:5px 0 5px;
  color:var(--v2-ink);
  font-size:28px;
  line-height:1;
  letter-spacing:-.065em;
}

.ifv2-card-head p{
  margin:0;
  color:var(--v2-muted);
  font-weight:800;
}

.ifv2-type-toggle,
.ifv2-tax-toggle,
.ifv2-price-mode{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  padding:5px;
  border-radius:22px;
  background:#f1f5f9;
  margin-bottom:18px;
}

.ifv2-type-toggle label,
.ifv2-tax-toggle label,
.ifv2-price-mode label{
  cursor:pointer;
}

.ifv2-type-toggle input,
.ifv2-tax-toggle input,
.ifv2-price-mode input{
  display:none;
}

.ifv2-type-toggle span,
.ifv2-tax-toggle span,
.ifv2-price-mode span{
  display:grid;
  place-items:center;
  min-height:48px;
  border-radius:17px;
  color:#64748b;
  font-weight:950;
}

.ifv2-type-toggle input:checked + span,
.ifv2-tax-toggle input:checked + span,
.ifv2-price-mode input:checked + span{
  color:#fff;
  background:linear-gradient(135deg,var(--v2-primary),var(--v2-purple));
  box-shadow:0 12px 26px rgba(99,91,255,.25);
}

.ifv2-fields{
  display:grid;
  gap:14px;
}

.ifv2-fields.two{
  grid-template-columns:1fr 1fr;
}

.ifv2-fields label,
.ifv2-item-grid label{
  display:grid;
  gap:7px;
  color:var(--v2-ink);
  font-size:13px;
  font-weight:950;
}

.ifv2-fields input,
.ifv2-fields select,
.ifv2-item input,
.ifv2-item textarea{
  width:100%;
  min-height:56px;
  border-radius:20px;
  border:1px solid #dce5f2;
  background:#fff;
  padding:0 15px;
  color:var(--v2-ink);
  font-size:16px;
  outline:none;
}

.ifv2-item textarea{
  resize:none;
  overflow:hidden;
  min-height:58px;
  padding:15px;
  line-height:1.45;
  font-family:inherit;
}

.ifv2-fields input:focus,
.ifv2-fields select:focus,
.ifv2-item input:focus,
.ifv2-item textarea:focus{
  border-color:rgba(99,91,255,.65);
  box-shadow:0 0 0 5px rgba(99,91,255,.10);
}

.ifv2-small-btn{
  border:0;
  min-height:44px;
  padding:0 14px;
  border-radius:16px;
  background:var(--v2-primary);
  color:#fff;
  font-weight:950;
}

.ifv2-suggestions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:16px;
}

.ifv2-suggestions button{
  border:1px solid var(--v2-line);
  background:#fff;
  color:var(--v2-ink);
  border-radius:999px;
  padding:12px 15px;
  font-weight:950;
  box-shadow:var(--v2-soft);
}

.ifv2-items{
  display:grid;
  gap:12px;
}

.ifv2-item{
  padding:16px;
  border-radius:26px;
  background:#fbfdff;
  border:1px solid #edf2f7;
  box-shadow:0 10px 26px rgba(8,20,39,.05);
}

.ifv2-item-top{
  display:grid;
  grid-template-columns:1fr 42px;
  gap:10px;
  align-items:start;
}

.ifv2-item-top button{
  width:42px;
  height:42px;
  border:0;
  border-radius:16px;
  background:#fff1f2;
  color:#be123c;
  font-size:22px;
  font-weight:950;
}

.ifv2-item-grid{
  display:grid;
  grid-template-columns:.7fr .9fr 1fr;
  gap:10px;
  margin-top:12px;
}

.ifv2-item-total{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid #e7edf5;
}

.ifv2-item-total span{
  color:var(--v2-muted);
  font-weight:900;
}

.ifv2-item-total strong{
  color:var(--v2-primary);
  font-size:18px;
}

.ifv2-duplicate{
  margin-top:10px;
  width:100%;
  border:1px solid #dbeafe;
  background:#eff6ff;
  color:#1d4ed8;
  border-radius:16px;
  min-height:42px;
  font-weight:950;
}

.ifv2-summary{
  display:grid;
  gap:10px;
  margin:16px 0;
}

.ifv2-summary div{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:center;
  padding:13px 0;
  border-bottom:1px solid #edf2f7;
}

.ifv2-summary span{
  color:var(--v2-muted);
  font-weight:900;
}

.ifv2-summary strong{
  color:var(--v2-ink);
  font-size:18px;
}

.ifv2-summary .grand{
  padding:18px;
  border:0;
  border-radius:24px;
  background:linear-gradient(135deg,#f6f9ff,#fff);
  border:1px solid var(--v2-line);
}

.ifv2-summary .grand strong{
  color:var(--v2-primary);
  font-size:30px;
  letter-spacing:-.06em;
}

.ifv2-save{
  width:100%;
  min-height:54px;
  border:0;
  border-radius:20px;
  color:#fff;
  background:linear-gradient(135deg,var(--v2-primary),var(--v2-purple));
  font-weight:950;
  box-shadow:0 14px 32px rgba(99,91,255,.26);
}

.ifv2-cancel{
  display:grid;
  place-items:center;
  min-height:48px;
  margin-top:10px;
  border-radius:18px;
  color:var(--v2-ink);
  background:#f8fafc;
  text-decoration:none;
  font-weight:950;
}

.ifv2-mobile-save{
  display:none;
}

.ifv2-pop{
  animation:ifv2Pop .45s ease-out both;
}

@keyframes ifv2Pop{
  0%{transform:scale(.985); box-shadow:0 0 0 0 rgba(99,91,255,.28);}
  55%{transform:scale(1.01); box-shadow:0 0 0 9px rgba(99,91,255,.08);}
  100%{transform:scale(1); box-shadow:0 0 0 0 rgba(99,91,255,0);}
}

@media(max-width:900px){
  .invoice-form-v2-main{
    padding:12px 12px 180px!important;
  }

  .ifv2-hero{
    display:block;
    padding:24px;
    border-radius:34px;
    margin-bottom:14px;
  }

  .ifv2-hero h1{
    font-size:39px;
  }

  .ifv2-live-total{
    text-align:left;
    margin-top:18px;
  }

  .ifv2-live-total strong{
    font-size:42px;
  }

  .ifv2-grid{
    grid-template-columns:1fr;
    gap:14px;
  }

  .ifv2-card{
    padding:18px;
    border-radius:30px;
  }

  .ifv2-sticky{
    position:static;
  }

  .ifv2-fields.two,
  .ifv2-item-grid{
    grid-template-columns:1fr;
  }

  .ifv2-suggestions{
    display:grid;
    grid-template-columns:1fr;
  }

  .ifv2-suggestions button{
    min-height:52px;
    text-align:left;
    border-radius:20px;
  }

  .ifv2-side .ifv2-save,
  .ifv2-side .ifv2-cancel{
    display:none;
  }

  .ifv2-mobile-save{
    position:fixed;
    left:12px;
    right:12px;
    bottom:92px;
    z-index:9996;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    padding:10px;
    border-radius:25px;
    background:rgba(255,255,255,.92);
    border:1px solid var(--v2-line);
    box-shadow:0 22px 65px rgba(8,20,39,.22);
    backdrop-filter:blur(16px);
  }

  .ifv2-mobile-save span,
  .ifv2-mobile-save strong{
    display:block;
  }

  .ifv2-mobile-save span{
    color:var(--v2-muted);
    font-size:12px;
    font-weight:950;
  }

  .ifv2-mobile-save strong{
    color:var(--v2-ink);
    font-size:20px;
    letter-spacing:-.04em;
  }

  .ifv2-mobile-save button{
    min-height:50px;
    min-width:130px;
    border:0;
    border-radius:18px;
    color:#fff;
    background:linear-gradient(135deg,var(--v2-primary),var(--v2-purple));
    font-weight:950;
  }
}
