*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}:root{--bg: #0b1120;--bg-2: #0f172a;--surface: #131c31;--surface-2: #1b2540;--border: #263149;--text: #e8edf7;--muted: #94a3b8;--accent: #6366f1;--accent-2: #818cf8;--danger: #f87171;--ok: #34d399;--radius: 18px;--radius-sm: 12px;--nav-h: 68px;--safe-b: env(safe-area-inset-bottom, 0px);--safe-t: env(safe-area-inset-top, 0px)}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:16px;line-height:1.45;-webkit-font-smoothing:antialiased;overscroll-behavior-y:none}button,input,textarea{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}h1,h2{font-weight:700;letter-spacing:-.02em}.muted{color:var(--muted)}.small{font-size:.82rem}.center{text-align:center;margin-inline:auto}.app{min-height:100%;display:flex;flex-direction:column;background:radial-gradient(1200px 600px at 50% -10%,rgba(99,102,241,.14),transparent 60%),var(--bg)}.main{flex:1;position:relative;overflow-y:auto;padding-bottom:calc(var(--nav-h) + var(--safe-b) + 12px)}.screen{max-width:680px;margin:0 auto;padding:calc(var(--safe-t) + 20px) 18px 28px;animation:fade .25s ease}@keyframes fade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.hero{margin-bottom:22px}.hero.compact{margin-bottom:16px}.hero-date{color:var(--accent-2);font-weight:600;font-size:.85rem;text-transform:capitalize;margin-bottom:4px}.hero-title{font-size:1.7rem;line-height:1.15}.hero-sub{color:var(--muted);margin-top:6px}.progress{margin-top:14px;height:8px;border-radius:99px;background:var(--surface-2);overflow:hidden}.progress-bar{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .4s ease}.block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:16px}.block-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.block-head h2{font-size:1.05rem}.area-head{display:flex;align-items:center;gap:8px}.task-list{list-style:none;display:flex;flex-direction:column;gap:2px}.task{display:flex;align-items:center;gap:12px;padding:10px 4px;border-radius:var(--radius-sm);transition:background .15s}.task:hover{background:#ffffff08}.task-title{flex:1;font-size:.98rem}.task.done .task-title{text-decoration:line-through;color:var(--muted)}.checkbox{width:26px;height:26px;flex-shrink:0;border-radius:9px;border:2px solid var(--border);display:grid;place-items:center;color:#fff;transition:all .15s}.checkbox:hover{border-color:var(--area, var(--accent))}.task.done .checkbox{background:var(--area, var(--accent));border-color:var(--area, var(--accent))}.dot{width:9px;height:9px;border-radius:99px;flex-shrink:0}.star{color:var(--muted);opacity:.5;padding:4px;transition:all .15s}.star.on{color:#fbbf24;opacity:1}.star:hover{opacity:1}.habit-row{display:flex;flex-wrap:wrap;gap:8px}.habit-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px 8px 8px;border-radius:99px;background:var(--surface-2);border:1px solid var(--border);transition:all .15s}.habit-pill:active{transform:scale(.96)}.habit-pill.done{border-color:var(--area);background:color-mix(in srgb,var(--area) 18%,var(--surface-2))}.habit-pill-check{width:26px;height:26px;display:grid;place-items:center;border-radius:99px;background:var(--bg-2);color:#fff;font-size:.9rem}.habit-pill.done .habit-pill-check{background:var(--area)}.habit-pill-name{font-size:.9rem;font-weight:500}.habit-pill-streak{display:inline-flex;align-items:center;gap:3px;font-size:.8rem;font-weight:700;color:#fb923c}.habit-cards{display:flex;flex-direction:column;gap:14px}.habit-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;position:relative;overflow:hidden}.habit-card:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--area)}.habit-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}.habit-card-title{display:flex;gap:12px;align-items:center}.habit-emoji{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:color-mix(in srgb,var(--area) 18%,var(--surface-2));font-size:1.3rem}.habit-name{font-weight:600}.habit-meta{font-size:.82rem;margin-top:2px}.streak-badge{display:inline-flex;align-items:center;gap:3px;color:#fb923c;font-weight:700}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:14px}.day-cell{aspect-ratio:1;border-radius:10px;background:var(--surface-2);border:1px solid transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;transition:all .15s}.day-dow{font-size:.6rem;color:var(--muted);text-transform:uppercase}.day-num{font-size:.85rem;font-weight:600}.day-cell.done{background:var(--area);color:#06121f}.day-cell.done .day-dow{color:#06121fb3}.day-cell.today{border-color:var(--area)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border-radius:14px;background:var(--surface-2);border:1px solid var(--border);font-weight:600;font-size:.95rem;transition:all .15s}.btn:active{transform:scale(.98)}.btn.primary{background:linear-gradient(180deg,var(--accent-2),var(--accent));border-color:transparent;color:#fff;box-shadow:0 6px 18px #6366f159}.btn.primary:disabled{opacity:.5;box-shadow:none}.btn.full{width:100%;margin-top:8px}.btn.lg{padding:15px;font-size:1.02rem}.btn.danger{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 40%,var(--border))}.habit-check.done{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 45%,var(--border));background:color-mix(in srgb,var(--ok) 12%,var(--surface));width:100%}.habit-check.primary{width:100%}.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.btn-row .btn{flex:1}.text-btn{display:inline-flex;align-items:center;gap:5px;color:var(--accent-2);font-weight:600;font-size:.88rem;padding:4px}.text-btn.danger{color:var(--danger)}.text-btn.center{display:flex;margin:4px auto 0}.icon-btn{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;color:var(--muted);transition:all .15s}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.icon-btn.ghost{opacity:.55}.icon-btn.ghost:hover{opacity:1;color:var(--danger)}.fab{position:fixed;right:max(18px,env(safe-area-inset-right));bottom:calc(var(--nav-h) + var(--safe-b) + 18px);width:58px;height:58px;border-radius:50%;background:linear-gradient(180deg,var(--accent-2),var(--accent));color:#fff;display:grid;place-items:center;box-shadow:0 10px 26px #6366f173;z-index:40;transition:transform .15s}.fab:active{transform:scale(.92)}.segmented{display:flex;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:4px;margin-bottom:16px}.seg{flex:1;padding:8px;border-radius:9px;font-size:.88rem;font-weight:600;color:var(--muted);transition:all .15s}.seg.active{background:var(--surface-2);color:var(--text)}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;position:relative;overflow:hidden}.stat:after{content:"";position:absolute;top:-20px;right:-20px;width:70px;height:70px;border-radius:50%;background:var(--accent);opacity:.14}.stat-value{display:block;font-size:2rem;font-weight:800;letter-spacing:-.03em;color:var(--accent)}.stat-label{font-size:.82rem;color:var(--muted)}.past-list{display:flex;flex-direction:column;gap:8px}.past-item{background:var(--surface-2);border-radius:var(--radius-sm);padding:10px 14px}.past-item summary{cursor:pointer;font-weight:600;font-size:.9rem}.past-item p{font-size:.88rem;margin-top:8px;color:var(--muted)}.past-item strong{color:var(--text)}.field{width:100%;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:13px 14px;font-size:1rem;transition:border .15s}.field:focus{outline:none;border-color:var(--accent-2)}.field.area{resize:vertical;min-height:60px;margin-bottom:4px}.field-label{display:block;font-size:.8rem;font-weight:600;color:var(--muted);margin:14px 0 7px}.switch-row{display:flex;align-items:center;gap:10px;margin:14px 0;font-size:.9rem}.switch-row input{width:20px;height:20px;accent-color:var(--accent)}.switch-row.big{padding:12px;background:var(--surface);border-radius:12px}.area-picker{display:flex;flex-wrap:wrap;gap:8px}.area-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:99px;background:var(--surface-2);border:1.5px solid var(--border);font-size:.88rem;font-weight:500;transition:all .15s}.area-chip.active{border-color:var(--chip);background:color-mix(in srgb,var(--chip) 18%,var(--surface-2));color:#fff}.empty{text-align:center;padding:30px 20px;color:var(--muted)}.empty-icon{display:inline-grid;place-items:center;width:60px;height:60px;border-radius:18px;background:var(--surface-2);color:var(--accent-2);margin-bottom:12px}.empty-title{font-weight:600;color:var(--text)}.empty-hint{font-size:.88rem;margin-top:4px}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#03071299;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:flex-end;justify-content:center;animation:fade .2s ease}.sheet{width:100%;max-width:560px;background:var(--surface);border:1px solid var(--border);border-radius:24px 24px 0 0;padding:8px 20px calc(24px + var(--safe-b));max-height:88vh;overflow-y:auto;animation:slideup .28s cubic-bezier(.22,1,.36,1)}@keyframes slideup{0%{transform:translateY(100%)}to{transform:none}}.sheet-head{display:flex;align-items:center;justify-content:space-between;padding:10px 0 6px;position:sticky;top:0;background:var(--surface)}.sheet-head h2{font-size:1.15rem}.sheet-body{padding-top:4px}.settings-group{margin-top:22px;padding-top:18px;border-top:1px solid var(--border)}.nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-h) + var(--safe-b));padding-bottom:var(--safe-b);background:color-mix(in srgb,var(--bg-2) 92%,transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border);z-index:50}.nav-brand{display:none}.nav-tabs{height:var(--nav-h);display:flex;max-width:680px;margin:0 auto}.nav-item{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);font-size:.6rem;font-weight:600;transition:color .15s;position:relative}.nav-item span{white-space:nowrap}.nav-item.active{color:var(--accent-2)}.nav-item.active:before{content:"";position:absolute;top:8px;width:34px;height:30px;border-radius:10px;background:color-mix(in srgb,var(--accent) 20%,transparent);z-index:-1}.settings-btn{position:absolute;top:calc(var(--safe-t) + 20px);right:18px;z-index:30;width:38px;height:38px;border-radius:11px;display:grid;place-items:center;color:var(--muted);background:var(--surface);border:1px solid var(--border)}.settings-btn:hover{color:var(--text)}.brand-flame{color:#fb923c}.onboarding{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(900px 500px at 50% -5%,rgba(99,102,241,.22),transparent 60%),var(--bg)}.onboard-card{width:100%;max-width:440px;background:var(--surface);border:1px solid var(--border);border-radius:26px;padding:30px 24px calc(24px + var(--safe-b));text-align:center}.onboard-logo{width:76px;height:76px;border-radius:22px;background:var(--surface-2);display:grid;place-items:center;margin:0 auto 18px}.onboard-card h1{font-size:1.55rem}.onboard-sub{color:var(--muted);margin:10px 0 6px;font-size:.95rem}.onboard-card .field-label,.onboard-card .switch-row span,.onboard-card .switch-row{text-align:left}.onboard-foot{margin-top:14px;font-size:.78rem;color:var(--muted)}@media (min-width: 860px){.app{flex-direction:row}.nav{position:sticky;top:0;height:100vh;width:230px;flex-shrink:0;border-top:none;border-right:1px solid var(--border);padding:24px 14px;background:var(--bg-2);-webkit-backdrop-filter:none;backdrop-filter:none}.nav-brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.2rem;letter-spacing:-.02em;padding:0 12px 22px}.nav-tabs{flex-direction:column;height:auto;gap:4px}.nav-item{flex-direction:row;justify-content:flex-start;gap:12px;padding:12px 14px;border-radius:12px;font-size:.95rem}.nav-item.active{background:color-mix(in srgb,var(--accent) 16%,transparent)}.nav-item.active:before{display:none}.main{padding-bottom:0;height:100vh}.screen{padding:34px 28px 60px}.fab{bottom:30px;right:30px}.settings-btn{top:28px;right:28px}.stat-grid{grid-template-columns:repeat(4,1fr)}}.phrase-card{display:flex;gap:12px;align-items:flex-start;background:linear-gradient(135deg,#818cf82e,#6366f10f);border:1px solid color-mix(in srgb,var(--accent) 35%,var(--border));border-radius:var(--radius);padding:16px;margin-bottom:16px}.phrase-card p{font-size:1.02rem;font-weight:600;line-height:1.35;letter-spacing:-.01em}.phrase-spark{color:var(--accent-2);flex-shrink:0;margin-top:2px}.notif-prompt{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:16px;color:var(--text)}.notif-prompt>svg{color:var(--accent-2);flex-shrink:0}.notif-prompt span{flex:1;font-size:.86rem;color:var(--muted);line-height:1.35}.notif-prompt strong{color:var(--text)}.notif-prompt-cta{flex:0 0 auto!important;background:var(--accent);color:#fff!important;font-weight:700;font-size:.85rem!important;padding:8px 14px;border-radius:10px}.alerts{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.alert{display:flex;flex-direction:column;gap:3px;text-align:left;padding:13px 15px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);border-left:4px solid var(--accent)}.alert.finanza{border-left-color:#34d399}.alert.finanza.warn{border-left-color:#f87171}.alert.promemoria{border-left-color:#fbbf24}.alert-title{font-weight:700;font-size:.9rem}.alert-body{font-size:.85rem;color:var(--muted);line-height:1.35}.month-nav{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:14px}.month-nav .icon-btn{font-size:1.5rem;line-height:1;background:var(--surface);border:1px solid var(--border)}.month-label{font-weight:700;text-transform:capitalize;min-width:150px;text-align:center}.fin-summary{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:16px}.fin-cell{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;text-align:center}.fin-cell-label{display:block;font-size:.72rem;color:var(--muted);margin-bottom:3px}.fin-cell-val{font-weight:800;font-size:.98rem;letter-spacing:-.02em}.fin-cell.in .fin-cell-val{color:#34d399}.fin-cell.out .fin-cell-val{color:#f87171}.fin-cell.saldo{background:var(--surface-2)}.fin-cell.saldo.neg .fin-cell-val{color:#f87171}.goal-list{display:flex;flex-direction:column;gap:14px}.goal-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.goal-title{font-weight:600}.goal-meta{margin-top:1px}.goal-pct{text-align:right;color:var(--muted);margin-top:5px;font-weight:600}.tx-list{list-style:none;display:flex;flex-direction:column;gap:2px}.tx{display:flex;align-items:center;gap:11px;padding:9px 2px;border-radius:var(--radius-sm)}.tx:hover{background:#ffffff08}.tx-icon{width:38px;height:38px;flex-shrink:0;display:grid;place-items:center;border-radius:11px;font-size:1.15rem;background:var(--surface-2)}.tx-icon.entrata{background:color-mix(in srgb,#34d399 16%,var(--surface-2))}.tx-icon.uscita{background:color-mix(in srgb,#f87171 16%,var(--surface-2))}.tx-main{flex:1;display:flex;flex-direction:column;min-width:0}.tx-cat{font-weight:500;font-size:.92rem}.tx-note{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tx-date{flex-shrink:0}.tx-amount{font-weight:800;font-size:.92rem;flex-shrink:0;letter-spacing:-.02em}.tx-amount.entrata{color:#34d399}.tx-amount.uscita{color:#f87171}.amount-field{font-size:1.5rem!important;font-weight:700;text-align:center}.seg.active.in{color:#34d399}.seg.active.out{color:#f87171}.work-summary{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.work-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:3px}.work-card-tag{font-size:.78rem;color:var(--muted)}.work-card-hours{font-size:1.8rem;font-weight:800;letter-spacing:-.03em;color:var(--accent-2)}.week-bars{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;align-items:end;height:130px}.wbar-col{display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;justify-content:flex-end}.wbar-track{width:100%;flex:1;display:flex;align-items:flex-end;background:var(--surface-2);border-radius:7px;overflow:hidden;min-height:4px}.wbar-fill{width:100%;background:linear-gradient(180deg,var(--accent-2),var(--accent));border-radius:7px 7px 0 0;min-height:2px;transition:height .3s ease}.wbar-fill.today{background:linear-gradient(180deg,#fbbf24,#f59e0b)}.wbar-h{font-size:.62rem;font-weight:700;color:var(--muted);height:.8rem}.wbar-dow{font-size:.66rem;color:var(--muted);text-transform:uppercase}.wbar-dow.today{color:#fbbf24;font-weight:700}.shift-days{display:flex;flex-direction:column;gap:16px}.shift-day-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid var(--border)}.shift-day-date{font-weight:600;font-size:.9rem;text-transform:capitalize}.shift-day-total{font-size:.82rem;color:var(--accent-2);font-weight:700}.shift-row{display:flex;align-items:center;gap:10px;padding:8px 6px;margin:0 -6px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}.shift-row:hover{background:#ffffff08}.shift-time{font-weight:700;font-size:.9rem;font-variant-numeric:tabular-nums;flex-shrink:0}.shift-info{flex:1;display:flex;flex-direction:column;min-width:0;gap:1px}.shift-dur{font-size:.85rem}.shift-note{font-size:.8rem;color:var(--accent-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shift-note-empty{opacity:.6}.shift-pay{font-weight:700;font-size:.85rem;color:#34d399;flex-shrink:0}.time-row{display:flex;gap:12px}.time-row>div{flex:1}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:11px 0}.toggle-label{display:block;font-weight:500;font-size:.94rem}.toggle-hint{display:block}.toggle{position:relative;width:46px;height:28px;flex-shrink:0;border-radius:99px;background:var(--surface-2);border:1px solid var(--border);transition:background .2s}.toggle.on{background:var(--accent);border-color:var(--accent)}.toggle input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer}.toggle-knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s;pointer-events:none}.toggle.on .toggle-knob{transform:translate(18px)}select.field{-moz-appearance:none;appearance:none;-webkit-appearance:none}
