:root{color-scheme:dark;--bg: #070816;--bg-grad-a: #26306a;--bg-grad-b: #10142b;--panel: #11152b;--panel2: #171c38;--panel3: #1e2444;--text: #f7f7ff;--text-soft: #c8ccee;--muted: #a7add4;--line: rgba(255 255 255 / .12);--line2: rgba(255 255 255 / .07);--gold: #ffd166;--gold-dim: rgba(255 209 102 / .18);--green: #39d98a;--green-dim: rgba(57 217 138 / .18);--red: #ff5c7a;--red-dim: rgba(255 92 122 / .16);--blue: #7c8cff;--blue-dim: rgba(124 140 255 / .16);--purple: #b36bff;--purple-dim:rgba(179 107 255 / .18);--badge-bg: rgba(255 255 255 / .08);--input-bg: rgba(0 0 0 / .28);--hover-bg: rgba(255 255 255 / .05);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 48px;--radius-sm: 10px;--radius-md: 16px;--radius-lg: 22px;--radius-xl: 28px;--radius-pill: 999px;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-md: 17px;--text-lg: 20px;--text-xl: 26px;--text-2xl: 38px;--text-3xl: clamp(38px, 6vw, 82px);--shadow-card: 0 24px 80px rgba(0 0 0 / .4);--shadow-btn: 0 10px 30px rgba(255 209 102 / .28);--shadow-blue: 0 0 18px rgba(124 140 255 / .35);--glow-gold: 0 0 20px rgba(255 209 102 / .4);--glow-green: 0 0 20px rgba(57 217 138 / .35);--glow-purple: 0 0 40px rgba(179 107 255 / .28);--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--t-fast: .12s var(--ease-out);--t-base: .2s var(--ease-out);--t-slow: .35s var(--ease-out)}[data-theme=light]{color-scheme:light;--bg: #f0f2fc;--bg-grad-a: #c8d0f5;--bg-grad-b: #dde1f8;--panel: #ffffff;--panel2: #f4f5fd;--panel3: #eaedf8;--text: #111330;--text-soft: #2d3160;--muted: #5a609a;--line: rgba(0 0 30 / .12);--line2: rgba(0 0 30 / .06);--gold: #b07800;--gold-dim: rgba(176 120 0 / .12);--green: #1a8f5a;--green-dim: rgba(26 143 90 / .12);--red: #c9233f;--red-dim: rgba(201 35 63 / .1);--blue: #3545d6;--blue-dim: rgba(53 69 214 / .12);--purple: #7b2fd4;--purple-dim:rgba(123 47 212 / .12);--badge-bg: rgba(0 0 30 / .07);--input-bg: rgba(0 0 30 / .04);--hover-bg: rgba(0 0 30 / .04);--shadow-card: 0 8px 32px rgba(0 0 30 / .12);--shadow-btn: 0 6px 18px rgba(176 120 0 / .22);--shadow-blue: 0 0 14px rgba(53 69 214 / .22);--glow-gold: 0 0 14px rgba(176 120 0 / .22);--glow-green: 0 0 14px rgba(26 143 90 / .2);--glow-purple: 0 0 24px rgba(123 47 212 / .18)}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:var(--text-base);line-height:1.6;background:radial-gradient(circle at top left,var(--bg-grad-a) 0%,var(--bg-grad-b) 35%,var(--bg) 78%);background-attachment:fixed;color:var(--text);min-height:100vh}button,input,select,textarea{font:inherit}button{cursor:pointer}h1,h2,h3,h4{line-height:1.15;font-weight:800}h2{font-size:var(--text-lg);margin:0 0 var(--space-3)}h3{font-size:var(--text-md);margin:0 0 var(--space-3)}p{margin:var(--space-2) 0}img,svg{display:block;max-width:100%}.app{min-height:100vh}.shell{width:min(1220px,calc(100% - 28px));margin:0 auto;padding:var(--space-6) 0 var(--space-8)}.hero{display:grid;grid-template-columns:1.2fr .8fr;gap:var(--space-5);align-items:stretch;margin-bottom:var(--space-5)}.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--space-4)}.col-4{grid-column:span 4}.col-5{grid-column:span 5}.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-8{grid-column:span 8}.col-12{grid-column:span 12}.card{background:linear-gradient(160deg,#ffffff17,#ffffff0a);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);backdrop-filter:blur(18px);transition:box-shadow var(--t-base),border-color var(--t-base)}.card:hover{border-color:#ffffff2e;box-shadow:var(--shadow-card),0 0 0 1px #ffffff0a}[data-theme=light] .card{background:linear-gradient(160deg,#fff,#ffffffd9);border-color:#00001e1a}[data-theme=light] .card:hover{border-color:#00001e2e}.panel{padding:var(--space-5)}.hero-main{padding:var(--space-7) var(--space-7) var(--space-6);position:relative;overflow:hidden}.hero-main:after{content:"";position:absolute;inset:auto -80px -120px auto;width:330px;height:330px;background:radial-gradient(circle,var(--purple),transparent 65%);opacity:.28;pointer-events:none}.eyebrow{color:var(--gold);text-transform:uppercase;font-size:var(--text-xs);letter-spacing:.14em;font-weight:800;margin-bottom:var(--space-2)}.hero h1{font-size:var(--text-3xl);line-height:.92;margin:var(--space-3) 0;background:linear-gradient(135deg,var(--text) 40%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero p{color:var(--muted);font-size:var(--text-md);line-height:1.55;max-width:580px}.stats{padding:var(--space-5);display:grid;gap:var(--space-3)}.stat{padding:var(--space-4);border:1px solid var(--line);border-radius:var(--radius-lg);background:#0000002e;transition:background var(--t-base),border-color var(--t-base)}.stat:hover{background:#00000047;border-color:#ffffff2e}.stat b{display:block;font-size:var(--text-xl);font-weight:800;color:var(--gold)}.stat span{color:var(--muted);font-size:var(--text-sm)}[data-theme=light] .stat{background:#00001e0a}[data-theme=light] .stat:hover{background:#00001e14}.hero-controls{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-5)}.actions{display:flex;gap:var(--space-3);flex-wrap:wrap}.theme-toggle{border:1px solid var(--line);background:#ffffff14;color:var(--text);border-radius:var(--radius-pill);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-weight:700;line-height:1;display:inline-flex;align-items:center;gap:var(--space-1);cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-fast);flex-shrink:0}.theme-toggle:hover{background:#ffffff24;border-color:#ffffff38}.theme-toggle:active{transform:scale(.95)}.theme-toggle:focus-visible{outline:2px solid var(--blue);outline-offset:3px}[data-theme=light] .theme-toggle{background:#00001e0f;border-color:#00001e24}[data-theme=light] .theme-toggle:hover{background:#00001e1a}.btn{border:0;border-radius:var(--radius-pill);padding:12px 22px;font-size:var(--text-base);font-weight:800;color:#080a16;background:var(--gold);box-shadow:var(--shadow-btn);transition:transform var(--t-fast),box-shadow var(--t-fast),filter var(--t-fast);display:inline-flex;align-items:center;gap:var(--space-2)}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-btn),var(--glow-gold);filter:brightness(1.05)}.btn:active{transform:translateY(0);box-shadow:var(--shadow-btn);filter:brightness(.96)}.btn:focus-visible{outline:3px solid var(--gold);outline-offset:3px}.btn.secondary{background:#ffffff1a;color:var(--text);border:1px solid var(--line);box-shadow:none}.btn.secondary:hover{background:#ffffff29;border-color:#ffffff38;box-shadow:none;filter:none}.btn.secondary:focus-visible{outline-color:var(--blue)}.btn.danger{background:var(--red-dim);color:#ffd9e0;border:1px solid rgba(255 92 122 / .35);box-shadow:none}.btn.danger:hover{background:#ff5c7a3d;box-shadow:0 0 18px #ff5c7a40;filter:none}[data-theme=light] .btn{color:#fff;background:var(--blue);box-shadow:var(--shadow-blue)}[data-theme=light] .btn:hover{box-shadow:var(--shadow-blue),0 0 18px #3545d647}[data-theme=light] .btn:focus-visible{outline-color:var(--blue)}[data-theme=light] .btn.secondary{background:#00001e0f;color:var(--text);border-color:var(--line);box-shadow:none}[data-theme=light] .btn.danger{background:var(--red-dim);color:var(--red);border-color:#c9233f40}.tabs{display:flex;gap:var(--space-2);flex-wrap:wrap;margin:var(--space-5) 0;padding:0;list-style:none}.tab{border:1px solid var(--line);background:#ffffff12;color:var(--text);border-radius:var(--radius-pill);padding:10px 16px;font-size:var(--text-sm);font-weight:700;display:inline-flex;align-items:center;gap:var(--space-2);transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast)}.tab:hover{background:#ffffff1f;border-color:#fff3;transform:translateY(-1px)}.tab:active{transform:translateY(0)}.tab.active{background:var(--blue);border-color:transparent;color:#fff;box-shadow:var(--shadow-blue)}.tab.active:hover{filter:brightness(1.08);background:var(--blue)}.tab:focus-visible{outline:2px solid var(--blue);outline-offset:3px}.tab-icon{font-size:1em;line-height:1}[data-theme=light] .tab{background:#00001e0d;border-color:var(--line)}[data-theme=light] .tab:hover{background:#00001e17}[data-theme=light] .tab.active{background:var(--blue);color:#fff}.field{display:grid;gap:var(--space-1);margin:var(--space-3) 0}.field label{font-size:var(--text-sm);color:var(--muted);font-weight:700;letter-spacing:.02em}.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);background:var(--input-bg);color:var(--text);border-radius:var(--radius-md);padding:11px var(--space-3);outline:none;transition:border-color var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);appearance:none;-webkit-appearance:none}.field input:hover,.field select:hover,.field textarea:hover{border-color:#ffffff38}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #7c8cff38}.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible{outline:2px solid var(--blue);outline-offset:2px}[data-theme=light] .field input,[data-theme=light] .field select,[data-theme=light] .field textarea{background:#00001e0a;border-color:#00001e24;color:var(--text)}[data-theme=light] .field input:focus,[data-theme=light] .field select:focus,[data-theme=light] .field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3545d62e}.score-ring{width:170px;height:170px;border-radius:50%;display:grid;place-items:center;margin:var(--space-3) auto;background:conic-gradient(var(--green) calc(var(--score) * 1%),rgba(255 255 255 / .1) 0);position:relative;transition:background var(--t-slow);filter:drop-shadow(0 0 12px rgba(57 217 138 / .35))}.score-ring:before{content:"";position:absolute;inset:14px;border-radius:50%;background:var(--panel);transition:background var(--t-base)}.score-ring div{position:relative;text-align:center;z-index:1}.score-ring b{font-size:var(--text-2xl);font-weight:900;color:var(--green)}.score-ring span{color:var(--muted);font-size:var(--text-sm)}.bar{height:10px;border-radius:var(--radius-pill);background:#ffffff1a;overflow:hidden;margin-top:var(--space-1)}.bar>span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--blue),var(--green));width:var(--w, 0%);transition:width var(--t-slow);position:relative;overflow:hidden}.bar>span:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255 255 255 / .25) 50%,transparent 100%);animation:bar-shimmer 2s linear infinite}.mission{display:flex;gap:var(--space-3);align-items:flex-start;padding:var(--space-4);border:1px solid var(--line);border-radius:var(--radius-lg);background:#00000029;margin:var(--space-3) 0;transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-fast)}.mission:hover{background:#0000003d;border-color:#ffffff2e;transform:translate(2px)}.mission.done{opacity:.55;filter:saturate(.5)}.mission.done:hover{transform:none}[data-theme=light] .mission{background:#00001e0a}[data-theme=light] .mission:hover{background:#00001e14}.badge{display:inline-flex;align-items:center;gap:var(--space-1);border:1px solid var(--line);border-radius:var(--radius-pill);padding:5px 10px;background:var(--badge-bg);font-weight:800;font-size:var(--text-xs);white-space:nowrap;flex-shrink:0;transition:background var(--t-fast)}.map{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-bottom:var(--space-5)}.zone{min-height:126px;padding:var(--space-4);border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(160deg,#7c8cff2e,#ffffff0a);position:relative;overflow:hidden;transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base)}.zone:not(.locked):hover{transform:translateY(-3px);box-shadow:0 12px 30px #0000004d,var(--shadow-blue);border-color:#7c8cff80}.zone.locked{filter:saturate(.25);opacity:.5}.zone strong{display:block;font-size:var(--text-md);font-weight:800}.zone small{color:var(--muted);font-size:var(--text-sm)}.zone p{font-size:var(--text-xs);margin:var(--space-2) 0 0}.event{border:1px dashed rgba(255 209 102 / .55);background:var(--gold-dim);border-radius:var(--radius-lg);padding:var(--space-4);transition:background var(--t-base)}.event:hover{background:#ffd16624}[data-theme=light] .event{border-color:#b0780066;background:#b0780014}.drop{border:2px dashed rgba(124 140 255 / .5);border-radius:var(--radius-lg);padding:var(--space-6);text-align:center;background:var(--blue-dim);transition:border-color var(--t-fast),background var(--t-fast);cursor:pointer}.drop:hover,.drop:focus-within{border-color:var(--blue);background:#7c8cff24}.drop p{color:var(--muted);margin-bottom:var(--space-3)}.drop-label{display:block;cursor:pointer}.drop input[type=file]{display:block;margin:var(--space-2) auto 0;font-size:var(--text-sm);color:var(--muted);cursor:pointer}.drop input[type=file]:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:var(--radius-sm)}[data-theme=light] .drop{border-color:#3545d666;background:#3545d60f}.table-wrap{overflow-y:auto;max-height:340px;border-radius:var(--radius-md);border:1px solid var(--line)}table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}thead{position:sticky;top:0;z-index:2;background:var(--panel2)}[data-theme=light] thead{background:var(--panel3)}th,td{padding:var(--space-3) var(--space-3);border-bottom:1px solid var(--line2);text-align:left}th{color:var(--muted);font-weight:700;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em}tbody tr{transition:background var(--t-fast)}tbody tr:hover{background:var(--hover-bg)}tbody tr:last-child td{border-bottom:0}.pill{border-radius:var(--radius-pill);padding:4px 10px;font-size:var(--text-xs);font-weight:800;background:#ffffff1a}.toast{position:fixed;right:var(--space-5);bottom:var(--space-5);background:var(--panel2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);box-shadow:0 18px 50px #00000080,var(--shadow-blue);z-index:100;font-weight:700;animation:toast-in var(--t-slow) both;max-width:340px}[data-theme=light] .toast{background:var(--panel);box-shadow:0 8px 30px #00001e2e,var(--shadow-blue)}.confetti{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:200}.confetti i{position:absolute;top:-20px;width:10px;height:16px;background:var(--gold);border-radius:2px;animation:fall 1.4s linear forwards;transform:rotate(20deg)}.onboarding-overlay{position:fixed;inset:0;z-index:500;display:grid;place-items:center;background:radial-gradient(circle at top left,var(--bg-grad-a) 0%,var(--bg-grad-b) 35%,var(--bg) 78%);padding:var(--space-4)}.onboarding-card{width:min(560px,100%);max-height:90vh;overflow-y:auto}.settings-overlay{position:fixed;inset:0;z-index:500;display:grid;place-items:center;background:#0009;backdrop-filter:blur(4px);padding:var(--space-4)}[data-theme=light] .settings-overlay{background:#00001e73}.settings-card{width:min(480px,100%);max-height:90vh;overflow-y:auto}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.settings-title{margin:0}.settings-close{border:1px solid var(--line);background:#ffffff14;color:var(--text);border-radius:var(--radius-pill);width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;font-size:var(--text-base);cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast);flex-shrink:0}.settings-close:hover{background:#ffffff24;border-color:#ffffff38}.settings-close:focus-visible{outline:2px solid var(--blue);outline-offset:3px}[data-theme=light] .settings-close{background:#00001e0f;border-color:#00001e24}[data-theme=light] .settings-close:hover{background:#00001e1a}.settings-section{padding:var(--space-4) 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:var(--space-3)}.settings-section:first-of-type{border-top:none}.settings-section-title{margin:0 0 var(--space-1);font-size:var(--text-sm);color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.settings-action-btn{align-self:flex-start}.settings-file-label{cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-2)}.settings-file-field{margin:0}.settings-hint{margin:0;font-size:var(--text-xs)}.settings-error{color:var(--red);font-size:var(--text-sm);font-weight:700;margin:0;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);background:var(--red-dim);border:1px solid rgba(255 92 122 / .3)}[data-theme=light] .settings-error{background:#c9233f14;border-color:#c9233f40}.settings-confirm{padding:var(--space-3) var(--space-4);border:1px solid var(--line);border-radius:var(--radius-lg);background:#ffffff0a;display:flex;flex-direction:column;gap:var(--space-3)}.settings-confirm--danger{border-color:#ff5c7a4d;background:var(--red-dim)}[data-theme=light] .settings-confirm--danger{background:#c9233f0f;border-color:#c9233f38}.settings-confirm-text{margin:0;font-weight:700;font-size:var(--text-sm)}.settings-confirm-btns{display:flex;gap:var(--space-3);flex-wrap:wrap}@media(prefers-reduced-motion:reduce){.settings-overlay{backdrop-filter:none}}.wizard-progress{display:flex;gap:var(--space-2);margin-bottom:var(--space-3)}.wizard-dot{width:10px;height:10px;border-radius:50%;background:#ffffff2e;transition:background var(--t-base),transform var(--t-base)}.wizard-dot.active{background:var(--blue);transform:scale(1.25)}.wizard-dot.done{background:var(--green)}[data-theme=light] .wizard-dot{background:#00001e26}.wizard-step-label{margin:0 0 var(--space-2);font-size:var(--text-xs);letter-spacing:.04em;font-weight:700;text-transform:uppercase}.wizard-title{margin-bottom:var(--space-2)!important}.wizard-subtitle{margin-bottom:var(--space-4)!important}.wizard-fields{display:flex;flex-direction:column;gap:0}.wizard-hint{margin-top:var(--space-2)}.wizard-nav{display:flex;gap:var(--space-3);align-items:center}.field-hint{font-size:var(--text-xs);display:block;margin-top:var(--space-1)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;filter:none!important;box-shadow:none!important}.world-map-svg-wrap{margin-bottom:var(--space-5);border-radius:var(--radius-lg);border:1px solid var(--line);background:#0000002e;overflow:hidden}.world-map-svg{width:100%;height:auto;display:block}.zone-node.locked{pointer-events:none}.zone-pulse-ring{animation:zone-pulse 2s ease-in-out infinite;transform-origin:center}@keyframes zone-pulse{0%,to{opacity:.7;r:42}50%{opacity:.25;r:50}}@media(prefers-reduced-motion:reduce){.zone-pulse-ring{animation:none}}.checkin-fields{display:flex;flex-direction:column}.checkin-field-row{display:grid;grid-template-columns:1fr auto;gap:var(--space-2);align-items:end}.checkin-field-row .checkin-field-meta{display:flex;flex-direction:column;gap:2px}.checkin-field-row input{grid-column:1 / -1}.checkin-prev{font-size:var(--text-xs)}.checkin-review{border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-4)}.review-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--line2);font-size:var(--text-sm)}.review-row:last-child{border-bottom:0}.review-value{font-weight:700;display:flex;align-items:center;gap:var(--space-2)}.delta-positive{color:var(--green);font-weight:700}.delta-negative{color:var(--red);font-weight:700}.delta-neutral{color:var(--muted);font-weight:700}.import-summary{margin-top:var(--space-4);border:1px solid var(--line);border-radius:var(--radius-lg);padding:var(--space-4);background:#0000001f}.import-summary h3{margin-bottom:var(--space-3)}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--line2);font-size:var(--text-sm)}.summary-row:last-of-type{border-bottom:0}.recurring-panel{margin-top:var(--space-5);border-top:1px solid var(--line);padding-top:var(--space-4)}.recurring-total{margin-bottom:var(--space-3)!important}.recurring-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--line2);font-size:var(--text-sm)}.recurring-row:last-child{border-bottom:0}.recurring-name{flex:1;font-weight:600}.recurring-amount{font-weight:700;white-space:nowrap}.empty-state{text-align:center;padding:var(--space-7) var(--space-4)}.empty-emoji{font-size:48px;line-height:1;margin-bottom:var(--space-3)!important}.empty-title{font-weight:800;font-size:var(--text-md);margin-bottom:var(--space-2)!important}.chart-note{margin-bottom:var(--space-2)!important;font-size:var(--text-xs);opacity:.8}.xp-bar{margin-top:var(--space-2);height:8px}.xp-bar-label{margin:var(--space-1) 0 0!important;font-size:var(--text-xs)!important}.game-section-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.game-section-header h2{margin:0}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-3)}.achievement-card{display:flex;gap:var(--space-3);align-items:flex-start;padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--line);background:#00000024;transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-fast)}.achievement-card.earned{border-color:#ffd16666;background:var(--gold-dim)}.achievement-card.earned:hover{background:#ffd1662e;border-color:#ffd16699;transform:translateY(-2px)}.achievement-card.locked{filter:saturate(.25);opacity:.55}.achievement-card.locked:hover{opacity:.7;filter:saturate(.35)}[data-theme=light] .achievement-card{background:#00001e0a}[data-theme=light] .achievement-card.earned{background:#b0780014;border-color:#b078004d}.achievement-emoji{font-size:28px;line-height:1;flex-shrink:0}.achievement-body{flex:1;min-width:0}.achievement-title{display:block;font-size:var(--text-sm);font-weight:800;margin-bottom:2px}.achievement-desc{font-size:var(--text-xs)!important;margin:0!important}.achievement-date{display:block;font-size:var(--text-xs);margin-top:4px}.shop-coins{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-md);color:var(--gold);margin-left:auto}.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-3)}.shop-card{display:flex;gap:var(--space-3);align-items:flex-start;padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--line);background:#00000024;transition:background var(--t-fast),border-color var(--t-fast)}.shop-card.owned{border-color:#39d98a59;background:var(--green-dim)}[data-theme=light] .shop-card{background:#00001e0a}[data-theme=light] .shop-card.owned{background:#1a8f5a14;border-color:#1a8f5a4d}.shop-emoji{font-size:30px;line-height:1;flex-shrink:0}.shop-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.shop-title{font-size:var(--text-sm);font-weight:800}.shop-kind{font-size:var(--text-xs)!important;margin:0!important}.shop-btn{margin-top:var(--space-2);padding:8px 14px;font-size:var(--text-xs)}.shop-owned-badge{display:inline-flex;align-items:center;gap:var(--space-1);margin-top:var(--space-2);padding:5px 10px;border-radius:var(--radius-pill);border:1px solid rgba(57 217 138 / .4);background:var(--green-dim);color:var(--green);font-size:var(--text-xs);font-weight:800}[data-theme=light] .shop-owned-badge{border-color:#1a8f5a59;background:#1a8f5a1a}.event-card{display:flex;flex-direction:column;gap:var(--space-3)}.event-title{font-size:var(--text-md)}.event-amount{font-size:var(--text-xl);font-weight:900;margin:0!important}.event-positive{border-color:#39d98a80;background:var(--green-dim)}.event-positive:hover{background:#39d98a24}.event-negative{border-color:#ff5c7a73;background:var(--red-dim)}.event-negative:hover{background:#ff5c7a24}[data-theme=light] .event-positive{border-color:#1a8f5a66;background:#1a8f5a14}[data-theme=light] .event-negative{border-color:#c9233f59;background:#c9233f0f}.event-choices{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.event-choice-btn{padding:8px 14px;font-size:var(--text-xs)}.boss-section{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--line)}.boss-title{color:var(--red);margin-bottom:var(--space-2)!important}.subscription-row{flex-wrap:wrap;gap:var(--space-2);align-items:center}.decision-btns{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-left:auto}.decision-btn{padding:6px 12px;font-size:var(--text-xs);border-radius:var(--radius-pill)}.decision-btn.chosen{background:#ffd16633;border-color:var(--gold);color:var(--gold)}.decision-btn.chosen:hover{background:#ffd16647}[data-theme=light] .decision-btn.chosen{background:#b078001f;border-color:var(--gold);color:var(--gold)}.decision-badge{font-size:var(--text-xs)}.decision-opzeggen{color:var(--red);border-color:#ff5c7a66}.decision-houden{color:var(--green);border-color:#39d98a66}.boss-btn{display:block;width:100%;margin-top:var(--space-4);padding:14px 20px;font-size:var(--text-base);text-align:center;justify-content:center;box-shadow:var(--shadow-btn),var(--glow-gold);animation:boss-pulse 2s ease-in-out infinite}@keyframes boss-pulse{0%,to{box-shadow:var(--shadow-btn),var(--glow-gold)}50%{box-shadow:var(--shadow-btn),0 0 40px #ffd166a6}}@media(prefers-reduced-motion:reduce){.boss-btn{animation:none}}.boss-defeated{display:flex;flex-direction:column;gap:var(--space-3)}.boss-defeated-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill);border:1px solid rgba(57 217 138 / .4);background:var(--green-dim);color:var(--green);font-weight:800;font-size:var(--text-sm);align-self:flex-start}.boss-savings{margin:0!important}.spending-upload-row{display:flex;justify-content:flex-end}.spending-upload-btn{font-size:var(--text-sm);padding:8px 16px;cursor:pointer}.spending-header-top{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-4)}.spending-months{margin-bottom:var(--space-1)!important}.spending-total-row{display:flex;align-items:baseline;gap:var(--space-2)}.spending-total-label{color:var(--muted);font-size:var(--text-sm)}.spending-total-amount small{font-size:var(--text-sm);font-weight:400;color:var(--muted)}.spending-savings-chip{display:inline-flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--line);background:#ffffff0f;font-size:var(--text-sm);transition:background var(--t-base),border-color var(--t-base)}.spending-savings-chip--active{border-color:#39d98a73;background:var(--green-dim);color:var(--green)}.spending-savings-chip--active strong{font-size:var(--text-md)}[data-theme=light] .spending-savings-chip--active{border-color:#1a8f5a59;background:#1a8f5a1a}.spending-cat-bar{display:flex;height:12px;border-radius:var(--radius-pill);overflow:hidden;background:#ffffff14;margin-bottom:var(--space-3)}.spending-cat-bar-segment{height:100%;transition:width var(--t-slow);min-width:2px}.spending-cat-bar-segment:only-child{border-radius:var(--radius-pill)}.spending-cat-legend{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4)}.spending-legend-item{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs)}.spending-cat-card{padding:var(--space-4) var(--space-5)}.spending-cat-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap}.spending-cat-name{margin:0;font-size:var(--text-md);flex:1}.spending-cat-pct{font-size:var(--text-xs)}.spending-cat-total{font-weight:800;font-size:var(--text-base);margin-left:auto;white-space:nowrap}.spending-cat-total small{font-weight:400;font-size:var(--text-xs);color:var(--muted)}.spending-merchant-list{display:flex;flex-direction:column;gap:0}.spending-merchant-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--line2);transition:background var(--t-fast),padding var(--t-fast);flex-wrap:wrap}.spending-merchant-row:last-child{border-bottom:0}.spending-merchant-row:hover{background:var(--hover-bg);border-radius:var(--radius-sm);padding-left:var(--space-2);padding-right:var(--space-2)}.spending-merchant-row.cut .spending-merchant-name{text-decoration:line-through;color:var(--muted)}.spending-merchant-info{display:flex;flex-direction:column;gap:var(--space-1);min-width:0;flex:1}.spending-merchant-name{font-weight:600;font-size:var(--text-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color var(--t-fast),text-decoration var(--t-fast)}.spending-merchant-meta{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);font-size:var(--text-xs)}.spending-recurring-badge{font-size:var(--text-xs);padding:3px 7px}.spending-save-chip{display:inline-flex;align-items:center;padding:3px 8px;border-radius:var(--radius-pill);border:1px solid rgba(57 217 138 / .4);background:var(--green-dim);color:var(--green);font-size:var(--text-xs);font-weight:800;white-space:nowrap}[data-theme=light] .spending-save-chip{border-color:#1a8f5a59;background:#1a8f5a1a}.spending-cut-btn{flex-shrink:0;padding:6px 12px;font-size:var(--text-xs);border-radius:var(--radius-pill);transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast),transform var(--t-fast)}.spending-cut-btn--active,.spending-cut-btn[aria-pressed=true]{background:#39d98a24;border-color:#39d98a73;color:var(--green)}.spending-cut-btn--active:hover,.spending-cut-btn[aria-pressed=true]:hover{background:#39d98a38;border-color:#39d98a99}[data-theme=light] .spending-cut-btn--active,[data-theme=light] .spending-cut-btn[aria-pressed=true]{background:#1a8f5a1a;border-color:#1a8f5a66;color:var(--green)}.spending-transfers-note{font-size:var(--text-xs)!important;padding:var(--space-3) var(--space-4);border:1px solid var(--line2);border-radius:var(--radius-lg);background:#0000001a;margin:0}[data-theme=light] .spending-transfers-note{background:#00001e0a}@media(max-width:719px){.spending-merchant-row{flex-wrap:wrap;gap:var(--space-2)}.spending-cut-btn{flex:0 0 auto}.spending-header-top{flex-direction:column}.spending-savings-chip{align-self:stretch;justify-content:center}}[data-accent=emerald]{--gold: #34d399;--gold-dim: rgba(52 211 153 / .18);--shadow-btn: 0 10px 30px rgba(52 211 153 / .28);--glow-gold: 0 0 20px rgba(52 211 153 / .4)}[data-accent=emerald][data-theme=light]{--gold: #059669;--gold-dim: rgba(5 150 105 / .12);--shadow-btn: 0 6px 18px rgba(5 150 105 / .22);--glow-gold: 0 0 14px rgba(5 150 105 / .22)}[data-accent=violet]{--gold: #a78bfa;--gold-dim: rgba(167 139 250 / .18);--shadow-btn: 0 10px 30px rgba(167 139 250 / .28);--glow-gold: 0 0 20px rgba(167 139 250 / .4)}[data-accent=violet][data-theme=light]{--gold: #7c3aed;--gold-dim: rgba(124 58 237 / .12);--shadow-btn: 0 6px 18px rgba(124 58 237 / .22);--glow-gold: 0 0 14px rgba(124 58 237 / .22)}[data-accent=sunset]{--gold: #fb923c;--gold-dim: rgba(251 146 60 / .18);--shadow-btn: 0 10px 30px rgba(251 146 60 / .28);--glow-gold: 0 0 20px rgba(251 146 60 / .4)}[data-accent=sunset][data-theme=light]{--gold: #ea580c;--gold-dim: rgba(234 88 12 / .12);--shadow-btn: 0 6px 18px rgba(234 88 12 / .22);--glow-gold: 0 0 14px rgba(234 88 12 / .22)}.muted{color:var(--muted);font-size:var(--text-sm)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fall{to{transform:translateY(110vh) rotate(520deg)}}@keyframes toast-in{0%{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bar-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes bottom-nav-in{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:900px){.hero,.grid{display:block}.card{margin-bottom:var(--space-4)}.map{grid-template-columns:1fr}.shell{width:min(100% - 20px,1220px);padding-top:var(--space-4)}.hero h1{font-size:var(--text-2xl)}}@media(max-width:719px){.shell{padding-bottom:80px}.tabs{position:fixed;bottom:0;left:0;right:0;z-index:50;display:flex;flex-wrap:nowrap;gap:0;margin:0;padding:0;background:var(--panel);border-top:1px solid var(--line);box-shadow:0 -8px 30px #00000059;animation:bottom-nav-in .3s var(--ease-out) both;padding-bottom:env(safe-area-inset-bottom,0px)}[data-theme=light] .tabs{background:var(--panel);box-shadow:0 -4px 20px #00001e1f}.tab{flex:1;border-radius:0;border:0;border-top:2px solid transparent;background:transparent;flex-direction:column;gap:3px;padding:10px 4px;font-size:10px;font-weight:700;min-width:0;justify-content:center;align-items:center;color:var(--muted);transition:color var(--t-fast),border-top-color var(--t-fast),background var(--t-fast)}.tab:hover{transform:none;background:var(--hover-bg);color:var(--text);border-top-color:transparent}.tab.active{background:transparent;color:var(--blue);border-top-color:var(--blue);box-shadow:none;filter:none}.tab.active:hover{background:#7c8cff14;filter:none}.tab-icon{font-size:20px;line-height:1;display:block}.tab-label{display:block;line-height:1}.toast{bottom:calc(70px + var(--space-3) + env(safe-area-inset-bottom,0px))}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.confetti i{animation:none;display:none}.bar>span:after{animation:none}.score-ring{filter:none}}.spending-overview{display:flex;flex-direction:column;gap:var(--space-4)}.spending-upload-row{display:flex;justify-content:flex-end;margin-bottom:var(--space-2)}.spending-header{display:flex;flex-direction:column;gap:var(--space-4)}.spending-header-top{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:var(--space-4)}.spending-header-left{display:flex;flex-direction:column;gap:var(--space-2)}.spending-months{margin:0}.spending-total-row{display:flex;align-items:baseline;gap:var(--space-3)}.spending-label{color:var(--muted);font-size:var(--text-sm)}.spending-total-amount{font-size:var(--text-xl);font-weight:800;color:var(--text)}.spending-total-amount small{font-size:var(--text-sm);font-weight:400;color:var(--muted);margin-left:2px}.spending-savings-chip{display:flex;align-items:center;gap:var(--space-2);background:var(--green-dim);border:1px solid rgba(57 217 138 / .3);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);color:var(--green);flex-shrink:0}.spending-savings-chip.spending-savings-empty{background:#ffffff0d;border-color:var(--line);color:var(--muted)}.spending-savings-amount{font-size:var(--text-lg);font-weight:800;color:var(--green);display:block}.spending-scissors{font-size:var(--text-lg)}.spending-cat-bar{display:flex;height:12px;border-radius:var(--radius-pill);overflow:hidden;gap:2px}.spending-cat-bar-segment{height:100%;border-radius:0;transition:opacity var(--t-fast);min-width:4px}.spending-cat-bar-segment:first-child{border-radius:var(--radius-pill) 0 0 var(--radius-pill)}.spending-cat-bar-segment:last-child{border-radius:0 var(--radius-pill) var(--radius-pill) 0}.spending-cat-legend{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4);margin-top:var(--space-1)}.spending-legend-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm)}.spending-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.spending-cat-card{display:flex;flex-direction:column;gap:var(--space-3)}.spending-cat-header{display:flex;align-items:center;gap:var(--space-3)}.spending-cat-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.spending-cat-name{margin:0;flex:1;font-size:var(--text-md)}.spending-cat-pct{font-size:var(--text-sm)}.spending-cat-total{font-size:var(--text-md);font-weight:800;color:var(--text)}.spending-cat-total small{font-size:var(--text-sm);font-weight:400;color:var(--muted)}.spending-merchant-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--line2);border-radius:var(--radius-md);overflow:hidden}.spending-merchant-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);transition:background var(--t-fast);border-bottom:1px solid var(--line2)}.spending-merchant-row:last-child{border-bottom:none}.spending-merchant-row:hover{background:var(--hover-bg)}.spending-merchant-row.spending-merchant-cut{background:var(--green-dim)}.spending-merchant-row.spending-merchant-cut:hover{background:#39d98a26}.spending-merchant-info{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:0}.spending-merchant-name{font-weight:600;font-size:var(--text-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spending-merchant-name-cut{text-decoration:line-through;opacity:.6}.spending-merchant-count{font-size:var(--text-xs);flex-shrink:0}.spending-recurring-badge{flex-shrink:0;font-size:var(--text-xs);padding:2px 6px}.spending-merchant-right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.spending-merchant-amount{font-size:var(--text-sm);white-space:nowrap}.spending-save-chip{background:var(--green-dim);color:var(--green);border:1px solid rgba(57 217 138 / .3);border-radius:var(--radius-pill);padding:2px 10px;font-size:var(--text-sm);font-weight:700;white-space:nowrap}.spending-cut-btn{padding:6px 12px;font-size:var(--text-xs);font-weight:700;flex-shrink:0;min-width:56px}.spending-cut-btn.spending-cut-btn-active{background:#39d98a26;border-color:#39d98a59;color:var(--green)}.spending-cut-btn.spending-cut-btn-active:hover{background:#39d98a38}.spending-transfers{border-style:dashed}.spending-transfers-note{margin:0;font-size:var(--text-sm)}@media(max-width:719px){.spending-header-top{flex-direction:column}.spending-savings-chip{width:100%;justify-content:center}.spending-merchant-row{flex-wrap:wrap;gap:var(--space-2)}.spending-merchant-info{width:100%}.spending-merchant-right{width:100%;justify-content:flex-end}}
