*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
button{touch-action:manipulation;-webkit-tap-highlight-color:transparent;cursor:pointer}
input,textarea,select{touch-action:manipulation}
:root{
  --bg:#0D0B1E;--surface:#1A1530;--surface2:#241D42;--surface3:#2E2558;
  --primary:#8B5CF6;--primary-light:#A78BFA;--primary-dark:#6D28D9;
  --accent:#F59E0B;--success:#10B981;--danger:#EF4444;--warning:#FBBF24;
  --text:#F1EEFF;--text-muted:#9B8EC4;--text-dim:#6B5F9E;
  --radius:16px;--radius-sm:10px;--radius-lg:24px;
  --shadow:0 4px 24px rgba(0,0,0,0.4);--glow:0 0 20px rgba(139,92,246,0.3);
  --nav-h:68px;
}
html{height:100%;height:-webkit-fill-available}
html,body{overflow:hidden}
body{height:100%;height:-webkit-fill-available;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;-webkit-font-smoothing:antialiased}
#app{display:flex;flex-direction:column;height:100vh;height:100dvh;height:-webkit-fill-available;max-width:480px;margin:0 auto;position:relative;overflow:hidden}

/* HEADER */
.header{background:linear-gradient(135deg,#1A1530,#241D42);padding:12px 16px 10px;border-bottom:1px solid rgba(139,92,246,0.2);flex-shrink:0}
.header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.app-brand{display:flex;align-items:center;gap:8px}
.app-icon{font-size:20px;filter:drop-shadow(0 0 8px rgba(139,92,246,0.8))}
.app-name{font-size:19px;font-weight:800;background:linear-gradient(135deg,#A78BFA,#F59E0B);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.app-version{font-size:9px;color:var(--text-dim);font-weight:500;opacity:0.6;margin-left:1px;align-self:flex-end;margin-bottom:2px}
.streak-badge{display:flex;align-items:center;gap:4px;background:rgba(245,158,11,0.15);border:1px solid rgba(245,158,11,0.3);border-radius:20px;padding:3px 10px;font-weight:700;font-size:14px;color:var(--accent)}
.xp-section{}
.level-row{display:flex;align-items:center;gap:6px;margin-bottom:5px}
.level-tag{background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:20px}
.level-title{font-size:12px;color:var(--primary-light);font-weight:600;flex:1}
.xp-numbers{font-size:11px;color:var(--text-muted)}
.xp-bar-track{height:7px;background:rgba(139,92,246,0.15);border-radius:99px;overflow:hidden}
.xp-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:99px;transition:width 0.8s cubic-bezier(0.34,1.56,0.64,1);box-shadow:0 0 10px rgba(139,92,246,0.5)}

/* MAIN */
#main-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}
#main-content::-webkit-scrollbar{display:none}
.tab{display:none;padding:14px 14px calc(24px + env(safe-area-inset-bottom,0px));min-height:100%;animation:fadeIn 0.22s ease}
.tab.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.ios-safe-bottom{height:env(safe-area-inset-bottom,0px);flex-shrink:0;background:var(--bg)}

/* BACK BUTTON */
.btn-go-launcher{background:none;border:none;color:var(--primary-light);font-size:26px;font-weight:700;padding:0 10px 0 0;line-height:1;flex-shrink:0;transition:opacity 0.15s}
.btn-go-launcher:active{opacity:0.6}

/* DAILY CHALLENGE */
.daily-challenge-card{background:linear-gradient(135deg,#2D1B69,#1A1030);border:1px solid rgba(139,92,246,0.35);border-radius:var(--radius-lg);padding:14px;margin-bottom:14px;box-shadow:var(--glow)}
.dc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.dc-left{display:flex;align-items:center;gap:10px}
.dc-icon{font-size:26px}
.dc-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:600}
.dc-desc{font-size:13px;font-weight:700}
.dc-xp-badge{background:linear-gradient(135deg,var(--accent),#F97316);color:#000;font-size:11px;font-weight:800;padding:3px 9px;border-radius:20px;white-space:nowrap}
.dc-bar-track{height:5px;background:rgba(255,255,255,0.08);border-radius:99px;overflow:hidden;margin-bottom:5px}
.dc-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--success));border-radius:99px;transition:width 0.6s ease}
.dc-count{font-size:11px;color:var(--text-muted);text-align:right}

/* POMODORO HOME CARD */
.pomodoro-home-card{background:linear-gradient(135deg,#1E1030,#2A1545);border:1px solid rgba(239,100,67,0.3);border-radius:var(--radius-lg);padding:14px;margin-bottom:14px}
.pom-home-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.pom-home-left{display:flex;align-items:center;gap:10px}
.pom-home-icon{font-size:26px}
.pom-home-title{font-size:14px;font-weight:700;color:var(--text)}
.pom-home-sub{font-size:11px;color:var(--text-muted);margin-top:2px}
.pom-home-display{font-size:28px;font-weight:800;font-variant-numeric:tabular-nums;color:#FB923C;text-shadow:0 0 12px rgba(251,146,60,0.4);letter-spacing:-1px}
.pom-time-opts{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.pom-time-opt{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);color:var(--text-muted);border-radius:20px;padding:5px 11px;font-size:12px;font-weight:600;cursor:pointer;transition:all 0.2s;white-space:nowrap}
.pom-time-opt.selected{background:rgba(251,146,60,0.2);border-color:rgba(251,146,60,0.5);color:#FB923C}
.pom-time-opt:hover{border-color:rgba(251,146,60,0.4);color:#FB923C}
.pom-home-btns{display:flex;gap:8px}
.btn-pom-main{flex:1;background:linear-gradient(135deg,#EA580C,#DC2626);color:#fff;border:none;border-radius:var(--radius-sm);padding:11px;font-size:14px;font-weight:700;cursor:pointer;transition:all 0.2s;box-shadow:0 3px 14px rgba(234,88,12,0.4)}
.btn-pom-main:active{transform:scale(0.97)}
.btn-pom-reset-home{background:var(--surface2);border:1px solid rgba(255,255,255,0.1);color:var(--text-muted);border-radius:var(--radius-sm);padding:11px 14px;font-size:16px;cursor:pointer;transition:all 0.2s}
.btn-pom-reset-home:hover{color:var(--text)}
.pom-custom-row{display:flex;gap:8px;margin-top:8px}
.pom-custom-input{flex:1;padding:8px 12px;font-size:14px}
.btn-pom-set{background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 14px;font-size:13px;font-weight:700;cursor:pointer}

/* SECTION HEADER */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.section-header h2{font-size:16px;font-weight:700}
.btn-add{background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:6px 13px;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s;box-shadow:0 2px 10px rgba(139,92,246,0.4)}
.btn-add:active{transform:scale(0.95)}
.btn-icon{background:var(--surface2);border:1px solid rgba(255,255,255,0.1);color:var(--text-muted);border-radius:var(--radius-sm);padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:all 0.2s}
.btn-icon:hover{color:var(--text);border-color:var(--primary)}

/* TASK LIST */
.task-list{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.task-item{background:var(--surface);border-radius:var(--radius);padding:12px 12px 12px 0;display:flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,0.06);transition:all 0.2s;position:relative;overflow:hidden;animation:slideIn 0.3s ease}
@keyframes slideIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}
.task-item:active{transform:scale(0.98)}
.task-priority-bar{width:4px;align-self:stretch;border-radius:0 3px 3px 0;flex-shrink:0}
.priority-urgent .task-priority-bar{background:var(--danger)}
.priority-normal .task-priority-bar{background:var(--warning)}
.priority-later .task-priority-bar{background:var(--success)}
.task-check-btn{width:36px;height:36px;border-radius:50%;border:2px solid rgba(255,255,255,0.2);background:transparent;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all 0.25s;color:transparent;touch-action:manipulation}
.priority-urgent .task-check-btn{border-color:var(--danger)}
.priority-normal .task-check-btn{border-color:var(--warning)}
.priority-later .task-check-btn{border-color:var(--success)}
.task-check-btn:hover{transform:scale(1.15);background:rgba(139,92,246,0.2)}
.task-info{flex:1;min-width:0}
.task-title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.task-meta{display:flex;gap:6px;margin-top:3px;flex-wrap:wrap}
.task-date{font-size:11px;color:var(--text-muted)}
.task-xp-badge{font-size:11px;color:var(--accent);font-weight:600}
.task-rec-badge{font-size:12px;margin-left:4px}
.task-prio-tag{font-size:11px;padding:1px 6px;border-radius:20px;font-weight:600}
.priority-urgent .task-prio-tag{background:rgba(239,68,68,0.15);color:#FCA5A5}
.priority-normal .task-prio-tag{background:rgba(251,191,36,0.15);color:#FDE68A}
.priority-later .task-prio-tag{background:rgba(16,185,129,0.15);color:#6EE7B7}
.task-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}
.task-break-btn,.task-edit-btn,.task-delete-btn{background:transparent;border:none;color:var(--text-dim);cursor:pointer;font-size:16px;padding:8px 7px;border-radius:8px;transition:all 0.2s;touch-action:manipulation;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center}
.task-break-btn:hover{color:#6EE7B7;background:rgba(16,185,129,0.1)}
.task-edit-btn:hover{color:var(--primary-light);background:rgba(139,92,246,0.1)}
.task-delete-btn{flex-shrink:0}
.task-delete-btn:hover{color:var(--danger);background:rgba(239,68,68,0.1)}
.task-steps-badge{font-size:11px;color:#6EE7B7;font-weight:600}

/* Task picker */
.picker-task-btn{width:100%;display:flex;align-items:center;gap:0;background:var(--surface2);border:1px solid rgba(255,255,255,0.06);border-radius:var(--radius);padding:0;margin-bottom:8px;cursor:pointer;text-align:left;color:var(--text);transition:all 0.2s;-webkit-tap-highlight-color:transparent;overflow:hidden;font-family:inherit}
.picker-task-btn:hover,.picker-task-btn:active{border-color:var(--primary);background:rgba(139,92,246,0.1)}
.picker-bar{width:4px;align-self:stretch;flex-shrink:0}
.priority-urgent .picker-bar{background:var(--danger)}
.priority-normal .picker-bar{background:var(--warning)}
.priority-later .picker-bar{background:var(--success)}
.picker-info{flex:1;padding:12px 10px}
.picker-title{font-size:14px;font-weight:700;margin-bottom:4px}
.picker-prio{font-size:11px;color:var(--text-muted)}
.picker-arrow{font-size:20px;color:var(--text-dim);padding:0 12px}
.task-item.completed{opacity:0.5}
.task-item.completed .task-title{text-decoration:line-through;color:var(--text-muted)}
.task-item.completed .task-check-btn{background:var(--success);border-color:var(--success);color:#fff}
.template-item{border:1px dashed rgba(139,92,246,0.3)}
.empty-state{text-align:center;padding:36px 20px;color:var(--text-muted)}
.empty-state span{font-size:38px;display:block;margin-bottom:10px}
.empty-state p{font-size:14px}
.empty-sub{font-size:12px;margin-top:4px;color:var(--text-dim)}

/* ONE THING BUTTON */
.one-thing-btn{width:100%;display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,var(--surface2),var(--surface3));border:1px solid rgba(139,92,246,0.3);border-radius:var(--radius);padding:14px;cursor:pointer;text-align:left;color:var(--text);transition:all 0.2s;margin-bottom:16px}
.one-thing-btn:hover{border-color:var(--primary);box-shadow:var(--glow)}
.one-thing-btn:active{transform:scale(0.98)}
.one-thing-btn span:first-child{font-size:26px}
.one-thing-btn strong{font-size:14px;display:block}
.one-thing-btn p{font-size:11px;color:var(--text-muted);margin-top:2px}
.one-thing-btn .arrow{font-size:20px;color:var(--text-dim);margin-left:auto}

/* FILTER BAR */
.filter-bar{display:flex;gap:6px;overflow-x:auto;padding-bottom:8px;margin-bottom:10px;scrollbar-width:none}
.filter-bar::-webkit-scrollbar{display:none}
.filter-btn{background:var(--surface);border:1px solid rgba(255,255,255,0.08);color:var(--text-muted);border-radius:20px;padding:5px 12px;font-size:12px;cursor:pointer;white-space:nowrap;transition:all 0.2s;font-weight:500}
.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}

/* BRAIN DUMP */
.brain-dump-btn{width:100%;background:linear-gradient(135deg,rgba(16,185,129,0.1),rgba(6,182,212,0.1));border:1px dashed rgba(16,185,129,0.4);border-radius:var(--radius);padding:14px;color:#6EE7B7;font-size:14px;font-weight:600;cursor:pointer;transition:all 0.2s;text-align:center;margin-bottom:16px}
.brain-dump-btn:hover{background:rgba(16,185,129,0.15);border-style:solid}
.brain-dump-btn:active{transform:scale(0.98)}

/* CALENDAR */
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cal-header h2{font-size:16px;font-weight:700;text-transform:capitalize}
.cal-nav{width:34px;height:34px;background:var(--surface);border:1px solid rgba(255,255,255,0.08);border-radius:50%;color:var(--text);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.cal-nav:hover{background:var(--primary);border-color:var(--primary)}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.cal-weekdays span{text-align:center;font-size:10px;font-weight:600;color:var(--text-dim);padding:3px 0;text-transform:uppercase}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:16px}
.cal-day{aspect-ratio:1;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s;background:var(--surface);border:1px solid transparent;gap:2px}
.cal-day:hover{border-color:var(--primary)}
.cal-day:active{transform:scale(0.9)}
.cal-day.empty{background:transparent;cursor:default;border:none}
.cal-day.today{background:rgba(139,92,246,0.2);border-color:var(--primary)}
.cal-day.today .cal-day-num{color:var(--primary-light);font-weight:800}
.cal-day.selected{background:var(--primary);border-color:var(--primary);box-shadow:var(--glow)}
.cal-day.selected .cal-day-num{color:#fff}
.cal-day-num{font-size:12px;font-weight:600;line-height:1}
.cal-dots{display:flex;gap:2px;flex-wrap:wrap;justify-content:center;max-width:90%}
.cal-dot{width:4px;height:4px;border-radius:50%}
.cal-dot.urgent{background:var(--danger)}
.cal-dot.normal{background:var(--warning)}
.cal-dot.later{background:var(--success)}
.cal-dot.done{background:var(--text-dim)}
.cal-day-panel{background:var(--surface);border-radius:var(--radius);padding:14px;border:1px solid rgba(255,255,255,0.06)}
.cal-day-panel h3{font-size:15px;font-weight:700;margin-bottom:10px;color:var(--primary-light)}

/* EXERCISE TAB */
.exercise-week-card{background:var(--surface);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px;border:1px solid rgba(255,255,255,0.06)}
.exercise-week-label{font-size:11px;color:var(--text-muted);text-align:center;margin-bottom:12px;text-transform:uppercase;letter-spacing:0.5px}
.exercise-week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:14px}
.exercise-day-btn{display:flex;flex-direction:column;align-items:center;gap:3px;background:var(--surface2);border:2px solid transparent;border-radius:10px;padding:8px 2px;cursor:pointer;transition:all 0.2s;font-family:inherit}
.exercise-day-btn.done{background:rgba(16,185,129,0.15);border-color:var(--success)}
.exercise-day-btn.today{border-color:var(--primary)}
.exercise-day-btn.future{opacity:0.35;cursor:default}
.ex-day-name{font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase}
.ex-day-num{font-size:13px;font-weight:700;color:var(--text)}
.ex-day-check{font-size:13px;color:var(--success)}
.exercise-day-btn:not(.done) .ex-day-check{color:var(--text-dim)}
.exercise-summary{text-align:center}
.exercise-count-big{font-size:36px;font-weight:800;color:var(--primary-light);display:block}
.exercise-count-label{font-size:12px;color:var(--text-muted);display:block;margin-top:2px}
.rewards-section{margin-bottom:16px}
.rewards-title{font-size:15px;font-weight:700;margin-bottom:10px}
.reward-tier{background:var(--surface);border-radius:var(--radius);padding:14px;border:1px solid rgba(255,255,255,0.06);margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;transition:all 0.3s}
.reward-tier.unlocked{background:linear-gradient(135deg,rgba(16,185,129,0.1),rgba(6,182,212,0.05));border-color:rgba(16,185,129,0.3)}
.reward-tier-left{display:flex;align-items:center;gap:12px}
.reward-tier-icon{font-size:24px}
.reward-tier-req{font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.reward-tier-val{font-size:14px;font-weight:600;margin-top:2px}
.reward-tier-badge{font-size:12px;color:var(--text-muted);white-space:nowrap}
.reward-tier-badge.earned{color:var(--success);font-weight:700;font-size:13px}

/* SAVINGS TAB */
.goal-card{background:var(--surface);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px;border:1px solid rgba(255,255,255,0.06)}
.goal-card.goal-completed{border-color:rgba(245,158,11,0.3);background:linear-gradient(135deg,rgba(245,158,11,0.05),var(--surface))}
.goal-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:4px}
.goal-title-row{display:flex;align-items:center;gap:10px}
.goal-emoji{font-size:28px}
.goal-name{font-size:15px;font-weight:700}
.goal-amounts{font-size:12px;color:var(--text-muted);margin-top:2px}
.goal-done-badge{background:rgba(245,158,11,0.15);border:1px solid rgba(245,158,11,0.3);color:var(--accent);font-size:11px;font-weight:700;padding:3px 8px;border-radius:20px;white-space:nowrap}
.goal-progress-track{height:10px;background:rgba(255,255,255,0.06);border-radius:99px;overflow:hidden;margin:12px 0}
.goal-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:99px;transition:width 0.8s cubic-bezier(0.34,1.56,0.64,1)}
.goal-footer{display:flex;justify-content:space-between;margin-bottom:12px}
.goal-pct{font-size:12px;color:var(--primary-light);font-weight:600}
.goal-remaining{font-size:12px;color:var(--text-muted)}
.btn-deposit{width:100%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:var(--radius-sm);padding:11px;font-size:14px;font-weight:700;cursor:pointer;margin-bottom:8px;transition:all 0.2s}
.btn-deposit:active{transform:scale(0.98)}
.btn-delete-goal{width:100%;background:transparent;border:1px solid rgba(239,68,68,0.2);color:var(--danger);border-radius:var(--radius-sm);padding:8px;font-size:12px;cursor:pointer;transition:all 0.2s}
.btn-delete-goal:hover{background:rgba(239,68,68,0.1)}

/* ACHIEVEMENTS */
.achievements-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.achievements-top h2{font-size:16px;font-weight:700}
.achievements-badge{background:rgba(245,158,11,0.15);border:1px solid rgba(245,158,11,0.3);color:var(--accent);font-weight:700;font-size:13px;padding:3px 10px;border-radius:20px}
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}
.stat-card{background:var(--surface);border-radius:var(--radius);padding:12px 8px;text-align:center;border:1px solid rgba(255,255,255,0.06)}
.stat-num{display:block;font-size:22px;font-weight:800;color:var(--primary-light)}
.stat-label{font-size:10px;color:var(--text-muted);display:block;margin-top:3px}
.achievements-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding-bottom:16px}
.ach-card{background:var(--surface);border-radius:var(--radius);padding:14px 12px;border:1px solid rgba(255,255,255,0.06);transition:all 0.3s;text-align:center}
.ach-card.unlocked{background:linear-gradient(135deg,rgba(139,92,246,0.15),rgba(245,158,11,0.1));border-color:rgba(139,92,246,0.4);box-shadow:0 2px 16px rgba(139,92,246,0.15)}
.ach-card:not(.unlocked){filter:grayscale(0.8);opacity:0.55}
.ach-icon{font-size:30px;display:block;margin-bottom:7px}
.ach-name{font-size:12px;font-weight:700;margin-bottom:3px}
.ach-desc{font-size:10px;color:var(--text-muted);line-height:1.4}
.ach-done{font-size:10px;color:var(--success);margin-top:5px;font-weight:600}

/* LAUNCHER */
#tab-launcher{padding:18px 16px calc(28px + env(safe-area-inset-bottom,0px))}
.launcher-greeting{font-size:22px;font-weight:800;color:var(--text);margin-bottom:2px}
.launcher-sub{font-size:13px;color:var(--text-muted);margin-bottom:20px}
.launcher-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.launcher-icon{display:flex;flex-direction:column;align-items:center;gap:7px;background:var(--surface);border:1px solid rgba(255,255,255,0.07);border-radius:20px;padding:16px 8px 13px;cursor:pointer;transition:transform 0.15s,background 0.15s;-webkit-tap-highlight-color:transparent}
.launcher-icon:active{transform:scale(0.91)}
.lic-bg{width:54px;height:54px;border-radius:14px;background:color-mix(in srgb,var(--ic) 25%,transparent);border:1px solid color-mix(in srgb,var(--ic) 40%,transparent);display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:0 4px 12px color-mix(in srgb,var(--ic) 20%,transparent)}
.launcher-label{font-size:11px;font-weight:600;color:var(--text-muted);text-align:center;line-height:1.2}
.launcher-today-card{border-radius:var(--radius);overflow:hidden}
.launcher-today-inner{background:var(--surface);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius);padding:14px 16px}
.launcher-today-title{font-size:13px;font-weight:700;color:var(--text-muted);margin-bottom:8px}
.launcher-today-stats{display:flex;gap:8px;margin-bottom:12px}
.lt-stat{font-size:13px;font-weight:700;padding:4px 10px;border-radius:20px}
.lt-stat.pending{background:rgba(139,92,246,0.15);color:var(--primary-light)}
.lt-stat.done{background:rgba(16,185,129,0.15);color:var(--success)}
.lt-btn{background:none;border:none;color:var(--primary-light);font-size:13px;font-weight:600;padding:0;cursor:pointer}

/* ABA CALMA */
.calm-title{font-size:20px;font-weight:800;margin-bottom:6px;color:var(--text)}
.calm-subtitle{font-size:13px;color:var(--text-muted);margin-bottom:20px;line-height:1.5}
.calm-card{width:100%;background:var(--surface);border:1px solid rgba(255,255,255,0.07);border-radius:var(--radius-lg);padding:16px;display:flex;align-items:center;gap:14px;margin-bottom:12px;cursor:pointer;transition:all 0.18s;text-align:left;-webkit-tap-highlight-color:transparent}
.calm-card:active{transform:scale(0.98);background:var(--surface2)}
.calm-card-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}
.calm-card-info{flex:1;min-width:0}
.calm-card-name{font-size:15px;font-weight:700;color:var(--text);margin-bottom:3px}
.calm-card-desc{font-size:12px;color:var(--text-muted);line-height:1.4;margin-bottom:5px}
.calm-card-time{font-size:11px;color:var(--text-dim);font-weight:500}
.calm-arrow{font-size:22px;color:var(--text-dim);flex-shrink:0}
.calm-tip{background:rgba(139,92,246,0.08);border:1px solid rgba(139,92,246,0.2);border-radius:var(--radius-sm);padding:13px 14px;margin-top:8px;font-size:13px;color:var(--text-muted);line-height:1.5}

/* MODALS */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.75);display:flex;align-items:flex-end;justify-content:center;z-index:100;backdrop-filter:blur(4px)}
.modal-overlay.hidden{display:none}
.modal{background:var(--surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:480px;max-height:92vh;overflow-y:auto;animation:modalUp 0.3s cubic-bezier(0.34,1.56,0.64,1);border:1px solid rgba(139,92,246,0.2);border-bottom:none}
@keyframes modalUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-focus{border-radius:var(--radius-lg);margin:20px 16px;max-height:calc(100vh - 40px)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,0.06)}
.modal-head h3{font-size:17px;font-weight:700}
.modal-x{background:var(--surface2);border:none;color:var(--text-muted);width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.modal-x:hover{background:var(--danger);color:#fff}
.modal-x-abs{position:absolute;top:14px;right:14px}
.modal-body{padding:14px 18px;display:flex;flex-direction:column;gap:12px}
.modal-foot{padding:10px 18px 26px}
.field{width:100%;background:var(--surface2);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius-sm);color:var(--text);font-size:14px;padding:11px 13px;outline:none;transition:border-color 0.2s;font-family:inherit}
.field:focus{border-color:var(--primary)}
.field::placeholder{color:var(--text-dim)}
.field-ta{resize:none}
.field-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:5px;display:block}
.priority-row{display:flex;gap:6px}
.prio-btn{flex:1;background:var(--surface2);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius-sm);color:var(--text-muted);padding:9px 4px;font-size:11px;font-weight:600;cursor:pointer;transition:all 0.2s;display:flex;flex-direction:column;align-items:center;gap:3px}
.prio-btn:hover{border-color:var(--primary);color:var(--text)}
.prio-btn.selected{background:rgba(139,92,246,0.2);border-color:var(--primary);color:var(--text)}
.prio-xp{font-size:10px;color:var(--accent);font-weight:700}
.dt-row{display:flex;gap:8px}
.dt-group{flex:1;display:flex;flex-direction:column}
input[type="date"],input[type="time"]{color-scheme:dark}
.reminder-label{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;color:var(--text-muted)}
.reminder-label input{width:15px;height:15px;accent-color:var(--primary);cursor:pointer}
.reminder-before-row{background:rgba(139,92,246,0.07);border:1px solid rgba(139,92,246,0.18);border-radius:var(--radius-sm);padding:10px 12px;display:flex;flex-direction:column;gap:6px;margin-top:-4px}
.before-opts{display:flex;gap:6px}
.before-opt{flex:1;background:var(--surface2);border:1px solid rgba(255,255,255,0.1);border-radius:20px;color:var(--text-muted);padding:7px 4px;font-size:12px;font-weight:600;cursor:pointer;transition:all 0.2s;text-align:center}
.before-opt.selected{background:var(--primary);border-color:var(--primary);color:#fff}

/* SETTINGS CARD */
.settings-card{background:var(--surface);border:1px solid rgba(139,92,246,0.2);border-radius:var(--radius);padding:14px 16px;margin-bottom:16px}
.settings-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:10px}
.settings-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.settings-label{font-size:14px;color:var(--text);font-weight:500}
.toggle-switch{position:relative;display:inline-flex;width:46px;height:26px;flex-shrink:0;cursor:pointer}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute}
.toggle-thumb{position:absolute;inset:0;background:var(--surface2);border-radius:99px;border:1px solid rgba(255,255,255,0.1);transition:background 0.25s}
.toggle-thumb::after{content:'';position:absolute;left:3px;top:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform 0.25s,box-shadow 0.25s}
.toggle-switch input:checked+.toggle-thumb{background:var(--primary)}
.toggle-switch input:checked+.toggle-thumb::after{transform:translateX(20px);box-shadow:0 0 6px rgba(139,92,246,0.6)}

/* RECURRENCE */
.recurrence-box{background:rgba(139,92,246,0.06);border:1px solid rgba(139,92,246,0.2);border-radius:var(--radius-sm);padding:12px;display:flex;flex-direction:column;gap:8px}
.rec-type-row{display:flex;gap:6px}
.rec-btn{flex:1;background:var(--surface2);border:1px solid rgba(255,255,255,0.08);border-radius:20px;color:var(--text-muted);padding:6px 8px;font-size:12px;font-weight:600;cursor:pointer;transition:all 0.2s}
.rec-btn.selected{background:var(--primary);border-color:var(--primary);color:#fff}
.weekday-row{display:flex;gap:4px;justify-content:space-between}
.wd-btn{flex:1;background:var(--surface2);border:1px solid rgba(255,255,255,0.08);border-radius:8px;color:var(--text-muted);padding:6px 2px;font-size:11px;font-weight:600;cursor:pointer;transition:all 0.2s;text-align:center}
.wd-btn.selected{background:var(--primary);border-color:var(--primary);color:#fff}

/* BRAIN DUMP DISTRIBUTE */
.brain-dist-item{background:var(--surface2);border-radius:var(--radius-sm);padding:11px;margin-bottom:8px}
.brain-item-text{font-size:13px;font-weight:600;margin-bottom:8px;color:var(--text)}
.brain-day-pills{display:flex;gap:5px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
.brain-day-pills::-webkit-scrollbar{display:none}
.brain-day-pill{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:20px;padding:4px 10px;font-size:11px;cursor:pointer;white-space:nowrap;color:var(--text-muted);transition:all 0.2s;font-weight:500}
.brain-day-pill.selected{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:700}

/* MODAL GOAL */
.emoji-name-row{display:flex;gap:8px}
.emoji-field{width:56px;text-align:center;font-size:20px;padding:8px 4px;flex-shrink:0}

/* PRIMARY BUTTON */
.btn-primary{width:100%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:var(--radius-sm);padding:13px;font-size:15px;font-weight:700;cursor:pointer;transition:all 0.2s;box-shadow:0 4px 18px rgba(139,92,246,0.4)}
.btn-primary:hover{transform:translateY(-1px)}
.btn-primary:active{transform:scale(0.97)}

/* FOCUS MODAL */
.focus-content{padding:20px 22px 28px;text-align:center}
.focus-eyebrow{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-weight:600;margin-bottom:8px}
.focus-title{font-size:20px;font-weight:800;line-height:1.3;margin-bottom:6px}
.focus-desc{font-size:13px;color:var(--text-muted);margin-bottom:20px}
.pomodoro-wrap{margin-bottom:20px}
.pomodoro-ring{width:150px;height:150px;margin:0 auto 10px;position:relative}
.pom-svg{width:100%;height:100%;transform:rotate(-90deg)}
.pom-track{fill:none;stroke:rgba(255,255,255,0.06);stroke-width:8}
.pom-progress{fill:none;stroke:var(--primary);stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset 1s linear,stroke 0.3s;filter:drop-shadow(0 0 6px rgba(139,92,246,0.6))}
.pom-progress.break-phase{stroke:var(--success)}
.pom-time{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-1px}
.pom-phase{font-size:13px;color:var(--text-muted);font-weight:600;margin-bottom:10px}
.pom-btns{display:flex;gap:8px;justify-content:center}
.btn-pom{background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:9px 20px;font-size:14px;font-weight:700;cursor:pointer;transition:all 0.2s}
.btn-pom:hover{transform:scale(1.05)}
.btn-pom:active{transform:scale(0.95)}
.btn-pom-sec{background:var(--surface2);color:var(--text-muted)}
.btn-complete-focus{width:100%;background:linear-gradient(135deg,var(--success),#059669);color:#fff;border:none;border-radius:var(--radius-sm);padding:14px;font-size:16px;font-weight:800;cursor:pointer;transition:all 0.2s;box-shadow:0 4px 18px rgba(16,185,129,0.4)}
.btn-complete-focus:active{transform:scale(0.97)}

/* CELEBRATION */
.celebration{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.85);backdrop-filter:blur(6px)}
.celebration.hidden{display:none}
#confetti-canvas{position:absolute;inset:0;pointer-events:none;width:100%;height:100%}
.celebration-box{position:relative;z-index:1;text-align:center;padding:28px 22px;background:var(--surface);border-radius:var(--radius-lg);border:1px solid rgba(139,92,246,0.3);width:90%;max-width:340px;box-shadow:0 8px 48px rgba(0,0,0,0.6);animation:bounceIn 0.5s cubic-bezier(0.34,1.56,0.64,1)}
@keyframes bounceIn{from{transform:scale(0.5);opacity:0}to{transform:scale(1);opacity:1}}
.cel-emoji{font-size:58px;display:block;margin-bottom:10px;animation:pulse 0.5s ease infinite alternate}
@keyframes pulse{from{transform:scale(1)}to{transform:scale(1.1)}}
.cel-title{font-size:22px;font-weight:800;margin-bottom:6px}
.cel-xp{font-size:30px;font-weight:800;color:var(--accent);margin-bottom:6px;text-shadow:0 0 20px rgba(245,158,11,0.5)}
.cel-msg{font-size:14px;color:var(--text-muted);margin-bottom:20px}
.cel-btn{font-size:14px;padding:11px}

/* TOASTS */
.ach-toast{position:fixed;bottom:82px;left:50%;transform:translateX(-50%) translateY(20px);background:linear-gradient(135deg,#2D1B69,#1A1030);border:1px solid rgba(139,92,246,0.5);border-radius:var(--radius);padding:12px 16px;display:flex;align-items:center;gap:10px;min-width:260px;max-width:90vw;box-shadow:var(--shadow);z-index:150;opacity:0;transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1)}
.ach-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.ach-toast.hidden{display:none}
.toast-icon{font-size:26px}
.toast-head{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:600}
.toast-name{font-size:14px;font-weight:700;color:var(--accent)}
.levelup-toast{position:fixed;top:125px;left:50%;transform:translateX(-50%) scale(0.8);background:linear-gradient(135deg,#7C3AED,#F59E0B);border-radius:var(--radius);padding:2px;z-index:150;opacity:0;transition:all 0.4s cubic-bezier(0.34,1.56,0.64,1);box-shadow:0 8px 32px rgba(139,92,246,0.5)}
.levelup-toast.show{opacity:1;transform:translateX(-50%) scale(1)}
.levelup-toast.hidden{display:none}
.levelup-inner{background:var(--surface);border-radius:calc(var(--radius) - 2px);padding:10px 18px;display:flex;align-items:center;gap:10px}
.levelup-head{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--accent);font-weight:800}
.levelup-title{font-size:15px;font-weight:700}
/* REGULAÇÃO EMOCIONAL */
.regulation-section{margin-bottom:20px}
.reg-cards-row{display:flex;gap:10px;margin-top:8px}
.reg-card{flex:1;background:var(--surface);border:1px solid rgba(139,92,246,0.25);border-radius:var(--radius);padding:14px 12px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:all 0.18s;text-align:left}
.reg-card:active{transform:scale(0.96);opacity:0.85}
.reg-icon{font-size:30px;flex-shrink:0}
.reg-name{font-size:14px;font-weight:700;color:var(--text);margin-bottom:2px}
.reg-desc{font-size:11px;color:var(--text-muted)}

/* GROUNDING */
.ground-dots{display:flex;gap:6px;justify-content:center;margin-bottom:18px}
.gdot{flex:1;max-width:40px;height:6px;border-radius:99px;background:rgba(255,255,255,0.1);transition:all 0.35s}
.gdot.done{background:var(--success)}
.gdot.cur{background:var(--primary)}
.ground-card{border:1px solid;border-radius:var(--radius);padding:20px 16px;text-align:center;margin-bottom:16px}
.ground-big-emoji{font-size:52px;display:block;margin-bottom:10px;line-height:1}
.ground-sense-label{font-size:16px;font-weight:600;margin-bottom:6px}
.ground-tip{font-size:12px;color:var(--text-muted);line-height:1.4}
.ground-counter-row{display:flex;align-items:baseline;justify-content:center;gap:4px;margin-bottom:18px}
.ground-num{font-size:60px;font-weight:800;line-height:1}
.ground-denom{font-size:24px;color:var(--text-muted);font-weight:600}
.ground-found-btn{width:100%;padding:17px;border-radius:var(--radius);border:none;color:#fff;font-size:17px;font-weight:700;cursor:pointer;transition:transform 0.12s;letter-spacing:0.3px}
.ground-found-btn:active{transform:scale(0.96)}
.ground-step-done{text-align:center;font-size:18px;font-weight:700;color:var(--success);margin-bottom:12px}
.ground-complete{text-align:center;padding:24px 0}
.ground-complete>span{font-size:64px;display:block;margin-bottom:14px;line-height:1}
.ground-complete>p:first-of-type{font-size:22px;font-weight:800;margin-bottom:8px}
.ground-sub{font-size:13px;color:var(--text-muted);margin-bottom:24px;line-height:1.5}

/* BREATHING */
.breath-body{align-items:center;text-align:center;gap:14px}
.breath-desc-text{font-size:12px;color:var(--text-muted);text-align:center;line-height:1.4}
.breath-circle-wrap{display:flex;align-items:center;justify-content:center;width:220px;height:220px;margin:4px auto}
.breath-circle{width:180px;height:180px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;transform:scale(0.45);transition:transform 0.5s,background-color 0.5s;box-shadow:0 0 0 0 rgba(99,102,241,0.3)}
.breath-countdown{font-size:56px;font-weight:800;color:#fff;line-height:1;user-select:none}
.breath-phase-name{font-size:24px;font-weight:800;color:var(--text);letter-spacing:0.5px}
.breath-phase-sub{font-size:13px;color:var(--text-muted);line-height:1.4;max-width:220px;margin:0 auto}

/* ROTINAS */
.routine-card{background:var(--surface);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px;border:1px solid rgba(255,255,255,0.06);transition:all 0.2s;touch-action:manipulation}
.routine-card.routine-done{border-color:rgba(16,185,129,0.3);background:linear-gradient(135deg,rgba(16,185,129,0.05),var(--surface))}
.routine-card-top{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.routine-emoji{font-size:32px;flex-shrink:0}
.routine-name{font-size:15px;font-weight:700}
.routine-meta{font-size:11px;color:var(--text-muted);margin-top:3px}
.routine-card-btns{display:flex;gap:8px}
.btn-play-routine{flex:1;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:var(--radius-sm);padding:11px;font-size:14px;font-weight:700;cursor:pointer;touch-action:manipulation;transition:all 0.2s}
.btn-play-routine:active{transform:scale(0.97)}
.btn-edit-routine{background:var(--surface2);border:1px solid rgba(255,255,255,0.08);color:var(--text-muted);border-radius:var(--radius-sm);padding:11px 14px;font-size:16px;cursor:pointer;touch-action:manipulation;transition:all 0.2s}
.btn-edit-routine:hover{color:var(--text)}
.routine-tip{background:rgba(139,92,246,0.06);border:1px solid rgba(139,92,246,0.2);border-radius:var(--radius);padding:12px 14px;margin-top:8px;font-size:12px;color:var(--text-muted);line-height:1.5}
/* Play steps */
.play-step-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.05)}
.play-step-item:last-child{border-bottom:none}
.play-step-check{border-radius:20px;border:1.5px solid rgba(255,255,255,0.2);background:transparent;color:var(--text-muted);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;padding:6px 12px;transition:all 0.25s;touch-action:manipulation;white-space:nowrap}
.play-step-check.done{background:var(--success);border-color:var(--success);color:#fff}
.play-step-text{font-size:14px;font-weight:500;transition:all 0.2s}
.play-step-text.done{text-decoration:line-through;color:var(--text-muted)}
.play-step-dur{font-size:11px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}
.btn-reset-routine{width:100%;background:transparent;border:1px solid rgba(255,255,255,0.1);color:var(--text-muted);border-radius:var(--radius-sm);padding:10px;font-size:13px;cursor:pointer;touch-action:manipulation;transition:all 0.2s}
.btn-reset-routine:hover{border-color:var(--primary);color:var(--primary-light)}
/* Edit steps */
.edit-step-row{display:flex;gap:6px;margin-bottom:8px;align-items:center}
.step-drag{font-size:16px;color:var(--text-dim);flex-shrink:0;cursor:grab;padding:0 2px}
.edit-step-text{flex:1}
.edit-step-dur{width:72px;flex-shrink:0}
.edit-step-del{background:transparent;border:none;color:var(--danger);font-size:18px;cursor:pointer;padding:6px;touch-action:manipulation;flex-shrink:0;min-width:32px;min-height:32px;display:flex;align-items:center;justify-content:center}
.btn-ghost{background:transparent;border:1px dashed rgba(255,255,255,0.2);color:var(--text-muted);border-radius:var(--radius-sm);padding:10px;font-size:13px;cursor:pointer;width:100%;margin-top:4px;touch-action:manipulation;transition:all 0.2s}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary-light)}
.btn-delete-routine{background:transparent;border:none;color:var(--danger);font-size:12px;cursor:pointer;padding:8px 0;touch-action:manipulation;opacity:0.7;width:100%;text-align:left;margin-top:8px}
.btn-delete-routine:hover{opacity:1}

/* Banner de atualização */
#update-banner{position:fixed;top:0;left:0;right:0;z-index:999;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;display:flex;align-items:center;justify-content:space-between;padding:10px 16px;font-size:13px;font-weight:600;box-shadow:0 2px 12px rgba(0,0,0,0.4);max-width:480px;margin:0 auto}
#btn-update-now{background:#fff;color:var(--primary-dark);border:none;border-radius:20px;padding:5px 14px;font-size:12px;font-weight:700;cursor:pointer}

.hidden{display:none!important}
.modal::-webkit-scrollbar{width:3px}
.modal::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:99px}
