*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f0f0f5;
  --card:#ffffff;
  --navy:#0d1b40;
  --navy2:#1e2d5a;
  --purple:#7c6cf8;
  --purple-light:#ede9ff;
  --orange:#f59e0b;
  --orange-light:#fff8ed;
  --green:#10b981;
  --red:#ef4444;
  --gray:#6b7280;
  --gray2:#9ca3af;
  --gray3:#e5e7eb;
  --gray4:#f3f4f6;
  --text:#0d1b40;
  --text2:#4b5563;
  --border:#e5e7eb;
  --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow2:0 4px 16px rgba(0,0,0,.10);
  --radius:16px;
  --radius-sm:10px;
  --nav-h:68px;
  --safe-bottom:env(safe-area-inset-bottom,0px);
}
html,body{height:100%;background:var(--bg);font-family:'Inter',sans-serif;color:var(--text);-webkit-font-smoothing:antialiased}
.app{max-width:430px;margin:0 auto;min-height:100vh;position:relative;background:var(--bg)}

/* ── Nav ─────────────────────────────────────────────────── */
.bottom-nav{
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:430px;
  background:#fff;border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-around;
  height:calc(var(--nav-h) + var(--safe-bottom));
  padding-bottom:var(--safe-bottom);
  z-index:100;
}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 6px;cursor:pointer;border:none;background:none;font-family:'Inter',sans-serif;color:var(--gray2);font-size:10px;font-weight:500;min-width:48px;transition:color .15s}
.nav-item svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.nav-item.active{color:var(--purple)}
.nav-logo{font-size:16px;font-weight:800;color:var(--navy);letter-spacing:-.5px}
.nav-logo span{color:var(--orange)}

/* ── Views ───────────────────────────────────────────────── */
.view{display:none;padding:0 0 calc(var(--nav-h) + var(--safe-bottom) + 16px);min-height:100vh}
.view.active{display:block}
#view-home{display:none;flex-direction:column}
#view-home.active{display:flex}
.view-header{padding:20px 20px 0;display:flex;align-items:center;justify-content:space-between}
.view-back{width:36px;height:36px;border-radius:50%;background:var(--gray4);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}
.view-back svg{width:16px;height:16px;stroke:var(--navy);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.view-actions{display:flex;gap:8px}
.icon-btn{width:36px;height:36px;border-radius:50%;background:var(--gray4);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}
.icon-btn svg{width:18px;height:18px;stroke:var(--navy);fill:none;stroke-width:1.8}

/* ── Cards ───────────────────────────────────────────────── */
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.card-section{margin:0 16px 12px}

/* ── HOME VIEW ───────────────────────────────────────────── */
.home-hero{padding:28px 20px 20px}
.home-label{font-size:11px;font-weight:600;letter-spacing:.8px;color:var(--gray2);text-transform:uppercase;margin-bottom:6px}
.home-amount{font-size:52px;font-weight:800;color:var(--navy);line-height:1;letter-spacing:-2px}
.home-amount span{font-size:20px;font-weight:600;letter-spacing:0;margin-left:4px;color:var(--gray)}
.home-annual{font-size:14px;color:var(--text2);margin-top:8px}
.home-annual strong{color:var(--orange);font-weight:700}
.home-bar-wrap{margin:4px 20px 0;background:transparent;padding:0;display:flex;flex-direction:column;justify-content:flex-start}
.home-bar-track{height:10px;border-radius:12px;overflow:hidden;display:flex;gap:3px;margin-bottom:16px;cursor:pointer}
.home-bar-seg{height:100%;border-radius:0;transition:width .5s ease;cursor:pointer;position:relative}
.home-bar-seg:first-child{border-radius:10px 0 0 10px}
.home-bar-seg:last-child{border-radius:0 10px 10px 0}
.home-bar-seg:hover{filter:brightness(1.1);transform:scaleY(1.08)}
.home-bar-legend{display:flex!important;flex-direction:row!important;gap:8px!important;overflow-x:auto!important;scrollbar-width:none!important;padding-bottom:2px!important}
.legend-item{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--text2);cursor:pointer;padding:5px 10px;background:var(--card);border-radius:99px;white-space:nowrap;border:1px solid var(--border);flex-shrink:0;border-radius:8px;transition:background .15s}
.legend-item:hover{border-color:var(--purple);color:var(--purple)}
.legend-dot{width:clamp(7px,1.5vw,10px);height:clamp(7px,1.5vw,10px);border-radius:50%;flex-shrink:0}
.legend-pct{font-weight:400;color:var(--gray2);font-size:11px}
.next-card{margin:12px 20px 0;background:var(--card);border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px;cursor:pointer}
.next-card-logo{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.next-card-info{flex:1}
.next-card-label{font-size:10px;font-weight:600;letter-spacing:.6px;color:var(--gray2);text-transform:uppercase;margin-bottom:3px}
.next-card-name{font-size:16px;font-weight:700;color:var(--navy)}
.next-card-date{font-size:12px;color:var(--gray);margin-top:2px}
.next-card-price{font-size:18px;font-weight:700;color:var(--navy)}
.home-links{margin:12px 20px 0;display:flex;flex-direction:column;gap:1px;overflow:hidden}
.home-link{display:flex;align-items:center;justify-content:space-between;padding:14px 4px;font-size:15px;font-weight:600;color:var(--purple);cursor:pointer;background:none;border:none;font-family:'Inter',sans-serif;width:100%;text-align:left;border-bottom:1px solid var(--border)}
.home-link:last-child{border-bottom:none;color:var(--orange);font-weight:600}
.home-link svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.5}

/* ── LIST VIEW ───────────────────────────────────────────── */
.list-hero{padding:20px 20px 16px}
.list-title{font-size:32px;font-weight:800;color:var(--navy);letter-spacing:-1px;margin-top:4px;line-height:1.1}
.sort-pills{display:flex;gap:8px;padding:0 20px 12px;overflow-x:auto;scrollbar-width:none}
.sort-pills::-webkit-scrollbar{display:none}
.sort-pill-new{padding:8px 16px;border-radius:99px;font-size:13px;font-weight:600;border:1.5px solid var(--border);background:var(--card);color:var(--gray);cursor:pointer;white-space:nowrap;transition:all .15s;font-family:'Inter',sans-serif}
.sort-pill-new.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.sub-list{margin:0 16px;display:flex;flex-direction:column;gap:2px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.sub-row{display:flex;align-items:center;gap:14px;padding:14px 16px;cursor:pointer;border-bottom:1px solid var(--gray4);transition:background .1s}
.sub-row:last-child{border-bottom:none}
.sub-row:hover{background:var(--gray4)}
.sub-row-logo{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;position:relative}
.sub-row-logo img{position:absolute;inset:2px;width:40px;height:40px;border-radius:10px;object-fit:contain}
.sub-row-info{flex:1;min-width:0}
.sub-row-name{font-size:15px;font-weight:700;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sub-row-meta{font-size:12px;color:var(--gray);margin-top:2px}
.sub-row-price{font-size:16px;font-weight:700;color:var(--navy);white-space:nowrap}

/* ── ADD VIEW ────────────────────────────────────────────── */
.add-step{display:none}
.add-step.active{display:block}
.add-section-label{font-size:11px;font-weight:600;letter-spacing:.7px;color:var(--gray2);text-transform:uppercase;padding:0 20px;margin-bottom:10px}
.add-cant-section{margin:0 16px 16px;background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.add-cant-item{display:flex;align-items:center;gap:14px;padding:16px;border-bottom:1px solid var(--gray4);opacity:.45}
.add-cant-item:last-child{border-bottom:none}
.add-cant-icon{width:40px;height:40px;border-radius:10px;background:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.add-cant-icon svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:1.8}
.add-cant-text{flex:1}
.add-cant-title{font-size:15px;font-weight:600;color:var(--navy)}
.add-cant-sub{font-size:12px;color:var(--gray);margin-top:1px}
.add-cant-coming{font-size:11px;font-weight:600;color:var(--orange);background:var(--orange-light);padding:2px 8px;border-radius:99px}
.provider-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:0 16px}
.provider-btn{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--card);border-radius:var(--radius-sm);border:1.5px solid var(--border);cursor:pointer;font-family:'Inter',sans-serif;transition:all .15s;text-align:left}
.provider-btn:hover,.provider-btn.selected{border-color:var(--purple);background:var(--purple-light)}
.provider-btn-logo{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;position:relative}
.provider-btn-logo img{position:absolute;inset:1px;width:30px;height:30px;border-radius:7px;object-fit:contain}
.provider-btn-name{font-size:13px;font-weight:600;color:var(--navy)}
.add-form{padding:0 20px}
.add-field{margin-bottom:20px}
.add-field label{display:block;font-size:11px;font-weight:600;letter-spacing:.7px;color:var(--gray2);text-transform:uppercase;margin-bottom:8px}
.add-input{width:100%;padding:14px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:16px;font-family:'Inter',sans-serif;color:var(--navy);background:#fff;outline:none;transition:border-color .15s}
.add-input:focus{border-color:var(--purple)}
.add-input-suffix{position:relative}
.add-input-suffix .add-input{padding-right:40px}
.add-input-suffix::after{content:attr(data-suffix);position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:16px;color:var(--gray2);pointer-events:none}
.cat-grid{display:flex;flex-wrap:wrap;gap:8px}
.cat-pill-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:99px;border:1.5px solid var(--border);background:var(--card);font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;font-family:'Inter',sans-serif;transition:all .15s}
.cat-pill-btn.active{border-color:var(--purple);background:var(--purple-light);color:var(--purple);font-weight:600}
.add-next-btn{width:100%;padding:16px;background:var(--navy);color:#fff;border:none;border-radius:var(--radius-sm);font-size:16px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;margin-top:8px;transition:opacity .15s}
.add-next-btn:hover{opacity:.9}
.add-next-btn:disabled{opacity:.4;cursor:not-allowed}
.step-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 4px}
.step-label{font-size:12px;font-weight:600;color:var(--gray2)}
.add-hero-title{font-size:28px;font-weight:800;color:var(--navy);padding:8px 20px 20px;line-height:1.2;letter-spacing:-.5px}
.variant-list{margin:0 16px 16px;background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.variant-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--gray4);cursor:pointer;transition:background .1s}
.variant-item:last-child{border-bottom:none}
.variant-item:hover,.variant-item.selected{background:var(--purple-light)}
.variant-item.selected .variant-name{color:var(--purple)}
.variant-name{font-size:15px;font-weight:600;color:var(--navy)}
.variant-price{font-size:15px;font-weight:700;color:var(--navy)}

/* ── DETAIL VIEW ─────────────────────────────────────────── */
.detail-hero{padding:20px 20px 0}
.detail-tag{display:inline-block;padding:4px 12px;background:var(--purple-light);color:var(--purple);border-radius:99px;font-size:12px;font-weight:700;margin-bottom:16px}
.detail-price{font-size:48px;font-weight:800;color:var(--navy);letter-spacing:-2px;line-height:1}
.detail-price span{font-size:20px;font-weight:600;letter-spacing:0;color:var(--gray);margin-left:4px}
.detail-annual{font-size:14px;color:var(--text2);margin-top:8px}
.detail-annual strong{color:var(--orange);font-weight:700}
.detail-card{margin:16px 16px 0;background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.detail-card-label{font-size:10px;font-weight:600;letter-spacing:.7px;color:var(--gray2);text-transform:uppercase;margin-bottom:8px}
.detail-card-row{display:flex;align-items:center;justify-content:space-between}
.detail-card-main{font-size:16px;font-weight:600;color:var(--navy)}
.detail-card-sub{font-size:13px;color:var(--gray);margin-top:2px}
.detail-chart{margin:16px 16px 0;background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.bar-chart{display:flex;align-items:flex-end;gap:6px;height:64px;margin-bottom:8px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative}
.bar-fill{width:100%;border-radius:4px 4px 0 0;background:var(--gray3);min-height:4px;transition:height .3s}
.bar-fill.current{background:var(--purple)}
.bar-fill.changed{background:var(--orange)}
.bar-label{font-size:10px;color:var(--gray2);text-transform:uppercase}
.bar-change-dot{position:absolute;top:-8px;left:50%;transform:translateX(-50%);width:6px;height:6px;border-radius:50%;background:var(--orange)}
.chart-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.chart-footer-item{text-align:center}
.chart-footer-val{font-size:15px;font-weight:800;color:var(--navy)}
.chart-footer-lbl{font-size:10px;color:var(--gray2);text-transform:uppercase;letter-spacing:.5px;margin-top:1px}
.detail-actions{margin:16px 16px 0;display:flex;flex-direction:column;gap:10px}
.btn-pause{width:100%;padding:16px;border-radius:var(--radius-sm);background:var(--gray4);border:none;font-size:15px;font-weight:600;color:var(--navy);cursor:pointer;font-family:'Inter',sans-serif}
.btn-cancel{width:100%;padding:16px;border-radius:var(--radius-sm);background:none;border:none;font-size:15px;font-weight:600;color:var(--red);cursor:pointer;font-family:'Inter',sans-serif}

/* ── ACTIVITY VIEW ───────────────────────────────────────── */
.activity-hero{padding:20px 20px 16px}
.activity-title{font-size:32px;font-weight:800;color:var(--navy);letter-spacing:-1px;margin-top:4px}
.activity-list{margin:0 16px;display:flex;flex-direction:column;gap:2px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.activity-item{display:flex;align-items:center;gap:14px;padding:14px 16px;border-bottom:1px solid var(--gray4)}
.activity-item:last-child{border-bottom:none}
.activity-logo{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.activity-info{flex:1}
.activity-name{font-size:15px;font-weight:700;color:var(--navy)}
.activity-meta{font-size:11px;font-weight:600;letter-spacing:.4px;color:var(--gray2);text-transform:uppercase;margin:2px 0}
.activity-desc{font-size:13px;color:var(--gray)}
.activity-amount{font-size:16px;font-weight:700;color:var(--navy)}
.activity-amount.coming{color:var(--gray2)}

/* ── SETTINGS VIEW ───────────────────────────────────────── */
.settings-hero{padding:20px 20px 16px}
.settings-title{font-size:32px;font-weight:800;color:var(--navy);letter-spacing:-1px;margin-top:4px}
.settings-section{margin:0 16px 16px}
.settings-label{font-size:11px;font-weight:600;letter-spacing:.7px;color:var(--gray2);text-transform:uppercase;margin-bottom:8px;padding:0 4px}
.settings-card{background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--gray4)}
.settings-row:last-child{border-bottom:none}
.settings-row-left{display:flex;align-items:center;gap:12px}
.settings-row-title{font-size:15px;font-weight:500;color:var(--navy)}
.settings-row-sub{font-size:12px;color:var(--gray);margin-top:2px}
.toggle{width:48px;height:28px;border-radius:99px;background:var(--gray3);border:none;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}
.toggle.on{background:var(--purple)}
.toggle::after{content:'';position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle.on::after{transform:translateX(20px)}
.settings-version{text-align:center;padding:20px;font-size:12px;color:var(--gray2)}

/* ── EDIT MODAL (existing, restyled) ─────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:200;display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:#fff;border-radius:24px 24px 0 0;padding:24px 20px;padding-bottom:calc(24px + var(--safe-bottom));width:100%;max-width:430px;margin:0 auto;max-height:90vh;overflow-y:auto}
.modal h3{font-size:20px;font-weight:800;color:var(--navy);margin-bottom:20px;letter-spacing:-.3px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:11px;font-weight:600;letter-spacing:.7px;color:var(--gray2);text-transform:uppercase;margin-bottom:8px}
.form-group input,.form-group select{width:100%;padding:13px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:15px;font-family:'Inter',sans-serif;color:var(--navy);outline:none;background:#fff}
.form-group input:focus,.form-group select:focus{border-color:var(--purple)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.btn-row{display:flex;gap:10px;margin-top:20px}
.btn{padding:13px 20px;border-radius:10px;font-size:14px;font-weight:600;font-family:'Inter',sans-serif;cursor:pointer;border:none;transition:opacity .15s;flex:1}
.btn-primary{background:var(--purple);color:#fff}
.btn-secondary{background:var(--gray4);color:var(--navy)}
.btn-danger{background:rgba(239,68,68,.12);color:var(--red)}
.cancel-guide{margin-bottom:16px;padding:12px 14px;background:rgba(124,108,248,.08);border:1px solid rgba(124,108,248,.2);border-radius:10px}
.cancel-guide-label{font-size:10px;font-weight:600;letter-spacing:.5px;color:var(--gray2);margin-bottom:6px}
.cancel-guide a{display:inline-flex;align-items:center;gap:6px;color:var(--purple);font-size:13px;font-weight:600;text-decoration:none}
.cancel-guide-note{font-size:11px;color:var(--gray2);margin-top:4px}
.emoji-dropdown{position:relative}
.emoji-trigger{width:100%;padding:13px 14px;border:1.5px solid var(--border);border-radius:10px;background:#fff;display:flex;align-items:center;gap:8px;cursor:pointer;font-family:'Inter',sans-serif;font-size:15px;color:var(--navy)}
.emoji-panel{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:12px;box-shadow:var(--shadow2);z-index:10;display:none}
.emoji-panel.open{display:block}
.emoji-grid{display:flex;flex-wrap:wrap;gap:6px}
.emoji-btn{width:36px;height:36px;border-radius:8px;border:1.5px solid transparent;background:var(--gray4);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center}
.emoji-btn.selected{border-color:var(--purple);background:var(--purple-light)}

/* ── CONFIRM MODAL ───────────────────────────────────────── */
.confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;padding:20px}
.confirm-overlay.open{opacity:1;pointer-events:all}
.confirm-box{background:#fff;border-radius:20px;padding:24px;width:100%;max-width:360px;text-align:center}
.confirm-box h4{font-size:18px;font-weight:700;color:var(--navy);margin-bottom:8px}
.confirm-box p{font-size:14px;color:var(--gray);margin-bottom:20px}
.confirm-btns{display:flex;gap:10px}
.confirm-btns button{flex:1;padding:13px;border-radius:10px;font-size:14px;font-weight:600;font-family:'Inter',sans-serif;cursor:pointer;border:none}

/* ── TOAST ───────────────────────────────────────────────── */
#toast{position:fixed;bottom:calc(var(--nav-h) + 12px + var(--safe-bottom));left:50%;transform:translateX(-50%) translateY(10px);background:var(--navy);color:#fff;padding:12px 20px;border-radius:99px;font-size:14px;font-weight:500;opacity:0;transition:all .25s;pointer-events:none;z-index:400;white-space:nowrap;display:flex;align-items:center;gap:12px}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toastUndo{background:var(--orange);color:var(--navy);border:none;padding:5px 12px;border-radius:99px;font-size:13px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif}
