/* Voice Money Manager — Desktop Web Client design system
   Brand tokens mirror the mobile app (teal #0F9D8A) + landing (navy #050E1D). */
:root{
  --navy:#050E1D; --navy-2:#0A1830; --navy-3:#0F2244;
  --teal:#0F9D8A; --teal-2:#0B8A79; --teal-3:#1FB58F; --teal-soft:#E6F6F2;
  --amber:#D4A017; --amber-soft:#F5C94B;
  --ink:#0B1220; --muted:#5B6577; --muted-2:#8A9BB4;
  --bg:#EEF2F8; --surface:#FFFFFF; --surface-2:#F6F8FC; --border:#D9E1EE; --border-2:#E8EDF5;
  --hover:#E2EAF5;
  --income:#0D7A3E; --expense:#C41F1F; --transfer:#6428C8;
  --shadow-sm:0 1px 2px rgba(11,18,32,.06),0 1px 3px rgba(11,18,32,.05);
  --shadow:0 4px 16px rgba(11,18,32,.08);
  --shadow-lg:0 18px 48px rgba(11,18,32,.16);
  --r-sm:8px; --r:12px; --r-lg:16px; --r-xl:22px;
  --sb-w:248px; --topbar-h:64px;
  --font:'Inter','Instrument Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.5}
a{color:var(--teal-2);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
img{max-width:100%;display:block}
.hidden{display:none!important}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;
  border-radius:var(--r);padding:11px 18px;font:inherit;font-weight:600;font-size:14px;cursor:pointer;
  transition:.15s ease;white-space:nowrap;line-height:1}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover:not(:disabled){background:var(--teal-3)}
.btn-dark{background:var(--navy-2);color:#fff}
.btn-dark:hover:not(:disabled){background:var(--navy-3)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--border)}
.btn-ghost:hover:not(:disabled){background:var(--hover)}
.btn-danger{background:#fff;color:var(--expense);border-color:#f0c8c8}
.btn-danger:hover:not(:disabled){background:#fdf2f2}
.btn-block{width:100%}
.btn-sm{padding:7px 12px;font-size:13px}
.btn-lg{padding:14px 22px;font-size:15px}

/* ---------- Forms ---------- */
.field{margin-bottom:16px}
.label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:7px}
.input,select.input,textarea.input{width:100%;border:1px solid var(--border);background:var(--surface);
  border-radius:var(--r);padding:12px 14px;font:inherit;font-size:14px;color:var(--ink);transition:.15s}
.input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(15,157,138,.14)}
.input::placeholder{color:var(--muted-2)}
textarea.input{resize:vertical;min-height:84px}
.input-row{display:flex;gap:12px}
.input-row>*{flex:1}
.hint{font-size:12px;color:var(--muted);margin-top:6px}
.error-text{color:var(--expense);font-size:13px;margin-top:6px}
.checkrow{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--muted)}
.checkrow input{margin-top:2px}

/* ---------- Auth split-screen ---------- */
.auth-body{height:100vh;overflow:hidden}
.auth-split{display:grid;grid-template-columns:minmax(420px,1fr) 1.15fr;height:100vh}
.auth-pane{height:100vh;overflow-y:auto}
.auth-form-pane{display:flex;align-items:center;justify-content:center;background:var(--surface);padding:40px}
.auth-form-wrap{width:100%;max-width:380px}
.auth-logo{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:700;color:var(--ink);margin-bottom:32px}
.auth-logo b{color:var(--teal-2)}
.auth-title{font-size:26px;margin-bottom:6px}
.auth-sub{color:var(--muted);font-size:14px;margin-bottom:26px}
.auth-foot{margin-top:22px;font-size:14px;color:var(--muted);text-align:center}
.auth-alt{margin-top:8px;font-size:13px;text-align:center}
.auth-hero-pane{position:relative;background:var(--navy);overflow:hidden}
.auth-hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.auth-hero-overlay{position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(5,14,29,.78) 0%,rgba(11,138,121,.42) 55%,rgba(5,14,29,.86) 100%)}
.auth-hero-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:56px;color:#fff}
.auth-hero-badge{display:flex;align-items:center;gap:10px;margin-bottom:auto;font-weight:700;font-size:16px;color:#fff;opacity:.95}
.auth-hero-h1{font-size:46px;line-height:1.05;font-weight:800;color:#fff;letter-spacing:-.02em;max-width:9ch}
.auth-hero-p{margin-top:16px;font-size:16px;color:rgba(255,255,255,.82);max-width:42ch}
.auth-hero-dots{margin-top:28px;display:flex;gap:8px}
.auth-hero-dots i{width:28px;height:4px;border-radius:4px;background:rgba(255,255,255,.35)}
.auth-hero-dots i.on{background:var(--teal-3)}
@media(max-width:880px){
  .auth-split{grid-template-columns:1fr}
  .auth-hero-pane{display:none}
}

/* OTP code cells */
.otp{display:flex;gap:10px;justify-content:space-between}
.otp input{width:100%;aspect-ratio:1;text-align:center;font-size:22px;font-weight:700;
  border:1px solid var(--border);border-radius:var(--r);background:var(--surface-2)}
.otp input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(15,157,138,.14)}

/* ---------- App shell ---------- */
.app-body{min-height:100vh}
.sidebar{position:fixed;top:0;left:0;width:var(--sb-w);height:100vh;background:var(--navy);
  display:flex;flex-direction:column;padding:20px 14px;z-index:30}
.sidebar-brand{display:flex;align-items:center;gap:10px;padding:6px 10px 22px;color:#fff;font-weight:700;font-size:16px}
.sidebar-brand b{color:var(--teal-3)}
.nav{display:flex;flex-direction:column;gap:2px;flex:1}
.nav a{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--r);color:#AEBAD0;
  font-size:14px;font-weight:500;transition:.13s}
.nav a:hover{background:rgba(255,255,255,.06);color:#fff;text-decoration:none}
.nav a.active{background:var(--teal);color:#fff}
.nav a svg{width:19px;height:19px;flex:none}
.nav-sep{height:1px;background:rgba(255,255,255,.08);margin:10px 6px}
.sidebar-foot{border-top:1px solid rgba(255,255,255,.08);padding-top:12px}
.profile-chip{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--r);cursor:pointer;color:#fff}
.profile-chip:hover{background:rgba(255,255,255,.06)}
.profile-av{width:32px;height:32px;border-radius:50%;background:var(--teal);display:flex;align-items:center;
  justify-content:center;font-weight:700;font-size:13px;color:#fff;flex:none}
.profile-chip .nm{font-size:13px;font-weight:600;line-height:1.2}
.profile-chip .sub{font-size:11px;color:#8595B0}

.app-main{margin-left:var(--sb-w);min-height:100vh;display:flex;flex-direction:column}
.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:20}
.topbar h1{font-size:19px}
.topbar-actions{display:flex;align-items:center;gap:10px}
.app-content{padding:28px;max-width:none;width:100%}
@media(max-width:760px){
  .sidebar{transform:translateX(-100%);transition:.2s}
  .sidebar.open{transform:none}
  .app-main{margin-left:0}
}

/* ---------- Cards / layout ---------- */
.card{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.card-pad{padding:20px}
.card-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border-2)}
.card-head h3{font-size:15px}
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.row{display:flex;align-items:center;gap:12px}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}
.spread{flex:1}
.stack{display:flex;flex-direction:column;gap:14px}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head h2{font-size:23px}
.muted{color:var(--muted)}
.mb0{margin-bottom:0}

/* stat tiles */
.stat{padding:18px 20px}
.stat .lbl{font-size:12.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.stat .val{font-size:27px;font-weight:800;margin-top:6px;letter-spacing:-.02em}
.stat .val.pos{color:var(--income)} .stat .val.neg{color:var(--expense)}
.card.stat{transition:background .15s,box-shadow .15s,transform .15s}
.card.stat:hover{background:var(--hover);box-shadow:var(--shadow);transform:translateY(-1px)}
.acct-card{transition:background .15s,box-shadow .15s,transform .15s}
.acct-card:hover{background:var(--hover);box-shadow:var(--shadow);transform:translateY(-1px)}
.stat .delta{font-size:12.5px;margin-top:4px;color:var(--muted)}

/* ---------- Tables ---------- */
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);
  font-weight:600;padding:12px 16px;border-bottom:1px solid var(--border-2);background:var(--surface-2)}
.table td{padding:13px 16px;border-bottom:1px solid var(--border-2);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tbody tr:hover{background:var(--hover)}
.table .num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.amt-income{color:var(--income);font-weight:700}
.amt-expense{color:var(--expense);font-weight:700}
.amt-transfer{color:var(--transfer);font-weight:700}
.table-wrap{overflow-x:auto}

/* ---------- Badges / pills ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:600}
.badge-teal{background:var(--teal-soft);color:var(--teal-2)}
.badge-amber{background:#FBF1D6;color:#9A7406}
.badge-green{background:#E3F5EA;color:var(--income)}
.badge-red{background:#FBE6E6;color:var(--expense)}
.badge-gray{background:var(--surface-2);color:var(--muted);border:1px solid var(--border)}
.dot{width:10px;height:10px;border-radius:50%;flex:none;display:inline-block}
.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border:1px solid var(--border);
  border-radius:999px;font-size:13px;cursor:pointer;background:var(--surface)}
.chip.sel{background:var(--teal);color:#fff;border-color:var(--teal)}

/* segmented control */
.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:3px}
.seg button{border:none;background:transparent;padding:7px 14px;border-radius:9px;font:inherit;font-size:13px;
  font-weight:600;color:var(--muted);cursor:pointer}
.seg button.on{background:var(--teal);color:#fff;box-shadow:0 3px 10px rgba(15,157,138,.4);font-weight:700}

/* ---------- Modal ---------- */
.modal-back{position:fixed;inset:0;background:rgba(8,15,28,.5);backdrop-filter:blur(2px);z-index:50;
  display:flex;align-items:center;justify-content:center;padding:20px}
.modal{background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);width:100%;max-width:460px;
  max-height:90vh;overflow-y:auto}
.modal-lg{max-width:640px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--border-2)}
.modal-head h3{font-size:17px}
.modal-body{padding:22px}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:16px 22px;border-top:1px solid var(--border-2)}
.x-btn{border:none;background:transparent;font-size:22px;line-height:1;color:var(--muted);cursor:pointer}

/* ---------- Toast ---------- */
.toast-wrap{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:80;display:flex;flex-direction:column;align-items:center;gap:10px}
.toast{background:var(--navy-2);color:#fff;padding:13px 18px;border-radius:var(--r);box-shadow:var(--shadow-lg);
  font-size:14px;font-weight:500;min-width:220px;animation:slideup .2s ease}
.toast.ok{background:var(--teal-2)} .toast.err{background:var(--expense)}
@keyframes slideup{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- States ---------- */
.spinner{width:20px;height:20px;border:2.5px solid rgba(15,157,138,.25);border-top-color:var(--teal);
  border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
.spinner-lg{width:38px;height:38px;border-width:4px}
@keyframes spin{to{transform:rotate(360deg)}}
.loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--muted);gap:12px}
.empty{text-align:center;padding:56px 20px;color:var(--muted)}
.empty h3{font-size:17px;color:var(--ink);margin-bottom:8px}
.empty p{font-size:14px;max-width:42ch;margin:0 auto 18px}
.skel{background:linear-gradient(90deg,var(--surface-2) 25%,#eef1f7 37%,var(--surface-2) 63%);
  background-size:400% 100%;animation:shimmer 1.3s infinite;border-radius:6px;height:14px}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* progress bar */
.progress{height:8px;background:var(--surface-2);border-radius:999px;overflow:hidden}
.progress>i{display:block;height:100%;background:var(--teal);border-radius:999px;transition:width .3s}
.progress>i.over{background:var(--expense)}

/* misc utils */
.mt8{margin-top:8px}.mt16{margin-top:16px}.mt24{margin-top:24px}
.tr{text-align:right}.tc{text-align:center}
.fw600{font-weight:600}.fw700{font-weight:700}
.fs13{font-size:13px}.fs12{font-size:12px}
.gap8{gap:8px}.wrap{flex-wrap:wrap}
.tag{display:inline-block;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;
  padding:2px 8px;font-size:12px;color:var(--muted);margin:2px}
mark.hl{background:#FDE68A;color:inherit;padding:0 2px;border-radius:3px;font-weight:600}
.search-banner{background:#FEF6DC;border:1px solid #F0CE63;color:#7A5B05;border-radius:var(--r);
  padding:10px 16px;margin-bottom:14px;font-size:14px;display:flex;align-items:center;gap:8px}
.search-clear{margin-left:auto;background:transparent;border:1px solid #E2C566;color:#7A5B05;border-radius:8px;
  padding:4px 11px;font:inherit;font-size:13px;font-weight:600;cursor:pointer}
.search-clear:hover{background:#F8EDC6}

/* inline editable tags (transactions rows) — grey chips like the mobile app */
.tagx{display:inline-flex;align-items:center;gap:4px;background:#ECEEF1;border:1px solid #DDE1E6;color:#5B6470;
  border-radius:999px;padding:2px 4px 2px 10px;font-size:12px;font-weight:600;line-height:18px}
.tagx-x{width:16px;height:16px;border-radius:50%;border:0;background:#D7DBE0;color:#5B6470;font-size:13px;line-height:14px;
  cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0}
.tagx-x:hover{background:#C3C8CF;color:#1F2937}
.tagx-x:disabled{opacity:.5;cursor:default}
.tag-addbtn{display:inline-flex;align-items:center;background:transparent;border:1px dashed #C7CCD3;color:#8A919B;
  border-radius:999px;padding:2px 10px;font:inherit;font-size:12px;font-weight:600;line-height:18px;cursor:pointer}
.tag-addbtn:hover{border-color:#9AA1AB;color:#5B6470;background:#F4F5F7}
.tag-inp{width:110px;border:1px solid var(--border);border-radius:999px;padding:2px 10px;font:inherit;font-size:12px;
  line-height:18px;outline:none;color:#374151}
.tag-inp:focus{border-color:#0F9D8A;box-shadow:0 0 0 3px rgba(15,157,138,.12)}

/* clickable category badge */
.badge-click{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}
.badge-click:hover{transform:translateY(-1px);box-shadow:0 3px 10px rgba(15,23,42,.12)}

/* quick category picker modal */
.catpick-back{animation:catpick-fade .22s ease both}
@keyframes catpick-fade{from{opacity:0}to{opacity:1}}
.catpick{width:380px;max-width:92vw;animation:catpick-up .34s cubic-bezier(.18,1.15,.4,1) both}
@keyframes catpick-up{from{opacity:0;transform:translateY(22px) scale(.96)}to{opacity:1;transform:none}}
.catpick-body{max-height:420px;overflow:auto;padding:8px 10px 14px}
.catpick-item{display:flex;align-items:center;gap:11px;width:100%;border:0;background:transparent;border-radius:12px;
  padding:10px 13px;font:inherit;font-size:14px;font-weight:600;color:#1F2937;cursor:pointer;text-align:left;
  transition:background .15s ease,transform .12s ease}
.catpick-item:hover{background:#F2F6F5}
.catpick-item:active{transform:scale(.985)}
.catpick-item .dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
.catpick-item.child{padding-left:36px;font-weight:500;font-size:13.5px;color:#374151}
.catpick-item.on{background:rgba(15,157,138,.09);color:#0F9D8A}
.catpick-item .ck{margin-left:auto;color:#0F9D8A;font-weight:800}

/* premium centered toast */
.ptoast-wrap{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:400;pointer-events:none}
.ptoast{pointer-events:auto;background:#fff;border-radius:20px;overflow:hidden;text-align:center;
  min-width:270px;max-width:360px;padding:28px 36px 0;
  box-shadow:0 28px 70px rgba(15,23,42,.25),0 6px 18px rgba(15,23,42,.10);
  animation:ptoast-in .45s cubic-bezier(.18,1.3,.4,1) both}
@keyframes ptoast-in{from{opacity:0;transform:scale(.82) translateY(16px)}to{opacity:1;transform:none}}
.ptoast.out{animation:ptoast-out .24s ease both}
@keyframes ptoast-out{from{opacity:1;transform:none}to{opacity:0;transform:scale(.88) translateY(8px)}}
.ptoast-ic{width:54px;height:54px;margin:0 auto 13px;border-radius:50%;color:#fff;
  background:linear-gradient(135deg,#0F9D8A,#19C3A8);display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 20px rgba(15,157,138,.35);animation:ptoast-pop .55s cubic-bezier(.18,1.7,.45,1) .1s both}
@keyframes ptoast-pop{from{transform:scale(0)}to{transform:scale(1)}}
.ptoast-ic svg{width:26px;height:26px}
.ptoast-tt{font-weight:800;font-size:16px;color:#0F172A;letter-spacing:-.01em;padding-bottom:4px}
.ptoast-bar{height:4px;background:#EDF1F4;margin:16px -36px 0}
.ptoast-bar i{display:block;height:100%;background:linear-gradient(90deg,#0F9D8A,#19C3A8);
  animation:ptoast-drain 2.5s linear forwards}
@keyframes ptoast-drain{from{width:100%}to{width:0}}

/* premium toast v2: close X, Undo, error variant; .ptoast gains position context */
.ptoast{position:relative}
.ptoast-x{position:absolute;top:10px;right:12px;width:26px;height:26px;border:0;border-radius:50%;
  background:transparent;color:#9AA3AF;font-size:19px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease}
.ptoast-x:hover{background:#F1F3F5;color:#374151}
.ptoast-undo{margin-top:12px;border:1px solid rgba(15,157,138,.4);background:rgba(15,157,138,.06);color:#0F9D8A;
  border-radius:999px;padding:7px 26px;font:inherit;font-size:13px;font-weight:700;cursor:pointer;
  transition:background .15s ease,transform .12s ease}
.ptoast-undo:hover{background:rgba(15,157,138,.14)}
.ptoast-undo:active{transform:scale(.96)}
.ptoast-err .ptoast-ic{background:linear-gradient(135deg,#DC2626,#F05252);box-shadow:0 8px 20px rgba(220,38,38,.32)}
.ptoast-err .ptoast-bar i{background:linear-gradient(90deg,#DC2626,#F05252)}
.ptoast-err .ptoast-undo{border-color:rgba(220,38,38,.4);background:rgba(220,38,38,.06);color:#DC2626}

/* toast v3: bottom-center stack (up to 3), newest at the bottom */
.ptoast-wrap{flex-direction:column;align-items:center;justify-content:flex-end;gap:12px;padding-bottom:46px}

/* transactions rows: big vendor icon with the date stacked under it */
.row-icondate{display:flex;flex-direction:column;align-items:center;flex:0 0 auto;width:56px}
.row-when{display:flex;flex-direction:column;align-items:center;margin-top:5px;font-size:11px;line-height:1.3;
  font-weight:600;color:#A6ADB7;text-align:center}

/* transaction type badge — sits in front of the category */
.typb{display:inline-block;font-size:10.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;
  border-radius:6px;padding:2px 8px;line-height:16px}
.typb-expense{background:rgba(220,38,38,.07);color:#C2453B;border:1px solid rgba(220,38,38,.16)}
.typb-income{background:rgba(15,157,138,.09);color:#0F9D8A;border:1px solid rgba(15,157,138,.22)}
.typb-transfer{background:rgba(59,130,246,.09);color:#2F6FBF;border:1px solid rgba(59,130,246,.2)}

/* inline description editing — subtle dotted outline appears on row hover */
.desc-edit{display:inline-block;max-width:100%;outline:1.5px dashed transparent;outline-offset:3px;border-radius:6px;
  transition:outline-color .18s ease;cursor:text}
.table tbody tr:hover .desc-edit{outline-color:#CBD2D9}
.desc-edit:hover{outline-color:#9AA1AB !important}
.desc-inp{width:100%;max-width:420px;font:inherit;font-size:inherit;color:inherit;border:1.5px solid #0F9D8A;
  border-radius:8px;padding:3px 9px;outline:none;box-shadow:0 0 0 3px rgba(15,157,138,.12);background:#fff}

/* inline date editing — date under icon is clickable, native picker anchors to hidden input */
.row-when{position:relative;cursor:pointer;border-bottom:1px dashed transparent;transition:border-color .18s ease,color .18s ease}
.table tbody tr:hover .row-when{border-bottom-color:#CBD2D9}
.row-when:hover{color:#5B6470;border-bottom-color:#9AA1AB}
.row-when-input{position:absolute;inset:0;opacity:0;pointer-events:none;border:0;padding:0;width:100%;height:100%}

/* vendor icon click affordance */
.vend-click{display:inline-block;cursor:pointer;border-radius:12px;transition:transform .16s ease,box-shadow .16s ease}
.vend-click:hover{transform:scale(1.06);box-shadow:0 4px 14px rgba(15,23,42,.16)}

/* tag cluster — 10px breathing room after the type/category badges */
.tag-cluster{display:inline-flex;gap:4px;align-items:center;flex-wrap:wrap;margin-left:10px}

/* unified row hover: same darker tone as transaction rows + 1px lift, everywhere incl. modals */
.table tbody tr{transition:background .15s ease,transform .12s ease}
.table tbody tr:hover{transform:translateY(-1px)}
.catpick-item{transition:background .15s ease,transform .12s ease}
.catpick-item:hover{background:var(--hover);transform:translateY(-1px)}

/* tax badge under the amount — grey pill, mirrors mobile TransactionItem */
.taxb{display:inline-block;margin-top:4px;padding:2px 8px;border-radius:999px;border:1px solid var(--border);
  background:var(--surface-2);font-size:11px;font-weight:700;letter-spacing:.3px;color:var(--muted);
  font-variant-numeric:tabular-nums;white-space:nowrap}

/* dimmed currency letter prefix (CA / US) in amounts */
.cur-pfx{opacity:.5}

/* trash action — dimmed until hovered */
.trash-btn{opacity:.5;transition:opacity .15s ease}
.trash-btn:hover{opacity:1}

/* receipt viewer — near-fullscreen, wheel zoom + drag pan, floating zoom bar */
.rcpt-modal{width:min(1500px,96vw);height:92vh;background:#fff;border-radius:18px;display:flex;flex-direction:column;
  overflow:hidden;box-shadow:0 28px 70px rgba(15,23,42,.3)}
.rcpt-stage{flex:1;position:relative;overflow:hidden;background:#171D27;display:flex;align-items:center;justify-content:center;cursor:grab}
.rcpt-stage.drag{cursor:grabbing}
.rcpt-stage img{max-width:100%;max-height:100%;user-select:none;transition:transform .16s ease;will-change:transform}
.rcpt-zoombar{position:absolute;top:14px;left:50%;transform:translateX(-50%);z-index:6;display:flex;gap:10px;align-items:center;
  background:rgba(15,23,42,.78);backdrop-filter:blur(8px);color:#fff;border-radius:999px;padding:8px 16px;
  box-shadow:0 10px 28px rgba(0,0,0,.3)}
.rcpt-zoombar button{border:0;background:rgba(255,255,255,.14);color:#fff;width:26px;height:26px;border-radius:50%;
  font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.rcpt-zoombar button:hover{background:rgba(255,255,255,.28)}
.rcpt-zoombar button.rcpt-reset{width:auto;border-radius:999px;padding:0 13px;font-size:12px;font-weight:700}
.rcpt-zoombar input[type=range]{width:160px;accent-color:#19C3A8;cursor:pointer}
.rcpt-pct{font-size:12.5px;font-weight:700;min-width:42px;text-align:center;font-variant-numeric:tabular-nums}
.rcpt-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:6;width:42px;height:42px;border-radius:50%;border:0;
  background:rgba(15,23,42,.6);color:#fff;font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.rcpt-nav:hover{background:rgba(15,23,42,.85)}
.rcpt-nav.prev{left:16px}.rcpt-nav.next{right:16px}

/* toast position FINAL: dead-center of the screen (V+H), stacked if several */
.ptoast-wrap{flex-direction:column;align-items:center;justify-content:center;gap:12px;padding-bottom:0}

/* inline amount editing */
.amt-edit{display:inline-block;outline:1.5px dashed transparent;outline-offset:3px;border-radius:6px;cursor:text;transition:outline-color .18s ease}
.table tbody tr:hover .amt-edit{outline-color:#CBD2D9}
.amt-edit:hover{outline-color:#9AA1AB !important}
.amt-inp{width:120px;text-align:right;font:inherit;font-weight:700;border:1.5px solid #0F9D8A;border-radius:8px;
  padding:3px 9px;outline:none;box-shadow:0 0 0 3px rgba(15,157,138,.12);background:#fff}

/* tax badge interactions */
.taxb-click{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}
.taxb-click:hover{transform:translateY(-1px);box-shadow:0 3px 8px rgba(15,23,42,.12)}
.taxb-add{opacity:0;cursor:pointer;border-style:dashed;background:transparent;transition:opacity .18s ease}
.table tbody tr:hover .taxb-add{opacity:.75}
.taxb-add:hover{opacity:1 !important}

/* currency prefix dimmed further per operator */
.cur-pfx{opacity:.35}

/* clickable tag label + tag-view modal rows */
.tagx-lbl{cursor:pointer}
.tagx-lbl:hover{color:#1F2937;text-decoration:underline}
.tagview-row{display:flex;gap:12px;align-items:center;padding:9px 13px;border-radius:10px;
  transition:background .15s ease,transform .12s ease}
.tagview-row:hover{background:var(--hover);transform:translateY(-1px)}

/* type segment buttons (All/Expense/Income/Transfer) hover */
.seg button{transition:background .15s ease,color .15s ease,transform .12s ease}
.seg button:hover:not(.on){background:var(--hover);transform:translateY(-1px)}

/* vendor modal subtext — current vendor icon + "Change X to…" */
.vend-sub{display:flex;gap:9px;align-items:center;padding:12px 18px 0;font-size:13px;color:var(--muted)}
.vend-sub strong{color:#1F2937;font-weight:700}

/* voice search — mic beside search box */
.vmic{flex:0 0 auto;width:42px;height:42px;border-radius:12px;border:1px solid var(--border);background:#fff;
  color:#0F9D8A;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .15s ease,transform .12s ease,box-shadow .15s ease}
.vmic:hover{background:var(--hover);transform:translateY(-1px);box-shadow:0 3px 10px rgba(15,23,42,.10)}

/* voice modal */
.vs-body{display:flex;flex-direction:column;align-items:center;padding:22px 22px 24px;gap:10px}
.vmic-big{width:84px;height:84px;border-radius:50%;border:0;cursor:pointer;font-size:36px;color:#fff;
  background:linear-gradient(135deg,#0F9D8A,#19C3A8);display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 26px rgba(15,157,138,.35);transition:transform .15s ease}
.vmic-big:hover{transform:scale(1.05)}
.vmic-big.listening{animation:vmic-breathe 1.6s ease-in-out infinite}
@keyframes vmic-breathe{0%,100%{box-shadow:0 10px 26px rgba(15,157,138,.35),0 0 0 0 rgba(15,157,138,.35)}
  50%{box-shadow:0 10px 26px rgba(15,157,138,.45),0 0 0 18px rgba(15,157,138,0)}}
.vs-status{font-size:13.5px;font-weight:700;color:#5B6470;min-height:18px}
.vs-transcript{font-size:16.5px;font-weight:600;color:#0F172A;text-align:center;line-height:1.45;
  background:var(--surface-2);border:1px solid var(--border);border-radius:14px;padding:12px 16px;width:100%}
.vs-interim{color:#9AA3AF;font-weight:500}
.vs-hint{font-size:13px;color:#8A919B;text-align:center;line-height:1.7}
.vs-hint em{color:#5B6470;font-style:italic}
.vs-opt{display:flex;gap:10px;align-items:center;width:100%;text-align:left;border:1px solid var(--border);
  background:#fff;border-radius:12px;padding:11px 14px;font:inherit;font-size:14px;font-weight:600;color:#1F2937;
  cursor:pointer;margin-bottom:7px;transition:background .15s ease,transform .12s ease}
.vs-opt:hover{background:var(--hover);transform:translateY(-1px)}
.vs-opt ion-icon{color:#0F9D8A;font-size:17px;flex:0 0 auto}

/* custom tax inline input row */
.tax-custom{display:flex;gap:8px;align-items:center;padding:4px 14px 12px 40px}

/* import page — banky hero */
.imp-hero{text-align:center;padding:34px 28px 28px}
.imp-hero-title{font-size:26px;font-weight:800;letter-spacing:-.02em;color:#0F172A;margin:0 0 8px}
.imp-hero-sub{color:var(--muted);font-size:14.5px;line-height:1.6;max-width:640px;margin:0 auto 22px}
.imp-banks{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:12px}
.imp-bank{display:inline-flex;border-radius:14px;transition:transform .15s ease,box-shadow .15s ease}
.imp-bank:hover{transform:translateY(-2px) scale(1.06);box-shadow:0 6px 16px rgba(15,23,42,.14)}
.imp-banks-note{max-width:560px;margin:0 auto 24px}
.imp-formats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;text-align:left;
  max-width:760px;margin:0 auto 22px}
.imp-format{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--border);border-radius:14px;
  padding:14px 16px;background:var(--surface-2);transition:background .15s ease,transform .12s ease}
.imp-format:hover{background:var(--hover);transform:translateY(-1px)}
.imp-format-ic{flex:0 0 36px;width:36px;height:36px;border-radius:10px;background:rgba(15,157,138,.1);color:#0F9D8A;
  font-size:19px;display:flex;align-items:center;justify-content:center}
.imp-format-lbl{font-weight:800;font-size:14px;color:#0F172A}
.imp-how{max-width:560px;margin:0 auto;text-align:left;border-top:1px solid var(--border);padding-top:20px}
.imp-how-title{font-weight:800;font-size:14px;color:#0F172A;margin-bottom:8px}
.imp-how-steps{margin:0;padding-left:20px;color:var(--muted);font-size:14px;line-height:2}

/* clickable type badge */
.typb-click{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}
.typb-click:hover{transform:translateY(-1px);box-shadow:0 3px 8px rgba(15,23,42,.12)}

/* account cell — small bank logo + clickable switcher */
.acct-cell{display:flex;gap:9px;align-items:center;cursor:pointer;border-radius:9px;padding:5px 8px;margin:-5px -8px;
  transition:background .15s ease,transform .12s ease}
.acct-cell:hover{background:var(--hover);transform:translateY(-1px)}

/* amount text +2px */
.amt-edit{font-size:16px}


/* tag view modal — roomier columns */
.tagview-row{gap:24px;padding:10px 18px}

/* tag view modal — year/month/day filter row */
.tv-filters{display:flex;gap:10px;padding:12px 18px 2px}
.tv-filters .input{flex:1;padding:8px 11px;font-size:13.5px}

/* hover tooltip (data-tip) */
.tip{position:relative}
.tip:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);
  background:#0F172A;color:#fff;font-size:11.5px;font-weight:600;padding:5px 10px;border-radius:7px;white-space:nowrap;
  z-index:60;box-shadow:0 6px 16px rgba(0,0,0,.25);pointer-events:none}
.tip:hover::before{content:"";position:absolute;bottom:calc(100% + 3px);left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:#0F172A;z-index:60;pointer-events:none}

/* tooltip: render BELOW the element (top placement clipped inside modals) */
.tip:hover::after{bottom:auto;top:calc(100% + 8px)}
.tip:hover::before{bottom:auto;top:calc(100% + 3px);border-top-color:transparent;border-bottom-color:#0F172A}

/* restore-from-backup toggle on import upload step */
.restore-toggle{display:flex;gap:10px;align-items:flex-start;margin:14px 0 4px;padding:12px 14px;border:1px dashed var(--border);
  border-radius:12px;font-size:13.5px;color:var(--muted);cursor:pointer;transition:background .15s ease,border-color .15s ease}
.restore-toggle:hover{background:var(--hover)}
.restore-toggle:has(input:checked){border-color:#0F9D8A;background:rgba(15,157,138,.06)}
.restore-toggle input{margin-top:2px;accent-color:#0F9D8A;width:16px;height:16px;flex:0 0 auto}
.restore-toggle strong{color:#1F2937}

/* Export-as-PDF icon — green standout like Full View */
.x-btn.exp-pdf{background:#0F9D8A;color:#fff;border-radius:9px}
.x-btn.exp-pdf:hover{background:#0C8071;color:#fff}

/* inline edit inputs: explicit dark text — color:inherit was resolving to white in some rows */
.desc-inp,.amt-inp,.tag-inp{color:#0F172A !important;caret-color:#0F172A;background:#fff !important;-webkit-text-fill-color:#0F172A}

/* attach receipt — 3 square option cards */
.rcpt-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.rcpt-card{aspect-ratio:1.15/1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  border:1.5px dashed var(--border);border-radius:14px;background:var(--surface-2);cursor:pointer;font:inherit;
  padding:10px;text-align:center;transition:background .15s ease,border-color .15s ease,transform .12s ease}
.rcpt-card:hover{background:var(--hover);border-color:#0F9D8A;transform:translateY(-1px)}
.rcpt-card ion-icon{font-size:26px;color:#0F9D8A}
.rcpt-card span{font-size:13px;font-weight:700;color:#1F2937;line-height:1.3}
.rcpt-card small{font-size:11px;color:var(--muted)}
.rcpt-preview{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--border);border-radius:14px;padding:12px}
.rcpt-preview img{width:74px;height:74px;object-fit:cover;border-radius:10px;flex:0 0 auto}

/* OCR result rows */
.ocr-row{display:flex;gap:10px;align-items:center;padding:7px 4px;border-bottom:1px solid var(--border-2);cursor:pointer}
.ocr-row input{accent-color:#0F9D8A;width:16px;height:16px;flex:0 0 auto}
.ocr-row .olbl{font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);flex:0 0 86px}
.ocr-row .oval{font-size:13.5px;font-weight:600;color:#0F172A;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* SPLIT badge under the row icon (mobile parity) */
.splitb{display:inline-flex;align-items:center;gap:3px;margin-top:4px;font-size:9.5px;font-weight:800;letter-spacing:.05em;
  color:#16A34A;background:rgba(22,163,74,.1);border:1px solid rgba(22,163,74,.28);border-radius:6px;padding:1.5px 6px}
.splitb ion-icon{font-size:10px}

/* mic button: filled green + attention pulse */
.vmic{background:linear-gradient(135deg,#0F9D8A,#19C3A8);border-color:transparent;color:#fff;
  animation:vmic-pulse 2.4s ease-out infinite}
.vmic:hover{background:linear-gradient(135deg,#0C8071,#15A78F);color:#fff;transform:translateY(-1px) scale(1.05);
  box-shadow:0 6px 16px rgba(15,157,138,.35);animation:none}
@keyframes vmic-pulse{0%{box-shadow:0 0 0 0 rgba(15,157,138,.45)}70%{box-shadow:0 0 0 12px rgba(15,157,138,0)}100%{box-shadow:0 0 0 0 rgba(15,157,138,0)}}

/* add-transaction FAB: same pulse + stronger hover */
.fab{animation:vmic-pulse 2.4s ease-out infinite}
.fab:hover{animation:none;transform:translateY(-2px) scale(1.06);box-shadow:0 10px 26px rgba(15,157,138,.4)}

/* add/edit transaction modal: 80px wider; Note/Tags compact 2-row textareas */
.modal-lg{max-width:720px}
textarea.input.ta-sm{min-height:58px;height:58px}

/* "Last: …" quick-prefill links above Add-transaction fields */
.lbl-row{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.lastlink{background:none;border:0;padding:0;font:inherit;font-size:12px;font-weight:700;color:#0F9D8A;cursor:pointer;
  max-width:55%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lastlink:hover{text-decoration:underline;color:#0C8071}

/* Last: links — light grey (teal was too loud), teal only on hover */
.lastlink{color:#A6ADB7}
.lastlink:hover{color:#0F9D8A}

/* vendor recall bar */
.recall-bar{display:flex;gap:10px;align-items:center;border:1px dashed rgba(15,157,138,.45);background:rgba(15,157,138,.05);
  border-radius:12px;padding:9px 12px;margin:-6px 0 14px}

/* QR image centered in its modal */
.qr-img{display:block;margin:0 auto;border-radius:12px;width:220px;height:220px}

/* OCR preview v2 — premium, inline-editable */
.ocr-body{display:flex;gap:22px;padding:26px 30px 20px}
.ocr-left img{width:160px;max-height:300px;object-fit:cover;border-radius:16px;box-shadow:0 10px 26px rgba(15,23,42,.18)}
.ocr-fields{flex:1;min-width:0;display:flex;flex-direction:column}
.ocr-f{display:flex;gap:10px;align-items:center;padding:9px 0;border-bottom:1px solid var(--border-2)}
.ocr-f:last-child{border-bottom:0}
.ocr-l{flex:0 0 78px;font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.ocr-inp{flex:1;min-width:0;border:1.5px dashed transparent;background:transparent;border-radius:8px;padding:5px 9px;
  font:inherit;font-size:14px;font-weight:600;color:#0F172A;outline:none;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}
.ocr-inp:hover{border-color:#CBD2D9}
.ocr-inp:focus{border-color:#0F9D8A;background:#fff;box-shadow:0 0 0 3px rgba(15,157,138,.1)}
textarea.ocr-inp{resize:vertical;min-height:0}
.seg-sm button{padding:5px 13px;font-size:12px;text-transform:capitalize}

/* voice-mode FAB sits beside the + FAB */
.fab.fab-mic{right:96px;font-size:24px;display:flex;align-items:center;justify-content:center}

/* Voice Mode — sidebar premium badge button */
.vmode-btn{display:flex;align-items:center;gap:10px;width:100%;margin-top:10px;padding:10px 12px;border-radius:12px;
  border:1px solid rgba(25,195,168,.35);background:linear-gradient(135deg,rgba(15,157,138,.14),rgba(25,195,168,.05));
  color:#CFE8E3;font:inherit;font-size:13.5px;font-weight:700;cursor:pointer;text-align:left;
  transition:background .15s ease,transform .12s ease,border-color .15s ease}
.vmode-btn:hover{background:rgba(15,157,138,.22);transform:translateY(-1px)}
.vmode-ic{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#0F9D8A,#19C3A8);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:14px;flex:0 0 auto}
.vmode-badge{margin-left:auto;font-size:9px;font-weight:800;letter-spacing:.08em;
  background:linear-gradient(135deg,#F0CE63,#E2B53E);color:#4A3A05;border-radius:5px;padding:2px 6px}
.vmode-btn.on{border-color:#19C3A8;background:linear-gradient(135deg,rgba(15,157,138,.32),rgba(25,195,168,.16));color:#fff}
.vmode-btn.on .vmode-ic{animation:vmic-pulse 1.6s ease-out infinite}

/* import landing — two big choice cards */
.imp-choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:6px}
@media (max-width:860px){.imp-choice-grid{grid-template-columns:1fr}}
.imp-choice{background:var(--surface);border:1.5px solid var(--border);border-radius:20px;padding:38px 30px 30px;
  text-align:center;cursor:pointer;font:inherit;display:flex;flex-direction:column;align-items:center;gap:10px;
  transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.imp-choice:hover{transform:translateY(-3px);border-color:#0F9D8A;box-shadow:0 16px 40px rgba(15,23,42,.12)}
.imp-choice-ic{width:62px;height:62px;border-radius:18px;background:linear-gradient(135deg,rgba(15,157,138,.14),rgba(25,195,168,.07));
  color:#0F9D8A;font-size:28px;display:flex;align-items:center;justify-content:center}
.imp-choice h3{margin:4px 0 0;font-size:19px;font-weight:800;letter-spacing:-.01em;color:#0F172A}
.imp-choice p{margin:0;color:var(--muted);font-size:13.5px;line-height:1.6;max-width:360px}
.imp-banks-sm{margin:8px 0 4px;gap:9px}
.imp-go{margin-top:6px;display:inline-flex;align-items:center;background:linear-gradient(135deg,#0F9D8A,#19C3A8);color:#fff;
  border-radius:999px;padding:9px 26px;font-size:14px;font-weight:700;transition:transform .12s ease}
.imp-choice:hover .imp-go{transform:scale(1.04)}

/* Voice Mode intro — command chips */
.vmode-chips{display:flex;flex-wrap:wrap;gap:7px}
.vmode-chips span{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:4px 12px;
  font-size:12.5px;font-weight:600;color:#374151}

/* Voice Mode intro v2 — premium dark voice surface w/ floating command cloud */
.vm-intro{width:560px;max-width:94vw;background:linear-gradient(160deg,#0E1B2C 0%,#13243A 70%,#0F2433 100%);
  border-radius:24px;padding:26px 28px 26px;position:relative;color:#E6EEF6;overflow:hidden;
  box-shadow:0 32px 80px rgba(0,0,0,.5)}
.vm-intro::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 50% 34%,rgba(25,195,168,.22),transparent 55%)}
.vm-x{position:absolute;top:14px;right:16px;z-index:3;width:30px;height:30px;border:0;border-radius:50%;
  background:rgba(255,255,255,.08);color:#9FB0C3;font-size:18px;cursor:pointer;transition:background .15s}
.vm-x:hover{background:rgba(255,255,255,.18);color:#fff}
.vm-head{display:flex;align-items:center;gap:10px;position:relative;z-index:2}
.vm-title{font-size:20px;font-weight:800;letter-spacing:-.01em;color:#fff}
.vm-stage{position:relative;height:300px;margin:10px -6px 4px;z-index:2}
.vm-mic{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:84px;height:84px;border-radius:50%;
  background:linear-gradient(135deg,#0F9D8A,#19C3A8);color:#fff;font-size:36px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 14px rgba(25,195,168,.08),0 0 0 30px rgba(25,195,168,.04),0 14px 36px rgba(15,157,138,.5);
  animation:vm-breathe 2.6s ease-in-out infinite}
@keyframes vm-breathe{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.07)}}
.vm-chip{position:absolute;background:rgba(255,255,255,.07);border:1px solid rgba(25,195,168,.35);color:#CFE0EE;
  border-radius:999px;padding:7px 15px;font-size:13px;font-weight:600;white-space:nowrap;cursor:default;
  backdrop-filter:blur(6px);animation:vm-float 5.5s ease-in-out infinite;transition:background .2s ease,color .2s ease,transform .2s ease,border-color .2s ease}
.vm-chip:hover{background:linear-gradient(135deg,#0F9D8A,#19C3A8);border-color:transparent;color:#fff;
  transform:scale(1.1);box-shadow:0 8px 22px rgba(15,157,138,.45);animation-play-state:paused}
.vm-chip:nth-child(2){animation-delay:0s}.vm-chip:nth-child(3){animation-delay:-.8s}
.vm-chip:nth-child(4){animation-delay:-1.6s}.vm-chip:nth-child(5){animation-delay:-2.4s}
.vm-chip:nth-child(6){animation-delay:-3.2s}.vm-chip:nth-child(7){animation-delay:-4s}
.vm-chip:nth-child(8){animation-delay:-4.8s}.vm-chip:nth-child(9){animation-delay:-2s}
.vm-chip:nth-child(10){animation-delay:-1.2s}
@keyframes vm-float{0%,100%{margin-top:0;transform:rotate(-1.2deg)}50%{margin-top:-9px;transform:rotate(1.2deg)}}
.vm-sub{position:relative;z-index:2;font-size:14px;line-height:1.65;color:#C8D6E4;margin:10px 0 8px;text-align:center}
.vm-privacy{position:relative;z-index:2;display:flex;gap:8px;align-items:flex-start;font-size:12.5px;line-height:1.6;
  color:#8FA3B8;margin:0 0 16px;text-align:left}
.vm-privacy ion-icon{color:#19C3A8;font-size:16px;flex:0 0 auto;margin-top:2px}
.vm-actions{position:relative;z-index:2;display:flex;gap:12px;justify-content:center}
.vm-btn-ghost{border:1px solid rgba(255,255,255,.22);background:transparent;color:#C8D6E4;border-radius:999px;
  padding:13px 28px;font:inherit;font-size:14.5px;font-weight:700;cursor:pointer;transition:background .15s ease,transform .12s ease}
.vm-btn-ghost:hover{background:rgba(255,255,255,.1);transform:translateY(-1px)}
.vm-btn-go{display:inline-flex;align-items:center;gap:9px;border:0;border-radius:999px;padding:13px 34px;
  font:inherit;font-size:15px;font-weight:800;cursor:pointer;color:#fff;
  background:linear-gradient(135deg,#0F9D8A,#19C3A8);box-shadow:0 10px 28px rgba(15,157,138,.45);
  transition:transform .12s ease,box-shadow .15s ease}
.vm-btn-go:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 14px 36px rgba(15,157,138,.6)}

/* Voice Mode tryout — modal stays above, page blurs behind */
#vmode-intro{backdrop-filter:blur(8px);background:rgba(8,15,26,.55)}
.vm-try-big{font-size:16.5px;padding:16px 42px;animation:vmic-pulse 2.2s ease-out infinite}
.vm-try-big:hover{animation:none}
.vm-listenline{display:flex;align-items:center;gap:9px;color:#CFE0EE;font-size:14.5px;font-weight:600;padding:10px 0}
.vm-listenline em{color:#19C3A8;font-style:italic}
.vm-dot{width:11px;height:11px;border-radius:50%;background:#19C3A8;animation:vm-dotpulse 1.1s ease-in-out infinite}
@keyframes vm-dotpulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
.vm-success{font-size:15px;font-weight:700;color:#fff;text-align:center;line-height:1.6;max-width:380px}

/* 11th chip in the Voice Mode cloud */
.vm-chip:nth-child(11){animation-delay:-3.6s}

/* whole account card opens its transactions */
.acct-click{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}
.acct-click:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(15,23,42,.12);background:var(--hover)}

/* Voice Mode sidebar sub-buttons + exit celebration */
.vmode-sub{display:flex;gap:6px;margin-top:7px}
.vmode-sub button{flex:1;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.05);color:#AEBAD0;
  border-radius:9px;padding:6px 4px;font:inherit;font-size:11.5px;font-weight:700;cursor:pointer;transition:background .15s,color .15s}
.vmode-sub button:hover{background:rgba(15,157,138,.25);color:#fff}
.vmx-burst{font-size:44px;animation:vmx-pop .7s cubic-bezier(.18,1.6,.45,1) both}
@keyframes vmx-pop{from{transform:scale(0) rotate(-30deg)}to{transform:scale(1) rotate(0)}}
.vmx-stats{display:flex;gap:14px;justify-content:center}
.vmx-stat{flex:1;max-width:175px;background:rgba(255,255,255,.06);border:1px solid rgba(25,195,168,.3);border-radius:16px;padding:18px 10px}
.vmx-num{font-size:34px;font-weight:800;color:#19C3A8;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.vmx-lbl{font-size:11.5px;font-weight:700;color:#9FB0C3;margin-top:4px;text-transform:uppercase;letter-spacing:.05em}

/* Voice Mode intro v3 — uniform chip grid, static mic, footer privacy section */
.vm-cloud{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;position:relative;z-index:2;margin-bottom:4px}
.vm-cloud .vm-chip{position:static;animation:none}
.vm-mic-static{position:static !important;transform:none !important;animation:vm-breathe2 2.6s ease-in-out infinite !important}
@keyframes vm-breathe2{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
.vm-privacy-foot{margin:18px -28px 0;padding:14px 28px 0;border-top:1px solid rgba(255,255,255,.1)}
.vm-privacy-foot strong{color:#CFE0EE}

/* Voice Mode on: the search-bar mic is redundant — collapse it smoothly; restore on exit */
.vmic{overflow:hidden;transition:opacity .35s ease,transform .35s ease,width .35s ease,padding .35s ease,border-width .35s ease}
body.vmode-on .vmic{opacity:0;transform:scale(.4);width:0;padding:0;border-width:0;pointer-events:none;animation:none}

/* verb-prefix chips — first row of the command cloud */
.vm-cloud-verbs{margin-bottom:8px}
.vm-chip-verb{background:linear-gradient(135deg,rgba(15,157,138,.28),rgba(25,195,168,.14));border-color:rgba(25,195,168,.55);
  color:#fff;font-weight:800}

/* intro v4: fully centered content */
.vm-intro{text-align:center}
.vm-intro .vm-privacy{justify-content:center;text-align:left}

/* intro heading: force true centering of title + PRO badge */
.vm-intro .vm-head{display:flex;justify-content:center !important;align-items:center;gap:10px;width:100%}

/* browsers without Web Speech API: dim Voice Mode, hide the search mic */
body.no-sr .vmode-btn{opacity:.45;cursor:not-allowed;animation:none}
body.no-sr .vmic{display:none}
body.no-sr .fab{animation:none}

/* Last links: grey label + green value */
.lastlink{color:#A6ADB7}
.lastlink .ll-k{color:#A6ADB7;font-weight:700}
.lastlink .ll-v{color:#0F9D8A;font-weight:700}
.lastlink:hover .ll-v{text-decoration:underline;color:#0C8071}

/* attach-receipt cards 30% shorter; modal footer always visible */
.rcpt-card{aspect-ratio:1.65/1}
.modal .modal-foot{position:sticky;bottom:0;background:var(--surface);z-index:6;border-top:1px solid var(--border)}

/* add/edit modal: Vendor | Amount | Date 3-col row + predictive vendor dropdown */
.input-row-3{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:14px}
@media (max-width:720px){.input-row-3{grid-template-columns:1fr}}
.vend-sug{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:1px solid var(--border);
  border-radius:12px;box-shadow:0 14px 34px rgba(15,23,42,.16);z-index:40;max-height:240px;overflow-y:auto}
.vend-sug-it{display:flex;gap:9px;align-items:center;width:100%;border:0;background:#fff;padding:8px 12px;
  font:inherit;font-size:13.5px;font-weight:600;color:#1F2937;cursor:pointer;text-align:left;transition:background .12s}
.vend-sug-it:hover{background:var(--hover)}

/* row trash: real icon, larger, red on hover */
.trash-btn{display:inline-flex;align-items:center;justify-content:center}
.trash-btn ion-icon{font-size:18px;color:#6B7280}
.trash-btn:hover ion-icon{color:#DC2626}

/* voice history rows */
.vmh-row{display:flex;justify-content:space-between;gap:10px;align-items:baseline;padding:8px 10px;border-bottom:1px solid var(--border-2)}
.vmh-row:last-child{border-bottom:0}
.vmh-say{font-size:13.5px;font-weight:600;color:#1F2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vmh-ago{font-size:11.5px;color:var(--muted);flex:0 0 auto}

/* voice history v2: hour-block label left, command right (tag-modal row style) */
.vmh-row{justify-content:flex-start}
.vmh-blk{flex:0 0 92px;font-size:12px;font-weight:600;color:var(--muted)}
.vmh-say{flex:1}

/* "…most Actions on Pages — TRY IT!" teaser chip */
.vm-chip-more{background:transparent;border-style:dashed;border-color:rgba(240,206,99,.55);color:#F0CE63;font-weight:800}

/* inline two-account split in the Add modal */
.splitlink{background:none;border:0;padding:0;font:inherit;font-size:12px;font-weight:700;color:#0F9D8A;cursor:pointer}
.splitlink:hover{text-decoration:underline;color:#0C8071}
.split-inline{border:1.5px dashed rgba(15,157,138,.45);background:rgba(15,157,138,.04);border-radius:14px;
  padding:13px 14px;margin:-4px 0 16px}
.split-cols,.split-row{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:8px}
.split-cols{margin-bottom:5px;font-weight:700}
.split-row{margin-bottom:8px}
.split-row .input{padding:9px 11px}

/* voice history v3: action + verbatim left, hour block right, hover lift */
.vmh-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:9px 12px;border-radius:10px;
  border-bottom:1px solid var(--border-2);transition:background .15s ease,transform .12s ease}
.vmh-row:hover{background:var(--hover);transform:translateY(-1px)}
.vmh-main{display:flex;flex-direction:column;gap:1px;min-width:0}
.vmh-verb{font-size:12px;color:var(--muted);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vmh-blk{flex:0 0 auto;text-align:right}

/* voice-assist: gentle teal pulse on fields still needing a human choice (not an error) */
.voice-need{border-color:#0F9D8A !important;box-shadow:0 0 0 3px rgba(15,157,138,.16);
  animation:vneed 1.9s ease-in-out infinite}
@keyframes vneed{0%,100%{box-shadow:0 0 0 3px rgba(15,157,138,.16)}50%{box-shadow:0 0 0 7px rgba(15,157,138,.05)}}

/* clickable Commands-executed tile in the exit modal */
.vmx-stat-link{cursor:pointer;transition:transform .15s ease,border-color .15s ease,background .15s ease}
.vmx-stat-link:hover{transform:translateY(-2px);border-color:#19C3A8;background:rgba(25,195,168,.12)}

/* untaxed rows: always-visible "No Tax" badge that flips to "+ ADD TAX" on hover */
.taxb-add{opacity:1 !important;border-style:solid;background:var(--surface-2);color:var(--muted);cursor:pointer}
.taxb-add .nt-b{display:none;color:#0F9D8A;font-weight:800}
.taxb-add:hover{border-style:dashed;border-color:rgba(15,157,138,.55);background:rgba(15,157,138,.06)}
.taxb-add:hover .nt-a{display:none}
.taxb-add:hover .nt-b{display:inline}

/* dictation hint toast under the Add/Edit modal (Voice Mode only) */
.vm-hint{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);z-index:260;max-width:92vw;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;background:rgba(14,27,44,.94);color:#CFE0EE;border:1px solid rgba(25,195,168,.45);
  border-radius:999px;padding:10px 20px;font-size:12.5px;font-weight:600;backdrop-filter:blur(8px);
  box-shadow:0 12px 30px rgba(0,0,0,.4);pointer-events:none}
.vm-hint em{color:#19C3A8;font-style:italic}

/* dictation hint: full-width footer bar, taller, larger type */
.vm-hint{left:0;right:0;bottom:0;transform:none;max-width:none;border-radius:0;border:0;
  border-top:1px solid rgba(25,195,168,.45);padding:18px 26px;font-size:15.5px;text-align:center;white-space:normal}

/* hint footer entrance: bar drops in after the modal, then the text fades in separately */
.vm-hint{animation:vmh-bar .5s cubic-bezier(.2,.9,.3,1) .35s both}
@keyframes vmh-bar{from{transform:translateY(100%)}to{transform:translateY(0)}}
.vm-hint-txt{display:inline-block;animation:vmh-txt .45s ease .95s both}
@keyframes vmh-txt{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* selected vendor/account logo inside combobox inputs */
.vend-cur{position:absolute;left:10px;top:50%;transform:translateY(-50%);pointer-events:none;line-height:0;z-index:2}
.input.has-vlogo{padding-left:42px}

/* always-visible listening dot beside the + FAB */
.fab-voice-dot{position:fixed;right:96px;bottom:34px;width:44px;height:44px;border-radius:50%;border:0;cursor:pointer;
  background:linear-gradient(135deg,#0F9D8A,#19C3A8);color:#fff;font-size:20px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 22px rgba(15,157,138,.45);z-index:90;animation:vmic-pulse 2s ease-out infinite}
.fab-voice-dot:hover{animation:none;transform:scale(1.08)}

/* Secure Vault (web) */
.vault-center{max-width:560px;margin:6vh auto 0;text-align:center}
.vault-center h2{margin:6px 0 8px;font-size:22px;font-weight:800;color:#0F172A}
.vault-lock{width:72px;height:72px;border-radius:50%;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;
  font-size:34px;background:linear-gradient(135deg,#0F9D8A,#19C3A8);box-shadow:0 12px 30px rgba(15,157,138,.35)}
.vault-lock-ok{background:linear-gradient(135deg,#16A34A,#22c55e);box-shadow:0 12px 30px rgba(22,163,74,.35)}
.vault-qr{width:240px;height:240px;border-radius:16px;margin:8px auto 0;display:block;box-shadow:0 8px 22px rgba(15,23,42,.14)}
.vault-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.vault-folders{display:flex;gap:8px;flex-wrap:wrap}
.vfolder{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:#fff;border-radius:999px;
  padding:7px 14px;font:inherit;font-size:13px;font-weight:600;color:#374151;cursor:pointer;transition:background .15s,transform .12s}
.vfolder:hover{background:var(--hover);transform:translateY(-1px)}
.vfolder.on{background:rgba(15,157,138,.1);border-color:#0F9D8A;color:#0F9D8A}
.vfolder .vcount{background:var(--surface-2);border-radius:999px;padding:0 7px;font-size:11px;color:var(--muted)}
.vault-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.vault-item{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--border);border-radius:14px;
  padding:14px;cursor:pointer;transition:transform .12s,box-shadow .15s,border-color .15s}
.vault-item:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(15,23,42,.1);border-color:#0F9D8A}
.vi-ico{flex:0 0 40px;width:40px;height:40px;border-radius:10px;background:rgba(15,157,138,.1);color:#0F9D8A;
  display:flex;align-items:center;justify-content:center;font-size:20px}
.vi-name{font-weight:700;color:#0F172A;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vi-sub{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vi-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:5px}
.vtag{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:1px 8px;font-size:11px;color:var(--muted)}
.vi-go{flex:0 0 auto;color:var(--muted);font-size:18px;align-self:center}

/* Secure Vault — file-explorer layout */
.vault-unlock{display:flex;align-items:center;gap:14px;flex-wrap:wrap;background:rgba(15,157,138,.06);
  border:1px solid rgba(15,157,138,.3);border-radius:14px;padding:12px 16px;margin-bottom:16px}
.vu-text{display:flex;align-items:center;gap:8px;flex:1;min-width:220px;font-size:13.5px;color:#374151}
.vu-text ion-icon{color:#0F9D8A;font-size:18px;flex:0 0 auto}
.vu-form{display:flex;gap:8px}
.vu-form .input{width:200px}
.vexp{display:grid;grid-template-columns:278px 1fr;gap:16px;align-items:start}
.vexp-rail{display:flex;flex-direction:column;gap:3px;position:sticky;top:14px;align-self:start;max-height:calc(100vh - 28px);overflow-y:auto;
  background:#fff;border:1px solid var(--border);border-radius:14px;padding:8px}
.vexp-fold{display:flex;align-items:center;gap:9px;width:100%;border:0;background:transparent;border-radius:10px;
  padding:9px 11px;font:inherit;font-size:13.5px;font-weight:600;color:#374151;cursor:pointer;text-align:left;
  transition:background .12s}
.vexp-fold:hover{background:var(--hover)}
.vexp-fold.on{background:rgba(15,157,138,.1);color:#0F9D8A}
.vexp-fold ion-icon{flex:0 0 auto;font-size:17px}
.vexp-fname{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vexp-fold .vcount{flex:0 0 auto;background:var(--surface-2);border-radius:999px;padding:0 8px;font-size:11px;color:var(--muted)}
.vexp-main{min-width:0}
.vexp-head{display:flex;align-items:center;justify-content:space-between;gap:10px;position:sticky;top:0;z-index:30;background:var(--bg);padding:10px 0;margin-bottom:6px;box-shadow:0 6px 10px -8px rgba(0,0,0,.12)}
.vexp-head h3{margin:0;font-size:16px;font-weight:800;color:#0F172A}
.vexp-list{display:flex;flex-direction:column;gap:8px}
.vrow{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid var(--border);border-radius:12px;
  padding:12px 14px;cursor:pointer;transition:transform .1s,box-shadow .14s,border-color .14s}
.vrow:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(15,23,42,.08);border-color:#0F9D8A}
@media (max-width:820px){ .vexp{grid-template-columns:1fr} .vexp-rail{flex-direction:row;overflow-x:auto;max-height:none} .vexp-fold{flex:0 0 auto} .vexp-fname{max-width:120px} }
.vexp-actions{display:flex;gap:6px;align-items:center}
.vrow-del{flex:0 0 auto;border:0;background:transparent;cursor:pointer;padding:4px;border-radius:8px;opacity:0;transition:opacity .12s,background .12s}
.vrow:hover .vrow-del{opacity:.6}
.vrow-del:hover{opacity:1 !important;background:rgba(220,38,38,.08)}
.vrow-del ion-icon{font-size:17px;color:#6B7280}
.vrow-del:hover ion-icon{color:#DC2626}
.vi-thumb{width:100px;height:100px;flex:0 0 100px;object-fit:cover;border-radius:12px;background:#EEF2F7;border:1px solid rgba(0,0,0,.06)}
.vrow{align-items:center}
.vexp-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.vexp-list .vrow{width:auto}
.vexp-list .muted{grid-column:1 / -1}
.vpager{display:flex;align-items:center;justify-content:center;gap:14px;padding:16px 0 4px}
.vpager-info{font-size:13px;color:#6B7280;font-weight:600}
@media(max-width:680px){.vexp-list{grid-template-columns:1fr}}
.vexp-list{align-items:start}
.vcard{background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:16px;padding:14px;display:flex;flex-direction:column;gap:10px}
.vcard-top{display:flex;align-items:flex-start;gap:10px}
.vcard-tico{flex:0 0 auto;width:38px;height:38px;border-radius:10px;background:#EEF2F7;display:flex;align-items:center;justify-content:center}
.vcard-tico ion-icon{font-size:21px;color:#0F9D8A}
.vcard-id{min-width:0;flex:1}
.vcard .vi-name{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vcard-meta{font-size:12.5px;color:#6B7280;margin-top:2px}
.vcard-img{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;background:#F1F4F8}
.vcard-img img{display:block;width:100%;height:280px;object-fit:cover}
.vcard-expand{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px}
.vcard-del{position:absolute;bottom:10px;right:10px;width:36px;height:36px;border-radius:50%;border:0;background:#EF4444;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px rgba(239,68,68,.45);opacity:0;transition:opacity .12s}
.vcard-img:hover .vcard-del{opacity:1}
.vcard-del ion-icon{font-size:21px}
.vcard-del:hover{background:#DC2626}
.vcard-filewrap{display:flex;align-items:center;gap:8px}
.vcard-file{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;border:1px dashed rgba(0,0,0,.15);background:#F8FAFC;border-radius:12px;padding:14px;cursor:pointer;font:inherit;font-weight:600;color:#374151}
.vcard-file ion-icon{font-size:20px;color:#0F9D8A}
.vcard-ai-h{font-size:11px;font-weight:800;letter-spacing:.04em;color:#0F9D8A;display:flex;align-items:center;gap:5px}
.vcard-ai-t{font-size:13.5px;color:#374151;line-height:1.55;margin:6px 0 0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.vcard-ai-t.open{-webkit-line-clamp:unset;overflow:visible}
.vcard-more{border:0;background:none;color:#0F9D8A;font-weight:700;font-size:12.5px;cursor:pointer;padding:4px 0 0}
.vlightbox{position:fixed;inset:0;z-index:1000;background:rgba(8,15,26,.93);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}
.vlb-close{position:absolute;top:16px;right:20px;width:44px;height:44px;border:0;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:30px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.vlb-close:hover{background:rgba(255,255,255,.22)}
.vlb-title{position:absolute;top:22px;left:24px;right:80px;color:#fff;font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vlb-stage{flex:1;width:100%;display:flex;align-items:center;justify-content:center;min-height:0}
.vlb-img{max-width:95vw;max-height:88vh;object-fit:contain;border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.5)}

.vi-edit{outline:none;border:1px dashed transparent;border-radius:6px;padding:1px 5px;margin:-1px -5px;cursor:text;transition:border-color .12s,background .12s}
.vi-edit:hover{border-color:rgba(15,157,138,.45)}
.vi-edit:focus{border-color:#0F9D8A;border-style:dashed;background:rgba(15,157,138,.06);white-space:normal;overflow:visible;text-overflow:clip}
.vi-tags{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.vcard-foot{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin-top:2px}
.vtag.editing{display:inline-flex;align-items:center;gap:2px;padding-left:6px;background:#EEF6F4;border:1px solid rgba(15,157,138,.3)}
.vtag-x{border:0;background:none;color:#9CA3AF;cursor:pointer;font-size:15px;line-height:1;padding:0 2px;font-weight:700}
.vtag-x:hover{color:#EF4444}
.vtag-input{border:1px dashed rgba(15,157,138,.55);border-radius:999px;padding:4px 12px;font:inherit;font-size:12px;outline:none;min-width:130px;flex:0 1 auto}
.vtag-input:focus{border-color:#0F9D8A;background:rgba(15,157,138,.05)}
.up-eyebrow{font-size:10px;font-weight:800;letter-spacing:.12em;color:#D97706;margin-bottom:2px}
.up-pick{display:flex;align-items:center;gap:10px;width:100%;border:1px solid rgba(15,157,138,.4);background:#F4FBF9;border-radius:14px;padding:14px;cursor:pointer;font:inherit;font-weight:600;color:#0F9D8A}
.up-pick:disabled{opacity:.5;cursor:not-allowed}
.up-pick ion-icon{font-size:22px}
.up-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:14px}
.up-thumb{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;background:#EEF2F7;border:1px solid rgba(0,0,0,.06)}
.up-thumb img{width:100%;height:100%;object-fit:cover}
.up-x{position:absolute;top:2px;right:2px;border:0;background:none;color:#fff;cursor:pointer;font-size:22px;line-height:0;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}
.up-badge{position:absolute;bottom:4px;left:4px;background:rgba(0,0,0,.65);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:6px}
.up-overlay{flex-direction:column;gap:0}
.up-shield{width:92px;height:92px;border-radius:50%;background:#0F9D8A;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(15,157,138,.5);animation:upPulse 2.4s ease-in-out infinite;margin-bottom:30px}
.up-shield ion-icon{font-size:44px;color:#fff}
.up-shield.done{animation:none}
@keyframes upPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
.up-otitle{color:#fff;font-size:25px;font-weight:800;letter-spacing:-.4px;margin-bottom:6px}
.up-osub{color:#9FB0C3;font-size:15px;margin-bottom:24px}
.up-track{width:240px;max-width:70vw;height:3px;border-radius:2px;background:rgba(15,157,138,.2);overflow:hidden}
.up-fill{height:100%;background:#19C3A8;width:100%;border-radius:2px;transition:width .3s}
.up-fill.run{width:40%;animation:upIndet 1.4s ease-in-out infinite}
@keyframes upIndet{0%{margin-left:-40%}100%{margin-left:100%}}
.up-ofoot{position:absolute;bottom:36px;left:0;right:0;text-align:center;color:#5B6B80;font-size:10.5px;letter-spacing:.06em}
.vexp-head{flex-wrap:wrap;gap:10px}
.vsearch{flex:1 1 200px;min-width:160px;max-width:360px;display:flex;align-items:center;gap:8px;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:12px;padding:8px 12px;transition:border-color .12s,box-shadow .12s}
.vsearch:focus-within{border-color:#0F9D8A;box-shadow:0 0 0 3px rgba(15,157,138,.12)}
.vsearch ion-icon{font-size:17px;color:#9AA6B5;flex:0 0 auto}
.vsearch input{border:0;outline:none;background:none;font:inherit;font-size:14px;flex:1;min-width:0;color:#1F2937}
.vsearch-x{border:0;background:none;cursor:pointer;color:#9AA6B5;display:flex;align-items:center;font-size:15px;flex:0 0 auto}
.vsearch-x:hover{color:#EF4444}
mark.vhl{background:#FDE68A;color:inherit;border-radius:3px;padding:0 1px}
.vcard{animation:vcardIn .18s ease}
@keyframes vcardIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.vgrid-sm{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;animation:vcardIn .2s ease}
.vsm{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;background:#EEF2F7;border:1px solid rgba(0,0,0,.07);cursor:grab;transition:opacity .15s,transform .15s,box-shadow .15s}
.vsm:hover{box-shadow:0 4px 14px rgba(0,0,0,.12);transform:translateY(-1px)}
.vsm:active{cursor:grabbing}
.vsm img{width:100%;height:100%;object-fit:cover;pointer-events:none}
.vsm-ico{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.vsm-ico ion-icon{font-size:26px;color:#0F9D8A}
.vsm.dragging{opacity:.4;transform:scale(.96)}
.vsm.sel{outline:2.5px solid #0F9D8A;outline-offset:-2.5px}
.vsm-check{position:absolute;top:4px;left:4px;background:rgba(255,255,255,.9);border-radius:5px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.vsm-check input{margin:0;cursor:pointer;width:13px;height:13px;accent-color:#0F9D8A}
.vexp-fold{transition:background .15s,outline-color .15s}
.vexp-fold.dropping{background:rgba(15,157,138,.16);outline:2px dashed #0F9D8A;outline-offset:-2px}
.vexp-fold.dropping .vcount{background:#0F9D8A;color:#fff}
.vcount{transition:transform .25s,background .25s,color .25s}
.vcount.bump{animation:vcountBump .5s ease}
@keyframes vcountBump{0%{transform:scale(1)}35%{transform:scale(1.5);background:#0F9D8A;color:#fff}100%{transform:scale(1)}}
@media(max-width:680px){.vgrid-sm{grid-template-columns:repeat(4,1fr)}}
/* folder-name line under item title + editable heading */
.vcard-meta-row{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-top:3px}
.vcard-fname{font-size:13px;font-weight:700;color:#0F9D8A;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:62%}
.vcard-fname.editable{cursor:text;border:1px dashed transparent;border-radius:5px;padding:0 4px;margin:0 -4px}
.vcard-fname.editable:hover{border-color:rgba(15,157,138,.45)}
.vcard-fname.editable:focus{outline:none;border-color:#0F9D8A;background:rgba(15,157,138,.06);white-space:normal;overflow:visible;text-overflow:clip;max-width:none}
.vcard-meta-row .vcard-meta{flex:0 0 auto;white-space:nowrap;margin:0}
.vexp-title{display:flex;align-items:baseline;min-width:0;margin:0}
.vexp-tname{font-weight:800}
.vexp-tname.editable{cursor:text;border:1px dashed transparent;border-radius:6px;padding:0 5px;margin:0 -5px}
.vexp-tname.editable:hover{border-color:rgba(15,157,138,.45)}
.vexp-tname.editable:focus{outline:none;border-color:#0F9D8A;background:rgba(15,157,138,.06)}
.vexp-tcount{color:#6B7280;font-weight:700;white-space:nowrap}
.btn-on{background:#0F9D8A !important;color:#fff !important;border-color:#0F9D8A !important}
/* pdf / doc preview tile */
.vcard-docimg{display:flex;align-items:center;justify-content:center;height:280px;background:linear-gradient(135deg,#F8FAFC,#EAEFF5);cursor:pointer}
.vcard-doc{display:flex;flex-direction:column;align-items:center;gap:10px;color:#64748B}
.vcard-doc ion-icon{font-size:66px}
.vcard-docimg.pdf .vcard-doc{color:#DC2626}
.vcard-doc-ext{font-size:12px;font-weight:800;letter-spacing:.08em;padding:2px 9px;border-radius:6px;background:rgba(100,116,139,.14)}
.vcard-docimg.pdf .vcard-doc-ext{background:rgba(220,38,38,.12);color:#DC2626}
.vsm-ico.pdf ion-icon{color:#DC2626}
.vsm-ext{position:absolute;bottom:4px;right:4px;background:rgba(220,38,38,.12);color:#DC2626;font-size:9px;font-weight:800;padding:1px 5px;border-radius:5px}
/* pdf lightbox */
.vlb-pdf{width:92vw;height:88vh;border:0;border-radius:10px;background:#fff;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.vlb-open{position:absolute;bottom:22px;left:24px;color:#cfe;font-size:13px;text-decoration:underline;z-index:1}
/* marquee + folder picker */
.vmarquee{position:fixed;z-index:2500;border:1.5px solid #3B82F6;background:rgba(59,130,246,.16);border-radius:4px;pointer-events:none}
.vpick-list{display:flex;flex-direction:column;gap:6px;max-height:52vh;overflow:auto}
.vpick-row{display:flex;align-items:center;gap:10px;width:100%;border:1px solid rgba(0,0,0,.08);background:#fff;border-radius:10px;padding:11px 12px;cursor:pointer;font:inherit;text-align:left}
.vpick-row:hover{background:#F4FBF9;border-color:rgba(15,157,138,.45)}
.vpick-row ion-icon{font-size:18px;color:#0F9D8A;flex:0 0 auto}
.vpick-nm{flex:1;font-weight:600;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vsort{position:relative}
.vsort-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:60;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:12px;box-shadow:0 12px 34px rgba(0,0,0,.16);padding:6px;min-width:200px;display:flex;flex-direction:column;gap:2px}
.vsort-item{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;border:0;background:none;font:inherit;font-size:13px;padding:9px 10px;border-radius:8px;cursor:pointer;text-align:left;color:#1F2937}
.vsort-item:hover{background:#F4FBF9}
.vsort-item.on{color:#0F9D8A;font-weight:700}
.vsort-item ion-icon{color:#0F9D8A;font-size:16px;flex:0 0 auto}
.vcard-meta-row{justify-content:flex-start}
.vcard-flabel{font-size:13px;font-weight:700;color:#6B7280;flex:0 0 auto}
.vcard-meta-row .vcard-meta{margin-left:auto;padding-left:10px}
.vexp-newfold{display:flex;align-items:center;gap:8px;width:100%;border:1px dashed rgba(15,157,138,.5);background:#F4FBF9;color:#0F9D8A;border-radius:10px;padding:9px 10px;font:inherit;font-weight:700;cursor:pointer;margin-bottom:8px}
.vexp-newfold:hover{background:#E8F6F2}
.vexp-newfold ion-icon{font-size:18px}
.vthumb-size{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.72);color:#fff;font-size:11px;font-weight:700;padding:2px 9px;border-radius:7px;pointer-events:none;white-space:nowrap;z-index:2}
.vthumb-size-sm{bottom:4px;font-size:9px;padding:1px 6px;border-radius:5px}
.vthumb-pdf{position:absolute;top:8px;left:8px;background:#DC2626;color:#fff;font-size:10px;font-weight:800;letter-spacing:.06em;padding:2px 7px;border-radius:6px;z-index:2;box-shadow:0 2px 6px rgba(0,0,0,.25)}

.vexp-railbtn{display:flex;align-items:center;gap:8px;width:100%;border-radius:10px;padding:9px 10px;font:inherit;font-weight:700;font-size:13.5px;cursor:pointer;white-space:nowrap}
.vexp-railbtn ion-icon{font-size:18px;flex:0 0 auto}
.vexp-upload{border:1.5px solid #0B1830;background:#0B1830;color:#fff}
.vexp-upload:hover{background:#16294a}

.vexp-railtop{display:flex;gap:6px;margin-bottom:6px}
.vexp-railtop .vexp-railbtn{flex:1;justify-content:center;padding:9px 6px;min-width:0;margin:0}
.vexp-railtop .vexp-railbtn span{overflow:hidden;text-overflow:ellipsis}
.vcard{cursor:grab}
.vcard:active{cursor:grabbing}
.vcard.dragging{opacity:.4;transform:scale(.98)}
.vcard .vi-name,.vcard .vcard-fname{cursor:text}
.vfold-lock{font-size:13px;color:#9AA6B5;flex:0 0 auto}
.vfold-lock-h{margin:0 6px;font-size:15px}
.vfname-lock{font-size:12px;color:#9AA6B5;margin-left:5px;flex:0 0 auto}
.up-pick.over{background:#E8F6F2;border-color:#0F9D8A;box-shadow:0 0 0 3px rgba(15,157,138,.15)}
.vsel-count{font-size:12.5px;font-weight:700;color:#0F9D8A;white-space:nowrap}
.vcard-fmove{border:0;background:none;font:inherit;font-size:13px;font-weight:700;color:#0F9D8A;cursor:pointer;padding:0;max-width:55%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}
.vcard-fmove:hover{text-decoration:underline}
.vfmove-caret{font-size:13px;color:#0F9D8A;cursor:pointer;flex:0 0 auto;margin-left:2px}
.vpick-row.on{background:#EEF6F4;border-color:rgba(15,157,138,.5)}
.vpick-new{color:#0F9D8A;border-style:dashed;border-color:rgba(15,157,138,.5)}
.vpick-new .vpick-nm{font-weight:700}
.vexp-main{position:relative}
.vdrop-overlay{position:absolute;inset:0;z-index:20;background:rgba(15,157,138,.10);border:2.5px dashed #0F9D8A;border-radius:14px;display:flex;align-items:center;justify-content:center}
.vdrop-card{display:flex;flex-direction:column;align-items:center;gap:6px;color:#0F9D8A;background:#fff;padding:24px 34px;border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.18)}
.vdrop-card ion-icon{font-size:46px}
.vdrop-t{font-weight:800;font-size:18px}
.vdrop-s{font-size:13px;color:#6B7280}
.vexp-fold.filedrop{background:rgba(15,157,138,.16);outline:2px dashed #0F9D8A;outline-offset:-2px;animation:filedropPulse .8s ease-in-out infinite}
@keyframes filedropPulse{0%,100%{box-shadow:0 0 0 0 rgba(15,157,138,.30)}50%{box-shadow:0 0 0 6px rgba(15,157,138,.12)}}
.vsm-meta{position:absolute;bottom:4px;left:4px;right:4px;display:flex;flex-direction:column;align-items:center;gap:2px;pointer-events:none;z-index:2}
.vsm-meta .vthumb-size{position:static;transform:none}
.vsm-folder{background:rgba(0,0,0,.62);color:#fff;font-size:8.5px;font-weight:700;padding:1px 6px;border-radius:5px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.vcard-ai-h{display:flex;align-items:center;justify-content:space-between}
.vcard-ai-edit{border:0;background:none;color:#0F9D8A;font-weight:700;font-size:11px;cursor:pointer;padding:0}
.vcard-ai-edit:hover{text-decoration:underline}
.vcard-ai-t{cursor:text;-webkit-user-select:text;user-select:text}
.vcard-ai-ta{width:100%;min-height:96px;max-height:400px;border:1px solid rgba(15,157,138,.4);border-radius:10px;padding:9px 11px;font:inherit;font-size:13.5px;line-height:1.55;resize:vertical;outline:none;color:#374151;box-sizing:border-box}
.vcard-ai-ta:focus{border-color:#0F9D8A;box-shadow:0 0 0 3px rgba(15,157,138,.12)}
.vcard-ai-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}
.vbtn-danger{color:#DC2626 !important}
.vbtn-danger:hover{background:rgba(220,38,38,.08) !important;border-color:rgba(220,38,38,.3) !important}
.vexp-fold.child{font-size:13px}
.vexp-fold.child .vexp-fname{color:#5B6B80}
.vexp-fold.child ion-icon:first-child{color:#9AA6B5;font-size:15px}
.nf-label{display:block;font-size:12px;font-weight:700;color:#6B7280;margin:14px 0 6px}
.vfold-toggle{flex:0 0 auto;width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;border-radius:5px;font-size:15px;font-weight:800;line-height:1;color:#5B6B80;cursor:pointer;margin-right:-2px}
.vfold-toggle:hover{background:rgba(15,157,138,.14);color:#0F9D8A}
.vfold-toggle.ghost{visibility:hidden;cursor:default}
.vlb-img{will-change:transform}
.vlb-img.grab{cursor:grab}
.vlb-img.grab:active{cursor:grabbing}
.vlb-tools{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:6px;background:rgba(18,28,42,.94);border-radius:999px;padding:6px 10px;z-index:5}
.vlb-tools button{width:34px;height:34px;border:0;border-radius:50%;background:rgba(255,255,255,.10);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px}
.vlb-tools button:hover{background:rgba(255,255,255,.22)}
.vlb-tools button:disabled{opacity:.5}
.vlb-zoom{color:#fff;font-size:12px;font-weight:700;min-width:44px;text-align:center}
.vlb-sep{width:1px;height:22px;background:rgba(255,255,255,.2);margin:0 2px}
.vlb-save{width:auto !important;border-radius:999px !important;padding:0 14px !important;background:#0F9D8A !important;font-weight:700;font-size:13px}
.vlb-save:hover{background:#16b89f !important}
.vlb-cropbox{position:fixed;border:1.5px solid #fff;box-shadow:0 0 0 9999px rgba(0,0,0,.55);z-index:6;cursor:move}
.vlb-cropbox .vch{position:absolute;background:#fff;border:1px solid rgba(0,0,0,.3)}
.vlb-cropbox .vch.nw{left:-6px;top:-6px;width:12px;height:12px;cursor:nwse-resize;border-radius:2px}
.vlb-cropbox .vch.ne{right:-6px;top:-6px;width:12px;height:12px;cursor:nesw-resize;border-radius:2px}
.vlb-cropbox .vch.sw{left:-6px;bottom:-6px;width:12px;height:12px;cursor:nesw-resize;border-radius:2px}
.vlb-cropbox .vch.se{right:-6px;bottom:-6px;width:12px;height:12px;cursor:nwse-resize;border-radius:2px}
.vlb-cropbox .vch.n{top:-4px;left:50%;margin-left:-12px;width:24px;height:8px;cursor:ns-resize;border-radius:2px}
.vlb-cropbox .vch.s{bottom:-4px;left:50%;margin-left:-12px;width:24px;height:8px;cursor:ns-resize;border-radius:2px}
.vlb-cropbox .vch.e{right:-4px;top:50%;margin-top:-12px;width:8px;height:24px;cursor:ew-resize;border-radius:2px}
.vlb-cropbox .vch.w{left:-4px;top:50%;margin-top:-12px;width:8px;height:24px;cursor:ew-resize;border-radius:2px}
.vcard-noai{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.vcard-runai{display:inline-flex;align-items:center;gap:6px;border:0;background:#0F9D8A;color:#fff;border-radius:10px;padding:9px 14px;font:inherit;font-weight:700;font-size:13px;cursor:pointer;box-shadow:0 2px 8px rgba(15,157,138,.3)}
.vcard-runai:hover{background:#0c8676}
.vcard-runai:disabled{opacity:.6;cursor:default}
.vcard-runai ion-icon{font-size:16px}
.vcard-runai .spinner{width:13px;height:13px;border-width:2px;margin-right:4px}
.vlb-tools .vlb-del:hover{background:rgba(220,38,38,.85)}
.vlb-tools .vlb-del ion-icon{color:#fff}
.vexp-main{min-height:calc(100vh - 180px)}
.vdrop-overlay{pointer-events:none}
.vdrop-ai{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:12px;font-weight:700;color:#0F9D8A;background:rgba(15,157,138,.1);padding:5px 10px;border-radius:999px}
.vdrop-ai ion-icon{font-size:15px}
.vexp-thead-ic{font-size:19px;color:#0F9D8A;flex:0 0 auto;margin-right:7px}
.vcard-ai-links{display:flex;gap:14px;align-items:center}
.vcard-ai-edit.on{color:#0B1830;text-decoration:underline}
.vcard-del.restore{background:#0F9D8A}
.vcard-del.restore:hover{background:#0c8676}
.vault-gate{max-width:460px;margin:40px auto;text-align:center}
.vgate-form{display:flex;flex-direction:column;gap:10px;max-width:320px;margin:18px auto 0}
.vgate-form .input{text-align:center}
.vsm{user-select:none;-webkit-user-select:none}
.vsm img{-webkit-user-drag:none;user-drag:none}
.vgrid-sm.selecting{user-select:none;-webkit-user-select:none}
.vgrid-sm.selecting .vsm-check{pointer-events:none}
.vgrid-sm.selecting .vsm{cursor:crosshair}
