:root{
  --bg:#f4f6fb;--panel:#fff;--ink:#111827;--muted:#64748b;--line:#e5e7eb;--primary:#0f172a;--good:#166534;--bad:#991b1b;--warn:#9a3412;--shadow:0 10px 30px rgba(15,23,42,.08);--radius:20px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;font-size:16px;line-height:1.35;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
button{touch-action:manipulation}
input,select,textarea{width:100%;min-height:46px;border:1px solid var(--line);border-radius:14px;padding:11px 12px;background:#fff;color:var(--ink);font-size:16px;outline:none}
input:focus,select:focus,textarea:focus{border-color:#93c5fd;box-shadow:0 0 0 4px rgba(59,130,246,.12)}
label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:800;color:#374151}
.hp{position:absolute;left:-9999px;opacity:0;height:1px;width:1px}
.app-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px max(14px,env(safe-area-inset-left)) 14px max(14px,env(safe-area-inset-right));padding-top:calc(14px + env(safe-area-inset-top));background:rgba(15,23,42,.96);color:#fff;backdrop-filter:blur(10px)}
.app-header h1{margin:0;font-size:20px;letter-spacing:.2px}.app-header p{margin:2px 0 0;color:#cbd5e1;font-size:12px}.header-pill{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:10px 12px;font-weight:900;font-size:12px;text-align:center}
.app-shell{max-width:1120px;margin:0 auto;padding:14px 14px calc(40px + env(safe-area-inset-bottom))}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin:0 0 14px}
.section-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.section-title h2,.panel h2{margin:0;font-size:20px}.section-title span{font-size:12px;color:var(--muted);font-weight:800;text-align:right}
.primary,.ghost,button.primary,button.ghost{border:0;border-radius:15px;min-height:46px;padding:12px 16px;font-weight:900;cursor:pointer;text-align:center;display:inline-flex;justify-content:center;align-items:center;gap:8px}
.primary{background:var(--primary);color:#fff}.ghost{background:#fff;color:var(--primary);border:1px solid var(--line)}.full{width:100%}.big{min-height:54px;font-size:17px}
.button-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}.button-row>*{flex:1;min-width:130px}.button-row form{display:flex}
.business-filter-form{display:grid;grid-template-columns:minmax(240px,1fr) minmax(180px,220px) 90px 110px 100px;gap:10px;align-items:end}.compact-apply,.compact-link{min-height:48px;display:flex;align-items:center;justify-content:center;text-align:center}.filter-note{margin:8px 0 0;color:var(--muted);font-size:12px;font-weight:700}
.toolbar-form{display:grid;grid-template-columns:1fr 130px;gap:10px;align-items:end}.grid-form{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.filter-grid{display:grid;grid-template-columns:2fr 1fr 120px;gap:10px;align-items:end}.stack{display:grid;gap:14px}
.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:0 0 14px}.metric{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:14px;min-height:84px;display:flex;flex-direction:column;justify-content:space-between}.metric span{font-size:12px;color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.04em}.metric strong{font-size:23px;line-height:1.1;word-break:break-word}.metric:nth-child(1) strong{color:var(--good)}.metric:nth-child(2) strong{color:var(--bad)}
.tag-nav{display:flex;gap:8px;overflow-x:auto;position:sticky;top:70px;z-index:10;background:rgba(244,246,251,.94);padding:8px 0 12px;margin:0 0 10px;backdrop-filter:blur(10px);-webkit-overflow-scrolling:touch}.tag-btn{white-space:nowrap;display:flex;align-items:center;justify-content:center;min-height:48px;border-radius:999px;border:1px solid var(--line);background:#fff;font-weight:900;font-size:13px;box-shadow:0 8px 18px rgba(15,23,42,.06);text-align:center;padding:8px 14px;color:#0f172a}.tag-btn.active{background:#0f172a;color:#fff;border-color:#0f172a}
.cards-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.tx-card{background:#fff;border:1px solid var(--line);border-left:6px solid #64748b;border-radius:18px;padding:13px;box-shadow:0 8px 18px rgba(15,23,42,.06);overflow:hidden}.tx-card.income{border-left-color:#16a34a}.tx-card.expense{border-left-color:#dc2626}.danger-left{border-left-color:#dc2626!important}.tx-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.tx-top strong{display:block;font-size:16px;line-height:1.2;overflow-wrap:anywhere}.tx-top span{display:block;color:var(--muted);font-size:12px;font-weight:800;margin-top:4px}.amount{font-weight:1000;font-size:17px;white-space:nowrap}.tx-meta{display:flex;flex-wrap:wrap;gap:7px;margin:10px 0}.tx-meta span{background:#f1f5f9;border-radius:999px;padding:6px 9px;font-size:12px;font-weight:800;color:#475569}.note{margin:8px 0;color:#374151;font-size:14px;line-height:1.35;background:#fffbeb;border:1px solid #fde68a;border-radius:12px;padding:10px;overflow-wrap:anywhere}
.receipt-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.receipt-pill{background:#eef2ff;color:#1e3a8a;border-radius:999px;padding:8px 10px;font-size:13px;font-weight:800;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.alert,.toast{border-radius:16px;padding:12px 14px;margin:0 0 12px;font-weight:800}.alert{background:#fee2e2;color:#7f1d1d;border:1px solid #fecaca}.toast{background:#dcfce7;color:#14532d;border:1px solid #bbf7d0}.empty-state{margin-top:14px;border:1px dashed #cbd5e1;border-radius:18px;background:#f8fafc;color:var(--muted);padding:18px;text-align:center;font-weight:800}
.lock-panel{border-color:#fed7aa;background:#fff7ed;text-align:center}.lock-panel h2{color:#9a3412}.zelle-box{font-size:28px;font-weight:1000;background:#fff;border:1px solid #fed7aa;border-radius:18px;padding:16px;margin:16px 0;letter-spacing:.5px}.small-warning{font-size:12px;color:#64748b;line-height:1.4}.copyright{text-align:center;color:#64748b;font-size:12px;margin:20px 0}.bottom-space{height:32px}
.report-document-header h1{margin:0}.report-subtitle{color:#64748b}.report-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.report-grid article{border:1px solid var(--line);border-radius:18px;padding:14px;background:#fff;overflow:auto}.report-table{width:100%;border-collapse:collapse;font-size:13px;min-width:320px}.report-table td{padding:9px;border-bottom:1px solid #f1f5f9}.report-table td:last-child{text-align:right;font-weight:900}.report-table .total td{font-weight:1000;background:#f8fafc}.report-table .grand td{font-weight:1000;background:#0f172a;color:#fff}
.login-body{min-height:100vh;display:grid;place-items:center;padding:18px;background:linear-gradient(160deg,#0f172a,#1e3a8a)}.login-card{width:min(720px,100%);background:#fff;border-radius:24px;padding:24px;box-shadow:var(--shadow)}.login-card h1{margin:0 0 6px;font-size:28px}.login-card p{color:#64748b}
@media(max-width:820px){.business-filter-form{grid-template-columns:1fr 1fr}.business-filter-form label{grid-column:1/-1}.app-shell{padding:10px 10px 36px}.summary-grid{grid-template-columns:repeat(2,1fr)}.grid-form,.filter-grid,.cards-list,.report-grid{grid-template-columns:1fr}.toolbar-form{grid-template-columns:1fr}.button-row{display:grid;grid-template-columns:1fr 1fr}.button-row>*{min-width:0}.tag-nav{top:64px}.metric strong{font-size:20px}}
@media(max-width:420px){.business-filter-form{grid-template-columns:1fr}.app-header{align-items:flex-start}.app-header h1{font-size:18px}.header-pill{font-size:11px;padding:8px 10px}.panel{padding:13px;border-radius:18px}.summary-grid{gap:8px}.metric span{font-size:11px}.metric strong{font-size:18px}.button-row{grid-template-columns:1fr}.tx-top{display:grid}.amount{white-space:normal;font-size:20px}.primary,.ghost{width:100%}.zelle-box{font-size:24px}.login-body{display:block;padding:14px}.login-card{margin:20px auto}}
@media print{.app-header,.tag-nav,.panel form,.button-row,.toast,.alert,.lock-panel{display:none!important}body{background:#fff}.app-shell{max-width:none;padding:0}.panel,.report-grid article{box-shadow:none;border:0}.report-grid{grid-template-columns:1fr}}


/* v3 iPhone menu fix */
.tag-nav{
  display:flex!important;
  flex-wrap:nowrap!important;
  gap:8px!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  position:sticky!important;
  top:70px!important;
  z-index:10!important;
  background:rgba(244,246,251,.96)!important;
  padding:9px 10px 12px!important;
  margin:0 -4px 10px!important;
  backdrop-filter:blur(10px)!important;
  -webkit-overflow-scrolling:touch!important;
  scroll-snap-type:x proximity!important;
  scrollbar-width:none!important;
}
.tag-nav::-webkit-scrollbar{display:none!important}
.tag-btn{
  flex:0 0 auto!important;
  white-space:nowrap!important;
  min-width:auto!important;
  min-height:44px!important;
  padding:9px 13px!important;
  border-radius:999px!important;
  font-size:13px!important;
  line-height:1!important;
  scroll-snap-align:start!important;
}
.tag-btn.active{
  transform:translateY(-1px);
}
@media(max-width:420px){
  .tag-nav{
    top:62px!important;
    gap:6px!important;
    padding-left:8px!important;
    padding-right:8px!important;
  }
  .tag-btn{
    font-size:12px!important;
    padding:9px 11px!important;
    min-height:42px!important;
  }
  .app-header{
    gap:8px!important;
  }
  .header-pill{
    max-width:145px!important;
    white-space:normal!important;
    line-height:1.15!important;
  }
}


/* v6 FINAL iPhone menu fix: no overflow, 2-row app grid */
.tag-nav{
  display:grid!important;
  grid-template-columns:repeat(4, minmax(0, 1fr))!important;
  gap:7px!important;
  overflow:visible!important;
  position:sticky!important;
  top:68px!important;
  z-index:10!important;
  background:rgba(244,246,251,.97)!important;
  padding:8px 6px 10px!important;
  margin:0 0 10px!important;
  backdrop-filter:blur(10px)!important;
  width:100%!important;
  max-width:100%!important;
}

.tag-btn{
  width:100%!important;
  min-width:0!important;
  max-width:100%!important;
  min-height:42px!important;
  padding:7px 4px!important;
  border-radius:14px!important;
  font-size:11.5px!important;
  line-height:1.1!important;
  white-space:normal!important;
  text-align:center!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important;
  text-overflow:clip!important;
  box-shadow:0 5px 12px rgba(15,23,42,.05)!important;
}

.tag-btn.active{
  box-shadow:0 8px 18px rgba(15,23,42,.18)!important;
}

@media(max-width:420px){
  .tag-nav{
    top:62px!important;
    grid-template-columns:repeat(4, minmax(0, 1fr))!important;
    gap:6px!important;
    padding:7px 4px 9px!important;
  }
  .tag-btn{
    font-size:10.8px!important;
    min-height:40px!important;
    padding:6px 2px!important;
    border-radius:13px!important;
  }
}

@media(max-width:360px){
  .tag-btn{
    font-size:10px!important;
    min-height:38px!important;
  }
}


/* v7 login/password security */
.header-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end}
.logout-mini{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:999px;color:#fff;font-weight:900;font-size:12px;padding:9px 10px;white-space:nowrap}
.alert.warn{background:#fff7ed;color:#9a3412;border-color:#fed7aa}
@media(max-width:420px){.header-actions{flex-direction:column;align-items:flex-end;gap:5px}.logout-mini{font-size:11px;padding:7px 9px}}


/* v14 Money Flow */
.metric-link{
  text-decoration:none!important;
  color:inherit!important;
}
.metric-link small{
  color:#64748b;
  font-size:11px;
  font-weight:900;
  margin-top:5px;
}
.money-action-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:14px;
}
.money-action{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  border-radius:16px;
  border:1px solid #e5e7eb;
  background:#fff;
  color:#0f172a;
  font-weight:1000;
  box-shadow:0 8px 18px rgba(15,23,42,.06);
}
.money-action.active{
  background:#0f172a;
  color:#fff;
  border-color:#0f172a;
}
.readonly-pill{
  width:100%;
  min-height:46px;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:12px;
  background:#f8fafc;
  color:#0f172a;
  font-weight:1000;
  display:flex;
  align-items:center;
}
@media(max-width:420px){
  .money-action-row{
    grid-template-columns:1fr;
  }
}


/* v15 safe bilingual switch */
.lang-switch{
  display:inline-flex;
  gap:5px;
  margin-top:6px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  padding:4px;
}
.lang-switch a{
  color:#fff;
  text-decoration:none;
  font-weight:1000;
  font-size:11px;
  padding:6px 10px;
  border-radius:999px;
}
.lang-switch a.active{
  background:#fff;
  color:#0f172a;
}

/* v16 clean invoice additions */
.lang-switch{display:flex;gap:6px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.lang-switch a{padding:7px 10px;border-radius:999px;background:#e5e7eb;color:#111827;text-decoration:none;font-weight:800;font-size:13px}
.lang-switch a.active{background:#0f172a;color:#fff}
.mini-box{border:1px dashed #cbd5e1;border-radius:14px;padding:12px;background:#f8fafc;margin:8px 0}
.invoice-lines{display:grid;gap:8px;margin:10px 0}
.invoice-line{display:grid;grid-template-columns:1.7fr .55fr .8fr;gap:8px;align-items:center}
.invoice-line.head{font-weight:800;color:#334155;font-size:13px;padding:0 4px}
.invoice-line input{width:100%;box-sizing:border-box}
.print-body{background:#fff;color:#111827}
.print-invoice{max-width:860px;margin:24px auto;padding:28px;background:#fff}
.print-head{display:flex;justify-content:space-between;gap:20px;border-bottom:2px solid #111827;padding-bottom:18px;margin-bottom:18px}
.print-head h1{margin:0;font-size:36px}.bill-to{margin:18px 0}.invoice-table{width:100%;border-collapse:collapse;margin-top:14px}.invoice-table th,.invoice-table td{border-bottom:1px solid #d1d5db;padding:10px;text-align:left}.invoice-table th{background:#f3f4f6}.invoice-table tfoot td{font-weight:900;font-size:18px}.invoice-table th:nth-child(n+2),.invoice-table td:nth-child(n+2){text-align:right}
@media(max-width:640px){.invoice-line{grid-template-columns:1fr}.invoice-line.head{display:none}.print-invoice{padding:16px;margin:0}.print-head{display:block}.header-actions{align-items:flex-end}}
@media print{.no-print,.tag-nav,.app-header,.button-row,.toast{display:none!important}.print-invoice{max-width:none;margin:0;padding:0}.print-body{background:#fff}}


.receipt-cart-label{grid-column:1/-1}.receipt-cart{margin-top:6px;border:1px dashed #cbd5e1;border-radius:16px;padding:12px;background:#f8fafc}.receipt-cart-input{width:100%;padding:10px;background:#fff;border-radius:12px}.receipt-cart-help{font-size:12px;color:#64748b;margin-top:8px;font-weight:700}.receipt-cart-list{list-style:none;margin:10px 0 0;padding:0;display:grid;gap:8px}.receipt-cart-empty{font-size:13px;color:#64748b;background:#fff;border-radius:12px;padding:10px}.receipt-cart-item{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:10px;font-size:13px;font-weight:800}.receipt-cart-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.receipt-cart-remove{border:0;border-radius:999px;background:#fee2e2;color:#991b1b;font-weight:900;padding:7px 10px;cursor:pointer;flex:0 0 auto}

.pl-receipt-list{display:grid;gap:12px}.pl-receipt-card{background:#fff;border:1px solid var(--line);border-left:6px solid #64748b;border-radius:18px;padding:14px;box-shadow:0 8px 18px rgba(15,23,42,.06)}.pl-receipt-card.income{border-left-color:#16a34a}.pl-receipt-card.expense{border-left-color:#dc2626}.pl-receipt-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.pl-receipt-head strong{display:block;font-size:16px;line-height:1.2}.pl-receipt-head span{display:block;color:var(--muted);font-size:12px;font-weight:800;margin-top:4px}.receipt-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-top:12px}.receipt-thumb{display:grid;gap:7px;text-decoration:none;color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:9px;font-size:12px;font-weight:800;overflow:hidden}.receipt-thumb img{width:100%;height:110px;object-fit:cover;border-radius:10px;background:#fff;border:1px solid #e2e8f0}.receipt-thumb span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.receipt-file-icon{height:110px;border-radius:10px;background:#eef2ff;color:#1e3a8a;display:grid;place-items:center;font-size:22px;font-weight:1000;border:1px solid #c7d2fe}.no-receipts{margin-top:10px;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:12px;padding:10px;color:#64748b;font-weight:800;font-size:13px}
@media print{.receipt-gallery{grid-template-columns:repeat(3,1fr)}.receipt-thumb{break-inside:avoid}.receipt-thumb img,.receipt-file-icon{height:130px}.pl-receipt-card{break-inside:avoid;box-shadow:none}}

.business-switch{display:none!important;}

/* v16 final invoice payment link */
.inline-paid-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:0}
.inline-paid-form select{min-width:110px;border:1px solid #cbd5e1;border-radius:12px;padding:9px 10px;font-weight:800;background:#fff;color:#0f172a}
.inline-paid-form button{white-space:nowrap}
.paid-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#dcfce7;color:#166534;border:1px solid #86efac;padding:10px 12px;font-weight:1000;min-width:130px}
@media(max-width:640px){.inline-paid-form{width:100%;display:grid;grid-template-columns:1fr}.inline-paid-form select,.inline-paid-form button{width:100%}.paid-badge{width:100%;box-sizing:border-box}}

/* v16 final vendors / getting started */
.getting-started-panel{border-color:#dbeafe;background:linear-gradient(180deg,#ffffff,#f8fbff)}
.start-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.start-card{display:flex;flex-direction:column;gap:8px;min-height:112px;border:1px solid var(--line);border-radius:20px;background:#fff;padding:16px;box-shadow:0 8px 18px rgba(15,23,42,.06)}
.start-card strong{font-size:20px;line-height:1.15}.start-card span{color:var(--muted);font-size:13px;font-weight:800;line-height:1.35}.start-card.income{border-left:6px solid #16a34a}.start-card.expense{border-left:6px solid #dc2626}
@media(max-width:640px){.start-grid{grid-template-columns:1fr}.start-card{min-height:94px}}

.category-columns{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:14px 0}
.chip-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.chip{display:inline-flex;align-items:center;border:1px solid #dbe3ef;background:#f8fafc;border-radius:999px;padding:7px 10px;font-size:.9rem;color:#243447}
@media(max-width:760px){.category-columns{grid-template-columns:1fr}}
