:root {
  --bg1: rgba(255,255,255,.16); --bg2: rgba(255,255,255,.08); --border: rgba(255,255,255,.22);
  --text: #f7fbff; --muted: rgba(247,251,255,.7); --good: #86efac; --bad: #fca5a5;
  --shadow: 0 20px 60px rgba(0,0,0,.28);
  --btn-from: #7dd3fc; --btn-to: #a78bfa;
  --focus-c: rgba(125,211,252,.7); --focus-s: rgba(125,211,252,.12);
}
* { box-sizing: border-box; }
body { margin: 0; font-family: Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif; color: var(--text); min-height: 100vh; transition: background 0.5s ease; }
body.theme-bleu   { background: radial-gradient(circle at top left,rgba(125,211,252,.35),transparent 30%), radial-gradient(circle at top right,rgba(167,139,250,.28),transparent 26%), linear-gradient(135deg,#08111f 0%,#0c1830 48%,#0a1020 100%); }
body.theme-rose   { background: radial-gradient(circle at top left,rgba(251,113,133,.35),transparent 30%), radial-gradient(circle at top right,rgba(244,114,182,.28),transparent 26%), linear-gradient(135deg,#1f0812 0%,#30081c 48%,#1a0510 100%); }
body.theme-vert   { background: radial-gradient(circle at top left,rgba(134,239,172,.35),transparent 30%), radial-gradient(circle at top right,rgba(52,211,153,.28),transparent 26%), linear-gradient(135deg,#081f10 0%,#0a3018 48%,#061a0c 100%); }
body.theme-violet { background: radial-gradient(circle at top left,rgba(196,181,253,.35),transparent 30%), radial-gradient(circle at top right,rgba(129,140,248,.28),transparent 26%), linear-gradient(135deg,#120818 0%,#1e0830 48%,#0e0616 100%); }
body.theme-orange { background: radial-gradient(circle at top left,rgba(253,186,116,.35),transparent 30%), radial-gradient(circle at top right,rgba(251,146,60,.28),transparent 26%), linear-gradient(135deg,#1f1008 0%,#301a08 48%,#1a0c06 100%); }
body.theme-noir   { background: radial-gradient(circle at top left,rgba(148,163,184,.15),transparent 30%), radial-gradient(circle at top right,rgba(100,116,139,.12),transparent 26%), linear-gradient(135deg,#0a0a0a 0%,#141414 48%,#0d0d0d 100%); }
#themePicker { position: fixed; bottom: 24px; right: 24px; z-index: 500; display: flex; flex-direction: column; align-items: flex-end; gap: 10px; }
#themeToggle { width: 48px; height: 48px; border-radius: 50%; border: 2px solid rgba(255,255,255,.25); background: rgba(255,255,255,.12); backdrop-filter: blur(12px); cursor: pointer; font-size: 20px; display: flex; align-items: center; justify-content: center; box-shadow: 0 8px 24px rgba(0,0,0,.3); transition: transform .2s; }
#themeToggle:hover { transform: scale(1.1); }
#themeOptions { display: none; flex-direction: column; gap: 8px; align-items: flex-end; }
#themeOptions.open { display: flex; }
.themeBtn { display: flex; align-items: center; gap: 10px; padding: 8px 14px 8px 10px; border-radius: 999px; border: 1px solid rgba(255,255,255,.2); background: rgba(255,255,255,.1); backdrop-filter: blur(12px); cursor: pointer; font-size: 13px; font-weight: 600; color: var(--text); transition: all .2s; white-space: nowrap; box-shadow: 0 4px 16px rgba(0,0,0,.25); }
.themeBtn:hover { background: rgba(255,255,255,.2); transform: translateX(-4px); }
.themeBtn.active { border-color: rgba(255,255,255,.5); background: rgba(255,255,255,.22); }
.themeDot { width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0; }
.tabBar { display: flex; gap: 4px; padding: 12px 18px 0; }
.tab { background: rgba(255,255,255,.06); color: var(--muted); border: 1px solid rgba(255,255,255,.1); border-radius: 12px 12px 0 0; padding: 8px 16px; font-size: 13px; font-weight: 600; cursor: pointer; transition: all .2s; }
.tab:hover { background: rgba(255,255,255,.12); color: var(--text); }
.tab.active { background: rgba(255,255,255,.15); color: var(--text); border-color: rgba(255,255,255,.25); border-bottom-color: transparent; }
.prevBlock { display: flex; flex-direction: column; gap: 12px; }
.prevRow { display: flex; justify-content: space-between; align-items: center; padding: 14px 18px; border-radius: 16px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); }
.prevRow .label { font-size: 14px; color: var(--muted); }
.prevRow .amount { font-size: 20px; font-weight: 800; }
.prevRow.total { background: rgba(255,255,255,.11); border-color: rgba(255,255,255,.22); }
.prevRow.total .label { color: var(--text); font-weight: 700; }
.prevDivider { height: 1px; background: rgba(255,255,255,.12); margin: 4px 0; }
.progressWrap { margin-top: 4px; }
.progressLabel { display: flex; justify-content: space-between; font-size: 12px; color: var(--muted); margin-bottom: 8px; }
.progressBar { height: 10px; border-radius: 999px; background: rgba(255,255,255,.08); overflow: hidden; }
.progressFill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--btn-from), var(--btn-to)); transition: width .5s ease; }
.wrap { max-width: 1200px; margin: 0 auto; padding: 24px; }
.hero { display: flex; flex-wrap: wrap; gap: 16px; align-items: end; justify-content: space-between; margin-bottom: 22px; }
h1 { margin: 0; font-size: clamp(26px, 4vw, 40px); }
.sub { color: var(--muted); margin-top: 8px; max-width: 760px; line-height: 1.5; }
.grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 16px; }
.card { grid-column: span 12; background: linear-gradient(180deg, var(--bg1), var(--bg2)); border: 1px solid var(--border); backdrop-filter: blur(18px); border-radius: 22px; box-shadow: var(--shadow); overflow: hidden; }
.card .hd { padding: 18px 18px 0 18px; display: flex; justify-content: space-between; gap: 12px; align-items: flex-start; }
.card .bd { padding: 18px; }
.title { font-size: 18px; font-weight: 700; }
.help { font-size: 13px; color: var(--muted); line-height: 1.5; margin-top: 6px; }
.pill { padding: 8px 12px; border-radius: 999px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14); font-size: 12px; color: var(--muted); }
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.stat { padding: 14px; border-radius: 18px; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12); }
.stat .k { font-size: 12px; color: var(--muted); margin-bottom: 8px; }
.stat .v { font-size: 22px; font-weight: 800; }
.stat .s { font-size: 12px; color: var(--muted); margin-top: 6px; }
.sectionGrid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.tableWrap { overflow: auto; border-radius: 18px; border: 1px solid rgba(255,255,255,.1); }
table { width: 100%; border-collapse: collapse; min-width: 400px; background: rgba(255,255,255,.05); }
th, td { padding: 12px 10px; border-bottom: 1px solid rgba(255,255,255,.08); text-align: left; vertical-align: middle; }
th { font-size: 12px; color: var(--muted); font-weight: 600; background: rgba(255,255,255,.04); }
td input { width: 100%; padding: 10px 12px; border-radius: 12px; border: 1px solid rgba(255,255,255,.12); background: rgba(4,10,20,.36); color: var(--text); outline: none; }
td input:focus { border-color: var(--focus-c); box-shadow: 0 0 0 3px var(--focus-s); }
.btnRow { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 14px; }
button { border: none; border-radius: 14px; padding: 11px 14px; color: #08111f; font-weight: 700; cursor: pointer; background: linear-gradient(135deg, var(--btn-from), var(--btn-to)); }
.ghost { background: rgba(255,255,255,.08); color: var(--text); border: 1px solid rgba(255,255,255,.14); }
.danger { background: linear-gradient(135deg, #fca5a5, #fb7185); color: #1a0a0a; }
.toggle { position: relative; display: inline-block; width: 38px; height: 22px; flex-shrink: 0; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggleSlider { position: absolute; inset: 0; border-radius: 999px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.18); cursor: pointer; transition: .25s; }
.toggleSlider:before { content:''; position:absolute; width:16px; height:16px; left:2px; top:2px; border-radius:50%; background:rgba(255,255,255,.5); transition:.25s; }
.toggle input:checked + .toggleSlider { background: linear-gradient(135deg, var(--btn-from), var(--btn-to)); border-color: transparent; }
.toggle input:checked + .toggleSlider:before { transform: translateX(16px); background: white; }
.deductCell { text-align: center; white-space: nowrap; font-size: 11px; color: var(--muted); }
.deductCell label { display: flex; flex-direction: column; align-items: center; gap: 3px; cursor: pointer; }
.infoOnly { opacity: .5; }
.footerInfo { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 14px; }
.note { padding: 14px; border-radius: 18px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12); color: var(--muted); line-height: 1.5; }
#lockScreen { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; padding: 20px; }
body.theme-bleu #lockScreen { background: linear-gradient(135deg,#08111f,#0c1830,#0a1020); }
body.theme-rose #lockScreen { background: linear-gradient(135deg,#1f0812,#30081c,#1a0510); }
body.theme-vert #lockScreen { background: linear-gradient(135deg,#081f10,#0a3018,#061a0c); }
body.theme-violet #lockScreen { background: linear-gradient(135deg,#120818,#1e0830,#0e0616); }
body.theme-orange #lockScreen { background: linear-gradient(135deg,#1f1008,#301a08,#1a0c06); }
body.theme-noir #lockScreen { background: linear-gradient(135deg,#0a0a0a,#141414,#0d0d0d); }
#lockBox { background: linear-gradient(180deg, var(--bg1), var(--bg2)); border: 1px solid var(--border); backdrop-filter: blur(18px); border-radius: 24px; padding: 40px 36px; text-align: center; box-shadow: var(--shadow); width: 100%; max-width: 400px; }
#lockInput { width: 100%; padding: 14px; border-radius: 14px; border: 1px solid rgba(255,255,255,.18); background: rgba(4,10,20,.5); color: var(--text); font-size: 16px; outline: none; margin-bottom: 16px; }
#lockError { color: var(--bad); font-size: 13px; margin-top: 12px; }
#syncStatus { padding: 6px 10px; border-radius: 20px; font-size: 11px; font-weight: 600; margin-left: 8px; display: inline-block; }
@media (max-width: 640px) {
  .wrap { padding: 12px; padding-bottom: 80px; }
  .hero { gap: 10px; margin-bottom: 14px; }
  .hero .pill { display: none; }
  h1 { font-size: 22px; }
  .sub { font-size: 13px; margin-top: 4px; }
  .card { border-radius: 16px; }
  .card .hd { padding: 14px 14px 0 14px; flex-direction: column; gap: 4px; }
  .card .bd { padding: 12px; }
  .title { font-size: 16px; }
  .help { font-size: 12px; }
  .stats { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .stat { padding: 10px; border-radius: 14px; }
  .stat .v { font-size: 18px; }
  .stat .k, .stat .s { font-size: 11px; }
  .sectionGrid { grid-template-columns: 1fr; gap: 10px; }
  .footerInfo { grid-template-columns: repeat(3, 1fr); gap: 8px; font-size: 12px; }
  .note { padding: 10px; border-radius: 14px; }
  .tableWrap { border-radius: 14px; }
  th, td { padding: 8px 6px; font-size: 12px; }
  td input { padding: 8px; font-size: 13px; border-radius: 10px; }
  button { padding: 10px 12px; font-size: 13px; border-radius: 12px; }
  .btnRow { margin-top: 10px; gap: 8px; }
  #goalInput { font-size: 20px !important; padding: 12px !important; }
  #lockBox { padding: 28px 20px; border-radius: 20px; }
  #lockBox h2 { font-size: 20px; }
  #themePicker { bottom: 16px; right: 16px; }
  #themeToggle { width: 42px; height: 42px; font-size: 18px; }
  .tabBar { padding: 10px 12px 0; }
  .tab { padding: 7px 12px; font-size: 12px; }
  .prevRow { padding: 12px 14px; }
  .prevRow .amount { font-size: 17px; }
}
