:root{
  --bg:#F1F0EB; --surface:#FFFFFF; --ink:#16231F; --muted:#6E776F;
  --primary:#0E4749; --primary-dark:#0A3536;
  --accent:#E0792B;
  --debit:#B6432F; --debit-bg:#FBEAE6;
  --done:#267A57; --done-bg:#E7F3EC;
  --border:#E4E2D9; --radius:16px;
  --shadow:0 2px 10px rgba(20,30,25,.06);
}
html[data-theme="dark"]{
  --bg:#111C17; --surface:#1A2A23; --ink:#EAF2EC; --muted:#8FA69C;
  --debit:#E17A63; --debit-bg:#3A231D;
  --done:#5FCB93; --done-bg:#163728;
  --border:#2A3B33;
  --shadow:0 2px 10px rgba(0,0,0,.35);
}
html[data-font="small"]{zoom:.9;}
html[data-font="large"]{zoom:1.14;}
body.density-compact .card{padding:8px 11px;margin-bottom:6px;gap:5px;}
body.density-compact .card-meta{gap:2px 8px;}
body.density-compact .card-notes,body.density-compact .card-temp-notes{padding:5px 8px;font-size:11px;}
body.density-compact .sum-bar{gap:6px;}
body.hide-phone .card-phone{display:none;}
body.hide-address .card-address{display:none;}
body.hide-notes .card-notes{display:none;}
body.hide-temp .card-temp-notes{display:none;}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;height:100%;}
body{font-family:'Vazirmatn',sans-serif;background:var(--bg);color:var(--ink);min-height:100vh;padding-bottom:env(safe-area-inset-bottom);transition:background .25s;}
button,input,textarea{font-family:inherit;}
body.no-select,body.no-select *{user-select:none;-webkit-user-select:none;}

/* ===== global tap/press feedback ===== */
button{transition:transform .13s cubic-bezier(.34,1.56,.64,1),background .18s,opacity .13s,box-shadow .18s,border-color .18s,color .18s;}
button:active{transform:scale(.94);}
.icon-btn:active{transform:scale(.88);}
.fab:active{transform:scale(.90);}
.sort-pill{transition:background .18s,color .18s,border-color .18s,transform .13s;}
.sort-pill:active{transform:scale(.93);}
.daytab{transition:background .18s,color .18s,transform .13s;}
.daytab:active{transform:scale(.95);}
.act-btn:active,.drag-handle:active{transform:scale(.88);}
.badge{transition:transform .15s;}
.opt-row button,.day-grid button,.week-pill,.type-toggle button{transition:background .18s,color .18s,border-color .18s,transform .13s;}
.opt-row button:active,.day-grid button:active,.week-pill:active,.type-toggle button:active{transform:scale(.93);}
.palette-swatch:active{transform:scale(.9)!important;}

/* ===== card list entrance animation ===== */
@keyframes cardIn{from{opacity:0;transform:translateY(12px) scale(.97);}to{opacity:1;transform:none;}}
.card-enter{animation:cardIn .34s cubic-bezier(.22,.85,.3,1) both;}

/* ===== "just visited" pop ===== */
@keyframes visitPop{0%{box-shadow:0 0 0 0 rgba(38,122,87,.5);}70%{box-shadow:0 0 0 12px rgba(38,122,87,0);}100%{box-shadow:var(--shadow);}}
.card.just-visited{animation:visitPop .6s ease;}

/* ===== card removal ===== */
.card.removing{overflow:hidden;transition:max-height .28s ease,opacity .22s ease,transform .22s ease,margin .28s ease,padding .28s ease;opacity:0;transform:scale(.94);}

/* ===== toggle switch ===== */
.toggle{position:relative;display:inline-block;width:42px;height:25px;flex:0 0 auto;}
.toggle input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer;z-index:2;}
.toggle-track{position:absolute;inset:0;background:var(--border);border-radius:20px;transition:background .25s;}
.toggle-thumb{position:absolute;top:2.5px;right:2.5px;width:20px;height:20px;background:#fff;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:transform .28s cubic-bezier(.34,1.56,.64,1);}
.toggle input:checked ~ .toggle-track{background:var(--primary);}
.toggle input:checked ~ .toggle-track .toggle-thumb{transform:translateX(-17px);}

/* ===== palette swatches ===== */
.palette-row{display:flex;gap:11px;flex-wrap:wrap;padding:2px 0;}
.palette-swatch{width:42px;height:42px;border-radius:50%;border:2.5px solid var(--border);position:relative;padding:0;cursor:pointer;flex:0 0 auto;}
.palette-swatch.sel{border-color:var(--ink);}
.palette-swatch.sel::after{content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:800;text-shadow:0 1px 3px rgba(0,0,0,.5);}

/* ===== unvisit confirm ===== */
.unvisit-icon{font-size:32px;text-align:center;margin-bottom:2px;}

.appbar{position:sticky;top:0;z-index:60;background:linear-gradient(180deg,var(--primary),var(--primary-dark));color:#fff;padding:12px 14px 10px;box-shadow:0 2px 8px rgba(0,0,0,.2);}
.appbar-top{display:flex;align-items:center;gap:7px;}
.appbar-logo{height:38px;flex:0 0 auto;border-radius:8px;background:#fff;padding:3px 7px;display:block;}
.logo-btn{background:none;border:none;padding:0;flex:0 0 auto;cursor:pointer;line-height:0;}
.logo-overlay{position:fixed;inset:0;background:rgba(10,15,12,.88);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;}
.logo-overlay.open{opacity:1;pointer-events:auto;}
.logo-overlay img{max-width:86vw;max-height:70vh;border-radius:16px;background:#fff;padding:14px;box-shadow:0 10px 40px rgba(0,0,0,.4);}
.logo-overlay-close{position:absolute;top:18px;left:18px;width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.15);border:none;color:#fff;display:flex;align-items:center;justify-content:center;}
.logo-overlay-close svg{width:20px;height:20px;}
.appbar-titles{flex:1;min-width:0;overflow:hidden;}
.appbar-titles h1{font-size:14.5px;font-weight:800;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.appbar-date{font-size:11px;opacity:.85;margin-top:2px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.icon-btn{background:rgba(255,255,255,.14);border:none;color:#fff;width:36px;height:36px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.icon-btn svg{width:17px;height:17px;}
.icon-btn:active{background:rgba(255,255,255,.28);}

/* sync status pill (shown while offline or while changes are still uploading) */
.sync-badge{display:none;align-items:center;gap:6px;position:absolute;left:12px;bottom:-13px;background:var(--accent);color:#fff;font-size:10.5px;font-weight:700;padding:3px 10px;border-radius:20px;box-shadow:0 3px 10px rgba(0,0,0,.18);z-index:5;}
.sync-badge .sync-dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:syncPulse 1.1s ease-in-out infinite;}
.sync-badge.offline{background:var(--muted);}
.sync-badge.offline .sync-dot{animation:none;}
@keyframes syncPulse{0%,100%{opacity:1;}50%{opacity:.35;}}
.archive-restore-btn{flex:0 0 auto;padding:6px 12px;font-size:11.5px;}

.daytabs{display:flex;gap:5px;overflow-x:auto;background:var(--primary-dark);padding:8px 10px 8px;scrollbar-width:none;}
.daytabs::-webkit-scrollbar{display:none;}
.daytab{flex:0 0 auto;padding:8px 13px 7px;border:none;cursor:pointer;font-size:12.5px;font-weight:700;color:rgba(255,255,255,.6);background:rgba(255,255,255,.07);border-radius:9px 9px 3px 3px;white-space:nowrap;transition:.15s;border-bottom:3px solid transparent;}
.daytab.active{background:var(--bg);color:var(--primary-dark);}
.daytab.today:not(.active)::after{content:'';display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--accent);margin-right:5px;vertical-align:middle;}
.daytab .cnt{display:inline-block;margin-right:5px;background:rgba(255,255,255,.18);color:#fff;font-size:9.5px;font-weight:700;min-width:16px;height:16px;line-height:16px;border-radius:8px;text-align:center;padding:0 2px;}
.daytab.active .cnt{background:var(--primary);color:#fff;}

.nb-bar{display:flex;align-items:center;gap:8px;background:var(--primary-dark);padding:0 14px 10px;}
.nb-label{font-size:11px;font-weight:700;color:rgba(255,255,255,.6);flex:0 0 auto;}
.nb-txt{font-size:11.5px;color:#fff;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.nb-txt.empty{color:rgba(255,255,255,.4);font-weight:500;}
.nb-edit{background:rgba(255,255,255,.13);border:none;color:#fff;width:24px;height:24px;border-radius:7px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;}
.nb-edit svg{width:12px;height:12px;}

.sort-bar{display:flex;align-items:center;gap:6px;padding:12px 14px 4px;overflow-x:auto;scrollbar-width:none;}
.sort-bar::-webkit-scrollbar{display:none;}
.sort-label{font-size:11.5px;font-weight:700;color:var(--muted);flex:0 0 auto;margin-inline-start:2px;}
.sort-pill{flex:0 0 auto;display:inline-flex;align-items:center;gap:4px;padding:7px 13px;border:1.5px solid var(--border);border-radius:20px;background:var(--surface);font-size:12px;font-weight:700;color:var(--muted);white-space:nowrap;}
.sort-pill svg{width:12px;height:12px;}
.sort-pill.active{background:var(--primary);border-color:var(--primary);color:#fff;}

main{padding:10px 14px 110px;max-width:560px;margin:0 auto;}
.sum-bar{display:flex;gap:8px;margin-bottom:14px;}
.sum-card{flex:1;background:var(--surface);border-radius:14px;padding:10px 6px;text-align:center;box-shadow:var(--shadow);}
.sum-card .lbl{font-size:10px;color:var(--muted);font-weight:600;}
.sum-card .val{font-size:13.5px;font-weight:800;margin-top:3px;direction:ltr;unicode-bidi:plaintext;}
.sum-card.debit .val{color:var(--debit);}

/* ===== unvisited-debtors alert banner ===== */
.debtor-alert{display:flex;align-items:center;gap:10px;background:var(--debit-bg);border:1.5px solid var(--debit);border-radius:14px;padding:10px 12px;margin-bottom:14px;}
.debtor-alert-icon{font-size:18px;flex:0 0 auto;line-height:1;}
.debtor-alert-body{flex:1;min-width:0;}
.debtor-alert-title{font-size:12.5px;font-weight:800;color:var(--debit);line-height:1.7;}
.debtor-alert-sub{font-size:11px;color:var(--debit);opacity:.85;margin-top:1px;}
.sum-card.done .val{color:var(--done);}

.card{background:var(--surface);border-radius:var(--radius);padding:12px 13px;margin-bottom:9px;box-shadow:var(--shadow);border-right:5px solid #ccc;display:flex;flex-direction:column;gap:8px;transition:background .2s,box-shadow .2s,opacity .2s;position:relative;}
.card.visited{background:linear-gradient(0deg,var(--done-bg),var(--surface) 60%);}
.card.future{opacity:.7;}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;}
.card-name-wrap{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1;}
.card-name{font-size:14.5px;font-weight:700;}
.badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:2px 8px;border-radius:6px;color:#fff;width:fit-content;}
.badge.from-day{}
.badge.future-wk{background:#607D8B;}
.badge.creditor{background:var(--done);}
.badge.debtor{background:var(--debit);}
.card-amount{font-size:15px;font-weight:800;direction:ltr;unicode-bidi:plaintext;white-space:nowrap;color:var(--debit);flex:0 0 auto;}
.card-amount.creditor{color:var(--done);}
.card-meta{font-size:11.5px;color:var(--muted);display:flex;flex-wrap:wrap;gap:3px 10px;}
.card-meta a{color:var(--muted);text-decoration:none;direction:ltr;unicode-bidi:plaintext;}
.card-notes{font-size:12px;color:var(--ink);background:var(--bg);border-radius:9px;padding:7px 10px;line-height:1.7;}
.card-temp-notes{font-size:12px;color:#795548;background:#FFF8E1;border-radius:9px;padding:7px 10px;line-height:1.7;border-right:3px solid #FFC107;}

.card-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px dashed var(--border);padding-top:8px;gap:6px;}
.visit-check{display:flex;align-items:center;gap:7px;cursor:pointer;min-width:0;}
.visit-check input{width:20px;height:20px;accent-color:var(--done);cursor:pointer;flex:0 0 auto;}
.visit-check.locked{cursor:not-allowed;}
.visit-check.locked input{cursor:not-allowed;}
.visit-lbl{font-size:12px;font-weight:700;color:var(--muted);white-space:nowrap;}
.visit-lbl.on{color:var(--done);}
.visit-lbl.locked{color:#9AA39B;}
.visit-time{font-size:11px;color:var(--done);font-weight:700;direction:ltr;white-space:nowrap;}
.card-actions{display:flex;gap:5px;flex:0 0 auto;}
.act-btn{background:var(--bg);border:none;width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--muted);}
.act-btn svg{width:15px;height:15px;}
.act-btn.link-on{background:var(--done-bg);color:var(--done);}

/* Custom sort drag handles */
.drag-handle{background:var(--bg);border:none;width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:grab;touch-action:none;}
.drag-handle svg{width:15px;height:15px;}
.card.dragging{cursor:grabbing;box-shadow:0 16px 30px rgba(20,30,25,.28);opacity:.98;border-radius:calc(var(--radius) + 2px);}
.card.dragging .drag-handle{cursor:grabbing;color:var(--primary);}

.empty-state{text-align:center;padding:50px 20px 30px;color:var(--muted);}
.empty-state svg{width:44px;height:44px;opacity:.3;margin-bottom:12px;}
.empty-state p{font-size:13px;margin:0 0 14px;line-height:1.8;}
.empty-cta{background:var(--primary);color:#fff;border:none;padding:10px 18px;border-radius:12px;font-size:13px;font-weight:700;}

.fab{position:fixed;bottom:22px;inset-inline-end:18px;z-index:55;width:54px;height:54px;border-radius:17px;border:none;background:var(--accent);color:#fff;box-shadow:0 6px 16px rgba(224,121,43,.45);display:flex;align-items:center;justify-content:center;}
.fab svg{width:23px;height:23px;}
.fab:active{transform:scale(.93);}

/* Overlays */
.overlay{position:fixed;inset:0;background:rgba(15,25,20,.52);z-index:100;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;}
.overlay.open{opacity:1;pointer-events:auto;}
/* confirmation/alert dialogs must always sit above other sheets (e.g. edit modal) regardless of DOM order */
#unvisitOverlay,#confirmOverlay{z-index:220;}
.sheet{width:100%;max-width:520px;background:var(--surface);border-radius:22px 22px 0 0;padding:20px 18px calc(20px + env(safe-area-inset-bottom));max-height:90vh;overflow-y:auto;transform:translateY(24px);transition:transform .25s;}
.overlay.open .sheet{transform:translateY(0);}
.handle{width:36px;height:4px;background:var(--border);border-radius:3px;margin:0 auto 14px;}
.sheet h2{font-size:16px;font-weight:800;margin:0 0 4px;}
.sheet-sub{font-size:12px;color:var(--muted);margin:0 0 14px;line-height:1.8;}
.fld{margin-bottom:13px;}
.fld label{display:block;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:5px;}
.fld input,.fld textarea{width:100%;border:1.5px solid var(--border);border-radius:12px;padding:11px 12px;font-size:14px;background:var(--bg);color:var(--ink);resize:vertical;}
.fld input:focus,.fld textarea:focus{outline:none;border-color:var(--primary);}
.fld textarea{min-height:68px;line-height:1.6;}

.type-toggle{display:flex;gap:8px;margin-bottom:13px;}
.type-toggle button{flex:1;padding:10px 4px;border-radius:12px;border:1.5px solid var(--border);background:var(--bg);font-size:12.5px;font-weight:700;color:var(--muted);}
.type-toggle button.sel-debit{background:var(--debit-bg);border-color:var(--debit);color:var(--debit);}
.type-toggle button.sel-credit{background:var(--done-bg);border-color:var(--done);color:var(--done);}

/* Settings sheet */
.settings-sheet{max-height:92vh;}
.settings-group{margin-bottom:18px;}
.settings-label{font-size:12px;font-weight:700;color:var(--muted);margin:0 0 8px;}
.settings-hint{font-size:11px;color:var(--muted);line-height:1.8;margin:8px 0 0;}
.opt-row{display:flex;gap:8px;}
.opt-row button{flex:1;padding:10px 6px;border-radius:12px;border:1.5px solid var(--border);background:var(--bg);font-size:12.5px;font-weight:700;color:var(--muted);}
.opt-row button.sel{background:var(--primary);border-color:var(--primary);color:#fff;}
.switch-row{display:flex;align-items:center;justify-content:space-between;padding:10px 2px;font-size:13px;color:var(--ink);border-bottom:1px solid var(--border);}
.switch-row:last-child{border-bottom:none;}
.switch-row input{width:40px;height:24px;accent-color:var(--primary);}

/* Global search */
.search-overlay{position:fixed;inset:0;background:var(--bg);z-index:150;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .22s;}
.search-overlay.open{transform:translateY(0);}
.search-top{display:flex;align-items:center;gap:10px;padding:calc(12px + env(safe-area-inset-top)) 14px 10px;background:var(--surface);border-bottom:1px solid var(--border);flex:0 0 auto;}
.search-input-wrap{flex:1;display:flex;align-items:center;gap:8px;background:var(--bg);border:1.5px solid var(--border);border-radius:14px;padding:9px 12px;color:var(--muted);}
.search-input-wrap svg{width:17px;height:17px;flex:0 0 auto;}
.search-input-wrap input{flex:1;border:none;background:none;font-size:14px;color:var(--ink);outline:none;}
.search-close{background:none;border:none;color:var(--primary);font-size:13px;font-weight:700;flex:0 0 auto;padding:4px;}
.search-results{flex:1;overflow-y:auto;padding:10px 14px 40px;}
.search-hint{text-align:center;color:var(--muted);font-size:12.5px;padding:40px 20px;line-height:1.9;}
.search-row{display:flex;align-items:center;gap:10px;background:var(--surface);border-radius:14px;padding:11px 12px;margin-bottom:8px;box-shadow:var(--shadow);border-right:4px solid #ccc;}
.search-row-body{flex:1;min-width:0;}
.search-row-top{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.search-row-name{font-size:13.5px;font-weight:800;color:var(--ink);}
.search-row-day{font-size:10.5px;font-weight:700;color:#fff;background:var(--muted);padding:2px 8px;border-radius:8px;}
.search-row-meta{font-size:11.5px;color:var(--muted);margin-top:3px;display:flex;flex-wrap:wrap;gap:2px 8px;direction:ltr;text-align:right;unicode-bidi:plaintext;}
.search-row-amount{font-size:13px;font-weight:800;color:var(--debit);flex:0 0 auto;direction:ltr;}
.search-row-amount.creditor{color:var(--done);}
.card.search-highlight{animation:searchPulse 1.6s ease;}
@keyframes searchPulse{0%,100%{box-shadow:var(--shadow);}30%{box-shadow:0 0 0 3px var(--accent);}}

.day-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin-bottom:4px;}
.day-grid button{padding:10px 4px;border-radius:11px;border:1.5px solid var(--border);background:var(--bg);font-size:12px;font-weight:700;color:var(--ink);}
.day-grid button.sel{color:#fff;border-color:transparent;}
.day-grid button:disabled{opacity:.45;cursor:default;}

.week-row{display:flex;gap:6px;margin-top:8px;margin-bottom:14px;flex-wrap:wrap;}
.week-pill{flex:0 0 auto;padding:7px 12px;border:1.5px solid var(--border);border-radius:20px;background:var(--bg);font-size:12px;font-weight:700;color:var(--muted);}
.week-pill.sel{background:var(--primary);border-color:var(--primary);color:#fff;}

.actions-row{display:flex;gap:8px;margin-top:8px;}
.btn{flex:1;padding:12px;border-radius:13px;border:none;font-size:14px;font-weight:700;}
.btn-primary{background:var(--primary);color:#fff;}
.btn-ghost{background:var(--bg);color:var(--ink);}
.btn-danger{background:var(--debit-bg);color:var(--debit);}
.btn-skip{background:var(--bg);color:var(--muted);}
.btn:active{opacity:.85;}

/* Import */
.import-drop{border:1.5px dashed var(--border);border-radius:14px;padding:24px 14px;text-align:center;margin-bottom:14px;background:var(--bg);}
.import-drop svg{width:32px;height:32px;color:var(--primary);margin-bottom:8px;}
.import-drop p{font-size:12px;color:var(--muted);margin:0 0 12px;line-height:1.8;}
.file-btn{display:inline-block;background:var(--primary);color:#fff;padding:9px 18px;border-radius:11px;font-size:13px;font-weight:700;cursor:pointer;}
#fileInput{display:none;}
.stat-pill{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:10px;font-size:12.5px;font-weight:700;margin-bottom:8px;}
.stat-pill.ok{background:var(--done-bg);color:var(--done);}
.stat-pill.warn{background:var(--debit-bg);color:var(--debit);}
.stat-pill.info{background:#EAF1FB;color:var(--primary);}
.spinner{width:20px;height:20px;border:2.5px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto;}
@keyframes spin{to{transform:rotate(360deg);}}
.remove-list{max-height:280px;overflow-y:auto;border:1px solid var(--border);border-radius:12px;background:var(--bg);margin-bottom:14px;}
.remove-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid var(--border);}
.remove-row:last-child{border-bottom:none;}
.remove-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);flex:0 0 auto;}
.remove-row .rname{flex:1;font-size:13px;font-weight:600;}
.select-all-row{display:flex;gap:8px;margin-bottom:8px;}
.sel-all-btn{font-size:12px;font-weight:700;background:var(--bg);border:1.5px solid var(--border);border-radius:9px;padding:6px 12px;color:var(--muted);}

/* NC queue */
.nc-progress{font-size:12px;color:var(--muted);font-weight:700;margin-bottom:12px;}

/* ===== generic confirm sheet ===== */
.confirm-icon{font-size:32px;text-align:center;margin-bottom:2px;}
.confirm-msg{font-size:13px;color:var(--muted);line-height:1.9;text-align:center;margin:0 0 16px;}

/* ===== toast / undo snackbar ===== */
.toast-wrap{position:fixed;left:0;right:0;bottom:calc(18px + env(safe-area-inset-bottom));z-index:250;display:flex;justify-content:center;padding:0 14px;pointer-events:none;}
.toast{pointer-events:auto;display:flex;align-items:center;gap:12px;background:var(--ink);color:var(--bg);border-radius:14px;padding:12px 14px;box-shadow:0 8px 24px rgba(0,0,0,.28);font-size:12.5px;font-weight:600;max-width:520px;width:100%;transform:translateY(20px);opacity:0;transition:transform .25s cubic-bezier(.22,.85,.3,1),opacity .25s;}
html[data-theme="dark"] .toast{background:#EAF2EC;color:#111C17;}
.toast.show{transform:translateY(0);opacity:1;}
.toast-msg{flex:1;min-width:0;}
.toast-undo{flex:0 0 auto;background:none;border:none;color:var(--accent);font-weight:800;font-size:12.5px;padding:4px 6px;}

/* ===== GPS location ===== */
.gps-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;margin-top:8px;padding:10px;border-radius:12px;border:1.5px dashed var(--primary);background:var(--done-bg);color:var(--primary);font-size:12.5px;font-weight:700;}
.gps-btn svg{width:15px;height:15px;flex:0 0 auto;}
.gps-btn.saved{border-style:solid;border-color:var(--done);color:var(--done);}
.manual-loc-btn{background:var(--bg);border-color:var(--muted);color:var(--muted);}
.manual-loc-btn.saved{border-style:solid;border-color:var(--done);color:var(--done);background:var(--done-bg);}
.gps-status{font-size:11px;color:var(--muted);margin-top:6px;line-height:1.8;}
.gps-status.ok{color:var(--done);font-weight:700;}
.gps-status.err{color:var(--debit);font-weight:700;}
.card-address.has-gps::before{content:'📍 ';}

/* ===== dashboard ===== */
.dash-overlay{position:fixed;inset:0;background:var(--bg);z-index:150;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .22s;}
.dash-overlay.open{transform:translateY(0);}
.dash-top{display:flex;align-items:center;gap:10px;padding:calc(12px + env(safe-area-inset-top)) 14px 10px;background:linear-gradient(180deg,var(--primary),var(--primary-dark));color:#fff;flex:0 0 auto;}
.dash-top h2{flex:1;font-size:15px;font-weight:800;margin:0;}
.dash-close{background:rgba(255,255,255,.14);border:none;color:#fff;width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.dash-close svg{width:16px;height:16px;}
.dash-body{flex:1;overflow-y:auto;padding:14px 14px 40px;}
.map-overlay{position:fixed;inset:0;background:var(--bg);z-index:150;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .22s;}
.map-overlay.open{transform:translateY(0);}
.map-top{display:flex;align-items:center;gap:10px;padding:calc(12px + env(safe-area-inset-top)) 14px 10px;background:linear-gradient(180deg,var(--primary),var(--primary-dark));color:#fff;flex:0 0 auto;}
.map-top h2{flex:1;font-size:15px;font-weight:800;margin:0;}
.map-top .sub{font-size:11px;font-weight:600;color:rgba(255,255,255,.8);margin-top:1px;}
.map-close{background:rgba(255,255,255,.14);border:none;color:#fff;width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.map-close svg{width:16px;height:16px;}
.map-body{flex:1;position:relative;}
#mapContainer{position:absolute;inset:0;background:var(--border);}
.map-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:30px;text-align:center;color:var(--muted);font-size:13px;line-height:1.9;}
.map-locate-btn{position:absolute;bottom:18px;left:14px;z-index:400;background:var(--surface);color:var(--primary);border:1.5px solid var(--border);width:42px;height:42px;border-radius:50%;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;}
.map-locate-btn svg{width:20px;height:20px;}
.map-legend{position:absolute;top:10px;left:10px;z-index:400;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:8px 10px;font-size:11px;font-weight:700;display:flex;flex-direction:column;gap:5px;}
.map-legend-row{display:flex;align-items:center;gap:6px;}
.map-legend-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto;}
.map-chip-group{position:relative;display:inline-flex;flex-direction:column;align-items:center;}
.map-chip{position:relative;z-index:2;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;box-sizing:border-box;padding:5px 9px 6px;border-radius:11px;background:var(--surface);border:2px solid #999;box-shadow:0 1px 5px rgba(0,0,0,.3);white-space:nowrap;}
.map-chip-name{font-size:11px;font-weight:800;color:var(--ink);white-space:nowrap;line-height:14px;max-width:180px;overflow:hidden;text-overflow:ellipsis;}
.map-chip-amt{font-size:11px;font-weight:800;direction:ltr;unicode-bidi:plaintext;line-height:14px;white-space:nowrap;}
.map-chip-amt.debtor{color:var(--debit);}
.map-chip-amt.creditor{color:var(--done);}
.map-chip-stem{width:3px;height:10px;flex:0 0 auto;}
.map-dot{box-sizing:border-box;width:12px;height:12px;border-radius:50%;border:2.5px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.35),0 1px 3px rgba(0,0,0,.4);}
.map-chip-visited{position:absolute;z-index:3;top:-6px;left:-6px;width:16px;height:16px;border-radius:50%;background:var(--done);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;border:2px solid var(--surface);}
.map-user-dot{width:18px;height:18px;border-radius:50%;background:#1A73E8;border:3px solid #fff;box-shadow:0 0 0 4px rgba(26,115,232,.28),0 2px 6px rgba(0,0,0,.35);}
.map-popup .leaflet-popup-content-wrapper{border-radius:14px;}
.locpick-overlay{position:fixed;inset:0;background:var(--bg);z-index:170;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .22s;}
.locpick-overlay.open{transform:translateY(0);}
.locpick-top{display:flex;align-items:center;gap:10px;padding:calc(12px + env(safe-area-inset-top)) 14px 10px;background:linear-gradient(180deg,var(--primary),var(--primary-dark));color:#fff;flex:0 0 auto;}
.locpick-top h2{flex:1;font-size:14.5px;font-weight:800;margin:0;}
.locpick-top .sub{font-size:11px;font-weight:600;color:rgba(255,255,255,.8);margin-top:1px;}
.locpick-close{background:rgba(255,255,255,.14);border:none;color:#fff;width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.locpick-close svg{width:16px;height:16px;}
.locpick-body{flex:1;position:relative;}
#locPickContainer{position:absolute;inset:0;background:var(--border);}
.locpick-center-pin{position:absolute;top:50%;left:50%;transform:translate(-50%,-100%);z-index:400;pointer-events:none;width:34px;height:44px;}
.locpick-center-pin svg{width:34px;height:44px;filter:drop-shadow(0 3px 4px rgba(0,0,0,.4));}
.locpick-hint{position:absolute;top:10px;left:10px;right:10px;z-index:400;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:8px 12px;font-size:11.5px;color:var(--muted);text-align:center;font-weight:600;}
.locpick-bottom{flex:0 0 auto;padding:12px 14px calc(14px + env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border);display:flex;gap:10px;}
.locpick-bottom .btn{flex:1;}
.mp-name{font-size:13px;font-weight:800;color:var(--ink);margin-bottom:2px;}
.mp-amt{font-size:13px;font-weight:800;direction:ltr;unicode-bidi:plaintext;display:inline-block;}
.mp-amt.debtor{color:var(--debit);}
.mp-amt.creditor{color:var(--done);}
.mp-addr{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.6;}
.mp-nav{display:inline-block;margin-top:7px;font-size:11.5px;font-weight:700;color:var(--primary);text-decoration:none;}
.dash-month-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--surface);border-radius:14px;padding:8px 10px;box-shadow:var(--shadow);margin-bottom:14px;}
.dash-month-nav{background:var(--bg);border:none;width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--primary);flex:0 0 auto;}
.dash-month-nav svg{width:16px;height:16px;}
.dash-month-label{font-size:13.5px;font-weight:800;color:var(--ink);}
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:16px;}
.dash-card{background:var(--surface);border-radius:14px;padding:12px 12px;box-shadow:var(--shadow);}
.dash-card .lbl{font-size:11px;color:var(--muted);font-weight:700;margin-bottom:5px;}
.dash-card .val{font-size:17px;font-weight:800;color:var(--ink);direction:ltr;unicode-bidi:plaintext;}
.dash-card.debit .val{color:var(--debit);}
.dash-card.done .val{color:var(--done);}
.dash-section-title{font-size:12.5px;font-weight:800;color:var(--ink);margin:18px 0 10px;display:flex;align-items:center;gap:6px;}
.dash-bars{background:var(--surface);border-radius:14px;padding:14px 14px 8px;box-shadow:var(--shadow);}
.dash-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.dash-bar-day{width:46px;flex:0 0 auto;font-size:11.5px;font-weight:700;color:var(--muted);}
.dash-bar-track{flex:1;height:10px;background:var(--bg);border-radius:6px;overflow:hidden;}
.dash-bar-fill{height:100%;border-radius:6px;transition:width .4s ease;}
.dash-bar-val{width:26px;flex:0 0 auto;font-size:11px;font-weight:700;color:var(--ink);text-align:left;}
.dash-top-list{background:var(--surface);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;}
.dash-top-row{display:flex;align-items:center;gap:10px;padding:11px 13px;border-bottom:1px solid var(--border);}
.dash-top-row:last-child{border-bottom:none;}
.dash-top-rank{width:20px;flex:0 0 auto;font-size:12px;font-weight:800;color:var(--muted);}
.dash-top-name{flex:1;min-width:0;font-size:12.5px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dash-top-amt{flex:0 0 auto;font-size:12.5px;font-weight:800;color:var(--debit);direction:ltr;}
.dash-empty{text-align:center;color:var(--muted);font-size:12px;padding:20px;line-height:1.9;}
