*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
:root{
  --admin:#1b3a5c;--admin-light:#2d5986;
  --purple:#764ba2;--purple-light:#667eea;
  --teal:#00b09b;--teal-light:#43c6ac;--teal-dark:#00695c;
  --pink:#e65100;--pink-light:#ff8a50;--pink-dark:#bf360c;
  --rosa:#c62764;--rosa-light:#e8799a;--rosa-dark:#880e4f;
  --gold:#f7971e;--red:#e74c3c;--green:#2e7d32;
  --bg:#f4f3ff;--card:#fff;--text:#1a1a2e;--muted:#888;
  --radius:16px;--shadow:0 4px 24px rgba(0,0,0,.10);
}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;}

/* ── LOGIN ── */
#loginScreen{position:fixed;inset:0;background:linear-gradient(135deg,var(--admin-light),var(--admin));display:flex;align-items:center;justify-content:center;z-index:200;}
.login-box{background:#fff;border-radius:24px;padding:36px 32px;text-align:center;width:310px;box-shadow:0 20px 60px rgba(0,0,0,.2);}
.login-logo{font-size:2.2rem;margin-bottom:6px;}
.login-box h1{font-size:1.3rem;margin-bottom:3px;color:var(--admin);}
.login-box p{color:var(--muted);font-size:.85rem;margin-bottom:22px;}
.pin-dots{display:flex;justify-content:center;gap:12px;margin-bottom:20px;}
.pin-dot{width:15px;height:15px;border-radius:50%;border:2px solid #ddd;transition:all .2s;}
.pin-dot.filled{background:var(--admin);border-color:var(--admin);}
.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;}
.pin-btn{padding:15px;border:none;background:var(--bg);border-radius:12px;font-size:1.15rem;font-weight:600;cursor:pointer;transition:all .15s;color:var(--text);}
.pin-btn:active{background:var(--admin);color:#fff;transform:scale(.95);}
.pin-error{color:var(--red);font-size:.8rem;margin-top:10px;min-height:16px;}

/* ── SHELLS ── */
.shell{display:none;flex-direction:column;min-height:100vh;}
.shell.visible{display:flex;}

/* ── HEADERS ── */
.hdr{padding:14px 18px 12px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;}
.hdr-admin{background:linear-gradient(135deg,var(--admin-light),var(--admin));}
.hdr-sharelyn{background:linear-gradient(135deg,var(--purple-light),var(--purple));}
.hdr-teresa{background:linear-gradient(135deg,var(--pink-light),var(--pink));}
.hdr-teresa-personal{background:linear-gradient(135deg,var(--rosa-light),var(--rosa));}
.hdr h1{color:#fff;font-size:1rem;font-weight:700;}
.hdr .sub{color:rgba(255,255,255,.75);font-size:.72rem;margin-top:1px;}
.hdr-right{display:flex;align-items:center;gap:8px;}
.exit-btn{background:rgba(255,255,255,.2);border:none;color:#fff;padding:6px 13px;border-radius:20px;cursor:pointer;font-size:.78rem;font-weight:600;}
.scan-hdr-btn{background:rgba(255,255,255,.2);border:none;color:#fff;padding:6px 10px;border-radius:20px;cursor:pointer;font-size:1.1rem;line-height:1;transition:background .15s;}
.scan-hdr-btn:active{background:rgba(255,255,255,.4);}

/* ── PERSON SWITCHER ── */
.person-tabs{display:flex;background:rgba(255,255,255,.15);border-radius:20px;padding:3px;gap:2px;}
.p-tab{padding:5px 14px;border:none;background:transparent;color:rgba(255,255,255,.75);border-radius:16px;cursor:pointer;font-size:.8rem;font-weight:600;transition:all .2s;}
.p-tab.active{background:#fff;color:var(--admin);}
.p-tab.teresa.active{color:var(--pink-dark);}
.p-tab.teresa-personal.active{color:var(--rosa-dark);}
.p-tab.sharelyn.active{color:var(--purple);}

/* ── BALANCE BANNER ── */
.balance-banner{padding:20px 18px 18px;color:#fff;text-align:center;}
.bal-admin-sly{background:linear-gradient(135deg,var(--purple-light),var(--purple));}
.bal-teresa{background:linear-gradient(135deg,var(--pink-light),var(--pink));}
.bal-teresa-personal{background:linear-gradient(135deg,var(--rosa-light),var(--rosa));}
.balance-banner .bal-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;opacity:.85;margin-bottom:6px;}
.balance-banner .bal-amount{font-size:2.8rem;font-weight:900;letter-spacing:-.02em;text-shadow:0 2px 12px rgba(0,0,0,.18);}
.balance-banner .bal-sub{font-size:.75rem;opacity:.75;margin-top:4px;}
.bal-row{display:flex;justify-content:center;gap:16px;margin-top:14px;}
.bal-chip{background:rgba(255,255,255,.22);border-radius:14px;padding:9px 16px;text-align:center;backdrop-filter:blur(4px);}
.bal-chip .bc-label{font-size:.68rem;opacity:.8;}
.bal-chip .bc-val{font-size:1rem;font-weight:800;margin-top:2px;text-shadow:0 1px 4px rgba(0,0,0,.12);}

/* ── DASHBOARD TASK WIDGET ── */
.dash-todo-card{background:#fff;border-radius:16px;padding:14px 16px;margin:0 0 8px;box-shadow:0 2px 10px rgba(0,0,0,.07);border-left:4px solid transparent;}
.dash-todo-card.hl-teal{border-left-color:var(--teal);}
.dash-todo-card.hl-rosa{border-left-color:var(--rosa);}
.dash-todo-hdr{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:10px;}
.dash-todo-badge{background:var(--pink);color:#fff;border-radius:20px;padding:2px 9px;font-size:.72rem;font-weight:800;}
.dash-todo-card.hl-teal .dash-todo-badge{background:var(--teal);}
.dash-todo-card.hl-rosa .dash-todo-badge{background:var(--rosa);}
.dash-todo-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid #f5f5f5;}
.dash-todo-row:last-of-type{border-bottom:none;}
.dash-todo-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;background:var(--teal);}
.dash-todo-dot.rosa{background:var(--rosa);}
.dash-todo-text{font-size:.8rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dash-todo-more{font-size:.72rem;color:var(--muted);text-align:right;margin-top:8px;}
.dash-todo-empty{font-size:.8rem;color:var(--muted);text-align:center;padding:8px 0;margin:0;}

/* ── BOTTOM NAV ── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;display:flex;border-top:1px solid #eee;z-index:10;box-shadow:0 -4px 16px rgba(0,0,0,.06);}
.nav-btn{flex:1;padding:9px 0 11px;border:none;background:transparent;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--muted);transition:color .2s;}
.nav-btn.active{color:var(--admin);}
.nav-btn.s-active{color:var(--purple);}
.nav-btn.t-active{color:var(--pink);}
.nav-btn.tp-active{color:var(--rosa);}
.nav-icon{font-size:1.3rem;}
.nav-label{font-size:.65rem;font-weight:600;}

/* ── VIEWS ── */
.view{display:none;flex:1;overflow-y:auto;padding:14px 15px 88px;}
.view.active{display:block;}

/* ── CARDS ── */
.cards-row{display:grid;grid-template-columns:repeat(2,1fr);gap:11px;margin-bottom:14px;}
.stat-card{background:var(--card);border-radius:var(--radius);padding:15px;box-shadow:var(--shadow);}
.stat-card.hl{background:linear-gradient(135deg,var(--purple-light),var(--purple));}
.stat-card.hl .lbl,.stat-card.hl .val,.stat-card.hl .sub{color:#fff;}
.stat-card.hl-admin{background:linear-gradient(135deg,var(--admin-light),var(--admin));}
.stat-card.hl-admin .lbl,.stat-card.hl-admin .val,.stat-card.hl-admin .sub{color:#fff;}
.stat-card.hl-teal{background:linear-gradient(135deg,var(--pink-light),var(--pink));}
.stat-card.hl-teal .lbl,.stat-card.hl-teal .val,.stat-card.hl-teal .sub{color:#fff;}
.stat-card.hl-rosa{background:linear-gradient(135deg,var(--rosa-light),var(--rosa));}
.stat-card.hl-rosa .lbl,.stat-card.hl-rosa .val,.stat-card.hl-rosa .sub{color:#fff;}
.stat-card.hl-green{background:linear-gradient(135deg,#43a047,#1b5e20);}
.stat-card.hl-green .lbl,.stat-card.hl-green .val,.stat-card.hl-green .sub{color:#fff;}
.stat-card.gd{background:linear-gradient(135deg,var(--gold),#ffd200);}
.lbl{font-size:.67rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px;}
.val{font-size:1.2rem;font-weight:800;line-height:1.1;}
.sub{font-size:.68rem;color:var(--muted);margin-top:2px;}
.span2{grid-column:span 2;}

/* ── CHART ── */
.chart-card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);margin-bottom:13px;}
.chart-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #f0f0f0;}
.chart-hdr h3{font-size:.88rem;font-weight:700;color:#555;}
.chart-wrap{position:relative;height:210px;}

/* ── TX TOGGLE ── */
.tx-toggle-btn{background:transparent;border:2px solid #e0d9f7;color:var(--purple);padding:4px 12px;border-radius:16px;cursor:pointer;font-size:.75rem;font-weight:700;transition:all .2s;}
.tx-toggle-btn:hover,.tx-toggle-btn.teal-toggle{border-color:#ffd0a0;color:var(--pink);}
.tx-toggle-btn.rosa-toggle{border-color:var(--rosa-light);color:var(--rosa-dark);}

/* ── FILTERS ── */
.year-selector{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding:2px 0;}
.year-select-lbl{font-size:.78rem;font-weight:600;color:var(--muted);white-space:nowrap;}
.year-select{padding:7px 12px;border:1.5px solid #c5d5e8;border-radius:10px;background:#fff;color:var(--admin);font-size:.9rem;font-weight:700;cursor:pointer;min-width:90px;}
.year-select:focus{outline:none;border-color:var(--admin);}
.filter-row{display:flex;gap:7px;overflow-x:auto;padding-bottom:2px;margin-bottom:12px;scrollbar-width:none;}
.filter-row::-webkit-scrollbar{display:none;}
.pill{padding:5px 14px;border:2px solid #e0d9f7;background:#fff;color:var(--purple);border-radius:20px;cursor:pointer;font-size:.78rem;font-weight:600;white-space:nowrap;transition:all .2s;}
.pill.active{background:var(--purple);color:#fff;border-color:var(--purple);}
.pill.admin{border-color:#c5d5e8;color:var(--admin);}
.pill.admin.active{background:var(--admin);color:#fff;border-color:var(--admin);}
.pill.teal{border-color:#ffd0a0;color:var(--pink);}
.pill.teal.active{background:var(--pink);color:#fff;border-color:var(--pink);}
.pill.rosa{border-color:var(--rosa-light);color:var(--rosa-dark);}
.pill.rosa.active{background:var(--rosa);color:#fff;border-color:var(--rosa);}

/* ── TOP BARS ── */
.top-item{display:flex;align-items:center;gap:9px;margin-bottom:7px;}
.top-lbl{font-size:.78rem;color:var(--text);width:150px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.top-track{flex:1;background:#f0f0f0;border-radius:20px;height:9px;overflow:hidden;}
.top-fill{height:100%;border-radius:20px;background:linear-gradient(90deg,var(--purple-light),var(--purple));}
.top-fill.admin{background:linear-gradient(90deg,var(--admin-light),var(--admin));}
.top-fill.teal{background:linear-gradient(90deg,var(--pink-light),var(--pink));}
.top-fill.rosa{background:linear-gradient(90deg,var(--rosa-light),var(--rosa));}
.top-amt{font-size:.76rem;font-weight:700;color:var(--purple);width:88px;text-align:right;flex-shrink:0;}
.top-amt.admin{color:var(--admin);}
.top-amt.teal{color:var(--pink);}
.top-amt.rosa{color:var(--rosa-dark);}

/* ── TABLES ── */
.tx-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;font-size:.78rem;}
thead th{background:#f8f7ff;color:var(--purple);font-weight:700;padding:7px 9px;text-align:left;white-space:nowrap;}
thead.admin th{background:#eef2f8;color:var(--admin);}
thead.teal th{background:#fff3e0;color:var(--pink-dark);}
thead.rosa th{background:#fdf0f6;color:var(--rosa-dark);}
tbody tr{border-bottom:1px solid #f5f5f5;}
tbody tr:hover{background:#fafeff;}
tbody td{padding:7px 9px;vertical-align:middle;}
.badge{display:inline-block;padding:2px 7px;border-radius:11px;font-size:.68rem;font-weight:700;}
.b-cat{background:#f0ecff;color:var(--purple);}
.b-cat-admin{background:#e8eef6;color:var(--admin);}
.b-bank{background:#e0f7fa;color:#00838f;}
.b-cash{background:#fff8e1;color:#f57f17;}
.b-income{background:#e8f5e9;color:#2e7d32;}
.b-expense{background:#fce4ec;color:#880e4f;}
.b-method{background:#f3f3f3;color:#555;}
.amount-neg{color:var(--red);font-weight:700;}
.amount-pos{color:var(--green);font-weight:700;}
.del-btn{background:none;border:none;cursor:pointer;color:#ffb3b3;font-size:.95rem;padding:2px 4px;border-radius:5px;}
.del-btn:hover{color:var(--red);}
.receipt-thumb{width:38px;height:38px;object-fit:cover;border-radius:7px;cursor:pointer;border:2px solid #e0f2f1;vertical-align:middle;}

/* ── FORM ── */
.form-card{background:var(--card);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);margin-bottom:14px;}
.form-card h2{font-size:.95rem;font-weight:700;margin-bottom:16px;}
label{display:block;font-size:.75rem;font-weight:700;color:var(--muted);margin-bottom:4px;margin-top:13px;}
label:first-of-type{margin-top:0;}
input,select{width:100%;padding:11px 13px;border:2px solid #e8e4f8;border-radius:10px;font-size:.92rem;color:var(--text);background:#fff;transition:border .2s;outline:none;}
input:focus,select:focus{border-color:var(--purple);}
.teal-form input:focus,.teal-form select:focus{border-color:var(--pink);}
.admin-form input:focus,.admin-form select:focus{border-color:var(--admin);}
.rosa-form input:focus,.rosa-form select:focus{border-color:var(--rosa);}

/* ── CAT / METHOD GRID ── */
.opt-grid{display:grid;gap:7px;margin-top:4px;}
.opt-grid.cols3{grid-template-columns:repeat(3,1fr);}
.opt-grid.cols4{grid-template-columns:repeat(4,1fr);}
.opt-btn{padding:9px 5px;border:2px solid #e8e4f8;background:#fff;border-radius:10px;cursor:pointer;text-align:center;font-size:.7rem;font-weight:600;color:var(--text);transition:all .2s;line-height:1.4;}
.opt-btn:hover{border-color:var(--purple);}
.opt-btn.sel{background:var(--purple);color:#fff;border-color:var(--purple);}
.opt-btn.sel-admin{background:var(--admin);color:#fff;border-color:var(--admin);}
.opt-btn.sel-teal{background:var(--pink);color:#fff;border-color:var(--pink);}
.opt-btn.sel-rosa{background:var(--rosa);color:#fff;border-color:var(--rosa);}
.opt-icon{display:block;font-size:1.2rem;margin-bottom:2px;}

/* ── RECEIPT UPLOAD ── */
.receipt-drop{border:2px dashed #ffd0a0;border-radius:12px;padding:16px;text-align:center;cursor:pointer;background:#fff8f0;transition:all .2s;margin-top:6px;}
.receipt-drop:hover{border-color:var(--pink);}
.receipt-drop p{color:var(--muted);font-size:.8rem;margin-top:5px;}
.receipt-preview-img{max-width:100%;max-height:200px;border-radius:10px;margin-top:8px;display:none;}

/* ── BUTTONS ── */
.btn{width:100%;padding:13px;border:none;border-radius:12px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s;margin-top:16px;}
.btn-a{background:linear-gradient(135deg,var(--admin-light),var(--admin));color:#fff;}
.btn-p{background:linear-gradient(135deg,var(--purple-light),var(--purple));color:#fff;}
.btn-t{background:linear-gradient(135deg,var(--pink-light),var(--pink));color:#fff;}
.btn-tp{background:linear-gradient(135deg,var(--rosa-light),var(--rosa));color:#fff;}
.btn-s{background:linear-gradient(135deg,#43a047,#00c853);color:#fff;}
.btn-d{background:#fff0f0;color:var(--red);border:2px solid #ffd0d0;}
.btn:active{transform:scale(.98);}

/* ── UPLOAD ── */
.upload-area{border:2px dashed #c9bff0;border-radius:var(--radius);padding:28px 18px;text-align:center;cursor:pointer;transition:all .2s;background:#f9f7ff;margin-bottom:14px;}
.upload-area:hover,.upload-area.drag{border-color:var(--purple);background:#f0ecff;}
.upload-icon{font-size:2.2rem;margin-bottom:7px;}
.upload-area p{color:var(--muted);font-size:.85rem;}
.upload-area strong{color:var(--purple);}
#csvFileInput{display:none;}
.preview-box{background:#f9f7ff;border-radius:12px;padding:12px;margin-bottom:12px;max-height:240px;overflow-y:auto;}

/* ── ALERTS ── */
.alert{padding:11px 14px;border-radius:10px;font-size:.82rem;margin-bottom:11px;display:none;}
.alert.show{display:block;}
.alert-success{background:#e8fdf0;color:#2e7d32;border:1px solid #a5d6a7;}
.alert-error{background:#fff0f0;color:#c62828;border:1px solid #ffcdd2;}
.alert-info{background:#e8f4fd;color:#0277bd;border:1px solid #b3d9f7;}

/* ── LOADING / EMPTY ── */
.loading{text-align:center;padding:36px;color:var(--muted);font-size:.87rem;}
.spinner{display:inline-block;width:26px;height:26px;border:3px solid #e0d9f7;border-top-color:var(--admin);border-radius:50%;animation:spin .7s linear infinite;margin-bottom:7px;}
.empty{text-align:center;padding:36px 18px;color:var(--muted);}
.empty-icon{font-size:2.6rem;margin-bottom:7px;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── RECEIPT MODAL ── */
#receiptModal{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:400;display:none;align-items:center;justify-content:center;padding:16px;}
#receiptModal img{max-width:100%;max-height:90vh;border-radius:12px;}

/* ── MONTH BADGES ── */
.m-enero{background:#e8f4fd;color:#1565c0;}
.m-febrero{background:#fef3e2;color:#e65100;}
.m-marzo{background:#e8fdf2;color:#2e7d32;}
.m-abril{background:#fce4ec;color:#880e4f;}
.m-mayo{background:#f3e5f5;color:#6a1b9a;}
.m-otros{background:#f5f5f5;color:#555;}
.m-ingreso{background:#e8f5e9;color:#2e7d32;}

@media(min-width:600px){.view,.balance-banner{max-width:600px;margin-left:auto;margin-right:auto;} .hdr{justify-content:center;gap:14px;}}

/* ── EDIT MODAL ── */
#editModal{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:350;display:none;align-items:flex-end;justify-content:center;}
.edit-sheet{background:#fff;border-radius:22px 22px 0 0;padding:20px 18px 38px;width:100%;max-width:520px;max-height:94vh;overflow-y:auto;}
.edit-sheet-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.edit-sheet-hdr h3{font-size:1rem;font-weight:700;}
.edit-close{background:none;border:none;font-size:1.4rem;cursor:pointer;color:#888;line-height:1;}
.edit-pdots{display:flex;justify-content:center;gap:10px;margin:8px 0 10px;}
.edit-pdot{width:12px;height:12px;border-radius:50%;border:2px solid #ddd;transition:all .2s;}
.edit-pdot.ep-admin{background:var(--admin);border-color:var(--admin);}
.edit-pdot.ep-purple{background:var(--purple);border-color:var(--purple);}
.edit-pdot.ep-teal{background:var(--pink);border-color:var(--pink);}
.edit-pdot.ep-rosa{background:var(--rosa);border-color:var(--rosa);}
.edit-pin-box{background:#f9f7ff;border-radius:14px;padding:14px 12px 10px;margin-top:14px;}
.edit-pin-box p{font-size:.75rem;font-weight:700;color:var(--muted);text-align:center;margin-bottom:6px;}
.mini-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-width:230px;margin:0 auto;}
.mini-btn{padding:11px;border:none;background:#eee;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s;}
.mini-btn:active{transform:scale(.94);}
.ep-err{color:var(--red);font-size:.74rem;text-align:center;min-height:14px;margin-top:5px;}
.ep-ok{color:var(--green);font-size:.74rem;text-align:center;margin-top:5px;}
.edited-mark{font-size:.58rem;color:#bbb;margin-left:3px;cursor:default;}
tr.was-edited > td:first-child{border-left:3px solid #ffe082;}

/* ── TODO PAGE HEADER ── */
.todo-page-hdr{display:flex;justify-content:space-between;align-items:center;padding:14px 16px 8px;}
.todo-page-hdr h3{font-size:.95rem;font-weight:700;color:var(--text);}
.todo-add-fab{padding:8px 16px;border:none;border-radius:20px;background:var(--purple);color:#fff;font-size:.78rem;font-weight:700;cursor:pointer;box-shadow:0 2px 8px rgba(118,75,162,.3);transition:all .18s;}
.todo-add-fab.teal{background:var(--pink);box-shadow:0 2px 8px rgba(230,81,0,.25);}
.todo-add-fab:active{transform:scale(.95);}

/* ── TODO ── */
.todo-section-title{font-size:.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:14px 0 8px;padding-left:2px;}
.todo-item{display:flex;align-items:center;gap:10px;padding:11px 14px;background:var(--card);border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.06);margin-bottom:8px;transition:opacity .2s;}
.todo-item.done{opacity:.45;}
.todo-item.done .todo-title{text-decoration:line-through;color:var(--muted);}
.todo-check{width:22px;height:22px;border-radius:50%;border:2px solid #ddd;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all .2s;color:#fff;}
.todo-check.checked{background:var(--purple);border-color:var(--purple);}
.todo-check.checked-teal{background:var(--pink);border-color:var(--pink);}
.todo-check.checked-rosa{background:var(--rosa);border-color:var(--rosa);}
.todo-check.checked-admin{background:var(--admin);border-color:var(--admin);}
.todo-title{font-size:.88rem;font-weight:600;color:var(--text);line-height:1.3;}
.todo-body{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0;}
.todo-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.todo-cat-tag{font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:10px;background:#f0ecff;color:var(--purple);white-space:nowrap;}
.todo-cat-tag.teal{background:#fff3e0;color:var(--pink-dark);}
.todo-cat-tag.rosa{background:#fdf0f6;color:var(--rosa-dark);}
.todo-cat-tag.admin-tag{background:#e8eef6;color:var(--admin);}
.todo-date{font-size:.68rem;font-weight:700;padding:2px 7px;border-radius:10px;white-space:nowrap;}
.todo-date.overdue{background:#fce4ec;color:#c62828;}
.todo-date.today{background:#fff8e1;color:#e65100;}
.todo-date.tomorrow{background:#e3f2fd;color:#1565c0;}
.todo-date.future{background:#f3f3f3;color:#555;}
.todo-del{background:none;border:none;cursor:pointer;color:#ffb3b3;font-size:.95rem;padding:2px 4px;border-radius:5px;flex-shrink:0;}
.todo-del:hover{color:var(--red);}
.todo-done-toggle{width:100%;margin:12px 0 4px;padding:10px;border:2px dashed #e0d9f7;background:transparent;border-radius:12px;cursor:pointer;font-size:.8rem;font-weight:700;color:var(--purple);transition:all .2s;}
.todo-done-toggle.teal{border-color:#ffd0a0;color:var(--pink);}
.todo-done-toggle.rosa{border-color:var(--rosa-light);color:var(--rosa-dark);}
.todo-done-toggle.admin{border-color:#c5d5e8;color:var(--admin);}
.todo-done-toggle:hover{background:#f8f4ff;}
.todo-done-toggle.teal:hover{background:#fff8f0;}
.todo-done-toggle.rosa:hover{background:#fdf0f6;}
.todo-done-toggle.admin:hover{background:#f0f4f8;}
.todo-empty{text-align:center;padding:28px 18px;color:var(--muted);}
.todo-empty-icon{font-size:2.2rem;margin-bottom:6px;}

/* ── ESCÁNER ── */
#scannerModal{position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:450;display:none;align-items:flex-end;justify-content:center;}
.scanner-sheet{background:#fff;border-radius:22px 22px 0 0;padding:20px 18px 38px;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;}
.scanner-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
.scanner-hdr h3{font-size:1rem;font-weight:700;}
.scanner-hint{font-size:.78rem;color:var(--muted);text-align:center;margin-bottom:12px;}
#scannerView{width:100%;border-radius:12px;overflow:hidden;background:#111;min-height:190px;display:flex;align-items:center;justify-content:center;}
.scan-ok-icon{font-size:3rem;padding:30px;color:#2e7d32;width:100%;text-align:center;}
.scan-err{color:var(--red);text-align:center;padding:28px 16px;font-size:.85rem;line-height:1.6;}
.scanned-code-label{font-size:.72rem;color:var(--muted);margin:14px 0 4px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;}
.scanned-code-val{font-family:monospace;font-size:.9rem;background:#f5f5f5;padding:8px 12px;border-radius:8px;word-break:break-all;margin-bottom:12px;}
.product-card{background:#fff8f0;border:1px solid #ffd0a0;border-radius:12px;padding:14px;}
.product-name{font-size:.95rem;font-weight:700;color:var(--text);}
.product-brand{font-size:.78rem;color:var(--muted);margin-top:4px;}
.product-qty{font-size:.76rem;color:var(--pink);margin-top:3px;font-weight:600;}
.scan-not-found{color:var(--muted);font-size:.82rem;text-align:center;padding:10px 0;}
.desc-scan-row{display:flex;gap:8px;}
.desc-scan-row input{flex:1;}

/* ── PRESUPUESTOS ── */
.presu-card{background:#fff;border:1.5px solid #ffe0b2;border-radius:14px;padding:14px 16px;margin-bottom:12px;box-shadow:0 2px 8px rgba(230,81,0,.07);transition:box-shadow .2s;}
.presu-card.presu-comparing{border-color:var(--pink);box-shadow:0 2px 14px rgba(230,81,0,.22);}
.presu-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;}
.presu-store{font-weight:700;font-size:.9rem;color:var(--text);margin-bottom:3px;}
.presu-work-cat-tag{display:inline-block;font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:10px;background:#fff3e0;color:var(--pink-dark);margin-bottom:3px;}
.presu-meta{font-size:.75rem;color:var(--muted);}
.presu-note{font-size:.73rem;color:var(--muted);margin-top:3px;font-style:italic;}
.presu-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid #f5f0eb;}
/* Pantalla de elección / picker de comparación */
.presu-choice-screen{padding:16px;}
.presu-choice-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px;flex-wrap:wrap;}
.presu-choice-hdr h3{font-size:.92rem;font-weight:700;color:var(--pink-dark);flex:1;}
.presu-choice-sub{font-size:.78rem;color:var(--muted);margin-bottom:16px;line-height:1.5;}
.presu-choice-btns{display:flex;gap:12px;margin-bottom:14px;}
.presu-choice-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:18px 10px;border:2px solid #ffe0b2;border-radius:14px;background:#fff;cursor:pointer;transition:all .18s;}
.presu-choice-btn:hover,.presu-choice-btn:active{border-color:var(--pink);background:#fff8f0;}
.pcb-icon{font-size:1.8rem;}
.pcb-title{font-size:.82rem;font-weight:700;color:var(--text);}
.pcb-desc{font-size:.7rem;color:var(--muted);text-align:center;line-height:1.4;}
.presu-pick-card{background:#fff;border:1.5px solid #f0e8e0;border-radius:12px;padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:all .15s;}
.presu-pick-card:hover,.presu-pick-card:active{border-color:var(--pink);background:#fff8f0;}
/* Desglose de totales en la tarjeta */
.presu-breakdown{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:3px;font-size:.75rem;}
.pb-mat{color:var(--muted);}
.pb-labor{color:var(--teal);font-weight:600;}
.pb-sep{color:#ccc;}
.pb-total{font-weight:800;color:var(--pink-dark);}
.presu-meta-total{font-size:.78rem;font-weight:700;color:var(--pink-dark);margin-top:2px;}
/* Selector de categoría de trabajo */
.work-cat-scroll{display:flex;gap:8px;overflow-x:auto;padding:4px 0 8px;scrollbar-width:none;}
.work-cat-scroll::-webkit-scrollbar{display:none;}
.work-cat-btn{flex-shrink:0;padding:6px 12px;border:1.5px solid #e0d0b8;background:#fff;border-radius:20px;cursor:pointer;font-size:.75rem;font-weight:600;color:var(--pink-dark);white-space:nowrap;transition:all .18s;}
.work-cat-btn.active{background:var(--pink);color:#fff;border-color:var(--pink);}
/* Item de mano de obra */
.labor-row{background:#f7fdfb;}
.labor-badge{display:block;font-size:.65rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px;}
/* Subtotales materiales / mano de obra */
.presu-subtotals{border-top:1px dashed #e0e0e0;margin-top:8px;padding-top:8px;}
.presu-sub-row{display:flex;justify-content:space-between;font-size:.77rem;padding:3px 4px;color:var(--muted);}
.presu-sub-row.labor{color:var(--teal);}
/* Botón clonar */
.presu-btn-clone{border-color:#c8e6c9;color:#2e7d32;}
.presu-btn{padding:5px 10px;border:1px solid #e0d0c0;background:#fff;border-radius:8px;cursor:pointer;font-size:.74rem;font-weight:600;color:var(--pink-dark);transition:all .15s;}
.presu-btn:hover{background:#fff3e0;}
.presu-btn-green{border-color:#a5d6a7;color:var(--green);}
.presu-btn-green:hover{background:#e8f5e9;}
.presu-btn-del{border-color:#ffcdd2;color:var(--red);}
.presu-btn-del:hover{background:#ffebee;}
.presu-btn-cmp{border-color:#ffd0a0;color:var(--pink);}
.presu-btn-cmp.active{background:var(--pink);color:#fff;border-color:var(--pink);}
.presu-status-sel{padding:5px 8px;border:1px solid #e0d0c0;background:#fff;border-radius:8px;cursor:pointer;font-size:.74rem;color:var(--text);}
.presu-badge{font-size:.7rem;font-weight:700;padding:3px 9px;border-radius:10px;white-space:nowrap;flex-shrink:0;}
.b-pending{background:#fff9e6;color:#b8860b;}
.b-approved{background:#e8f5e9;color:var(--green);}
.b-rejected{background:#ffebee;color:var(--red);}
/* Item cards del formulario */
.presu-item-block{background:#fff;border:1.5px solid #f0e8e0;border-radius:12px;padding:11px 12px;margin-bottom:8px;}
.presu-item-block.labor-block{background:#f7fdfb;border-color:#c8e6c9;}
.presu-desc-wrap{position:relative;margin-bottom:8px;}
.presu-item-input{width:100%;border:1.5px solid #e8e8e8;border-radius:8px;padding:8px 10px;font-size:.82rem;font-family:inherit;box-sizing:border-box;background:#fafafa;}
.presu-item-input:focus{outline:none;border-color:var(--pink);background:#fff;}
.presu-item-input.num{text-align:right;background:#fafafa;}
.presu-item-input.labor-desc:focus{border-color:var(--teal);}
/* Dropdown de sugerencias */
.item-sugg-panel{position:absolute;top:calc(100% - 2px);left:0;right:0;background:#fff;border:1.5px solid var(--pink);border-top:none;border-radius:0 0 10px 10px;max-height:190px;overflow-y:auto;z-index:200;box-shadow:0 6px 18px rgba(0,0,0,.12);}
.item-sugg-opt{display:block;width:100%;text-align:left;padding:9px 12px;background:none;border:none;border-bottom:1px solid #f5f5f5;cursor:pointer;font-size:.8rem;color:var(--text);font-family:inherit;}
.item-sugg-opt:last-child{border-bottom:none;}
.item-sugg-opt:hover,.item-sugg-opt:active{background:#fff3e0;color:var(--pink-dark);}
/* Fila de cantidad / precio / total */
.presu-nums-row{display:flex;align-items:flex-end;gap:8px;}
.num-group{display:flex;flex-direction:column;flex:1;min-width:0;}
.num-lbl{font-size:.62rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:3px;white-space:nowrap;}
.num-total{font-size:.88rem;font-weight:800;color:var(--pink-dark);padding:8px 4px;}
.num-total.teal{color:var(--teal);}
.item-del-btn{background:none;border:none;cursor:pointer;color:#ffb3b3;font-size:1.1rem;padding:6px 4px;flex-shrink:0;line-height:1;}
.item-del-btn:hover{color:var(--red);}
/* Total y subtotales */
.presu-total-row{background:#fff8f0;display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-radius:10px;margin-top:12px;}
.presu-total-lbl{font-weight:700;color:var(--pink-dark);font-size:.85rem;}
.presu-total-val{font-size:1.15rem;font-weight:800;color:var(--pink);}
/* Tabla de detalle (vista, no formulario) */
.presu-items-table{width:100%;border-collapse:collapse;margin-top:6px;}
.presu-items-table th{background:#fff3e0;color:var(--pink-dark);font-size:.75rem;padding:6px 8px;text-align:left;}
.presu-items-table td{padding:5px 8px;border-bottom:1px solid #f5f0eb;font-size:.78rem;vertical-align:middle;}
.scan-btn{padding:0 14px;border:2px solid #ffd0a0;background:#fff8f0;border-radius:10px;cursor:pointer;font-size:1.35rem;flex-shrink:0;transition:all .2s;line-height:1;}
.scan-btn:active{background:var(--pink);border-color:var(--pink);}

/* ══════════════════════════════════════════════════════════
   ARELY — Household Expense Manager
   Palette: #FFFDFD · #F9EEF3 · #F6C9D8 · #F2A0BB · #D06B8D
   ══════════════════════════════════════════════════════════ */
:root{
  --arely:#D06B8D;--arely-light:#F2A0BB;--arely-lighter:#F6C9D8;
  --arely-bg:#F9EEF3;--arely-white:#FFFDFD;--arely-dark:#a8506f;
}

/* Header */
.hdr-arely{background:linear-gradient(135deg,var(--arely-light),var(--arely));}

/* Balance Banner */
.bal-arely{background:linear-gradient(135deg,var(--arely-light),var(--arely));}

/* Budget Progress Bar */
.arely-budget-bar-wrap{background:rgba(255,255,255,.3);border-radius:20px;height:22px;margin:12px 0 10px;overflow:hidden;}
.arely-budget-bar{height:100%;border-radius:20px;background:linear-gradient(90deg,var(--arely-white),var(--arely-lighter));display:flex;align-items:center;justify-content:flex-end;padding-right:8px;transition:width .5s ease;min-width:36px;}
.arely-budget-bar span{font-size:.72rem;font-weight:800;color:var(--arely-dark);}
.arely-budget-bar.bar-warning{background:linear-gradient(90deg,#ffe082,#ffb74d);}
.arely-budget-bar.bar-danger{background:linear-gradient(90deg,#ef9a9a,#e53935);} .arely-budget-bar.bar-danger span{color:#fff;}

/* Form */
.arely-form{border-top:4px solid var(--arely);}
.arely-form label{color:var(--arely-dark);}
.arely-form input[type="number"],.arely-form input[type="text"],.arely-form input[type="date"]{
  width:100%;padding:12px 14px;border:2px solid var(--arely-lighter);border-radius:10px;
  font-size:.95rem;color:var(--text);background:#fff;outline:none;box-sizing:border-box;
}
.arely-form input:focus{border-color:var(--arely);}

/* Buttons */
.btn-arely{background:linear-gradient(135deg,var(--arely-light),var(--arely));color:#fff;border:none;padding:14px;border-radius:12px;font-weight:700;cursor:pointer;font-size:.9rem;width:100%;margin-top:14px;transition:opacity .2s;}
.btn-arely:active{opacity:.85;}

/* Category selection */
.sel-arely{background:var(--arely)!important;color:#fff!important;border-color:var(--arely)!important;}

/* Toggle buttons */
.arely-toggle{background:var(--arely-bg);color:var(--arely);border:1.5px solid var(--arely-lighter);border-radius:14px;padding:5px 12px;font-size:.78rem;font-weight:700;cursor:pointer;}
.arely-toggle:active{background:var(--arely);color:#fff;}

/* Table header */
thead.arely th{background:var(--arely-bg);color:var(--arely-dark);}

/* Badge */
.b-arely-cat{background:var(--arely-bg);color:var(--arely-dark);font-size:.72rem;padding:3px 8px;border-radius:10px;white-space:nowrap;}

/* Nav active state */
.a-active{color:var(--arely)!important;}
.a-active .nav-icon{transform:scale(1.2);}
#arelyBottomNav .nav-btn.a-active::after{content:'';position:absolute;bottom:2px;width:22px;height:3px;background:var(--arely);border-radius:3px;}
#arelyBottomNav .nav-btn{position:relative;}

/* ── Category Breakdown Rows ── */
.arely-cat-row,.arely-budget-cat-row{display:flex;align-items:center;gap:10px;padding:10px 4px;border-bottom:1px solid #f5f0f3;}
.arely-cat-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.arely-cat-info{flex:1;min-width:0;}
.arely-cat-name{font-size:.82rem;font-weight:600;margin-bottom:4px;}
.arely-cat-bar-wrap{background:#f0e8ed;border-radius:6px;height:7px;overflow:hidden;}
.arely-cat-bar{height:100%;border-radius:6px;transition:width .4s ease;}
.arely-cat-amt{text-align:right;min-width:70px;}
.arely-cat-amt{font-size:.85rem;font-weight:700;color:var(--arely-dark);}
.arely-cat-pct{display:block;font-size:.68rem;color:var(--muted);font-weight:400;}

/* ── Budget Summary ── */
.arely-budget-summary{display:flex;justify-content:space-around;padding:14px 8px;background:var(--arely-bg);border-radius:12px;margin-top:14px;font-size:.82rem;}

/* ── Calendar ── */
.arely-cal-title{text-align:center;font-size:1.1rem;font-weight:800;color:var(--arely);margin-bottom:12px;}
.arely-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;text-align:center;}
.arely-cal-hdr{font-size:.68rem;font-weight:700;color:var(--muted);padding:4px 0;}
.arely-cal-day{padding:8px 2px;border-radius:8px;font-size:.82rem;font-weight:600;transition:all .2s;}
.arely-cal-day.empty{visibility:hidden;}
.cal-today-day{background:var(--arely);color:#fff;font-weight:800;box-shadow:0 2px 8px rgba(208,107,141,.4);}
.cal-past-day{color:#bbb;text-decoration:line-through;}
.cal-alert-day{background:#ffebee;color:#e53935;font-weight:700;border:1.5px solid #ef9a9a;}
.arely-cal-legend{display:flex;gap:16px;justify-content:center;margin-top:14px;padding:8px 0;}
.cal-leg-item{display:flex;align-items:center;gap:5px;font-size:.72rem;color:var(--muted);}
.cal-leg-dot{width:10px;height:10px;border-radius:50%;display:inline-block;}
.cal-leg-dot.cal-today{background:var(--arely);}
.cal-leg-dot.cal-past{background:#bbb;}
.cal-leg-dot.cal-alert{background:#e53935;}

/* Calendar Budget Status */
.arely-cal-status{padding:14px 16px;background:var(--arely-white);border-radius:12px;}
.arely-cal-status-pct{font-size:1.8rem;font-weight:900;margin-bottom:4px;}
.arely-cal-status-text{font-size:.88rem;font-weight:600;margin-bottom:6px;}
.arely-cal-status-detail{font-size:.78rem;color:var(--muted);}

/* ── Checklist / Todos ── */
.arely-fab{background:var(--arely)!important;color:#fff!important;}
.arely-todo-progress{background:var(--arely-white);border-radius:14px;padding:14px 16px;margin:10px 14px;box-shadow:var(--shadow);}
.arely-todo-prog-text{display:flex;justify-content:space-between;font-size:.8rem;font-weight:600;color:var(--text);margin-bottom:8px;}
.arely-todo-prog-bar-wrap{background:#f0e8ed;border-radius:8px;height:10px;overflow:hidden;}
.arely-todo-prog-bar{height:100%;border-radius:8px;background:linear-gradient(90deg,var(--arely-lighter),var(--arely));transition:width .4s ease;}
.arely-todo-prog-pct{text-align:center;font-size:.72rem;font-weight:700;color:var(--arely);margin-top:6px;}
.arely-todo-section-lbl{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:8px 18px 4px;}
.arely-todo-item{display:flex;align-items:center;gap:10px;padding:10px 14px;margin:4px 14px;background:#fff;border-radius:12px;box-shadow:0 1px 6px rgba(0,0,0,.05);transition:opacity .3s;}
.arely-todo-item.todo-done{opacity:.55;}
.arely-todo-check{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:2px;flex-shrink:0;}
.arely-todo-body{display:flex;align-items:center;gap:6px;flex:1;min-width:0;flex-wrap:wrap;}
.arely-todo-cat-icon{font-size:.95rem;}
.arely-todo-title-text{font-size:.85rem;font-weight:500;}
.arely-todo-title-text.strike{text-decoration:line-through;color:#aaa;}
.arely-todo-due{font-size:.68rem;background:var(--arely-bg);color:var(--arely);padding:2px 8px;border-radius:8px;font-weight:600;}

/* Sam's Avatar */
.sam-avatar{border:2px solid var(--arely-lighter);box-shadow:0 1px 4px rgba(208,107,141,.25);object-fit:cover;}
.opt-btn .sam-avatar{margin-right:2px;}
.arely-upload{border:2.5px dashed var(--arely-lighter)!important;background:var(--arely-white)!important;transition:border-color .2s;}
.arely-upload:hover,.arely-upload.drag{border-color:var(--arely)!important;background:var(--arely-bg)!important;}
.arely-upload strong{color:var(--arely)!important;}

/* ── TRASH / DELETION HISTORY MODAL ─────────────────────── */
.trash-access-btn{background:rgba(255,255,255,.22);border:none;border-radius:10px;padding:7px 10px;font-size:1.1rem;cursor:pointer;color:#fff;transition:background .2s;}
.trash-access-btn:hover{background:rgba(255,255,255,.38);}
.trash-sheet{background:#fff;border-radius:22px;width:100%;max-width:480px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.25);}
.trash-hdr{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #f0f0f0;flex-shrink:0;}
.trash-hdr h3{margin:0;font-size:1rem;color:#333;}
.trash-item{background:#fff;border:1px solid #f0f0f0;border-radius:14px;padding:12px 14px;margin-bottom:8px;transition:opacity .3s;}
.trash-item-meta{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-bottom:6px;}
.trash-person-badge{font-size:.66rem;font-weight:700;padding:2px 8px;border-radius:20px;text-transform:uppercase;}
.trash-date-badge{font-size:.68rem;color:var(--muted);background:#f5f5f5;padding:2px 8px;border-radius:20px;}
.trash-deleted-when{font-size:.67rem;color:#bbb;margin-left:auto;}
.trash-item-main{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;}
.trash-item-desc{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;}
.trash-item-desc strong{font-size:.85rem;color:#333;word-break:break-word;}
.trash-item-desc span{font-size:.72rem;color:var(--muted);}
.trash-item-amt{font-size:.95rem;font-weight:700;white-space:nowrap;}
.trash-item-actions{display:flex;gap:6px;}
.trash-btn{border:none;border-radius:10px;padding:7px 14px;font-size:.76rem;font-weight:700;cursor:pointer;transition:opacity .2s;}
.trash-btn:hover{opacity:.85;}
.trash-restore{background:#e8f5e9;color:#2e7d32;}
.trash-perm{background:#ffebee;color:#c62828;}

/* ── MONTH PICKER ──────────────────────────────────────── */
.arely-month-picker-wrap{overflow-x:auto;padding:10px 14px 4px;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.arely-month-picker-wrap::-webkit-scrollbar{display:none;}
.arely-month-picker{display:flex;gap:7px;width:max-content;}
.arely-month-chip{border:2px solid var(--arely-lighter);background:var(--arely-white);color:var(--arely-dark);border-radius:20px;padding:6px 14px;font-size:.76rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .18s;}
.arely-month-chip:hover{border-color:var(--arely);background:var(--arely-bg);}
.arely-month-chip.active{background:var(--arely);color:#fff;border-color:var(--arely);box-shadow:0 3px 10px rgba(208,107,141,.35);}

/* ── MONTH SUMMARY CARD ────────────────────────────────── */
.arely-month-summary{padding:16px 18px;background:linear-gradient(135deg,var(--arely-white),var(--arely-bg));border:1.5px solid var(--arely-lighter);}

/* ── CATEGORY FILTER ───────────────────────────────────── */
.arely-cat-row{cursor:pointer;border-radius:12px;transition:background .15s,box-shadow .15s;padding:8px 6px;margin:2px 0;}
.arely-cat-row:hover{background:var(--arely-bg);}
.arely-cat-row-active{background:var(--arely-bg) !important;box-shadow:0 0 0 2px var(--arely-light);border-radius:12px;}
.arely-cat-count{font-size:.65rem;color:var(--muted);font-weight:400;margin-left:4px;}
.arely-cat-arrow{font-size:.7rem;color:var(--arely);margin-left:4px;}
.arely-filter-clear{background:var(--arely-bg);color:var(--arely);border:1.5px solid var(--arely-lighter);border-radius:20px;padding:4px 12px;font-size:.74rem;font-weight:700;cursor:pointer;transition:all .15s;}
.arely-filter-clear:hover{background:var(--arely);color:#fff;}

/* ── CATEGORY TRANSACTION PANEL ────────────────────────── */
.arely-cat-tx-panel{border:2px solid var(--arely-lighter);background:var(--arely-white);}
.arely-cat-tx-panel .chart-hdr{background:var(--arely-bg);}

/* ── TASK: REPEATING BUTTONS ────────────────────────────── */
.arely-repeat-opts{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px;}
.arely-repeat-btn{border:2px solid var(--arely-lighter);background:#fff;color:var(--arely-dark);border-radius:20px;padding:6px 14px;font-size:.76rem;font-weight:600;cursor:pointer;transition:all .18s;}
.arely-repeat-btn.sel-arely{background:var(--arely);color:#fff;border-color:var(--arely);}
.arely-repeat-badge{font-size:.64rem;background:#fce4ec;color:#c2185b;border-radius:10px;padding:2px 8px;font-weight:700;margin-left:4px;}
.arely-due-soon{font-size:.64rem;background:#fff3e0;color:#e65100;border-radius:10px;padding:2px 8px;font-weight:700;margin-left:4px;}
.arely-overdue{font-size:.64rem;background:#ffebee;color:#c62828;border-radius:10px;padding:2px 8px;font-weight:700;margin-left:4px;}

/* ── TASK: HISTORY SECTION ─────────────────────────────── */
.arely-history-toggle{width:calc(100% - 28px);margin:6px 14px;background:var(--arely-bg);color:var(--arely-dark);border:1.5px solid var(--arely-lighter);border-radius:12px;padding:10px 16px;text-align:left;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s;}
.arely-history-toggle:hover{background:var(--arely-lighter);}
.arely-undo-btn{background:none;border:none;font-size:1.1rem;cursor:pointer;padding:4px 6px;color:var(--muted);transition:color .15s;flex-shrink:0;}
.arely-undo-btn:hover{color:var(--arely);}

/* ══════════════════════════════════════════════════════════
   NEW 2026-04-23 — Income tracking, per-cat budgets,
   custom categories, PDF import
   ══════════════════════════════════════════════════════════ */

/* ── TOAST ─────────────────────────────────────────────── */
#arelyToast{
  position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(16px);
  background:#333;color:#fff;padding:10px 22px;border-radius:24px;
  font-size:.82rem;font-weight:600;white-space:nowrap;
  opacity:0;transition:opacity .25s,transform .25s;
  z-index:9999;pointer-events:none;box-shadow:0 4px 18px rgba(0,0,0,.25);
}
#arelyToast.arely-toast-show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ── PER-CATEGORY BUDGET ROWS ───────────────────────────── */
.arely-cat-budget-section{padding:4px 0 8px;}
.arely-cat-budget-row{
  display:flex;align-items:center;gap:10px;
  padding:8px 14px;border-bottom:1px solid #f5f0f3;
}
.arely-cat-budget-row:last-child{border-bottom:none;}
.arely-cb-icon{font-size:1.2rem;width:26px;text-align:center;flex-shrink:0;}
.arely-cb-label{flex:1;font-size:.82rem;font-weight:600;color:var(--text);min-width:0;}
.arely-cb-input{
  width:90px;padding:6px 10px;font-size:.82rem;font-weight:700;
  border:2px solid var(--arely-lighter);border-radius:10px;
  text-align:right;color:var(--arely-dark);background:#fff;
  outline:none;transition:border-color .15s;
}
.arely-cb-input:focus{border-color:var(--arely);}
.arely-cb-bar-wrap{
  width:70px;height:6px;background:#f0e8ed;border-radius:4px;
  overflow:hidden;flex-shrink:0;
}
.arely-cb-bar{height:100%;border-radius:4px;transition:width .4s ease;}
.arely-cb-pct{font-size:.68rem;color:var(--muted);width:34px;text-align:right;flex-shrink:0;}

/* Budget summary banner in budget view */
.arely-budget-summary-banner{
  background:linear-gradient(135deg,var(--arely),#e8819f);
  border-radius:18px;padding:16px 18px;margin:10px 14px 0;
  color:#fff;
}
.arely-budget-summary-banner .abs-label{font-size:.72rem;opacity:.85;font-weight:600;}
.arely-budget-summary-banner .abs-amount{font-size:2rem;font-weight:800;margin:2px 0;}
.arely-budget-summary-banner .abs-row{display:flex;gap:14px;margin-top:8px;}
.arely-budget-summary-banner .abs-chip{
  flex:1;background:rgba(255,255,255,.2);
  border-radius:10px;padding:6px 10px;text-align:center;
}
.arely-budget-summary-banner .abs-chip-lbl{font-size:.68rem;opacity:.8;}
.arely-budget-summary-banner .abs-chip-val{font-size:.9rem;font-weight:700;}
.arely-budget-bar-total{
  height:8px;background:rgba(255,255,255,.3);
  border-radius:8px;overflow:hidden;margin-top:10px;
}
.arely-budget-bar-fill{height:100%;border-radius:8px;background:#fff;transition:width .5s ease;}

/* ── INCOME SUMMARY CARD (in Dashboard) ────────────────── */
.arely-income-card{
  background:linear-gradient(135deg,#e8f5e9,#f1f8e9);
  border:1.5px solid #a5d6a7;border-radius:18px;
  padding:14px 16px;margin:10px 14px 0;
}
.arely-income-card-hdr{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:10px;
}
.arely-income-card-hdr h4{
  margin:0;font-size:.88rem;font-weight:700;color:#2e7d32;
}
.arely-income-toggle-btn{
  background:#c8e6c9;color:#1b5e20;border:none;
  border-radius:14px;padding:4px 12px;font-size:.72rem;
  font-weight:700;cursor:pointer;transition:background .15s;
}
.arely-income-toggle-btn:hover{background:#a5d6a7;}
.arely-income-total{font-size:1.5rem;font-weight:800;color:#1b5e20;margin-bottom:8px;}
.arely-income-sources{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;}
.arely-income-source-chip{
  display:flex;align-items:center;gap:4px;
  background:#fff;border:1.5px solid #c8e6c9;
  border-radius:10px;padding:4px 10px;font-size:.74rem;font-weight:600;
}
.arely-income-source-chip .isc-lbl{color:#388e3c;}
.arely-income-source-chip .isc-val{color:#1b5e20;margin-left:2px;}
.arely-income-tx-list{margin-top:6px;}
.arely-income-tx-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:7px 4px;border-bottom:1px solid #e8f5e9;font-size:.78rem;
}
.arely-income-tx-row:last-child{border-bottom:none;}
.arely-income-tx-row .itx-date{color:var(--muted);font-size:.7rem;min-width:62px;}
.arely-income-tx-row .itx-desc{flex:1;padding:0 8px;color:var(--text);font-weight:500;}
.arely-income-tx-row .itx-src{
  font-size:.66rem;background:#c8e6c9;color:#1b5e20;
  border-radius:8px;padding:1px 6px;font-weight:700;margin-right:6px;
}
.arely-income-tx-row .itx-amt{font-weight:700;color:#1b5e20;}

/* ── INCOME VIEW ────────────────────────────────────────── */
.arely-income-view-hdr{
  padding:14px 18px 6px;
  font-size:1rem;font-weight:800;color:#2e7d32;
}
.arely-income-month-row{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;margin:0 0 2px;
  background:#fff;border:1px solid #e8f5e9;
  border-radius:12px;transition:background .15s;
}
.arely-income-month-row:hover{background:#f1f8e9;}
.arely-income-month-name{flex:1;font-size:.85rem;font-weight:700;color:var(--text);}
.arely-income-month-total{font-size:.9rem;font-weight:800;color:#1b5e20;}
.arely-income-month-ct{font-size:.72rem;color:var(--muted);margin-left:6px;}

/* Income detail table */
.arely-income-detail-table{width:100%;border-collapse:collapse;font-size:.78rem;}
.arely-income-detail-table th{
  background:#e8f5e9;color:#2e7d32;font-weight:700;
  padding:7px 10px;text-align:left;font-size:.72rem;
}
.arely-income-detail-table td{
  padding:7px 10px;border-bottom:1px solid #f1f8e9;
  color:var(--text);
}
.arely-income-detail-table tr:last-child td{border-bottom:none;}
.arely-income-detail-table .inc-amt{font-weight:700;color:#1b5e20;}

/* ── CUSTOM CATEGORY MODAL ──────────────────────────────── */
#arelyCatModal{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.5);z-index:4000;
  align-items:flex-end;justify-content:center;
}
#arelyCatModal.open{display:flex;}
.arely-cat-sheet{
  background:#fff;border-radius:22px 22px 0 0;
  width:100%;max-width:480px;padding:22px 20px 36px;
  box-shadow:0 -8px 40px rgba(0,0,0,.18);
  animation:slideUpSheet .25s ease;
}
@keyframes slideUpSheet{from{transform:translateY(100%)}to{transform:translateY(0)}}
.arely-cat-sheet h3{margin:0 0 16px;font-size:1rem;font-weight:800;color:var(--arely-dark);}
.arely-cat-sheet label{font-size:.78rem;font-weight:700;color:var(--muted);display:block;margin-bottom:4px;margin-top:12px;}
.arely-cat-sheet input[type=text]{
  width:100%;padding:12px 14px;font-size:.9rem;
  border:2px solid var(--arely-lighter);border-radius:12px;
  outline:none;box-sizing:border-box;transition:border-color .15s;
}
.arely-cat-sheet input[type=text]:focus{border-color:var(--arely);}
.arely-cat-sheet input[type=color]{
  width:52px;height:38px;border:none;background:none;cursor:pointer;
  vertical-align:middle;
}
.arely-cat-emoji-row{display:flex;flex-wrap:wrap;gap:6px;margin:6px 0;}
.arely-cat-emoji-btn{
  font-size:1.2rem;background:#f7f3f5;border:2px solid transparent;
  border-radius:10px;padding:5px 8px;cursor:pointer;transition:all .15s;
}
.arely-cat-emoji-btn.sel{border-color:var(--arely);background:var(--arely-bg);}
.arely-cat-modal-btns{display:flex;gap:8px;margin-top:18px;}
.arely-cat-modal-btns .btn{flex:1;}

/* ── NEW CATEGORY BUTTON IN GRID ────────────────────────── */
.arely-new-cat-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:4px;padding:8px;border-radius:12px;cursor:pointer;
  border:2px dashed var(--arely-lighter);
  background:var(--arely-white);color:var(--arely);
  font-size:.74rem;font-weight:700;transition:all .15s;min-height:58px;
}
.arely-new-cat-btn:hover{border-color:var(--arely);background:var(--arely-bg);}
.arely-new-cat-plus{font-size:1.4rem;line-height:1;}

/* ── ARELY TOGGLE BTN ───────────────────────────────────── */
.arely-toggle{background:var(--arely-bg);color:var(--arely);border:1.5px solid var(--arely-lighter);}
.arely-toggle:hover{background:var(--arely);color:#fff;}

/* ── NEW CATEGORY QUICK-ACCESS BUTTONS ─────────────────── */
.arely-newcat-btn{
  background:var(--arely);color:#fff;border:none;
  border-radius:20px;padding:6px 14px;font-size:.76rem;
  font-weight:700;cursor:pointer;white-space:nowrap;
  transition:opacity .15s;
}
.arely-newcat-btn:hover{opacity:.85;}
.arely-inline-newcat{
  background:none;border:none;color:var(--arely);
  font-size:.76rem;font-weight:700;cursor:pointer;
  text-decoration:underline;padding:0;
}
.arely-inline-newcat:hover{opacity:.7;}

/* ── EXPANDABLE TRANSACTION DESCRIPTIONS ────────────────── */
.arely-desc-cell{
  cursor:pointer;
  max-width:130px;
  vertical-align:middle;
}
.arely-desc-cell.small{
  max-width:110px;
  padding:6px 4px;
}
.arely-desc-short{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-size:.8rem;
  color:var(--text);
}
.arely-desc-full{
  display:none;
  font-size:.78rem;
  color:#555;
  white-space:normal;
  word-break:break-word;
  line-height:1.4;
  padding-top:2px;
}
/* When expanded: hide truncated, show full */
.arely-desc-cell.expanded .arely-desc-short{ display:none; }
.arely-desc-cell.expanded .arely-desc-full{ display:block; }
/* Tap hint underline on hover */
.arely-desc-cell:not(.expanded):hover .arely-desc-short{
  text-decoration:underline dotted var(--arely);
}

/* ── PARENT CATEGORY CHIPS (Dashboard) ─────────────────── */
.arely-parent-chips-wrap{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.arely-parent-chip{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:14px;
  border:1.5px solid #eee;
  background:#fafafa;
  cursor:pointer;
  transition:transform .12s, box-shadow .12s;
  min-width:90px;
}
.arely-parent-chip:hover{
  transform:translateY(-1px);
  box-shadow:0 3px 10px rgba(0,0,0,.08);
}
.arely-parent-chip.active-chip{
  border-width:2px;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
  transform:translateY(-1px);
}

/* ── CATEGORY GRID GROUP LABELS ─────────────────────────── */
.arely-catgrid-group-label{
  grid-column:1/-1;
  font-size:.68rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
  padding:10px 4px 4px;
  margin-top:4px;
  border-top:1px solid #f0e8ed;
}
.arely-catgrid-group-label:first-child{
  border-top:none;
  margin-top:0;
  padding-top:4px;
}

/* ── PARENT GROUP ACCORDION (Budget view) ───────────────── */
.arely-parent-group{
  border:1.5px solid #f0ecf4;
  border-radius:14px;
  margin-bottom:10px;
  overflow:hidden;
  background:#fff;
}
.arely-parent-group-hdr{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  cursor:pointer;
  list-style:none;
  user-select:none;
  background:#faf8fc;
}
.arely-parent-group-hdr::-webkit-details-marker{ display:none; }
.arely-parent-group-icon{
  width:34px;
  height:34px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.1rem;
  flex-shrink:0;
}
.arely-parent-group-name{
  font-size:.88rem;
  font-weight:700;
  color:var(--arely-dark);
  flex:1;
}
.arely-parent-group-meta{
  display:flex;
  align-items:baseline;
  gap:2px;
  font-size:.82rem;
}
.arely-parent-bar-wrap{
  width:50px;
  height:4px;
  background:#eee;
  border-radius:4px;
  overflow:hidden;
  flex-shrink:0;
}
.arely-parent-bar{
  height:100%;
  border-radius:4px;
  transition:width .3s;
}
.arely-parent-chevron{
  font-size:.8rem;
  color:var(--muted);
  transition:transform .2s;
  flex-shrink:0;
}
details.arely-parent-group[open] .arely-parent-chevron{
  transform:rotate(180deg);
}
.arely-parent-body{
  border-top:1px solid #f0ecf4;
}
.arely-parent-body .arely-cat-budget-row{
  border-radius:0;
  border-bottom:1px solid #faf7fc;
  padding-left:18px;
}
.arely-parent-body .arely-cat-budget-row:last-child{
  border-bottom:none;
}
