.card{background:rgba(255,255,255,0.85);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(14,165,233,0.12);border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:var(--shadow)}
.hero{background:rgba(255,255,255,0.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(14,165,233,0.18);border-radius:var(--radius);padding:15px 18px 13px;margin-bottom:8px;box-shadow:var(--shadow-lg)}
.jouro-info-anchor{position:relative}
.hero.jouro-info-anchor{padding-right:44px}
.hero-lbl,.today-spent-label{font-size:11px;font-weight:inherit;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);margin-bottom:10px}
.hero-bal{font-size:50px;font-weight:700;letter-spacing:-2px;line-height:1}
.hero-bal.pos{color:var(--value-positive)}
.hero-bal.neg{color:var(--red)}
.hero-sub{font-size:13px;color:var(--muted);margin-top:7px}
.formula{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.today-hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;align-items:start}
.today-hero-main{min-width:0;display:flex;flex-direction:column;align-items:center;text-align:center}
.today-hero-greeting{margin:0 0 8px;font-size:18px;font-weight:600;letter-spacing:-0.02em;color:var(--text)}
.today-hero-greeting strong{color:var(--green)}
.today-hero-side{position:relative;min-width:0;align-self:start;padding-left:18px}
.today-hero-side::before{content:'';position:absolute;left:0;top:4%;width:1px;height:88%;background:rgba(148,163,184,0.22);border-radius:999px}
.today-spent-card{height:100%;padding:0;border-radius:0;border:none;background:transparent;box-shadow:none}
.today-spent-label{text-align:center;white-space:nowrap}
.today-spent-body{display:flex;align-items:flex-end;gap:12px;margin-top:10px}
.today-spent-copy{min-width:0;flex:1;display:flex;flex-direction:column;align-items:center;text-align:center}
.today-spent-amount{font-size:32px;font-weight:700;line-height:1.04;color:var(--text);letter-spacing:-0.03em;white-space:nowrap;text-align:center}
.today-spent-meta{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:7px;min-width:0}
.today-spent-ops{font-size:12px;color:var(--muted);white-space:nowrap}
.today-spent-badge{display:inline;max-width:100%;padding:0;border:none;border-radius:0;background:transparent;font-size:12px;font-weight:600;color:var(--text);white-space:nowrap}
.today-progress-ring{display:none;--progress:0;--progress-color:#0EA5E9;position:relative;width:76px;height:76px;flex-shrink:0;margin-bottom:-10px;align-self:flex-end}
.today-progress-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.today-progress-ring-track,.today-progress-ring-fill{fill:none;stroke-width:10}
.today-progress-ring-track{stroke:rgba(148,163,184,0.22)}
.today-progress-ring-fill{stroke:var(--progress-color);stroke-linecap:round;stroke-dasharray:301.59;stroke-dashoffset:calc(301.59 - (301.59 * var(--progress)) / 100);transition:stroke-dashoffset 0.25s ease,stroke 0.25s ease}
.today-progress-value{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;letter-spacing:-0.03em;color:var(--text)}
.today-progress-mobile{display:block;margin-top:10px;padding-top:10px;border-top:1px solid rgba(148,163,184,0.18)}
.today-progress-mobile.jouro-info-anchor{padding-right:34px}
.today-progress-mobile.jouro-info-anchor .jouro-info-btn{top:10px;right:-32px}
.today-progress-mobile-head{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:12px;color:var(--muted)}
.today-progress-mobile.jouro-info-anchor .today-progress-mobile-head{padding-right:6px}
.today-progress-mobile-head strong{font-size:14px;font-weight:800;color:var(--text);white-space:nowrap}
.today-progress-mobile-bar{height:8px;margin-top:8px;border-radius:999px;background:rgba(148,163,184,0.18);overflow:hidden}
.today-progress-mobile-fill{width:0%;height:100%;border-radius:999px;background:#10b981;transition:width 0.25s ease,background 0.25s ease}
.today-calc-block{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.today-calc-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0;border:none;background:transparent;color:var(--text);font-family:inherit;font-size:13px;font-weight:600;line-height:1.4;cursor:pointer;text-align:left}
.today-calc-toggle:focus-visible{outline:2px solid rgba(14,165,233,0.35);outline-offset:4px;border-radius:8px}
.today-calc-toggle:active{opacity:0.75}
.today-calc-arrow{font-size:16px;line-height:1;color:var(--text);transition:transform 0.18s ease}
.chip{padding:5px 10px;border-radius:20px;font-size:12px;font-weight:500}
.chip-prev{background:#F1F5F9;border:1px solid #CBD5E1;color:#64748B}
.chip-daily{background:var(--value-positive-soft);color:var(--value-positive);font-weight:600}
.chip-spent{background:#FFE4E6;color:#BE123C;font-weight:600}
.chip-pos{background:var(--value-positive);color:#fff;font-weight:600}
.chip-neg{background:#F43F5E;color:#fff;font-weight:600}
.op{color:var(--muted);font-size:15px}
.kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:16px 12px;box-shadow:var(--shadow);min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.kpi.jouro-info-anchor{padding-right:38px}
.kpi.kpi-premium-corner.jouro-info-anchor{padding-right:56px}
.jouro-info-btn{position:absolute;top:12px;right:12px;z-index:2;width:20px;height:20px;border:none;border-radius:999px;background:rgba(14,165,233,0.12);color:#0369A1;font-family:inherit;font-size:12px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 1px 3px rgba(15,23,42,0.08)}
.jouro-info-btn:hover{background:rgba(14,165,233,0.18)}
.jouro-info-btn:focus-visible{outline:2px solid rgba(14,165,233,0.28);outline-offset:2px}
.kpi-lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:6px;line-height:1.28}
.kpi-val{font-size:22px;font-weight:600;letter-spacing:-0.02em;line-height:1.08;white-space:nowrap}
.kpi-sub{font-size:12px;color:var(--muted);margin-top:4px;line-height:1.3}
.kpi-premium-note{margin-top:6px}
.kpi-premium-corner{position:relative}
.kpi-grid > .kpi:nth-child(-n+2){align-items:flex-start;text-align:left}
.kpi-corner-star{position:absolute;top:10px;right:40px;display:inline-flex;align-items:center;gap:0;padding:4px 8px;border-radius:999px;background:rgba(16,185,129,0.10);border:1px solid rgba(16,185,129,0.20);font-size:0;line-height:1;color:#059669;white-space:nowrap}
.kpi-corner-star::after{content:'⭐';font-size:12px;font-weight:700;line-height:1}
@media (max-width:560px){
  .kpi-corner-star{padding:3px 6px}
  .kpi-corner-star::after{font-size:11px}
}
.kpi-wide{grid-column:1 / -1;align-items:stretch;justify-content:flex-start;padding:14px 14px 12px;text-align:left}
.kpi-link{cursor:pointer}
.kpi-link:active{transform:translateY(1px)}
.kpi-link:focus-visible{outline:2px solid rgba(14,165,233,0.35);outline-offset:3px}
.kpi-wide-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.kpi-wide.jouro-info-anchor .kpi-wide-head{padding-right:10px}
.kpi-wide-head .kpi-lbl{margin-bottom:0}
.kpi-wide-head .kpi-val{text-align:right}
.kpi-sub-accent{display:inline-flex;align-self:flex-start;margin-top:8px;padding:5px 9px;border-radius:999px;background:rgba(14,165,233,0.08);color:#0369A1;font-size:11px;font-weight:600;line-height:1.2}
.sec-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.sec-title{font-size:13px;font-weight:500}
.add-btn{font-size:12px;color:var(--green);cursor:pointer;padding:5px 10px;border-radius:var(--radius-sm);border:1px solid rgba(14,165,233,0.3);background:var(--green-light)}
.today-primary-action{display:flex;width:100%;box-sizing:border-box;align-items:center;justify-content:center;gap:10px;min-height:52px;margin:0 0 10px;border:none;border-radius:20px;background:linear-gradient(135deg,#0EA5E9 0%,#38BDF8 55%,#22C55E 130%);box-shadow:0 14px 28px rgba(14,165,233,0.18);font-size:15px;font-weight:700}
.today-primary-action:active{transform:translateY(1px)}
.tx-list{display:flex;flex-direction:column;gap:1px}
.tx-row{display:flex;align-items:center;gap:10px;padding:11px 10px;border-radius:var(--radius-sm);cursor:pointer}
.tx-row:active{background:var(--surface2)}
.tx-row-spread{background:rgba(14,165,233,0.05);border:1px dashed rgba(14,165,233,0.18)}
.tx-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;background:var(--green-light)}
.tx-icon-spread{background:rgba(14,165,233,0.14);color:#0369A1}
.tx-info{flex:1;min-width:0}
.tx-name-row{display:flex;align-items:center;gap:8px;min-width:0}
.tx-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tx-cat{font-size:11px;color:var(--muted);margin-top:1px}
.tx-subline{font-size:11px;color:var(--text);margin-top:3px}
.tx-badge{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:0.03em;white-space:nowrap}
.tx-badge.spread-source{background:rgba(14,165,233,0.12);color:#0369A1}
.tx-badge.spread-impact{background:rgba(2,132,199,0.14);color:#075985}
.tx-amt{font-size:14px;font-weight:600;color:var(--red);white-space:nowrap}
.tx-dl{font-size:10px;color:var(--muted);text-align:right;margin-top:1px}
.sum-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.sum-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;box-shadow:var(--shadow)}
.sum-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:4px}
.sum-val{font-size:18px;font-weight:600}
.tabs{display:flex;gap:2px;background:var(--surface2);border-radius:var(--radius-sm);padding:3px;margin-bottom:12px}
.tab{flex:1;padding:8px;border-radius:6px;font-size:13px;cursor:pointer;color:var(--muted);text-align:center;transition:all 0.15s}
.tab.active{background:var(--surface);color:var(--text);font-weight:500}
.notif{position:fixed;top:16px;left:50%;transform:translateX(-50%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 18px;font-size:13px;z-index:600;opacity:0;transition:opacity 0.3s;pointer-events:none;white-space:nowrap}
.notif.show{opacity:1}
.notif.success{border-color:rgba(14,165,233,0.5);color:var(--green)}
.notif.error{border-color:rgba(226,75,74,0.5);color:var(--red)}
.icon-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--text)}
.icon-btn:active{background:var(--surface2)}
.dev-banner{padding:10px 16px;background:linear-gradient(135deg,#082F49 0%,#0EA5E9 100%);color:#fff;border-bottom:1px solid rgba(255,255,255,0.18);display:flex;align-items:center;justify-content:center;text-align:center;flex-shrink:0;box-shadow:0 4px 18px rgba(8,47,73,0.18)}
.dev-banner-text{font-size:11px;font-weight:700;letter-spacing:0.08em;line-height:1.5;text-transform:uppercase}
.dev-banner-text strong{color:#E0F2FE}
.reset-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;background:var(--surface);border:1px solid var(--border);border-radius:20px;font-size:11px;color:var(--muted);margin-bottom:12px}
#page-today .reset-badge{display:none}
.empty{text-align:center;padding:24px 0;color:var(--muted);font-size:13px}
.today-calc-modal{position:fixed;inset:0;background:rgba(15,23,42,0.42);z-index:945;display:none;align-items:flex-end;justify-content:center;padding:16px}
.today-calc-modal.is-open{display:flex}
.today-calc-modal-card{width:100%;max-width:460px;background:linear-gradient(180deg,rgba(240,249,255,0.96),rgba(255,255,255,0.98));border:1px solid rgba(14,165,233,0.16);border-radius:24px;box-shadow:0 24px 60px rgba(15,23,42,0.16);overflow:hidden}
.today-calc-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 12px}
.today-calc-modal-title{font-size:16px;font-weight:700;color:var(--text);letter-spacing:-0.02em}
.today-calc-modal-sub{margin-top:6px;font-size:12px;line-height:1.5;color:var(--muted)}
.today-calc-modal-close{border:none;background:transparent;color:var(--muted);font-size:24px;line-height:1;cursor:pointer;font-family:inherit}
.today-calc-modal-body{padding:0 18px 18px}
.today-calc-breakdown{padding:6px 0 0}
.today-calc-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:12px 0;border-bottom:1px solid rgba(148,163,184,0.14);font-size:13px;color:var(--text)}
.today-calc-row:last-child{border-bottom:none}
.today-calc-row strong{font-size:14px;font-weight:700;white-space:nowrap}
.today-calc-row.is-positive strong{color:var(--value-positive)}
.today-calc-row.is-negative strong{color:var(--red)}
.today-calc-row.is-total{margin-top:2px;padding-top:14px}
.today-calc-row.is-total span{font-weight:600}
.today-calc-row.is-total strong{font-size:16px}
.jouro-info-modal{position:fixed;inset:0;z-index:935;display:none;align-items:flex-end;justify-content:center;padding:16px 16px calc(16px + env(safe-area-inset-bottom));pointer-events:none}
.jouro-info-modal.is-open{display:flex}
.jouro-info-backdrop{position:absolute;inset:0;background:rgba(15,23,42,0.54);pointer-events:auto}
.jouro-info-card{position:relative;width:100%;max-width:420px;padding:20px 18px 18px;border-radius:24px;background:rgba(255,255,255,0.98);border:1px solid rgba(148,163,184,0.18);box-shadow:0 24px 60px rgba(15,23,42,0.2);pointer-events:auto}
.jouro-info-title{font-size:17px;font-weight:700;letter-spacing:-0.02em;color:var(--text)}
.jouro-info-text{margin-top:10px;font-size:13px;line-height:1.65;color:var(--muted)}
.jouro-info-actions{margin-top:18px}
.jouro-info-confirm{width:100%;min-height:46px;padding:12px 16px;border:none;border-radius:16px;background:#0EA5E9;color:#fff;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer}
.jouro-info-confirm:active{opacity:0.9}
.today-premium-projection.jouro-info-anchor{padding-right:42px}
.jouro-tour{position:fixed;inset:0;z-index:920;display:none;align-items:flex-end;justify-content:center;padding:16px 16px calc(16px + env(safe-area-inset-bottom));pointer-events:none}
.jouro-tour.is-open{display:flex}
.jouro-tour-backdrop{position:absolute;inset:0;background:rgba(15,23,42,0.58);pointer-events:auto}
.jouro-tour-card{position:relative;width:100%;max-width:460px;padding:18px 18px 16px;border-radius:24px;background:linear-gradient(180deg,rgba(240,249,255,0.98),rgba(255,255,255,0.99));border:1px solid rgba(14,165,233,0.18);box-shadow:0 24px 60px rgba(15,23,42,0.22);pointer-events:auto}
.jouro-tour-step{font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#0369A1}
.jouro-tour-title{margin-top:8px;font-size:17px;font-weight:700;letter-spacing:-0.02em;color:var(--text)}
.jouro-tour-text{margin-top:10px;font-size:13px;line-height:1.6;color:var(--muted)}
.jouro-tour-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:18px}
.jouro-tour-btn{flex:1;min-height:46px;padding:12px 16px;border-radius:16px;border:1px solid transparent;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer}
.jouro-tour-btn:active{opacity:0.88}
.jouro-tour-btn-primary{background:#0EA5E9;border-color:#0EA5E9;color:#fff}
.jouro-tour-btn-secondary{background:rgba(148,163,184,0.08);border-color:rgba(148,163,184,0.22);color:var(--text)}
.jouro-tour-highlight{position:relative;z-index:921;box-shadow:0 0 0 3px rgba(14,165,233,0.22),0 18px 36px rgba(14,165,233,0.14);transition:box-shadow 0.2s ease}
.drawer-bg{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:100;display:none;align-items:flex-end;justify-content:center}
.drawer-bg.show{display:flex}
.drawer{background:var(--surface);border-radius:24px 24px 0 0;padding:20px 20px max(28px,env(safe-area-inset-bottom));width:100%;max-width:480px;border-top:1px solid var(--border);max-height:92vh;overflow-y:auto;box-shadow:0 -8px 40px rgba(14,165,233,0.12)}
.dh{width:36px;height:4px;border-radius:2px;background:var(--border);margin:0 auto 18px}
.dt{font-size:18px;font-weight:600;margin-bottom:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.da{display:flex;gap:8px;margin-top:18px}
.db{flex:1;padding:14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text);font-size:15px;cursor:pointer;font-family:inherit}
.db:active{opacity:0.8}
.db.primary{background:var(--green);color:#fff;border-color:var(--green)}
.db.danger{background:var(--red);color:#fff;border-color:var(--red);flex:0;padding:14px 16px}
.spread-drawer-card{margin-top:4px;padding:14px;border:1px solid rgba(14,165,233,0.18);border-radius:14px;background:rgba(14,165,233,0.05)}
.spread-drawer-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:10px}
.spread-drawer-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.spread-drawer-metric{padding:10px;border-radius:10px;background:var(--surface);border:1px solid var(--border)}
.spread-drawer-metric span{display:block;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:4px}
.spread-drawer-metric strong{font-size:13px;color:var(--text)}
.spread-drawer-sub{font-size:12px;color:var(--muted);margin-top:10px;line-height:1.5}
.spread-drawer-list{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.spread-drawer-row{display:flex;align-items:center;justify-content:space-between;padding:9px 10px;border-radius:10px;background:var(--surface);border:1px solid var(--border);font-size:12px}
.spread-toggle-row{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:12px;color:var(--text)}
.spread-toggle-row input{accent-color:var(--green)}
@media (max-width:339px){
  .today-hero-grid{grid-template-columns:1fr}
}
@media (max-width:520px){
  .hero{padding:13px 16px 11px}
  .hero-lbl{font-size:11px;margin-bottom:8px}
  .hero-bal{font-size:48px}
  .hero-sub{font-size:13px}
  .today-hero-grid{gap:12px}
  .today-hero-greeting{font-size:18px}
  .today-hero-side{padding-left:14px}
  .today-spent-body{gap:10px;margin-top:9px}
  .today-spent-amount{font-size:30px}
  .today-spent-meta{gap:6px;margin-top:6px}
  .today-spent-ops{font-size:11px}
  .today-spent-badge{font-size:11px}
  .today-progress-ring{width:72px;height:72px;margin-bottom:-8px}
  .today-progress-value{font-size:13px}
  .kpi-grid{gap:7px}
  .kpi{padding:14px 10px}
  .kpi-lbl{font-size:10px}
  .kpi-val{font-size:22px}
  .kpi-sub{font-size:11px}
  .kpi-wide{padding:13px 12px 11px}
  .kpi-sub-accent{margin-top:7px;font-size:10px}
  .today-primary-action{min-height:50px;border-radius:18px}
  .today-calc-modal{padding:0}
  .today-calc-modal-card{max-width:none;border-radius:24px 24px 0 0}
  .jouro-info-modal{padding:0}
  .jouro-info-card{max-width:none;border-radius:24px 24px 0 0;padding:20px 16px calc(16px + env(safe-area-inset-bottom))}
  .jouro-tour{padding:0}
  .jouro-tour-card{max-width:none;border-radius:24px 24px 0 0;padding:18px 16px calc(16px + env(safe-area-inset-bottom))}
  .jouro-tour-actions{gap:8px}
  .spread-drawer-grid{grid-template-columns:1fr}
}
@media (max-width:390px){
  .hero-lbl:first-of-type{font-size:10px}
  .today-hero-grid{gap:10px}
  .today-hero-side{padding-left:12px}
  .today-spent-amount{font-size:30px}
  .today-spent-meta{gap:5px}
  .today-progress-ring{width:70px;height:70px;margin-bottom:-7px}
  .kpi{padding:13px 9px}
  .kpi-val{font-size:22px}
}
@media (max-width:339px){
  .today-hero-side{padding-left:0}
  .today-hero-side::before{display:none}
  .kpi-grid{grid-template-columns:1fr}
}
