/* ═══════════════════════════════════════
   plan@sachside — Design tokens (ApniJodi)
   ═══════════════════════════════════════ */
:root {
  --bg: #0D0D0D;
  --bg-2: #1A1A1A;
  --bg-card: #151515;
  --accent: #D4FF00;
  --accent-hover: #E5FF33;
  --accent-glow: rgba(212,255,0,0.08);
  --border: #2A2A2A;
  --text: #FFFFFF;
  --text-2: #A0A0A0;
  --text-muted: #555;
  --radius-sm: 0.5rem;
  --radius: 1rem;
  --radius-lg: 1.5rem;
  --font: 'Inter', -apple-system, sans-serif;
  --shadow: 0 4px 16px rgba(0,0,0,0.4);
  --glow: 0 0 24px rgba(212,255,0,0.15);
  --c-planned: #2A2A2A;
  --c-active: var(--accent);
  --c-done: #22c55e;
  --c-not-doing: #444;
  --c-carried: #f97316;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}
.auth-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem}
.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem 2rem;max-width:380px;width:100%;text-align:center;box-shadow:var(--shadow)}
.auth-logo{font-size:1.75rem;font-weight:800;letter-spacing:-0.03em;margin-bottom:0.5rem}
.auth-logo-at{color:var(--accent)}
.auth-subtitle{color:var(--text-2);font-size:0.875rem;margin-bottom:2rem;line-height:1.5}
.auth-note{font-size:0.75rem;color:var(--text-muted);margin-top:1rem}
.top-nav{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0.75rem 1.25rem;background:rgba(13,13,13,0.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);gap:1rem}
.nav-logo{font-size:1rem;font-weight:800;letter-spacing:-0.02em;white-space:nowrap}
.nav-logo-at{color:var(--accent)}
.nav-center{display:flex;gap:0.25rem}
.nav-tab{background:transparent;border:none;color:var(--text-2);padding:0.4rem 0.9rem;border-radius:var(--radius-sm);font-size:0.8125rem;font-weight:500;cursor:pointer;transition:all 0.2s}
.nav-tab:hover{color:var(--text);background:var(--bg-2)}
.nav-tab.active{color:var(--bg);background:var(--accent);font-weight:600}
.nav-right{display:flex;align-items:center;gap:0.75rem}
.streak-pill{display:flex;align-items:center;gap:0.25rem;background:var(--bg-2);border:1px solid var(--border);border-radius:99px;padding:0.25rem 0.65rem;font-size:0.8125rem;font-weight:600}
.nav-avatar{background:none;border:none;cursor:pointer;border-radius:50%;overflow:hidden;width:28px;height:28px;padding:0}
.nav-avatar img{width:28px;height:28px;object-fit:cover;border-radius:50%}
.nav-btn{background:none;border:none;cursor:pointer;color:var(--text-2);padding:0.4rem;display:flex;align-items:center;justify-content:center;transition:color 0.2s;width:28px;height:28px}
.nav-btn:hover{color:var(--accent)}
.main-content{padding:1.25rem;max-width:1100px;margin:0 auto}
.view{display:none}.view.active{display:block}
.board-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:0.75rem}
.month-nav{display:flex;align-items:center;gap:0.75rem}
.month-btn{background:var(--bg-2);border:1px solid var(--border);color:var(--text);width:32px;height:32px;border-radius:var(--radius-sm);cursor:pointer;font-size:1.1rem;transition:all 0.2s}
.month-btn:hover{border-color:var(--accent);color:var(--accent)}
.month-title{font-size:1.25rem;font-weight:700}
.board-meta{display:flex;align-items:center;gap:0.75rem}
.meta-pill{background:var(--bg-2);border:1px solid var(--border);border-radius:99px;padding:0.25rem 0.75rem;font-size:0.8125rem;color:var(--text-2)}
.motivation-bar{margin:0 0 1rem;background:linear-gradient(135deg,rgba(212,255,0,0.06),rgba(59,130,246,0.06));border:1px solid rgba(212,255,0,0.14);border-radius:0.95rem;padding:0.85rem 1rem;overflow:hidden;position:relative}
.motivation-bar::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,0.04) 45%,transparent 70%);transform:translateX(-100%);animation:motivationSweep 9s ease-in-out infinite}
.motivation-bar-inner{display:flex;align-items:center;gap:0.85rem;flex-wrap:wrap;position:relative;z-index:1;animation:motivationFade .45s ease}
.motivation-kicker{font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--accent)}
.motivation-text{font-size:0.92rem;font-weight:600;color:var(--text);flex:1;min-width:240px}
.motivation-meta{font-size:0.76rem;color:var(--text-2)}
.current-header{display:flex;justify-content:space-between;align-items:flex-end;gap:0.75rem;flex-wrap:wrap;margin-bottom:1rem}
.current-title{font-size:1.35rem;font-weight:800;letter-spacing:-0.03em}
.current-date{font-size:0.85rem;color:var(--text-2)}
.current-hero{background:linear-gradient(135deg,rgba(212,255,0,0.08),rgba(212,255,0,0.02));border:1px solid rgba(212,255,0,0.16);border-radius:1rem;padding:1rem 1.1rem;margin-bottom:1rem;min-height:152px;display:flex;flex-direction:column;justify-content:center;gap:0.55rem}
.current-hero.empty{background:var(--bg-card);border-color:var(--border)}
.current-hero-kicker{font-size:0.76rem;color:var(--accent);text-transform:uppercase;letter-spacing:0.08em;font-weight:700}
.current-hero-title{font-size:1.35rem;font-weight:800;line-height:1.15}
.current-hero-meta{font-size:0.9rem;color:var(--text-2)}
.current-hero-actions{display:flex;gap:0.5rem;flex-wrap:wrap;margin-top:0.2rem}
.current-stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-bottom:1rem}
.current-list-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem}
.current-task-list{display:flex;flex-direction:column;gap:0.65rem}
.current-task-card{background:var(--bg-2);border:1px solid var(--border);border-radius:0.85rem;padding:0.85rem 0.95rem;display:flex;justify-content:space-between;align-items:center;gap:0.75rem;cursor:pointer;transition:border-color .18s ease,transform .18s ease}
.current-task-card:hover{border-color:var(--accent);transform:translateY(-1px)}
.current-task-main{display:flex;flex-direction:column;gap:0.22rem;min-width:0}
.current-task-title{font-size:0.95rem;font-weight:700;color:var(--text);word-break:break-word}
.current-task-meta{font-size:0.76rem;color:var(--text-2)}
.current-task-status{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;padding:0.22rem 0.5rem;border-radius:999px;white-space:nowrap}
.current-task-status[data-status="done"]{background:#12351f;color:#86efac}
.current-task-status[data-status="active"]{background:#38420a;color:#d9f99d}
.current-task-status[data-status="planned"]{background:#262626;color:#cbd5e1}
.current-task-status[data-status="carried"]{background:#3d1f0d;color:#fdba74}
.current-task-status[data-status="not_doing"]{background:#3b1212;color:#fda4af}
.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:0.375rem;margin-bottom:0.375rem;text-align:center;font-size:0.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0.375rem}
.day-cell{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0.4rem;min-height:90px;transition:border-color 0.2s;position:relative}
.day-cell.today{border-color:var(--accent)!important}
.day-cell.other-month{opacity:0.3;pointer-events:none}
.day-cell:hover{border-color:#3a3a3a}
.day-num{font-size:0.7rem;font-weight:600;color:var(--text-muted);margin-bottom:0.3rem}
.day-cell.today .day-num{color:var(--accent);font-weight:700}
.ticket-chips{display:flex;flex-direction:column;gap:2px}
.chip{height:14px;border-radius:3px;cursor:pointer;transition:all 0.15s;border:1px solid transparent;position:relative;display:flex;align-items:center;justify-content:center}
.chip:hover{filter:brightness(1.2);transform:scaleY(1.08)}
.chip[data-status="planned"]{background:var(--c-planned);border-color:#3a3a3a}
.chip[data-status="active"]{background:var(--accent);animation:pulse-chip 1.4s ease-in-out infinite}
.chip[data-status="done"]{background:var(--c-done)}
.chip[data-status="not_doing"]{background:var(--c-not-doing)}
.chip[data-status="carried"]{background:transparent;border-color:var(--c-carried);border-width:1.5px}
.chip-slot{position:absolute;left:2px;font-size:8px;color:rgba(255,255,255,0.4);font-weight:600;line-height:1}
.chip[data-status="active"] .chip-slot{color:rgba(0,0,0,0.6)}
@keyframes pulse-chip{0%,100%{box-shadow:0 0 0 0 rgba(212,255,0,0.4)}50%{box-shadow:0 0 0 3px rgba(212,255,0,0)}}
.active-banner{position:fixed;bottom:0;left:0;right:0;z-index:200;background:#111;border-top:2px solid var(--accent);padding:0.75rem 1.25rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.active-banner-info{display:flex;align-items:center;gap:0.5rem;flex:1;min-width:0}
.active-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse-chip 1.4s ease-in-out infinite;flex-shrink:0}
.active-banner-info span:last-child{font-size:0.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.active-timer{font-size:1.25rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--accent);white-space:nowrap}
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;background:var(--accent);color:#000;border:none;border-radius:var(--radius-sm);padding:0.75rem 1.5rem;font-size:0.9375rem;font-weight:700;cursor:pointer;transition:all 0.2s;width:100%}
.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--glow)}
.btn-primary:disabled{opacity:0.4;cursor:not-allowed}
.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0.75rem 1.5rem;font-size:0.9375rem;font-weight:600;cursor:pointer;transition:all 0.2s}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
.btn-ghost{display:inline-flex;align-items:center;justify-content:center;background:none;color:var(--text-2);border:none;padding:0.6rem;font-size:0.875rem;cursor:pointer;transition:color 0.2s;width:100%;margin-top:0.25rem}
.btn-ghost:hover{color:var(--text)}
.btn-sm{padding:0.35rem 0.85rem;font-size:0.8125rem;width:auto}
.btn-google{gap:0.75rem}
.btn-start{flex:1;background:var(--accent);color:#000;border:none;border-radius:var(--radius-sm);padding:0.85rem;font-size:1rem;font-weight:700;cursor:pointer;transition:all 0.2s}
.btn-start:hover{background:var(--accent-hover)}
.btn-not-doing{flex:1;background:transparent;color:var(--text-muted);border:1px solid #333;border-radius:var(--radius-sm);padding:0.85rem;font-size:0.9375rem;font-weight:500;cursor:pointer;transition:all 0.2s}
.btn-not-doing:hover{border-color:#666;color:var(--text-2)}
.btn-complete{background:var(--accent);color:#000;border:none;border-radius:var(--radius-sm);padding:0.6rem 1.1rem;font-size:0.875rem;font-weight:700;cursor:pointer;transition:all 0.2s;white-space:nowrap}
.btn-complete:hover{background:var(--accent-hover)}
.overlay-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:300;display:none}
.overlay-backdrop.open{display:block}
.action-card{position:fixed;left:50%;bottom:50%;transform:translate(-50%,50%) scale(0.95);z-index:301;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;width:min(360px,92vw);box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:all 0.25s cubic-bezier(0.34,1.56,0.64,1)}
.action-card.open{opacity:1;pointer-events:all;transform:translate(-50%,50%) scale(1)}
.action-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0.5rem}
.action-ticket-project{font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-2)}
.action-ticket-slot{font-size:0.75rem;color:var(--text-muted)}
.action-ticket-title{font-size:1.0625rem;font-weight:600;margin-bottom:1.25rem;line-height:1.3}
.action-btns{display:flex;gap:0.625rem}
.sheet-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.75);z-index:400;display:none;backdrop-filter:blur(4px)}
.sheet-backdrop.open{display:block}
.bottom-sheet{position:fixed;bottom:0;left:0;right:0;z-index:401;background:var(--bg-card);border-top:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:1.25rem 1.25rem 2rem;max-width:600px;margin:0 auto;transform:translateY(100%);transition:transform 0.3s cubic-bezier(0.32,0.72,0,1);display:flex;flex-direction:column;gap:0.875rem}
.bottom-sheet.open{transform:translateY(0)}
.bottom-sheet-tall{max-height:85vh;overflow-y:auto}
.sheet-handle{width:40px;height:4px;background:var(--border);border-radius:99px;align-self:center;margin-bottom:0.25rem;flex-shrink:0}
.sheet-title{font-size:1.125rem;font-weight:700}
.sheet-subtitle{font-size:0.8125rem;color:var(--text-2);line-height:1.5}
.reason-textarea{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:0.9375rem;padding:0.75rem;resize:vertical;min-height:90px;width:100%;transition:border-color 0.2s}
.reason-textarea:focus{outline:none;border-color:var(--accent)}
.sheet-char-count{font-size:0.75rem;color:var(--text-muted);text-align:right}
.complete-duration{font-size:1.5rem;font-weight:700;color:var(--accent)}
.mood-label{font-size:0.875rem;color:var(--text-2);margin-bottom:0.5rem}
.mood-required{color:#f87171;font-size:0.75rem}
.mood-row{display:flex;gap:0.75rem}
.mood-btn{background:var(--bg-2);border:2px solid var(--border);border-radius:var(--radius-sm);font-size:1.5rem;width:56px;height:56px;cursor:pointer;transition:all 0.15s}
.mood-btn:hover{border-color:var(--accent);transform:scale(1.1)}
.mood-btn.selected{border-color:var(--accent);background:var(--accent-glow)}
.detail-header{display:flex;justify-content:space-between;align-items:center}
.detail-project-tag{font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;padding:0.2rem 0.6rem;border-radius:99px}
.detail-slot{font-size:0.75rem;color:var(--text-muted)}
.detail-title{font-size:1.125rem;font-weight:700;line-height:1.3}
.detail-status-badge{display:inline-flex;align-items:center;gap:0.3rem;font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;padding:0.2rem 0.6rem;border-radius:99px;background:var(--bg-2);width:fit-content}
.detail-body{font-size:0.875rem;color:var(--text-2);line-height:1.6}
.detail-title-input{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:0.9375rem;padding:0.65rem 0.75rem;width:100%}
.detail-title-input:focus{outline:none;border-color:var(--accent)}
.detail-slot-select{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:0.875rem;padding:0.6rem 0.75rem;width:100%;cursor:pointer}
.detail-edit{display:flex;flex-direction:column;gap:0.5rem}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
.stat-card.wide{grid-column:1/-1}
.stat-bottom{margin-top:1rem}
.stat-card-head{display:flex;align-items:flex-end;justify-content:space-between;gap:0.75rem;flex-wrap:wrap;margin-bottom:0.85rem}
.stat-label{font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-muted);margin-bottom:0.5rem}
.stat-value{font-size:2rem;font-weight:800;line-height:1}
.stat-sub{font-size:0.8125rem;color:var(--text-2);margin-top:0.375rem}
.heatmap{display:flex;flex-wrap:wrap;gap:3px;margin-top:0.5rem}
.hm-cell{width:12px;height:12px;border-radius:2px;background:var(--bg-2);transition:background 0.15s;cursor:pointer}
.hm-cell[data-pct="0"]{background:#1a1a1a}
.hm-cell[data-pct="1"]{background:#1a3a0a}
.hm-cell[data-pct="2"]{background:#2d5c10}
.hm-cell[data-pct="3"]{background:#4d9118}
.hm-cell[data-pct="4"]{background:var(--accent)}
.upcoming-insights{display:grid;grid-template-columns:minmax(270px,320px) minmax(0,1fr);gap:0.85rem}
.horizon-cards{display:flex;flex-direction:column;gap:0.65rem}
.horizon-card{background:var(--bg-2);border:1px solid var(--border);border-radius:0.75rem;padding:0.75rem}
.horizon-title{font-size:0.76rem;color:var(--text-2);text-transform:uppercase;letter-spacing:0.05em}
.horizon-util{font-size:1.4rem;font-weight:800;color:var(--text);margin-top:0.2rem}
.horizon-bar{margin-top:0.45rem;height:8px;background:#202020;border-radius:999px;overflow:hidden}
.horizon-bar-fill{height:100%;width:0%;background:linear-gradient(90deg,#4d9118 0%,var(--accent) 100%);transition:width .28s ease}
.horizon-meta{display:flex;justify-content:space-between;align-items:center;font-size:0.74rem;color:var(--text-2);margin-top:0.45rem}
.freezone-panel{background:var(--bg-2);border:1px solid var(--border);border-radius:0.75rem;padding:0.8rem}
.freezone-header{display:flex;justify-content:space-between;align-items:center;gap:0.65rem;flex-wrap:wrap;margin-bottom:0.45rem}
.freezone-title{font-size:0.85rem;font-weight:700;color:var(--text)}
.freezone-kpi{font-size:0.75rem;color:var(--text-2)}
.freezone-chart{display:flex;flex-direction:column;gap:0.35rem;max-height:310px;overflow:auto;padding-right:0.1rem}
.freezone-row{display:grid;grid-template-columns:84px minmax(0,1fr) 56px;gap:0.55rem;align-items:center}
.freezone-date{font-size:0.72rem;color:var(--text-2)}
.freezone-slots{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0.28rem}
.freezone-slot{height:16px;border-radius:4px;background:#1a1a1a;border:1px solid #2a2a2a}
.freezone-slot.filled{background:#3f640f;border-color:#6a9b1b}
.freezone-slot.free{background:#121212;border-color:#313131}
.freezone-count{font-size:0.72rem;color:var(--text-2);text-align:right}
.projects-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.projects-list{display:flex;flex-direction:column;gap:0.75rem}
.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:all 0.2s}
.project-card:hover{border-color:var(--accent);transform:translateY(-1px)}
.project-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.project-info{flex:1}
.project-name{font-weight:600;font-size:0.9375rem}
.project-priority{font-size:0.75rem;color:var(--text-muted);margin-top:0.15rem}
.project-bar-wrap{width:120px}
.project-bar-track{height:4px;background:var(--bg-2);border-radius:99px;overflow:hidden}
.project-bar-fill{height:100%;border-radius:99px;transition:width 0.4s ease}
.project-bar-label{font-size:0.7rem;color:var(--text-muted);margin-top:0.2rem;text-align:right}
.color-picker{display:flex;gap:0.5rem;flex-wrap:wrap}
.cp-swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all 0.15s}
.cp-swatch.selected{border-color:var(--text);transform:scale(1.2)}
.setup-form{display:flex;flex-direction:column;gap:0.75rem}
.setup-csv-block{display:flex;flex-direction:column;gap:0.5rem;padding:0.75rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm)}
.setup-csv-label{display:block;font-size:0.8125rem;font-weight:600;color:var(--text);line-height:1.25}
.setup-csv-label-main{margin-top:0.1rem}
.setup-csv-label-secondary{margin-top:0.2rem}
.setup-csv-controls{display:flex;gap:0.5rem;align-items:center;flex-wrap:wrap}
.setup-csv-file{flex:1;min-width:200px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-2);font-size:0.75rem;padding:0.4rem 0.5rem}
.setup-csv-hint{font-size:0.75rem;color:var(--text-muted)}
.setup-csv-feedback{font-size:0.75rem;line-height:1.4;color:var(--text-2);white-space:pre-wrap}
.setup-csv-feedback.error{color:#fda4af}
.setup-csv-feedback.success{color:#86efac}
.day-summary-list{display:flex;flex-direction:column;gap:0.5rem;max-height:48vh;overflow:auto;padding-right:0.25rem}
.day-ticket-row{display:flex;align-items:flex-start;justify-content:space-between;gap:0.5rem;padding:0.65rem;border:1px solid var(--border);border-radius:0.65rem;background:var(--bg-2)}
.day-ticket-main{display:flex;flex-direction:column;gap:0.2rem;min-width:0}
.day-ticket-title{font-size:0.875rem;font-weight:600;color:var(--text);word-break:break-word}
.day-ticket-sub{font-size:0.75rem;color:var(--text-2)}
.day-ticket-status{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;padding:0.15rem 0.45rem;border-radius:99px;white-space:nowrap}
.day-ticket-status[data-status="done"]{background:#12351f;color:#86efac}
.day-ticket-status[data-status="active"]{background:#38420a;color:#d9f99d}
.day-ticket-status[data-status="planned"]{background:#262626;color:#cbd5e1}
.day-ticket-status[data-status="carried"]{background:#3d1f0d;color:#fdba74}
.day-ticket-status[data-status="not_doing"]{background:#3b1212;color:#fda4af}
.setup-day-row{display:flex;align-items:center;gap:0.75rem;padding:0.6rem;background:var(--bg-2);border-radius:var(--radius-sm)}
.setup-day-label{font-size:0.8125rem;font-weight:600;color:var(--text-2);width:56px;flex-shrink:0}
.setup-slots{display:flex;gap:0.375rem;flex-wrap:wrap;flex:1}
.setup-slot{display:flex;align-items:center;gap:0.3rem;background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:0.25rem 0.5rem;font-size:0.75rem;cursor:pointer;transition:all 0.2s}
.setup-slot:hover,.setup-slot.filled{border-color:var(--accent);color:var(--accent)}
.setup-slot select{background:transparent;border:none;color:inherit;font-family:var(--font);font-size:0.75rem;cursor:pointer;outline:none}

.error-popup{position:fixed;right:1rem;bottom:1rem;z-index:1000;max-width:420px;width:calc(100vw - 2rem);opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .2s ease,transform .2s ease}
.error-popup.open{opacity:1;transform:translateY(0);pointer-events:auto}
.error-popup-content{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;background:#2a1111;border:1px solid #7f1d1d;border-left:4px solid #ef4444;color:#fecaca;border-radius:.75rem;padding:.75rem .9rem;box-shadow:var(--shadow)}
.error-popup.success .error-popup-content{background:#0f2817;border:1px solid #166534;border-left-color:#22c55e;color:#bbf7d0}
.error-popup.info .error-popup-content{background:#111f2e;border:1px solid #1d4ed8;border-left-color:#60a5fa;color:#dbeafe}
.error-popup-title{font-size:.875rem;font-weight:700;color:#fee2e2}
.error-popup-message{font-size:.8125rem;color:#fecaca;line-height:1.4;margin-top:.15rem;word-break:break-word}
.error-popup-close{background:transparent;border:1px solid #7f1d1d;color:#fecaca;border-radius:.5rem;padding:.25rem .5rem;font-size:.75rem;cursor:pointer}
.error-popup-close:hover{border-color:#ef4444;color:#fee2e2}
.error-popup.success .error-popup-title{color:#dcfce7}
.error-popup.success .error-popup-message{color:#bbf7d0}
.error-popup.success .error-popup-close{border-color:#166534;color:#bbf7d0}
.error-popup.info .error-popup-title{color:#dbeafe}
.error-popup.info .error-popup-message{color:#bfdbfe}
.error-popup.info .error-popup-close{border-color:#1d4ed8;color:#bfdbfe}

@media(max-width:600px){
  .day-cell{min-height:70px;padding:0.3rem}
  .day-num{font-size:0.65rem}
  .chip{height:11px}
  .month-title{font-size:1rem}
  .nav-tab{padding:0.35rem 0.55rem;font-size:0.75rem}
  .stats-grid{grid-template-columns:1fr 1fr}
  .current-stats-grid{grid-template-columns:1fr}
  .motivation-bar-inner{align-items:flex-start}
  .motivation-text{min-width:0}
  .upcoming-insights{grid-template-columns:1fr}
  .freezone-row{grid-template-columns:76px minmax(0,1fr) 48px}
  .active-banner{gap:0.5rem}
  .active-timer{font-size:1rem}
  .error-popup{right:.5rem;left:.5rem;bottom:.5rem;width:auto;max-width:none}
  .setup-csv-controls{flex-direction:column;align-items:stretch}
  .setup-csv-file{min-width:0;width:100%}
  #btn-setup-csv-import{width:100%}
  .setup-day-row{align-items:flex-start}
  .setup-day-label{width:44px;font-size:0.75rem}
  .setup-slots{width:100%}
  .setup-slot{flex:1;min-width:82px}
  .day-ticket-row{flex-direction:column;align-items:flex-start}
}
@media(max-width:380px){.nav-center{display:none}}
@keyframes motivationSweep{0%{transform:translateX(-100%)}50%{transform:translateX(100%)}100%{transform:translateX(100%)}}
@keyframes motivationFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.view.active{animation:fadeInUp 0.3s ease-out}
