*{box-sizing:border-box;margin:0;padding:0}
:root{
  --c1:#fffbf2;--c2:#ffffff;--c3:#f5f3ff;
  --acc:#7c3aed;--acc2:#f43f5e;--acc3:#10b981;--acc4:#06b6d4;--acc5:#f97316;
  --white:#1c1917;--muted:#78716c;--border:#e5e7eb;
  --card:rgba(124,58,237,0.03);--card2:rgba(124,58,237,0.08);
  --radius:16px;--radius2:12px;
  --shadow:0 1px 3px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:0 4px 8px rgba(0,0,0,0.08),0 2px 4px rgba(0,0,0,0.04)
}
html,body{height:100%;background:var(--c1);color:var(--white);font-family:'Segoe UI',system-ui,sans-serif;font-size:14px;overflow:hidden}
/* position:fixed anchors to the visual viewport so content never slides behind
   Android gesture bars. left:max(0px,calc(50%-240px)) centers on desktop without
   transform (transform would break child position:fixed overlays). */
.app{position:fixed;top:0;bottom:0;left:max(0px,calc(50% - 240px));width:min(100vw,480px);display:flex;flex-direction:column;background:var(--c1)}
.screen{display:none;flex-direction:column;height:100%;overflow:hidden}
.screen.active{display:flex}
.scroll-area{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}

/* TOPBAR */
.topbar{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--c2);border-bottom:1px solid var(--border);flex-shrink:0;z-index:10;box-shadow:var(--shadow)}
.topbar-title{font-size:15px;font-weight:600;flex:1}
.back-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:22px;line-height:1;padding:0 4px;flex-shrink:0}

/* BOTTOM NAV
   Horizontally scrollable so all 10 items fit without squishing.
   Safe-area padding keeps the bar above the iPhone home indicator. */
.bottom-nav{
  display:flex;
  justify-content:flex-start;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  gap:2px;
  padding:8px 6px max(28px,env(safe-area-inset-bottom,28px));
  background:var(--c2);
  border-top:1px solid var(--border);
  flex-shrink:0;
  box-shadow:0 -1px 4px rgba(0,0,0,0.06);
}
.bottom-nav::-webkit-scrollbar{display:none}
/* Fade on right edge hints that the nav is scrollable */
.bottom-nav::after{content:'';position:sticky;right:0;top:0;width:24px;height:100%;background:linear-gradient(to right,transparent,var(--c2));flex-shrink:0;pointer-events:none}
.nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;color:var(--muted);cursor:pointer;font-size:9px;padding:4px 8px;border-radius:8px;transition:color .2s;min-width:54px;flex-shrink:0}
.nav-btn.active{color:var(--acc)}
.nav-btn svg{width:20px;height:20px}

/* BUTTONS */
.btn{border:none;border-radius:var(--radius2);padding:12px 20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-primary{background:var(--acc);color:#111827;width:100%}
.btn-primary:hover{opacity:.9}
.btn-ghost{background:var(--card2);color:var(--white);border:1px solid var(--border);width:100%}
.btn-ghost:hover{border-color:var(--acc)}
.btn-sm{padding:7px 14px;font-size:12px;border-radius:6px}
.btn-danger{background:rgba(239,68,68,.1);color:var(--acc2);border:1px solid rgba(239,68,68,.25)}

/* FORMS */
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:11px;color:var(--muted);letter-spacing:.8px;text-transform:uppercase}
.field input,.field select,.field textarea{background:var(--c3);border:1px solid var(--border);border-radius:var(--radius2);padding:10px 13px;color:var(--white);font-size:14px;outline:none;width:100%;transition:border .2s}
.field input:focus,.field select:focus{border-color:var(--acc)}
.field select option{background:var(--c2)}

/* CARDS */
.card{background:var(--c2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}

/* TOGGLE */
.tog{width:42px;height:23px;border-radius:12px;background:var(--border);position:relative;cursor:pointer;transition:background .3s;border:none;flex-shrink:0}
.tog.on{background:var(--acc)}
.tog::after{content:'';position:absolute;width:17px;height:17px;border-radius:50%;background:white;top:3px;left:3px;transition:left .3s}
.tog.on::after{left:22px}

/* PROGRESS BAR */
.prog-bar{height:6px;background:var(--c3);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px;transition:width .5s}

/* BADGES */
.badge{font-size:10px;padding:3px 9px;border-radius:20px;font-weight:600;white-space:nowrap}
.badge-warn{background:rgba(124,58,237,.12);color:var(--acc)}
.badge-ok{background:rgba(34,197,94,.15);color:var(--acc3)}
.badge-red{background:rgba(239,68,68,.15);color:var(--acc2)}
.badge-blue{background:rgba(59,130,246,.15);color:var(--acc4)}

/* AVATAR */
.av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}

/* MODAL */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:none;align-items:flex-end;justify-content:center}
.overlay.open{display:flex}
.modal{background:var(--c2);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:480px;padding:20px;padding-bottom:max(20px,env(safe-area-inset-bottom,20px));border-top:1px solid var(--border);max-height:88svh;overflow-y:auto;box-shadow:0 -4px 20px rgba(0,0,0,0.1)}
.modal h3{font-size:16px;font-weight:600;margin-bottom:14px}

/* TASK CARD */
.task-card{background:var(--c2);border:1px solid var(--border);border-radius:var(--radius2);padding:12px;display:flex;align-items:center;gap:11px;transition:border-color .2s;box-shadow:var(--shadow)}
.task-card.clickable{cursor:pointer}
.task-card.clickable:hover{border-color:var(--acc)}
.task-card.faded{opacity:.5}

/* SAVINGS GOAL CARD */
.goal-card{background:var(--c2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow)}
.goal-card.achieved{border-color:var(--acc3)}

/* TX ITEM */
.tx-item{display:flex;align-items:center;gap:11px;padding:11px;background:var(--card);border-radius:var(--radius2)}

/* PIN */
.pin-dots{display:flex;gap:14px;justify-content:center;margin:16px 0}
.pin-dot{width:13px;height:13px;border-radius:50%;border:2px solid var(--border);transition:all .2s}
.pin-dot.filled{background:var(--acc);border-color:var(--acc)}
.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:220px;margin:0 auto}
.pin-key{background:var(--c3);border:1px solid var(--border);border-radius:var(--radius2);padding:15px;font-size:18px;font-weight:600;cursor:pointer;text-align:center;transition:all .2s;user-select:none}
.pin-key:active{background:var(--card2);border-color:var(--acc)}

/* REPORT */
.report-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.report-row:last-child{border-bottom:none}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.stat-box{background:var(--c3);border-radius:var(--radius2);padding:12px;text-align:center}
.stat-val{font-size:22px;font-weight:800}
.stat-lbl{font-size:10px;color:var(--muted);margin-top:2px;text-transform:uppercase;letter-spacing:.5px}

/* CHIP */
.chip-row{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
.chip{padding:6px 14px;border-radius:20px;border:1px solid var(--border);font-size:12px;cursor:pointer;background:var(--card);white-space:nowrap;transition:all .2s;flex-shrink:0}
.chip.active{background:rgba(124,58,237,.12);border-color:var(--acc);color:var(--acc)}

/* ALERT */
.alert{border-radius:var(--radius2);padding:11px 13px;font-size:13px;display:flex;gap:9px;align-items:flex-start;line-height:1.5}
.alert-info{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.2);color:var(--acc4)}
.alert-ok{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2);color:var(--acc3)}
.alert-warn{background:rgba(124,58,237,.08);border:1px solid rgba(124,58,237,.2);color:var(--acc)}

/* SECTION LABEL */
.sec-lbl{font-size:11px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;padding:14px 16px 8px}

/* WELCOME */
.welcome-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:18px;text-align:center;overflow-y:auto}

/* ONBOARDING */
.ob-slide{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 32px 16px;text-align:center;opacity:0;transform:translateX(40px);transition:opacity .35s,transform .35s;pointer-events:none}
.ob-slide.active{opacity:1;transform:translateX(0);pointer-events:auto}
.ob-slide.exit{opacity:0;transform:translateX(-40px)}
.ob-emoji{font-size:72px;margin-bottom:24px;line-height:1}
.ob-title{font-size:24px;font-weight:800;letter-spacing:-.4px;margin-bottom:12px}
.ob-body{font-size:15px;color:var(--muted);line-height:1.7;max-width:300px}
.ob-dot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;transition:background .2s,width .2s;border-radius:4px}
.ob-dot.active{background:var(--acc);width:20px}

/* PROFILE MODAL */
.prof-emoji-btn{background:var(--c3);border:2px solid transparent;border-radius:8px;padding:6px;font-size:22px;cursor:pointer;line-height:1;transition:border-color .15s,transform .15s}
.prof-emoji-btn:hover{transform:scale(1.15)}
.prof-emoji-btn.selected{border-color:var(--acc)}
.prof-color-swatch{width:30px;height:30px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s;outline:none}
.prof-color-swatch:hover{transform:scale(1.15)}
.prof-color-swatch.selected{border-color:var(--white);box-shadow:0 0 0 2px var(--acc)}

/* FEEDBACK RATING */
.rating-btn{background:var(--c3);border:2px solid transparent;border-radius:10px;padding:6px 10px;font-size:24px;cursor:pointer;line-height:1;transition:border-color .15s,transform .15s}
.rating-btn:hover{transform:scale(1.2)}
.rating-btn.selected{border-color:var(--acc);background:var(--c2)}
