/* ══════════════════════════════════
   CSS THEME VARIABLES
══════════════════════════════════ */
    :root {
      /* Default: Walnut Brown */
      --clr-primary: #5a534b;
      --clr-primary-lt: #7a716a;
      --clr-primary-dk: #3a3530;
      --clr-accent: #6a6058;
      --clr-bg: #c8c4bc;
      --clr-panel: #e8e4dd;
      --clr-panel2: #dedad4;
      --clr-border: #ccc9c2;
      --clr-border2: #a09890;
      --clr-border3: #b0aa9f;
      --clr-text: #3a3530;
      --clr-text-lt: #c0bab2;
      --clr-fg: #f0ede8;
      --clr-tt-main: #9fcb84;
      --clr-tt-dark: #85bc69;
      --clr-tt-lt: #c9e2b7;
      --clr-tt-bg: #eef3eb;
      --clr-tt-panel: #f7f9f5;
      --clr-tt-ring-bg: #d8ebcc;
      --clr-tt-stats: #89c36c;
      --clr-tt-task-title: #c6e0b4;
      --clr-tt-hover: #edf5e8;
      --clr-tt-border: #bcbcbc;
      --clr-tt-range: #edf5e8;
      --clr-tt-range-b: #d7e3d0;
      --clr-cb-checked: #6f7d6b;
    }

    /* ── 1. Walnut Brown (default – already in :root above) ── */

    /* ── 2. Rose Blush ── */
    .theme-rose {
      --clr-primary: #b5706a;
      --clr-primary-lt: #c98a84;
      --clr-primary-dk: #7a3f3a;
      --clr-accent: #c98484;
      --clr-bg: #f0dedd;
      --clr-panel: #faeaea;
      --clr-panel2: #f5e0df;
      --clr-border: #e8cbc9;
      --clr-border2: #d4a8a5;
      --clr-border3: #e0b8b5;
      --clr-text: #7a3f3a;
      --clr-text-lt: #e8c5c2;
      --clr-fg: #fff5f5;
      --clr-tt-main: #c87878;
      --clr-tt-dark: #b55a5a;
      --clr-tt-lt: #e8b8b8;
      --clr-tt-bg: #faeaea;
      --clr-tt-panel: #fff5f5;
      --clr-tt-ring-bg: #f0d0d0;
      --clr-tt-stats: #c07070;
      --clr-tt-task-title: #e0a8a8;
      --clr-tt-hover: #faeaea;
      --clr-tt-border: #e0c0be;
      --clr-tt-range: #faeaea;
      --clr-tt-range-b: #e8cbc9;
      --clr-cb-checked: #b56060;
    }

    /* ── 3. Ocean Blue ── */
    .theme-ocean {
      --clr-primary: #2e6b9e;
      --clr-primary-lt: #4a85b8;
      --clr-primary-dk: #1a3f6a;
      --clr-accent: #3a7ab0;
      --clr-bg: #cde0f0;
      --clr-panel: #deedf8;
      --clr-panel2: #d0e5f5;
      --clr-border: #b8d4e8;
      --clr-border2: #90b8d8;
      --clr-border3: #a8cce0;
      --clr-text: #1a3f6a;
      --clr-text-lt: #a8cce4;
      --clr-fg: #eef5fc;
      --clr-tt-main: #3a8ac8;
      --clr-tt-dark: #2970a8;
      --clr-tt-lt: #90c4e4;
      --clr-tt-bg: #deedf8;
      --clr-tt-panel: #eef5fc;
      --clr-tt-ring-bg: #b8d8f0;
      --clr-tt-stats: #3080b8;
      --clr-tt-task-title: #7ab8d8;
      --clr-tt-hover: #deedf8;
      --clr-tt-border: #a8cce0;
      --clr-tt-range: #deedf8;
      --clr-tt-range-b: #b8d4e8;
      --clr-cb-checked: #2e6b9e;
    }

    /* ── 4. Forest Green ── */
    .theme-forest {
      --clr-primary: #3a6b48;
      --clr-primary-lt: #558060;
      --clr-primary-dk: #1e3d28;
      --clr-accent: #4a7858;
      --clr-bg: #c8ddc8;
      --clr-panel: #daeeda;
      --clr-panel2: #cce4cc;
      --clr-border: #b4d0b4;
      --clr-border2: #8cba8c;
      --clr-border3: #a4c8a4;
      --clr-text: #1e3d28;
      --clr-text-lt: #a8c8a8;
      --clr-fg: #eef8ee;
      --clr-tt-main: #4a9060;
      --clr-tt-dark: #3a7848;
      --clr-tt-lt: #8ec8a0;
      --clr-tt-bg: #daeeda;
      --clr-tt-panel: #eef8ee;
      --clr-tt-ring-bg: #b4d8c0;
      --clr-tt-stats: #428858;
      --clr-tt-task-title: #7abc90;
      --clr-tt-hover: #daeeda;
      --clr-tt-border: #a4c8a4;
      --clr-tt-range: #daeeda;
      --clr-tt-range-b: #b4d0b4;
      --clr-cb-checked: #3a6b48;
    }

    /* ── 5. Midnight Purple ── */
    .theme-purple {
      --clr-primary: #5a3a78;
      --clr-primary-lt: #7a5898;
      --clr-primary-dk: #30184e;
      --clr-accent: #6a4888;
      --clr-bg: #d8c8e8;
      --clr-panel: #eadcf8;
      --clr-panel2: #e0d0f0;
      --clr-border: #c8b8e0;
      --clr-border2: #a890c8;
      --clr-border3: #bca8d8;
      --clr-text: #30184e;
      --clr-text-lt: #c8b0e0;
      --clr-fg: #f5eeff;
      --clr-tt-main: #7858a8;
      --clr-tt-dark: #604090;
      --clr-tt-lt: #b898d8;
      --clr-tt-bg: #eadcf8;
      --clr-tt-panel: #f5eeff;
      --clr-tt-ring-bg: #c8a8e8;
      --clr-tt-stats: #6848a0;
      --clr-tt-task-title: #a880c8;
      --clr-tt-hover: #eadcf8;
      --clr-tt-border: #c0a8d8;
      --clr-tt-range: #eadcf8;
      --clr-tt-range-b: #c8b8e0;
      --clr-cb-checked: #604090;
    }

    /* ── 6. Sunset Orange ── */
    .theme-sunset {
      --clr-primary: #b86040;
      --clr-primary-lt: #d07858;
      --clr-primary-dk: #7a3818;
      --clr-accent: #c87050;
      --clr-bg: #f0dbc8;
      --clr-panel: #faeade;
      --clr-panel2: #f5e0cc;
      --clr-border: #e8ccb0;
      --clr-border2: #d4a880;
      --clr-border3: #e0bc98;
      --clr-text: #7a3818;
      --clr-text-lt: #e8c8a0;
      --clr-fg: #fff8f0;
      --clr-tt-main: #d07048;
      --clr-tt-dark: #b85830;
      --clr-tt-lt: #e8b090;
      --clr-tt-bg: #faeade;
      --clr-tt-panel: #fff8f0;
      --clr-tt-ring-bg: #f0c8a8;
      --clr-tt-stats: #c86840;
      --clr-tt-task-title: #e0a078;
      --clr-tt-hover: #faeade;
      --clr-tt-border: #e0c0a0;
      --clr-tt-range: #faeade;
      --clr-tt-range-b: #e8ccb0;
      --clr-cb-checked: #b06040;
    }

    /* ── 7. Slate Gray ── */
    .theme-slate {
      --clr-primary: #485870;
      --clr-primary-lt: #607080;
      --clr-primary-dk: #283040;
      --clr-accent: #586878;
      --clr-bg: #c8d0d8;
      --clr-panel: #dce4ec;
      --clr-panel2: #d0dce8;
      --clr-border: #b8c8d4;
      --clr-border2: #90a8bc;
      --clr-border3: #a8bccc;
      --clr-text: #283040;
      --clr-text-lt: #b0c4d4;
      --clr-fg: #f0f4f8;
      --clr-tt-main: #6080a8;
      --clr-tt-dark: #487090;
      --clr-tt-lt: #98b8d0;
      --clr-tt-bg: #dce4ec;
      --clr-tt-panel: #f0f4f8;
      --clr-tt-ring-bg: #b8d0e4;
      --clr-tt-stats: #587898;
      --clr-tt-task-title: #80a8c0;
      --clr-tt-hover: #dce4ec;
      --clr-tt-border: #a8c0d0;
      --clr-tt-range: #dce4ec;
      --clr-tt-range-b: #b8c8d4;
      --clr-cb-checked: #507090;
    }

    /* ── 8. Caramel Gold ── */
    .theme-gold {
      --clr-primary: #9a7830;
      --clr-primary-lt: #b89048;
      --clr-primary-dk: #604800;
      --clr-accent: #aa8838;
      --clr-bg: #ecdcc0;
      --clr-panel: #f8ecd4;
      --clr-panel2: #f0e0c0;
      --clr-border: #e0cca0;
      --clr-border2: #c8a870;
      --clr-border3: #d8bc88;
      --clr-text: #604800;
      --clr-text-lt: #e0c888;
      --clr-fg: #fdf8f0;
      --clr-tt-main: #c8a040;
      --clr-tt-dark: #a88028;
      --clr-tt-lt: #e8c880;
      --clr-tt-bg: #f8ecd4;
      --clr-tt-panel: #fdf8f0;
      --clr-tt-ring-bg: #e8d098;
      --clr-tt-stats: #b89030;
      --clr-tt-task-title: #d8b868;
      --clr-tt-hover: #f8ecd4;
      --clr-tt-border: #d8c090;
      --clr-tt-range: #f8ecd4;
      --clr-tt-range-b: #e0cca0;
      --clr-cb-checked: #a07828;
    }

    /* ── 9. Dark Mode ── */
    .theme-dark {
      --clr-primary: #2a2a3a;
      --clr-primary-lt: #3a3a50;
      --clr-primary-dk: #14141e;
      --clr-accent: #3a3a50;
      --clr-bg: #1a1a28;
      --clr-panel: #c8c8e0;
      --clr-panel2: #c8c8e0;
      --clr-border: #383850;
      --clr-border2: #484860;
      --clr-border3: #404058;
      --clr-text: #14141e;
      --clr-text-lt: #606080;
      --clr-fg: #e8e8f8;
      --clr-tt-main: #4858a8;
      --clr-tt-dark: #3848a0;
      --clr-tt-lt: #7088c8;
      --clr-tt-bg: #252538;
      --clr-tt-panel: #252538;
      --clr-tt-ring-bg: #3848a0;
      --clr-tt-stats: #404888;
      --clr-tt-task-title: #505888;
      --clr-tt-hover: #2e2e45;
      --clr-tt-border: #404058;
      --clr-tt-range: #252538;
      --clr-tt-range-b: #383850;
      --clr-cb-checked: #5868b8;
    }

    /* ── 10. Mint Fresh ── */
    .theme-mint {
      --clr-primary: #38887a;
      --clr-primary-lt: #50a090;
      --clr-primary-dk: #185848;
      --clr-accent: #489888;
      --clr-bg: #c0e0d8;
      --clr-panel: #d8f0ec;
      --clr-panel2: #68c0b8;
      --clr-border: #a8d8d0;
      --clr-border2: #80c0b8;
      --clr-border3: #98ccc4;
      --clr-text: #185848;
      --clr-text-lt: #a0d0c8;
      --clr-fg: #eefaf8;
      --clr-tt-main: #40a898;
      --clr-tt-dark: #288878;
      --clr-tt-lt: #80c8c0;
      --clr-tt-bg: #d8f0ec;
      --clr-tt-panel: #eefaf8;
      --clr-tt-ring-bg: #a8dcd4;
      --clr-tt-stats: #389888;
      --clr-tt-task-title: #68c0b8;
      --clr-tt-hover: #d8f0ec;
      --clr-tt-border: #98ccc4;
      --clr-tt-range: #d8f0ec;
      --clr-tt-range-b: #a8d8d0;
      --clr-cb-checked: #308878;
    }

    /* ══════════════════════════════════
   THEME SWITCHER UI
══════════════════════════════════ */
    .theme-bar {
      position: fixed;
      top: 10px;
      left: 50%;
      transform: translateX(-50%);
      z-index: 950;
      display: flex;
      align-items: center;
      gap: 6px;
      background: rgba(0, 0, 0, 0.35);
      backdrop-filter: blur(6px);
      border-radius: 30px;
      padding: 5px 10px;
    }

    .theme-bar-label {
      font-size: 9px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 1px;
      color: rgba(255, 255, 255, 0.7);
      margin-right: 4px;
      white-space: nowrap;
    }

    .theme-swatch {
      width: 22px;
      height: 22px;
      border-radius: 50%;
      cursor: pointer;
      border: 2.5px solid transparent;
      transition: transform .15s, border-color .15s;
      position: relative;
      flex-shrink: 0;
    }

    .theme-swatch:hover {
      transform: scale(1.25);
    }

    .theme-swatch.active {
      border-color: #fff;
      transform: scale(1.2);
    }

    .theme-swatch[title]::after {
      content: attr(title);
      position: absolute;
      bottom: -24px;
      left: 50%;
      transform: translateX(-50%);
      background: rgba(0, 0, 0, 0.7);
      color: #fff;
      font-size: 8px;
      white-space: nowrap;
      padding: 2px 5px;
      border-radius: 3px;
      pointer-events: none;
      opacity: 0;
      transition: opacity .15s;
    }

    .theme-swatch:hover::after {
      opacity: 1;
    }

    /* ══════════════════════════════════
   CUSTOM LANGUAGE DROPDOWN
══════════════════════════════════ */
    .lang-dropdown {
      position: relative;
      flex-shrink: 0;
    }

    .lang-trigger {
      display: flex;
      align-items: center;
      gap: 5px;
      background: rgba(255,255,255,.18);
      border: 1px solid rgba(255,255,255,.25);
      border-radius: 12px;
      padding: 4px 8px 4px 6px;
      color: #fff;
      font-size: 10px;
      font-weight: 700;
      cursor: pointer;
      white-space: nowrap;
      transition: background .15s, border-color .15s;
      backdrop-filter: blur(4px);
      letter-spacing: .4px;
    }

    .lang-trigger:hover {
      background: rgba(255,255,255,.28);
      border-color: rgba(255,255,255,.45);
    }

    .lang-flag { font-size: 13px; line-height: 1; }
    .lang-name { max-width: 68px; overflow: hidden; text-overflow: ellipsis; }
    .lang-caret { font-size: 8px; opacity: .75; transition: transform .2s; }
    .lang-dropdown.open .lang-caret { transform: rotate(180deg); }

    .lang-menu {
      display: none;
      position: absolute;
      top: calc(100% + 8px);
      right: 0;
      min-width: 170px;
      max-height: 280px;
      overflow-y: auto;
      background: rgba(28,28,36,.96);
      backdrop-filter: blur(14px);
      border: 1px solid rgba(255,255,255,.14);
      border-radius: 12px;
      padding: 6px 4px;
      z-index: 9999;
      box-shadow: 0 8px 32px rgba(0,0,0,.45);
      scroll-behavior: smooth;
    }

    .lang-menu::-webkit-scrollbar { width: 4px; }
    .lang-menu::-webkit-scrollbar-track { background: transparent; }
    .lang-menu::-webkit-scrollbar-thumb { background: rgba(255,255,255,.2); border-radius: 4px; }

    .lang-dropdown.open .lang-menu { display: block; animation: langFadeIn .18s ease; }

    @keyframes langFadeIn {
      from { opacity:0; transform: translateY(-6px); }
      to   { opacity:1; transform: translateY(0); }
    }

    .lang-group-label {
      font-size: 8.5px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .8px;
      color: rgba(255,255,255,.38);
      padding: 8px 10px 3px;
    }

    .lang-option {
      display: block;
      width: 100%;
      text-align: left;
      background: none;
      border: none;
      color: rgba(255,255,255,.88);
      font-size: 11px;
      font-weight: 500;
      padding: 6px 10px;
      border-radius: 7px;
      cursor: pointer;
      transition: background .12s;
      letter-spacing: .2px;
    }

    .lang-option:hover { background: rgba(255,255,255,.12); }
    .lang-option.active { background: rgba(255,255,255,.18); color: #fff; font-weight: 700; }

    /* ══════════════════════════════════
   PROFILE PAGE
══════════════════════════════════ */
    .profile-body {
      max-width: 820px;
      margin: 0 auto;
      padding: 10px 0 40px;
    }

    .profile-hero {
      background: var(--clr-primary);
      border-radius: 14px;
      padding: 32px 28px;
      display: flex;
      align-items: center;
      gap: 24px;
      margin-bottom: 16px;
      position: relative;
      overflow: hidden;
    }

    .profile-hero::before {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(255,255,255,.07) 0%, transparent 60%);
      pointer-events: none;
    }

    .profile-avatar-wrap {
      position: relative;
      flex-shrink: 0;
    }

    .profile-avatar-big {
      width: 80px;
      height: 80px;
      border-radius: 50%;
      border: 3px solid rgba(255,255,255,.35);
      object-fit: cover;
      background: var(--clr-primary-dk);
      display: block;
    }

    .profile-avatar-placeholder {
      width: 80px;
      height: 80px;
      border-radius: 50%;
      border: 3px solid rgba(255,255,255,.35);
      background: var(--clr-primary-dk);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 32px;
      color: rgba(255,255,255,.7);
      flex-shrink: 0;
    }

    .profile-hero-info { flex: 1; }

    .profile-hero-name {
      font-size: 22px;
      font-weight: 800;
      color: var(--clr-fg);
      letter-spacing: .5px;
      margin-bottom: 4px;
    }

    .profile-hero-email {
      font-size: 12px;
      color: rgba(255,255,255,.6);
      margin-bottom: 10px;
    }

    .profile-badge {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      background: rgba(255,255,255,.14);
      border: 1px solid rgba(255,255,255,.22);
      border-radius: 20px;
      padding: 3px 10px;
      font-size: 10px;
      font-weight: 700;
      color: rgba(255,255,255,.85);
      letter-spacing: .5px;
    }

    .profile-logout-btn {
      flex-shrink: 0;
      background: rgba(255,255,255,.12);
      border: 1.5px solid rgba(255,255,255,.3);
      color: var(--clr-fg);
      border-radius: 10px;
      padding: 9px 18px;
      font-size: 11px;
      font-weight: 700;
      cursor: pointer;
      letter-spacing: .5px;
      transition: background .2s, border-color .2s, transform .15s;
      display: flex;
      align-items: center;
      gap: 6px;
    }

    .profile-logout-btn:hover {
      background: rgba(220,50,50,.45);
      border-color: rgba(255,100,100,.5);
      transform: scale(1.04);
    }

    .profile-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 14px;
      margin-bottom: 14px;
    }

    .profile-card {
      background: var(--clr-panel);
      border: 1px solid var(--clr-border);
      border-radius: 12px;
      padding: 18px 20px;
    }

    .profile-card-title {
      font-size: 9px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 1px;
      color: var(--clr-primary);
      border-bottom: 1px solid var(--clr-border3);
      padding-bottom: 8px;
      margin-bottom: 14px;
    }

    .profile-stat-row {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 6px 0;
      border-bottom: 1px solid var(--clr-border);
      font-size: 11px;
    }

    .profile-stat-row:last-child { border-bottom: none; }

    .profile-stat-label {
      color: var(--clr-text);
      opacity: .75;
    }

    .profile-stat-value {
      font-weight: 700;
      color: var(--clr-text);
    }

    .profile-streak-big {
      text-align: center;
      padding: 10px 0;
    }

    .profile-streak-num {
      font-size: 48px;
      font-weight: 900;
      color: var(--clr-primary);
      line-height: 1;
    }

    .profile-streak-label {
      font-size: 10px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .8px;
      color: var(--clr-text);
      opacity: .6;
      margin-top: 4px;
    }

    .profile-full-card {
      background: var(--clr-panel);
      border: 1px solid var(--clr-border);
      border-radius: 12px;
      padding: 18px 20px;
      margin-bottom: 14px;
    }

    .profile-habit-chips {
      display: flex;
      flex-wrap: wrap;
      gap: 7px;
      margin-top: 2px;
    }

    .profile-habit-chip {
      background: var(--clr-primary);
      color: var(--clr-fg);
      border-radius: 20px;
      padding: 4px 11px;
      font-size: 10px;
      font-weight: 600;
      display: flex;
      align-items: center;
      gap: 4px;
    }

    .profile-settings-row {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 9px 0;
      border-bottom: 1px solid var(--clr-border);
      font-size: 11px;
    }

    .profile-settings-row:last-child { border-bottom: none; }

    .profile-settings-label {
      color: var(--clr-text);
      font-weight: 600;
    }

    .profile-settings-val {
      color: var(--clr-primary);
      font-weight: 700;
      font-size: 11px;
    }

    .profile-not-signed {
      text-align: center;
      padding: 48px 20px;
    }

    .profile-not-signed-icon { font-size: 52px; margin-bottom: 12px; }
    .profile-not-signed h2 { font-size: 18px; font-weight: 800; color: var(--clr-text); margin-bottom: 8px; }
    .profile-not-signed p { font-size: 12px; color: var(--clr-text); opacity: .65; margin-bottom: 20px; }

    .profile-signin-cta {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: var(--clr-primary);
      color: var(--clr-fg);
      border: none;
      border-radius: 10px;
      padding: 10px 22px;
      font-size: 12px;
      font-weight: 700;
      cursor: pointer;
      transition: background .2s, transform .15s;
    }

    .profile-signin-cta:hover { background: var(--clr-primary-lt); transform: scale(1.04); }

    /* ══════════════════════════════════
   SHELL / NAVIGATION
══════════════════════════════════ */
    *,
    *::before,
    *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
    }

    body {
      font-family: 'Segoe UI', Arial, sans-serif;
      background: var(--clr-bg);
      min-height: 100vh;
      overflow-x: hidden;
      transition: background .3s;
    }

    .shell {
      position: relative;
      min-height: 100vh;
    }

    .nav-arrow {
      position: fixed;
      top: 50%;
      transform: translateY(-50%);
      z-index: 900;
      background: var(--clr-primary);
      color: var(--clr-fg);
      border: none;
      border-radius: 50%;
      width: 44px;
      height: 44px;
      font-size: 22px;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      box-shadow: 0 3px 14px rgba(0, 0, 0, .35);
      transition: background .2s, transform .15s;
      user-select: none;
    }

    .nav-arrow:hover {
      background: var(--clr-accent);
      transform: translateY(-50%) scale(1.08);
    }

    .nav-arrow.left {
      left: 10px;
    }

    .nav-arrow.right {
      right: 10px;
    }

    .nav-dots {
      position: fixed;
      bottom: 14px;
      left: 50%;
      transform: translateX(-50%);
      display: flex;
      gap: 14px;
      z-index: 900;
      align-items: center;
      background: rgba(0, 0, 0, 0.18);
      backdrop-filter: blur(4px);
      border-radius: 20px;
      padding: 6px 14px;
    }

    .nav-dot {
      width: 10px;
      height: 10px;
      border-radius: 50%;
      background: var(--clr-border2);
      cursor: pointer;
      transition: background .2s, transform .15s;
      border: none;
      /* Bigger touch target */
      position: relative;
    }

    .nav-dot::after {
      content: '';
      position: absolute;
      inset: -8px;
    }

    .nav-dot.active {
      background: var(--clr-primary);
      transform: scale(1.3);
    }

    .page {
      display: none;
      padding: 46px 60px 12px;
      min-height: 100vh;
    }

    .page.active {
      display: block;
    }

    /* ══════════════════════════════════════════════════
   ██  HABIT TRACKER — CSS-VAR DRIVEN
══════════════════════════════════════════════════ */
    .ht-body {
      font-size: 11px;
      color: #222;
    }

    .ht-dashboard {
      display: grid;
      grid-template-columns: 152px 1fr 204px;
      grid-template-rows: auto auto auto;
      gap: 6px;
      max-width: 1340px;
      margin: 0 auto;
    }

    .ht-ph-light {
      font-size: 10px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .8px;
      text-align: center;
      color: var(--clr-text);
      border-bottom: 1px solid var(--clr-border3);
      padding-bottom: 4px;
      margin-bottom: 6px;
    }

    .ht-sidebar {
      grid-column: 1;
      grid-row: 1;
      display: flex;
      flex-direction: column;
      gap: 6px;
    }

    .ht-title-box {
      background: var(--clr-primary);
      border-radius: 5px;
      color: var(--clr-fg);
      text-align: center;
      padding: 10px 6px;
    }

    .ht-title-box h1 {
      font-size: 14px;
      font-weight: 900;
      letter-spacing: 1.2px;
      text-transform: uppercase;
    }

    .ht-title-box .ht-month-label {
      font-size: 12px;
      margin-top: 3px;
      letter-spacing: .5px;
      opacity: .85;
    }

    .ht-cal-box {
      background: var(--clr-primary);
      border-radius: 5px;
      padding: 8px;
      color: var(--clr-fg);
    }

    .ht-cal-box .ht-section-title {
      font-size: 9px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .7px;
      text-align: center;
      border-bottom: 1px solid rgba(255, 255, 255, .2);
      padding-bottom: 3px;
      margin-bottom: 7px;
    }

    .ht-cal-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 5px;
      margin-bottom: 6px;
    }

    .ht-cal-row:last-child {
      margin-bottom: 0;
    }

    .ht-cal-row label {
      font-size: 9px;
      text-transform: uppercase;
      font-weight: 700;
      white-space: nowrap;
    }

    .ht-cal-row select {
      flex: 1;
      font-size: 9px;
      padding: 3px 5px;
      border: none;
      border-radius: 3px;
      background: var(--clr-primary-lt);
      color: var(--clr-fg);
      cursor: pointer;
      outline: none;
    }

    .ht-cal-row select:hover {
      background: var(--clr-accent);
    }

    .ht-habits-panel {
      grid-column: 1;
      grid-row: 2;
      background: var(--clr-panel);
      border-radius: 5px;
      padding: 8px;
      display: flex;
      flex-direction: column;
      align-self: start;
    }

    .ht-hap-row {
      height: 24px;
      min-height: 24px;
      max-height: 24px;
      display: flex;
      align-items: center;
      overflow: hidden;
      border-bottom: 1px solid var(--clr-border);
    }

    .ht-hap-title {
      background: var(--clr-primary);
      color: var(--clr-fg);
      font-size: 9px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .7px;
      justify-content: center;
      border-radius: 3px 3px 0 0;
      border-bottom: 1px solid var(--clr-primary-dk) !important;
    }

    .ht-hap-spacer {
      background: var(--clr-panel2);
      border-bottom: 1px solid var(--clr-border) !important;
    }

    .ht-hap-habit {
      gap: 4px;
      padding: 0 4px;
    }

    .ht-hap-emoji {
      font-size: 11px;
      flex-shrink: 0;
      line-height: 1;
    }

    .ht-hap-name {
      flex: 1;
      font-size: 9.5px;
      color: var(--clr-text);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .ht-btn-del-habit {
      background: none;
      border: none;
      cursor: pointer;
      color: var(--clr-text-lt);
      font-size: 13px;
      line-height: 1;
      padding: 0 2px;
      flex-shrink: 0;
      transition: color .2s;
    }

    .ht-btn-del-habit:hover {
      color: #c0392b;
    }

    /* Habit time badge in sidebar */
    .ht-hap-time {
      font-size: 7.5px;
      font-weight: 800;
      color: var(--clr-primary);
      background: var(--clr-panel2);
      border: 1px solid var(--clr-border3);
      border-radius: 3px;
      padding: 1px 3px;
      cursor: pointer;
      white-space: nowrap;
      flex-shrink: 0;
      line-height: 1.4;
      transition: background .15s;
    }

    .ht-hap-time:hover {
      background: var(--clr-border);
    }

    .ht-hap-time.empty {
      font-size: 10px;
      background: transparent;
      border-color: transparent;
      color: var(--clr-text-lt);
      padding: 1px 1px;
    }

    .ht-hap-time.empty:hover {
      background: var(--clr-panel2);
      border-color: var(--clr-border3);
      color: var(--clr-primary);
    }

    .ht-hap-add {
      border-bottom: none !important;
      padding: 3px 0 0;
      height: auto !important;
      min-height: unset !important;
      max-height: unset !important;
    }

    .ht-btn-add-habit {
      width: 100%;
      padding: 4px 2px;
      font-size: 8.5px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .5px;
      background: var(--clr-primary);
      color: var(--clr-fg);
      border: none;
      border-radius: 0 0 3px 3px;
      cursor: pointer;
      transition: background .2s;
    }

    .ht-btn-add-habit:hover {
      background: var(--clr-accent);
    }

    .ht-top-band {
      grid-column: 2;
      grid-row: 1;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 6px;
    }

    .ht-chart-panel {
      background: var(--clr-panel);
      border-radius: 5px;
      padding: 8px;
    }

    .ht-chart-panel canvas {
      max-height: 110px;
    }

    .ht-right-top {
      grid-column: 3;
      grid-row: 1;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 6px;
    }

    .ht-kpi-box {
      background: var(--clr-primary);
      border-radius: 5px;
      padding: 10px 8px;
      color: var(--clr-fg);
    }

    .ht-kpi-row {
      margin-bottom: 9px;
    }

    .ht-kpi-row:last-child {
      margin-bottom: 0;
    }

    .ht-kpi-label {
      font-size: 9px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .6px;
      color: var(--clr-text-lt);
    }

    .ht-kpi-value {
      font-size: 22px;
      font-weight: 900;
      color: var(--clr-fg);
      line-height: 1.1;
    }

    .ht-overall-stats-box {
      background: var(--clr-panel);
      border-radius: 5px;
      padding: 8px;
    }

    .ht-overall-stats-box canvas {
      max-height: 105px;
    }

    .ht-matrix-area {
      grid-column: 2;
      grid-row: 2;
      background: var(--clr-panel);
      border-radius: 5px;
      padding: 8px;
      overflow-x: auto;
    }

    .ht-matrix-table {
      border-collapse: collapse;
      font-size: 8.5px;
      width: 100%;
      table-layout: fixed;
    }

    .ht-matrix-table th {
      background: var(--clr-primary-lt);
      color: var(--clr-fg);
      padding: 0 3px;
      text-align: center;
      font-weight: 600;
      border: 1px solid var(--clr-border2);
      height: 24px;
      overflow: hidden;
    }

    .ht-matrix-table td {
      border: 1px solid var(--clr-border);
      text-align: center;
      padding: 0;
      height: 24px;
    }

    .ht-wk-hdr {
      background: var(--clr-primary) !important;
      color: var(--clr-fg) !important;
      font-size: 9px;
      font-weight: 700;
    }

    .ht-day-lbl {
      font-size: 7.5px;
    }

    .ht-day-num {
      font-size: 7px;
      color: var(--clr-text-lt) !important;
    }

    .ht-today-col {
      background: rgba(90, 83, 75, .12) !important;
    }

    .ht-cb-cell {
      cursor: pointer;
    }

    .ht-cb-cell input[type=checkbox] {
      width: 12px;
      height: 12px;
      cursor: pointer;
      accent-color: var(--clr-primary);
    }

    /* Off day — double-clicked to mark as N/A */
    .ht-cb-cell.ht-off {
      background: repeating-linear-gradient(45deg,
          transparent,
          transparent 2px,
          rgba(0, 0, 0, 0.06) 2px,
          rgba(0, 0, 0, 0.06) 4px);
    }

    .ht-cb-cell.ht-off input[type=checkbox] {
      opacity: 0;
      pointer-events: none;
    }

    .ht-cb-cell.ht-off::after {
      content: '—';
      font-size: 10px;
      font-weight: 700;
      color: var(--clr-text-lt);
      display: flex;
      align-items: center;
      justify-content: center;
      width: 100%;
      height: 100%;
    }

    .ht-analysis-area {
      grid-column: 3;
      grid-row: 2;
      background: var(--clr-panel);
      border-radius: 5px;
      padding: 8px;
      overflow-y: auto;
    }

    .ht-analysis-table {
      width: 100%;
      border-collapse: collapse;
      font-size: 9px;
    }

    .ht-analysis-table th {
      background: var(--clr-primary-lt);
      color: var(--clr-fg);
      text-align: center;
      height: 24px;
      font-size: 8px;
      border: 1px solid var(--clr-border2);
    }

    .ht-analysis-table td {
      border: 1px solid var(--clr-border);
      padding: 2px 4px;
      text-align: center;
      height: 24px;
      color: var(--clr-text);
    }

    .ht-pb-wrap {
      background: var(--clr-border);
      border-radius: 2px;
      height: 8px;
      width: 100%;
    }

    .ht-pb-fill {
      background: var(--clr-primary);
      height: 8px;
      border-radius: 2px;
      transition: width .3s;
    }

    .ht-top10-panel {
      grid-column: 3;
      grid-row: 3;
      background: var(--clr-primary);
      border-radius: 5px;
      padding: 8px;
      color: var(--clr-fg);
      align-self: start;
    }

    .ht-top10-title {
      font-size: 10px;
      font-weight: 700;
      text-align: center;
      text-transform: uppercase;
      letter-spacing: .7px;
      margin-bottom: 6px;
      border-bottom: 1px solid rgba(255, 255, 255, .2);
      padding-bottom: 3px;
    }

    .ht-top10-row {
      display: flex;
      align-items: center;
      gap: 5px;
      padding: 3px 0;
      border-bottom: 1px solid rgba(255, 255, 255, .08);
    }

    .ht-top10-row:last-child {
      border-bottom: none;
    }

    .ht-top10-num {
      font-size: 9px;
      font-weight: 700;
      color: var(--clr-text-lt);
      width: 14px;
      text-align: right;
      flex-shrink: 0;
    }

    .ht-top10-name {
      font-size: 9.5px;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .ht-top10-pct {
      font-size: 8.5px;
      color: var(--clr-text-lt);
      margin-left: auto;
      flex-shrink: 0;
    }

    .ht-no-habits-msg {
      font-size: 9px;
      color: var(--clr-text-lt);
      text-align: center;
      padding: 8px 0;
    }

    .ht-empty-matrix {
      text-align: center;
      padding: 30px 10px;
      color: var(--clr-text-lt);
      font-size: 11px;
    }

    /* Modal */
    .ht-modal-overlay {
      display: none;
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, .4);
      z-index: 1000;
      align-items: center;
      justify-content: center;
    }

    .ht-modal-overlay.open {
      display: flex;
    }

    .ht-modal-box {
      background: var(--clr-panel);
      border-radius: 8px;
      padding: 18px 20px;
      min-width: 280px;
      box-shadow: 0 8px 32px rgba(0, 0, 0, .3);
    }

    .ht-modal-title {
      font-size: 13px;
      font-weight: 700;
      color: var(--clr-text);
      margin-bottom: 14px;
      text-align: center;
    }

    .ht-modal-field {
      margin-bottom: 10px;
    }

    .ht-modal-field label {
      display: block;
      font-size: 9px;
      font-weight: 700;
      text-transform: uppercase;
      color: var(--clr-primary-lt);
      margin-bottom: 3px;
    }

    .ht-modal-field input {
      width: 100%;
      padding: 6px 8px;
      font-size: 11px;
      border: 1px solid var(--clr-border3);
      border-radius: 4px;
      background: var(--clr-fg);
      color: var(--clr-text);
      outline: none;
    }

    .ht-modal-field input:focus {
      border-color: var(--clr-primary);
    }

    .ht-emoji-preview {
      font-size: 24px;
      text-align: center;
      margin-bottom: 6px;
    }

    .ht-modal-btns {
      display: flex;
      gap: 8px;
      margin-top: 14px;
    }

    .ht-btn-confirm {
      flex: 1;
      padding: 7px;
      font-size: 10px;
      font-weight: 700;
      text-transform: uppercase;
      background: var(--clr-primary);
      color: var(--clr-fg);
      border: none;
      border-radius: 4px;
      cursor: pointer;
    }

    .ht-btn-confirm:hover {
      background: var(--clr-accent);
    }

    .ht-btn-cancel {
      flex: 1;
      padding: 7px;
      font-size: 10px;
      font-weight: 700;
      text-transform: uppercase;
      background: var(--clr-border);
      color: var(--clr-text);
      border: none;
      border-radius: 4px;
      cursor: pointer;
    }

    .ht-btn-cancel:hover {
      background: var(--clr-border3);
    }

    .ht-emoji-grid {
      display: flex;
      flex-wrap: wrap;
      gap: 4px;
      max-height: 100px;
      overflow-y: auto;
      background: var(--clr-fg);
      border: 1px solid var(--clr-border3);
      border-radius: 4px;
      padding: 5px;
      margin-top: 5px;
    }

    .ht-emoji-btn {
      font-size: 18px;
      background: none;
      border: 1px solid transparent;
      border-radius: 3px;
      cursor: pointer;
      padding: 2px 3px;
      line-height: 1;
    }

    .ht-emoji-btn:hover,
    .ht-emoji-btn.selected {
      background: var(--clr-panel2);
      border-color: var(--clr-primary);
    }

    /* ══════════════════════════════════════════════════
   ██  TASK TRACKER — CSS-VAR DRIVEN
══════════════════════════════════════════════════ */
    .tt-body {
      background: transparent;
      color: #4f4f4f;
      transition: background .3s;
    }

    .tt-dashboard {
      width: 100%;
      max-width: 1340px;
      margin: 0 auto;
      background: transparent;
      border: none;
      box-shadow: none;
      padding: 0;
    }

    .tt-dashboard-inner {
      min-width: 0;
    }

    .tt-top-grid {
      display: grid;
      grid-template-columns: 152px 1fr 1fr 204px;
      gap: 6px;
      margin-bottom: 6px;
      align-items: stretch;
    }

    .tt-sidebar {
      display: grid;
      grid-template-rows: 70px 1fr;
      gap: 8px;
      height: 187px;
    }

    .tt-panel {
      background: var(--clr-panel);
      border: 1px solid var(--clr-border3);
      border-radius: 5px;
      position: relative;
      overflow: hidden;
    }

    .tt-panel-header {
      background: var(--clr-primary);
      color: var(--clr-fg);
      text-align: center;
      font-weight: 700;
      font-size: 10px;
      text-transform: uppercase;
      letter-spacing: .7px;
      padding: 5px 8px;
      border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    }

    .tt-brand {
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      background: var(--clr-primary);
      color: var(--clr-fg);
      border: none;
      border-radius: 5px;
      text-align: center;
    }

    .tt-brand h1 {
      margin: 0;
      font-size: 14px;
      letter-spacing: 1.2px;
      font-weight: 900;
      text-transform: uppercase;
    }

    .tt-brand span {
      font-size: 12px;
      font-weight: 600;
      margin-top: 3px;
      opacity: .85;
    }

    .tt-settings-body {
      padding: 8px 12px 10px;
      font-size: 11px;
      color: var(--clr-fg);
    }

    .tt-setting-row {
      display: grid;
      grid-template-columns: 52px 1fr;
      gap: 12px;
      padding: 4px 0;
      font-weight: 700;
      align-items: center;
      border-bottom: 1px solid rgba(255, 255, 255, .15);
    }

    .tt-setting-row:last-child {
      border-bottom: none;
    }

    .tt-setting-row .tt-label {
      color: rgba(255, 255, 255, .75);
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: .5px;
    }

    /* Override panel background for settings/calendar panel to match ht-cal-box */
    .tt-sidebar .tt-panel {
      background: var(--clr-primary);
      border-color: var(--clr-border3);
    }

    .tt-main-top {
      display: contents;
    }

    .tt-right-panels {
      display: grid;
      grid-template-rows: 1fr;
      grid-template-columns: 1fr 1fr;
      gap: 6px;
      height: 187px;
    }

    .tt-chart-panel {
      height: 187px;
    }

    .tt-insight-panel {
      height: auto;
      min-height: 0;
    }

    .tt-score-panel {
      height: auto;
      min-height: 0;
    }

    .tt-chart-wrap {
      padding: 8px 10px 6px 10px;
      height: calc(100% - 30px);
      display: flex;
      align-items: stretch;
      gap: 8px;
    }

    .tt-y-axis {
      width: 18px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      font-size: 8px;
      font-weight: 700;
      color: var(--clr-text);
      padding: 1px 0 12px;
      text-align: right;
      opacity: .6;
    }

    .tt-chart-area {
      flex: 1;
      position: relative;
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      padding: 6px 8px 18px 2px;
      border-left: 1px solid var(--clr-border2);
      border-bottom: 1px solid var(--clr-border2);
      background-image: linear-gradient(to top, transparent 0, transparent calc(20% - 1px), var(--clr-border) calc(20% - 1px), var(--clr-border) 20%, transparent 20%), linear-gradient(to top, transparent 0, transparent calc(40% - 1px), var(--clr-border) calc(40% - 1px), var(--clr-border) 40%, transparent 40%), linear-gradient(to top, transparent 0, transparent calc(60% - 1px), var(--clr-border) calc(60% - 1px), var(--clr-border) 60%, transparent 60%), linear-gradient(to top, transparent 0, transparent calc(80% - 1px), var(--clr-border) calc(80% - 1px), var(--clr-border) 80%, transparent 80%);
    }

    .tt-bar-group {
      width: 13.3%;
      height: 100%;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      align-items: center;
      gap: 6px;
    }

    .tt-bar-stack {
      width: 42px;
      height: 78px;
      position: relative;
      display: flex;
      align-items: flex-end;
      justify-content: center;
    }

    .tt-bar-light,
    .tt-bar-dark {
      position: absolute;
      bottom: 0;
      width: 42px;
      border-radius: 0;
    }

    .tt-bar-light {
      background: var(--clr-border2);
    }

    .tt-bar-dark {
      background: var(--clr-primary);
    }

    .tt-bar-label {
      font-size: 9px;
      font-weight: 700;
      color: var(--clr-text);
      letter-spacing: 0.3px;
      opacity: .7;
    }

    .tt-insight-body {
      padding: 8px 10px;
      display: flex;
      flex-direction: column;
      justify-content: space-around;
      gap: 6px;
      font-size: 11px;
      min-height: calc(100% - 30px);
    }

    .tt-insight-item {
      display: flex;
      flex-direction: column;
      padding: 6px 8px;
      border-bottom: 1px solid var(--clr-border3);
    }

    .tt-insight-item:last-child {
      border-bottom: none;
    }

    .tt-icon {
      font-size: 11px;
      line-height: 1;
      color: var(--clr-primary-lt);
      margin-bottom: 2px;
    }

    .tt-insight-label {
      color: var(--clr-text);
      font-weight: 700;
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: .6px;
      margin-bottom: 2px;
      opacity: .75;
    }

    .tt-insight-value {
      font-size: 22px;
      font-weight: 900;
      color: var(--clr-primary);
      line-height: 1.1;
    }

    .tt-insight-percent {
      font-size: 10px;
      font-weight: 700;
      color: var(--clr-text);
      margin-top: 1px;
      opacity: .7;
    }

    .tt-score-body {
      height: calc(100% - 30px);
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      gap: 10px;
      padding: 12px 8px 14px;
    }

    /* ── KPI panel (matches ht-kpi-box style) ── */
    .tt-kpi-panel {
      background: var(--clr-primary) !important;
      border-color: var(--clr-primary-dk) !important;
    }

    .tt-kpi-panel .tt-panel-header {
      background: var(--clr-primary-dk);
      color: var(--clr-fg);
      border-bottom-color: rgba(255, 255, 255, .15);
    }

    .tt-kpi-body {
      padding: 8px 10px;
      display: flex;
      flex-direction: column;
      justify-content: space-evenly;
      height: calc(100% - 30px);
    }

    .tt-kpi-row-item {
      padding: 4px 0;
      border-bottom: 1px solid rgba(255, 255, 255, .12);
    }

    .tt-kpi-row-item:last-child {
      border-bottom: none;
    }

    .tt-kpi-lbl {
      font-size: 9px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .6px;
      color: var(--clr-text-lt);
    }

    .tt-kpi-val {
      font-size: 20px;
      font-weight: 900;
      color: var(--clr-fg);
      line-height: 1.15;
    }

    /* ── Setting value display (bold like ht-cal-box) ── */
    .tt-setting-val {
      font-size: 11px;
      font-weight: 800;
      color: var(--clr-fg);
      letter-spacing: .3px;
    }

    /* ── Task tracker calendar panel — mirrors ht-cal-box ── */
    .tt-cal-panel {
      background: var(--clr-primary) !important;
      border-color: var(--clr-primary-dk) !important;
      padding: 8px !important;
      color: var(--clr-fg);
    }

    .tt-cal-header {
      background: transparent !important;
      border-bottom: 1px solid rgba(255, 255, 255, .2) !important;
      color: var(--clr-fg) !important;
      font-size: 9px !important;
      padding: 0 0 3px 0 !important;
      margin-bottom: 7px !important;
      text-align: center;
    }

    .tt-cal-panel .ht-cal-row label {
      color: var(--clr-fg);
    }

    .tt-week-val {
      flex: 1;
      font-size: 9px;
      font-weight: 800;
      color: var(--clr-fg);
      padding: 3px 5px;
      background: var(--clr-primary-lt);
      border-radius: 3px;
      text-align: center;
    }

    .tt-score-value {
      font-size: 28px;
      font-weight: 900;
      color: var(--clr-primary);
      line-height: 1;
    }

    .tt-score-bar {
      width: 80px;
      height: 8px;
      border-radius: 4px;
      background: var(--clr-border);
      overflow: hidden;
    }

    .tt-score-bar-fill {
      height: 100%;
      background: var(--clr-primary);
      border-radius: 4px;
      width: 0;
      transition: width .4s ease;
    }

    .tt-week-tools {
      display: flex;
      justify-content: space-between;
      gap: 8px;
      margin-bottom: 8px;
      flex-wrap: wrap;
      align-items: center;
      background: var(--clr-panel);
      border: 1px solid var(--clr-border3);
      border-radius: 5px;
      padding: 6px 8px;
    }

    .tt-tool-group {
      display: flex;
      gap: 6px;
      align-items: center;
      flex-wrap: wrap;
    }

    .tt-range-label {
      font-size: 11px;
      font-weight: 700;
      color: var(--clr-text);
      background: var(--clr-panel2);
      border: 1px solid var(--clr-border3);
      border-radius: 3px;
      padding: 6px 8px;
    }

    .tt-btn {
      border: 1px solid var(--clr-border3);
      background: var(--clr-panel);
      color: var(--clr-text);
      font-size: 11px;
      font-weight: 700;
      padding: 6px 9px;
      cursor: pointer;
      border-radius: 3px;
    }

    .tt-btn:hover {
      background: var(--clr-panel2);
    }

    .tt-btn.tt-primary {
      background: var(--clr-primary);
      color: var(--clr-fg);
      border-color: var(--clr-primary-dk);
    }

    .tt-btn.tt-primary:hover {
      background: var(--clr-accent);
    }

    .tt-days-grid {
      display: grid;
      grid-template-columns: repeat(7, 1fr);
      gap: 6px;
    }

    .tt-day-card {
      background: var(--clr-panel);
      border: 1px solid var(--clr-border3);
      border-radius: 5px;
      min-height: 410px;
      display: grid;
      grid-template-rows: 46px 1fr auto;
      overflow: hidden;
    }

    .tt-day-header {
      background: var(--clr-primary);
      color: var(--clr-fg);
      text-align: center;
      border-bottom: 1px solid rgba(255, 255, 255, 0.2);
      padding: 4px 4px 3px;
      position: relative;
    }

    .tt-day-name {
      font-size: 18px;
      font-weight: 700;
      line-height: 1.1;
    }

    .tt-day-date {
      font-size: 9px;
      font-weight: 700;
      margin-top: 8px;
      letter-spacing: 0.2px;
    }

    .tt-today-tag {
      position: absolute;
      top: 4px;
      right: 4px;
      font-size: 8px;
      font-weight: 700;
      padding: 1px 4px;
      border: 1px solid rgba(255, 255, 255, 0.6);
      background: rgba(255, 255, 255, 0.16);
      color: #fff;
    }

    .tt-tasks-wrap {
      display: flex;
      flex-direction: column;
      min-height: 0;
      background: var(--clr-panel);
    }

    .tt-tasks-title {
      background: var(--clr-primary-lt);
      color: var(--clr-fg);
      text-align: center;
      font-size: 11px;
      font-weight: 700;
      padding: 2px 0;
      border-top: 1px solid var(--clr-border3);
      border-bottom: 1px solid var(--clr-border3);
    }

    .tt-task-list {
      list-style: none;
      margin: 0;
      padding: 0;
      flex: 1;
    }

    .tt-task-row {
      min-height: 22px;
      display: grid;
      grid-template-columns: 12px 1fr auto;
      align-items: center;
      gap: 4px;
      border-bottom: 1px solid var(--clr-border);
      padding: 0 4px 0 5px;
      font-size: 10px;
      color: var(--clr-text);
    }

    .tt-task-inline-input {
      width: 100%;
      border: none;
      outline: none;
      background: transparent;
      font-size: 10px;
      color: var(--clr-text);
      padding: 3px 0;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      min-width: 0;
    }

    .tt-task-inline-input::placeholder {
      color: #a8a8a8;
    }

    .tt-task-inline-input:focus {
      background: var(--clr-panel2);
    }

    .tt-task-inline-input.done {
      text-decoration: line-through;
      text-decoration-thickness: 1px;
      color: var(--clr-text-lt);
    }

    /* Time badge on task row */
    .tt-task-time-badge {
      font-size: 8px;
      font-weight: 700;
      color: var(--clr-primary);
      background: var(--clr-panel2);
      border: 1px solid var(--clr-border3);
      border-radius: 3px;
      padding: 1px 4px;
      cursor: pointer;
      white-space: nowrap;
      flex-shrink: 0;
      line-height: 1.4;
      transition: background .15s;
      user-select: none;
    }

    .tt-task-time-badge:hover {
      background: var(--clr-border);
    }

    .tt-task-time-badge.empty {
      color: var(--clr-text-lt);
      background: transparent;
      border-color: transparent;
      font-size: 10px;
      padding: 1px 2px;
    }

    .tt-task-time-badge.empty:hover {
      background: var(--clr-panel2);
      border-color: var(--clr-border3);
      color: var(--clr-primary);
    }

    /* Inline time picker popup */
    .tt-time-popup {
      position: fixed;
      background: var(--clr-panel);
      border: 1px solid var(--clr-border2);
      border-radius: 6px;
      padding: 8px 10px;
      box-shadow: 0 4px 16px rgba(0, 0, 0, .22);
      z-index: 1200;
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 10px;
    }

    .tt-time-popup input[type=time] {
      border: 1px solid var(--clr-border3);
      border-radius: 4px;
      padding: 3px 6px;
      font-size: 11px;
      background: var(--clr-fg);
      color: var(--clr-text);
      outline: none;
    }

    .tt-time-popup input[type=time]:focus {
      border-color: var(--clr-primary);
    }

    .tt-time-popup-btn {
      padding: 3px 8px;
      font-size: 10px;
      font-weight: 700;
      border: none;
      border-radius: 3px;
      cursor: pointer;
    }

    .tt-time-popup-save {
      background: var(--clr-primary);
      color: var(--clr-fg);
    }

    .tt-time-popup-save:hover {
      background: var(--clr-accent);
    }

    .tt-time-popup-clear {
      background: var(--clr-border);
      color: var(--clr-text);
    }

    .tt-time-popup-clear:hover {
      background: var(--clr-border3);
    }

    .tt-checkbox {
      width: 11px;
      height: 11px;
      border: 1px solid var(--clr-border2);
      position: relative;
      background: var(--clr-panel);
      justify-self: center;
      cursor: pointer;
      padding: 0;
    }

    .tt-checkbox.checked {
      background: var(--clr-primary);
      border-color: var(--clr-primary-dk);
    }

    .tt-checkbox.checked::after {
      content: "✓";
      position: absolute;
      inset: -1px 0 0 1px;
      color: #fff;
      font-size: 10px;
      font-weight: 700;
      line-height: 11px;
    }

    .tt-footer {
      background: var(--clr-primary);
      color: var(--clr-fg);
      display: grid;
      grid-template-rows: 20px 1fr 28px;
      border-top: 1px solid rgba(255, 255, 255, 0.2);
    }

    .tt-goal-row {
      display: grid;
      grid-template-columns: 1fr auto;
      align-items: center;
      font-size: 11px;
      font-weight: 700;
      padding: 0 9px;
    }

    .tt-ring-wrap {
      display: flex;
      justify-content: center;
      align-items: center;
      padding: 6px 0 10px;
    }

    .tt-ring {
      --percent: 0;
      width: 74px;
      height: 74px;
      border-radius: 50%;
      background: conic-gradient(var(--clr-primary-dk) calc(var(--percent) * 1%), var(--clr-primary-lt) 0);
      display: grid;
      place-items: center;
      position: relative;
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.2);
    }

    .tt-ring::before {
      content: "";
      width: 54px;
      height: 54px;
      border-radius: 50%;
      background: var(--clr-fg);
      position: absolute;
    }

    .tt-ring span {
      position: relative;
      z-index: 1;
      color: var(--clr-primary-dk);
      font-size: 18px;
      font-weight: 800;
    }

    .tt-stats-row {
      background: var(--clr-primary-dk);
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 14px;
      font-size: 10px;
      padding: 5px 9px 6px;
      border-top: 1px solid rgba(255, 255, 255, .12);
    }

    .tt-stats-row .tt-stat-item {
      display: flex;
      align-items: center;
      gap: 5px;
    }

    .tt-stats-row .tt-muted {
      color: rgba(255, 255, 255, .7);
      font-weight: 600;
      font-size: 9px;
      text-transform: uppercase;
      letter-spacing: .4px;
    }

    .tt-stats-row .tt-num {
      font-weight: 900;
      color: var(--clr-fg);
      font-size: 13px;
      line-height: 1;
    }

    .tt-stats-dot {
      width: 7px;
      height: 7px;
      border-radius: 50%;
      flex-shrink: 0;
    }

    .tt-stats-dot.done {
      background: var(--clr-fg);
    }

    .tt-stats-dot.left {
      background: rgba(255, 255, 255, .3);
    }

    ::-webkit-scrollbar {
      width: 4px;
      height: 4px;
    }

    ::-webkit-scrollbar-track {
      background: transparent;
    }

    ::-webkit-scrollbar-thumb {
      background: var(--clr-border3);
      border-radius: 4px;
    }

    /* ══════════════════════════════════════════════════
       MOBILE — Day switcher UI elements (hidden on desktop)
    ══════════════════════════════════════════════════ */
    .mob-day-nav {
      display: none;
    }

    .mob-ht-day-view {
      display: none;
    }

    /* ══════════════════════════════════════════════════
       MOBILE RESPONSIVE  ≤ 768px
    ══════════════════════════════════════════════════ */
    @media (max-width: 768px) {

      /* ── Shell / Nav ── */
      .page {
        padding: 48px 10px 70px;
      }

      .nav-arrow {
        display: none;
      }

      .theme-bar {
        padding: 4px 8px;
        gap: 4px;
      }

      .theme-bar-label {
        display: none;
      }

      .theme-swatch {
        width: 18px;
        height: 18px;
      }

      /* ════════════════════════════════
         HABIT TRACKER — MOBILE
      ════════════════════════════════ */

      /* Hide the full desktop layout */
      .ht-dashboard {
        display: none;
      }

      /* Mobile habit tracker wrapper */
      .mob-ht-wrap {
        display: flex;
        flex-direction: column;
        gap: 10px;
      }

      /* Header row: title + month/year */
      .mob-ht-header {
        background: var(--clr-primary);
        border-radius: 8px;
        color: var(--clr-fg);
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 10px 14px;
      }

      .mob-ht-header h1 {
        font-size: 15px;
        font-weight: 900;
        letter-spacing: 1px;
        text-transform: uppercase;
      }

      .mob-ht-header .mob-month {
        font-size: 12px;
        opacity: .85;
      }

      /* KPI strip */
      .mob-ht-kpi {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        gap: 6px;
      }

      .mob-ht-kpi-item {
        background: var(--clr-panel);
        border-radius: 8px;
        padding: 10px 8px;
        text-align: center;
        border: 1px solid var(--clr-border3);
      }

      .mob-ht-kpi-label {
        font-size: 9px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: .6px;
        color: var(--clr-text);
        opacity: .6;
      }

      .mob-ht-kpi-val {
        font-size: 24px;
        font-weight: 900;
        color: var(--clr-primary);
        line-height: 1.1;
      }

      /* Day navigator */
      .mob-day-nav {
        display: flex;
        align-items: center;
        justify-content: space-between;
        background: var(--clr-primary);
        border-radius: 8px;
        padding: 8px 10px;
        color: var(--clr-fg);
        gap: 8px;
      }

      .mob-day-nav-btn {
        background: rgba(255, 255, 255, .18);
        border: none;
        color: var(--clr-fg);
        border-radius: 50%;
        width: 34px;
        height: 34px;
        font-size: 20px;
        font-weight: 700;
        cursor: pointer;
        flex-shrink: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: background .15s;
      }

      .mob-day-nav-btn:active {
        background: rgba(255, 255, 255, .35);
      }

      .mob-day-nav-center {
        flex: 1;
        text-align: center;
      }

      .mob-day-nav-name {
        font-size: 17px;
        font-weight: 900;
        letter-spacing: .5px;
      }

      .mob-day-nav-date {
        font-size: 10px;
        opacity: .8;
        margin-top: 1px;
      }

      .mob-day-nav-today {
        display: inline-block;
        font-size: 8px;
        font-weight: 700;
        background: rgba(255, 255, 255, .25);
        border-radius: 4px;
        padding: 1px 5px;
        margin-left: 5px;
        letter-spacing: .5px;
      }

      /* Habit checklist card */
      .mob-ht-day-view {
        display: flex;
        flex-direction: column;
        background: var(--clr-panel);
        border-radius: 8px;
        border: 1px solid var(--clr-border3);
        overflow: hidden;
      }

      .mob-ht-day-title {
        background: var(--clr-primary-lt);
        color: var(--clr-fg);
        font-size: 10px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: .6px;
        text-align: center;
        padding: 5px 0;
      }

      .mob-ht-habit-row {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 12px 16px;
        border-bottom: 1px solid var(--clr-border);
        cursor: pointer;
        transition: background .12s;
      }

      .mob-ht-habit-row:last-child {
        border-bottom: none;
      }

      .mob-ht-habit-row:active {
        background: var(--clr-panel2);
      }

      .mob-ht-habit-cb {
        width: 22px;
        height: 22px;
        border-radius: 50%;
        border: 2px solid var(--clr-border2);
        flex-shrink: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: background .15s, border-color .15s;
        font-size: 13px;
        color: transparent;
      }

      .mob-ht-habit-cb.done {
        background: var(--clr-primary);
        border-color: var(--clr-primary);
        color: var(--clr-fg);
      }

      .mob-ht-habit-emoji {
        font-size: 18px;
        flex-shrink: 0;
      }

      .mob-ht-habit-name {
        flex: 1;
        font-size: 13px;
        font-weight: 600;
        color: var(--clr-text);
      }

      .mob-ht-habit-name.done {
        text-decoration: line-through;
        opacity: .5;
      }

      .mob-ht-time-badge {
        font-size: 11px;
        font-weight: 800;
        color: var(--clr-primary);
        background: var(--clr-panel2);
        border: 1px solid var(--clr-border3);
        border-radius: 5px;
        padding: 3px 7px;
        cursor: pointer;
        white-space: nowrap;
        flex-shrink: 0;
      }

      .mob-ht-time-badge.empty {
        font-size: 15px;
        background: transparent;
        border-color: transparent;
        color: var(--clr-text-lt);
        padding: 2px 2px;
      }

      /* Progress bar under habits */
      .mob-ht-progress {
        padding: 10px 14px;
        background: var(--clr-panel);
        border-radius: 8px;
        border: 1px solid var(--clr-border3);
      }

      .mob-ht-prog-label {
        display: flex;
        justify-content: space-between;
        font-size: 11px;
        font-weight: 700;
        color: var(--clr-text);
        margin-bottom: 6px;
      }

      .mob-ht-prog-bar {
        height: 10px;
        border-radius: 5px;
        background: var(--clr-border);
        overflow: hidden;
      }

      .mob-ht-prog-fill {
        height: 100%;
        border-radius: 5px;
        background: var(--clr-primary);
        transition: width .4s ease;
      }

      /* Add habit button */
      .mob-ht-add-btn {
        width: 100%;
        padding: 13px;
        font-size: 13px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: .5px;
        background: var(--clr-primary);
        color: var(--clr-fg);
        border: none;
        border-radius: 8px;
        cursor: pointer;
        transition: background .2s;
      }

      .mob-ht-add-btn:active {
        background: var(--clr-accent);
      }

      /* Analysis section — shown at bottom on mobile */
      .mob-ht-analysis {
        background: var(--clr-panel);
        border-radius: 8px;
        border: 1px solid var(--clr-border3);
        padding: 10px;
      }

      .mob-ht-analysis-title {
        font-size: 10px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: .7px;
        text-align: center;
        color: var(--clr-text);
        border-bottom: 1px solid var(--clr-border3);
        padding-bottom: 6px;
        margin-bottom: 8px;
      }

      .mob-ht-analysis table {
        width: 100%;
        border-collapse: collapse;
        font-size: 11px;
      }

      .mob-ht-analysis th {
        background: var(--clr-primary-lt);
        color: var(--clr-fg);
        text-align: center;
        padding: 5px 4px;
        font-size: 9px;
        border: 1px solid var(--clr-border2);
      }

      .mob-ht-analysis td {
        border: 1px solid var(--clr-border);
        padding: 5px 4px;
        text-align: center;
        font-size: 10px;
        color: var(--clr-text);
      }

      /* ════════════════════════════════
         TASK TRACKER — MOBILE
      ════════════════════════════════ */

      /* Hide desktop layout */
      .tt-dashboard>.tt-dashboard-inner>.tt-top-grid {
        display: none;
      }

      .tt-days-grid {
        display: none;
      }

      .tt-week-tools {
        display: none;
      }

      /* Mobile task wrapper */
      .mob-tt-wrap {
        display: flex;
        flex-direction: column;
        gap: 10px;
      }

      /* Header */
      .mob-tt-header {
        background: var(--clr-primary);
        border-radius: 8px;
        color: var(--clr-fg);
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 10px 14px;
      }

      .mob-tt-header h1 {
        font-size: 15px;
        font-weight: 900;
        letter-spacing: 1px;
        text-transform: uppercase;
      }

      .mob-tt-header .mob-month {
        font-size: 12px;
        opacity: .85;
      }

      /* Week score strip */
      .mob-tt-score {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 6px;
      }

      .mob-tt-score-item {
        background: var(--clr-panel);
        border-radius: 8px;
        border: 1px solid var(--clr-border3);
        padding: 10px 12px;
      }

      .mob-tt-score-label {
        font-size: 9px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: .5px;
        color: var(--clr-text);
        opacity: .6;
        margin-bottom: 4px;
      }

      .mob-tt-score-val {
        font-size: 20px;
        font-weight: 900;
        color: var(--clr-primary);
      }

      .mob-tt-score-sub {
        font-size: 10px;
        color: var(--clr-text);
        opacity: .7;
        margin-top: 2px;
      }

      /* Week nav */
      .mob-tt-week-nav {
        display: flex;
        align-items: center;
        justify-content: space-between;
        background: var(--clr-panel);
        border-radius: 8px;
        border: 1px solid var(--clr-border3);
        padding: 6px 10px;
        gap: 6px;
      }

      .mob-tt-week-btn {
        background: var(--clr-primary);
        border: none;
        color: var(--clr-fg);
        border-radius: 6px;
        padding: 6px 14px;
        font-size: 13px;
        font-weight: 700;
        cursor: pointer;
      }

      .mob-tt-week-btn:active {
        opacity: .8;
      }

      .mob-tt-week-range {
        flex: 1;
        text-align: center;
        font-size: 11px;
        font-weight: 700;
        color: var(--clr-text);
      }

      /* Day task card */
      .mob-tt-day-card {
        background: var(--clr-panel);
        border-radius: 8px;
        border: 1px solid var(--clr-border3);
        overflow: hidden;
        min-height: 200px;
      }

      .mob-tt-task-row {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 11px 16px;
        border-bottom: 1px solid var(--clr-border);
      }

      .mob-tt-task-row:last-child {
        border-bottom: none;
      }

      .mob-tt-task-time {
        font-size: 10px;
        font-weight: 800;
        color: var(--clr-primary);
        background: var(--clr-panel2);
        border: 1px solid var(--clr-border3);
        border-radius: 4px;
        padding: 2px 6px;
        white-space: nowrap;
        flex-shrink: 0;
        cursor: pointer;
      }

      .mob-tt-task-time.empty {
        font-size: 13px;
        background: transparent;
        border-color: transparent;
        color: var(--clr-text-lt);
        padding: 2px 2px;
      }

      .mob-tt-cb {
        width: 22px;
        height: 22px;
        border-radius: 50%;
        border: 2px solid var(--clr-border2);
        flex-shrink: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 13px;
        color: transparent;
        cursor: pointer;
        transition: background .15s, border-color .15s;
      }

      .mob-tt-cb.done {
        background: var(--clr-primary);
        border-color: var(--clr-primary);
        color: var(--clr-fg);
      }

      .mob-tt-task-input {
        flex: 1;
        border: none;
        outline: none;
        background: transparent;
        font-size: 13px;
        font-weight: 600;
        color: var(--clr-text);
        padding: 0;
        -webkit-appearance: none;
        -webkit-text-fill-color: var(--clr-text);
      }

      .mob-tt-task-input::placeholder {
        color: var(--clr-text-lt);
        font-weight: 400;
      }

      .mob-tt-task-input.done {
        text-decoration: line-through;
        opacity: .5;
      }

      /* Footer progress */
      .mob-tt-day-footer {
        background: var(--clr-primary);
        color: var(--clr-fg);
        padding: 8px 14px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        font-size: 12px;
        font-weight: 700;
      }

      .mob-tt-day-pct {
        font-size: 18px;
        font-weight: 900;
      }

      /* Load sample / clear buttons */
      .mob-tt-tools {
        display: flex;
        gap: 8px;
      }

      .mob-tt-tool-btn {
        flex: 1;
        padding: 10px;
        font-size: 12px;
        font-weight: 700;
        border-radius: 8px;
        border: 1px solid var(--clr-border3);
        background: var(--clr-panel);
        color: var(--clr-text);
        cursor: pointer;
        text-align: center;
      }

      .mob-tt-tool-btn:active {
        background: var(--clr-panel2);
      }
    }

    /* ══════════════════════════════════════════════════
       YEARLY PROGRESS PAGE
    ══════════════════════════════════════════════════ */
    .yp-body {
      width: 100%;
      max-width: 1340px;
      margin: 0 auto;
      display: flex;
      flex-direction: column;
      gap: 14px;
    }

    .yp-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      flex-wrap: wrap;
    }

    .yp-title-box {
      background: var(--clr-primary);
      border-radius: 6px;
      color: var(--clr-fg);
      padding: 10px 18px;
      display: flex;
      align-items: baseline;
      gap: 10px;
    }

    .yp-title-box h1 {
      font-size: 16px;
      font-weight: 900;
      letter-spacing: 1.2px;
      text-transform: uppercase;
      margin: 0;
    }

    .yp-title-box span {
      font-size: 13px;
      font-weight: 600;
      opacity: .8;
    }

    .yp-year-nav {
      display: flex;
      align-items: center;
      gap: 8px;
    }

    .yp-year-btn {
      background: var(--clr-primary);
      color: var(--clr-fg);
      border: none;
      border-radius: 5px;
      padding: 7px 14px;
      font-size: 12px;
      font-weight: 700;
      cursor: pointer;
      transition: background .15s;
    }

    .yp-year-btn:hover {
      background: var(--clr-accent);
    }

    .yp-year-select {
      font-size: 12px;
      font-weight: 700;
      padding: 6px 10px;
      border: none;
      border-radius: 5px;
      background: var(--clr-primary-lt);
      color: var(--clr-fg);
      cursor: pointer;
      outline: none;
    }

    .yp-kpi-strip {
      display: flex;
      gap: 6px;
      align-items: stretch;
      background: var(--clr-panel);
      border: 1px solid var(--clr-border3);
      border-radius: 8px;
      padding: 10px 14px;
      flex-wrap: wrap;
    }

    .yp-kpi-item {
      flex: 1;
      min-width: 80px;
      text-align: center;
    }

    .yp-kpi-divider {
      width: 1px;
      min-width: 1px;
      flex: 0;
      background: var(--clr-border3);
      border-radius: 2px;
      margin: 0 4px;
    }

    .yp-kpi-label {
      font-size: 9px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .6px;
      color: var(--clr-text);
      opacity: .6;
      margin-bottom: 3px;
    }

    .yp-kpi-val {
      font-size: 22px;
      font-weight: 900;
      color: var(--clr-primary);
      line-height: 1.1;
    }

    .yp-charts {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 14px;
    }

    .yp-chart-card {
      background: var(--clr-panel);
      border: 1px solid var(--clr-border3);
      border-radius: 8px;
      padding: 14px;
    }

    .yp-chart-title {
      font-size: 11px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: .7px;
      color: var(--clr-text);
      text-align: center;
      padding-bottom: 10px;
      border-bottom: 1px solid var(--clr-border3);
      margin-bottom: 12px;
    }

    .yp-chart-wrap {
      position: relative;
      height: 260px;
    }

    .yp-chart-wrap canvas {
      width: 100% !important;
      height: 100% !important;
    }

    @media (max-width: 768px) {
      .yp-charts {
        grid-template-columns: 1fr;
      }

      .yp-chart-wrap {
        height: 220px;
      }

      .yp-kpi-strip {
        gap: 4px;
        padding: 8px 10px;
      }

      .yp-kpi-val {
        font-size: 18px;
      }

      .yp-kpi-divider {
        display: none;
      }
    }

    /* ══════════════════════════════════
       REMINDER SYSTEM
    ══════════════════════════════════ */
    .reminder-modal-overlay {
      display: none;
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, .45);
      z-index: 1100;
      align-items: center;
      justify-content: center;
    }

    .reminder-modal-overlay.open {
      display: flex;
    }

    .reminder-modal {
      background: var(--clr-panel);
      border-radius: 12px;
      padding: 20px 22px 18px;
      min-width: 320px;
      max-width: 420px;
      width: 90%;
      box-shadow: 0 10px 40px rgba(0, 0, 0, .35);
      max-height: 80vh;
      display: flex;
      flex-direction: column;
    }

    .reminder-modal-title {
      font-size: 14px;
      font-weight: 800;
      color: var(--clr-text);
      margin-bottom: 14px;
      text-align: center;
      text-transform: uppercase;
      letter-spacing: .8px;
    }

    .reminder-add-row {
      display: flex;
      gap: 8px;
      margin-bottom: 12px;
    }

    .reminder-add-row input[type=text] {
      flex: 1;
      padding: 7px 10px;
      font-size: 12px;
      border: 1px solid var(--clr-border3);
      border-radius: 5px;
      background: var(--clr-fg);
      color: var(--clr-text);
      outline: none;
    }

    .reminder-add-row input[type=text]:focus {
      border-color: var(--clr-primary);
    }

    .reminder-add-row input[type=time] {
      padding: 7px 8px;
      font-size: 12px;
      border: 1px solid var(--clr-border3);
      border-radius: 5px;
      background: var(--clr-fg);
      color: var(--clr-text);
      outline: none;
    }

    .reminder-add-btn {
      padding: 7px 12px;
      font-size: 11px;
      font-weight: 700;
      background: var(--clr-primary);
      color: var(--clr-fg);
      border: none;
      border-radius: 5px;
      cursor: pointer;
      white-space: nowrap;
    }

    .reminder-add-btn:hover {
      background: var(--clr-accent);
    }

    .reminder-list {
      flex: 1;
      overflow-y: auto;
      display: flex;
      flex-direction: column;
      gap: 6px;
      margin-bottom: 12px;
    }

    .reminder-item {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 8px 10px;
      background: var(--clr-fg);
      border: 1px solid var(--clr-border);
      border-radius: 6px;
    }

    .reminder-item-time {
      font-size: 12px;
      font-weight: 800;
      color: var(--clr-primary);
      white-space: nowrap;
      min-width: 42px;
    }

    .reminder-item-text {
      flex: 1;
      font-size: 11px;
      color: var(--clr-text);
    }

    .reminder-item-del {
      background: none;
      border: none;
      cursor: pointer;
      color: var(--clr-text-lt);
      font-size: 16px;
      line-height: 1;
      transition: color .15s;
      flex-shrink: 0;
    }

    .reminder-item-del:hover {
      color: #c0392b;
    }

    .reminder-empty {
      text-align: center;
      color: var(--clr-text-lt);
      font-size: 11px;
      padding: 16px 0;
    }

    .reminder-modal-close {
      width: 100%;
      padding: 8px;
      font-size: 11px;
      font-weight: 700;
      text-transform: uppercase;
      background: var(--clr-border);
      color: var(--clr-text);
      border: none;
      border-radius: 5px;
      cursor: pointer;
    }

    .reminder-modal-close:hover {
      background: var(--clr-border3);
    }

    .reminder-toast {
      position: fixed;
      top: 54px;
      left: 50%;
      transform: translateX(-50%) translateY(-20px);
      background: var(--clr-primary);
      color: var(--clr-fg);
      padding: 10px 18px;
      border-radius: 30px;
      font-size: 13px;
      font-weight: 700;
      box-shadow: 0 4px 18px rgba(0, 0, 0, .3);
      z-index: 2000;
      opacity: 0;
      transition: opacity .3s, transform .3s;
      pointer-events: none;
      max-width: 320px;
      text-align: center;
    }

    .reminder-toast.show {
      opacity: 1;
      transform: translateX(-50%) translateY(0);
    }

    /* ══════════════════════════════════
       PAYPAL PAYMENT MODAL
    ══════════════════════════════════ */
    #paymentOverlay {
      position: fixed;
      inset: 0;
      z-index: 10000;
      display: flex;
      align-items: center;
      justify-content: center;
      background: linear-gradient(135deg, #0f0c29 0%, #1a1040 50%, #24243e 100%);
      font-family: 'Segoe UI', Arial, sans-serif;
      transition: opacity .5s ease;
    }
    #paymentOverlay.hidden { opacity: 0; pointer-events: none; }
    .pay-card {
      background: rgba(255,255,255,.07);
      backdrop-filter: blur(24px);
      border: 1px solid rgba(255,255,255,.13);
      border-radius: 24px;
      padding: 44px 40px 36px;
      max-width: 440px;
      width: 92%;
      position: relative;
      box-shadow: 0 24px 64px rgba(0,0,0,.55);
    }
    .pay-badge {
      position: absolute;
      top: -14px;
      left: 50%;
      transform: translateX(-50%);
      background: linear-gradient(90deg, #0070ba, #00a8e0);
      color: #fff;
      font-size: 10px;
      font-weight: 800;
      letter-spacing: 1.2px;
      text-transform: uppercase;
      padding: 5px 18px;
      border-radius: 20px;
      white-space: nowrap;
      box-shadow: 0 4px 14px rgba(0,112,186,.45);
    }
    .pay-logo { text-align: center; font-size: 46px; margin-bottom: 6px; }
    .pay-title { text-align: center; font-size: 24px; font-weight: 900; color: #fff; letter-spacing: .5px; margin-bottom: 4px; }
    .pay-sub { text-align: center; font-size: 12px; color: rgba(255,255,255,.55); margin-bottom: 24px; line-height: 1.5; }
    .pay-price-box {
      background: rgba(255,255,255,.06);
      border: 1px solid rgba(255,255,255,.12);
      border-radius: 16px;
      padding: 20px;
      text-align: center;
      margin-bottom: 20px;
    }
    .pay-price-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,.45); margin-bottom: 6px; }
    .pay-price-amount { font-size: 52px; font-weight: 900; color: #fff; line-height: 1; letter-spacing: -1px; }
    .pay-price-amount sup { font-size: 22px; font-weight: 700; vertical-align: super; }
    .pay-price-note { font-size: 10px; color: rgba(255,255,255,.38); margin-top: 4px; }
    .pay-features { display: flex; flex-direction: column; gap: 8px; margin-bottom: 24px; }
    .pay-feature { display: flex; align-items: center; gap: 10px; font-size: 12px; color: rgba(255,255,255,.78); }
    .pay-feature-icon {
      width: 26px; height: 26px;
      background: rgba(0,112,186,.25);
      border: 1px solid rgba(0,160,220,.3);
      border-radius: 8px;
      display: flex; align-items: center; justify-content: center;
      font-size: 13px; flex-shrink: 0;
    }
    .pay-paypal-btn {
      width: 100%;
      background: linear-gradient(90deg, #0070ba 0%, #00a8e0 100%);
      color: #fff;
      border: none;
      border-radius: 14px;
      padding: 16px;
      font-size: 15px;
      font-weight: 800;
      cursor: pointer;
      display: flex; align-items: center; justify-content: center; gap: 10px;
      letter-spacing: .4px;
      transition: transform .15s, box-shadow .15s, filter .15s;
      box-shadow: 0 6px 22px rgba(0,112,186,.45);
      margin-bottom: 10px;
    }
    .pay-paypal-btn:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(0,112,186,.6); filter: brightness(1.08); }
    .pay-paypal-btn:active { transform: translateY(0); }
    .pay-already { text-align: center; margin-top: 6px; }
    .pay-already-btn { background: none; border: none; color: rgba(255,255,255,.45); font-size: 11px; cursor: pointer; text-decoration: underline; transition: color .15s; }
    .pay-already-btn:hover { color: rgba(255,255,255,.75); }
    .pay-secure { text-align: center; font-size: 10px; color: rgba(255,255,255,.28); margin-top: 14px; display: flex; align-items: center; justify-content: center; gap: 5px; }
    .pay-success { display: none; text-align: center; padding: 20px 0; }
    .pay-success-icon { font-size: 56px; margin-bottom: 12px; animation: popIn .4s cubic-bezier(.175,.885,.32,1.275); }
    @keyframes popIn { from { transform: scale(0); opacity: 0; } to { transform: scale(1); opacity: 1; } }
    .pay-success h2 { font-size: 20px; font-weight: 800; color: #fff; margin-bottom: 6px; }
    .pay-success p { font-size: 12px; color: rgba(255,255,255,.55); margin-bottom: 20px; }
    .pay-continue-btn {
      background: linear-gradient(90deg, #00b09b, #0070ba);
      color: #fff; border: none; border-radius: 12px;
      padding: 13px 32px; font-size: 13px; font-weight: 800; cursor: pointer;
      transition: transform .15s, filter .15s;
    }
    .pay-continue-btn:hover { transform: scale(1.04); filter: brightness(1.1); }

    /* payment method row */
    .pay-methods { display: flex; flex-direction: column; gap: 10px; margin-bottom: 12px; }

    /* usage progress bar */
    .pay-usage-bar-wrap { margin-bottom: 16px; }
    .pay-usage-label { font-size: 10px; color: rgba(255,255,255,.5); margin-bottom: 6px; text-align:center; }
    .pay-usage-track {
      height: 5px; border-radius: 10px;
      background: rgba(255,255,255,.1);
      overflow: hidden;
    }
    .pay-usage-fill {
      height: 100%; border-radius: 10px;
      background: linear-gradient(90deg, #0070ba, #00d4ff);
      transition: width .4s ease;
    }

    /* dismiss / snooze button */
    .pay-close-x-btn {
      background: none; border: none;
      color: rgba(255,255,255,.38); font-size: 11px;
      cursor: pointer; text-decoration: underline;
      transition: color .15s; padding: 2px 0;
    }
    .pay-close-x-btn:hover { color: rgba(255,255,255,.7); }

    /* top-right ✕ corner button on pay card */
    .pay-corner-close {
      position: absolute;
      top: 14px; right: 16px;
      background: rgba(255,255,255,.1);
      border: 1px solid rgba(255,255,255,.18);
      color: rgba(255,255,255,.6);
      width: 28px; height: 28px;
      border-radius: 50%;
      font-size: 13px; font-weight: 700;
      cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      transition: background .15s, color .15s, transform .12s;
      z-index: 10;
    }
    .pay-corner-close:hover {
      background: rgba(255,100,100,.25);
      border-color: rgba(255,100,100,.4);
      color: #fff;
      transform: scale(1.12);
    }

    /* floating click counter pill (bottom-left) */
    #payCounterPill {
      position: fixed;
      bottom: 52px; left: 14px;
      background: rgba(0,0,0,.5);
      backdrop-filter: blur(6px);
      border: 1px solid rgba(255,255,255,.15);
      color: rgba(255,255,255,.7);
      font-size: 9px; font-weight: 800;
      padding: 3px 8px; border-radius: 12px;
      z-index: 800;
      display: flex; align-items: center; gap: 4px;
      cursor: default;
      letter-spacing: .4px;
    }

    .pay-or-divider {
      display: flex; align-items: center; gap: 10px;
      color: rgba(255,255,255,.3); font-size: 11px; font-weight: 700;
    }
    .pay-or-divider::before, .pay-or-divider::after {
      content: ''; flex: 1; height: 1px; background: rgba(255,255,255,.14);
    }

    .pay-card-trigger-btn {
      width: 100%;
      background: rgba(255,255,255,.08);
      border: 1.5px solid rgba(255,255,255,.2);
      color: rgba(255,255,255,.88);
      border-radius: 14px;
      padding: 14px;
      font-size: 14px;
      font-weight: 700;
      cursor: pointer;
      letter-spacing: .3px;
      transition: background .15s, border-color .15s, transform .12s;
    }
    .pay-card-trigger-btn:hover {
      background: rgba(255,255,255,.15);
      border-color: rgba(255,255,255,.4);
      transform: translateY(-1px);
    }

    /* card view */
    .pay-card-header {
      display: flex; align-items: center; justify-content: space-between;
      margin-bottom: 14px;
    }
    .pay-back-btn {
      background: none; border: none; color: rgba(255,255,255,.5);
      font-size: 12px; cursor: pointer; transition: color .15s; padding: 0;
    }
    .pay-back-btn:hover { color: #fff; }
    .pay-card-title-row { display: flex; align-items: center; gap: 6px; font-size: 16px; font-weight: 800; color: #fff; }
    .pay-card-title-icon { font-size: 18px; }
    .pay-card-amount-badge {
      background: linear-gradient(90deg,#1a7f4e,#25a96a);
      color: #fff; font-size: 13px; font-weight: 800;
      padding: 4px 12px; border-radius: 20px;
    }
    .pay-card-accepted { display: flex; gap: 6px; margin-bottom: 16px; }
    .pay-card-brand {
      background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18);
      color: rgba(255,255,255,.7); font-size: 9px; font-weight: 800;
      padding: 3px 8px; border-radius: 5px; letter-spacing: .5px;
    }

    .pay-field-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 12px; }
    .pay-field-row { display: flex; gap: 12px; }
    .pay-field-label { font-size: 10px; font-weight: 700; color: rgba(255,255,255,.5); letter-spacing: .6px; text-transform: uppercase; }
    .pay-field-input {
      width: 100%; padding: 12px 14px; font-size: 14px; font-weight: 600;
      background: rgba(255,255,255,.08); border: 1.5px solid rgba(255,255,255,.16);
      border-radius: 10px; color: #fff; outline: none;
      transition: border-color .15s, background .15s;
    }
    .pay-field-input::placeholder { color: rgba(255,255,255,.28); font-weight: 400; }
    .pay-field-input:focus { border-color: rgba(100,180,255,.6); background: rgba(255,255,255,.12); }
    .pay-card-num-wrap { position: relative; }
    .pay-card-icon { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); font-size: 18px; pointer-events: none; }

    /* ══════════════════════════════════
       LOGIN PAGE
    ══════════════════════════════════ */
    #loginOverlay {
      position: fixed;
      inset: 0;
      z-index: 9999;
      display: flex;
      align-items: center;
      justify-content: center;
      background: linear-gradient(135deg, #1a1a2e 0%, #16213e 40%, #0f3460 100%);
      font-family: 'Segoe UI', Arial, sans-serif;
      transition: opacity 0.5s ease;
    }

    #loginOverlay.hidden {
      opacity: 0;
      pointer-events: none;
    }

    .login-card {
      background: rgba(255, 255, 255, 0.06);
      backdrop-filter: blur(20px);
      border: 1px solid rgba(255, 255, 255, 0.12);
      border-radius: 24px;
      padding: 48px 40px 40px;
      max-width: 400px;
      width: 90%;
      text-align: center;
      box-shadow: 0 32px 80px rgba(0, 0, 0, 0.5), inset 0 1px 0 rgba(255, 255, 255, 0.1);
      animation: loginCardIn 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
    }

    @keyframes loginCardIn {
      from {
        opacity: 0;
        transform: translateY(32px) scale(0.95);
      }

      to {
        opacity: 1;
        transform: translateY(0) scale(1);
      }
    }

    .login-logo {
      font-size: 52px;
      margin-bottom: 8px;
      filter: drop-shadow(0 4px 12px rgba(159, 203, 132, 0.5));
      animation: logoPulse 3s ease-in-out infinite;
    }

    @keyframes logoPulse {

      0%,
      100% {
        transform: scale(1)
      }

      50% {
        transform: scale(1.06)
      }
    }

    .login-title {
      font-size: 28px;
      font-weight: 800;
      letter-spacing: -0.5px;
      background: linear-gradient(135deg, #9fcb84, #5bc0de, #9fcb84);
      background-size: 200%;
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      animation: shimmer 4s linear infinite;
      margin-bottom: 6px;
    }

    @keyframes shimmer {
      0% {
        background-position: 0%
      }

      100% {
        background-position: 200%
      }
    }

    .login-subtitle {
      color: rgba(255, 255, 255, 0.5);
      font-size: 13px;
      margin-bottom: 32px;
      line-height: 1.5;
    }

    .login-features {
      display: flex;
      flex-direction: column;
      gap: 10px;
      margin-bottom: 28px;
      text-align: left;
    }

    .login-feature {
      display: flex;
      align-items: center;
      gap: 10px;
      color: rgba(255, 255, 255, 0.65);
      font-size: 13px;
    }

    .login-feature-icon {
      width: 28px;
      height: 28px;
      border-radius: 8px;
      background: rgba(159, 203, 132, 0.15);
      border: 1px solid rgba(159, 203, 132, 0.3);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 14px;
      flex-shrink: 0;
    }

    .login-google-btn {
      width: 100%;
      padding: 14px 20px;
      background: #fff;
      color: #1f1f1f;
      border: none;
      border-radius: 12px;
      font-size: 15px;
      font-weight: 600;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
      transition: transform 0.15s, box-shadow 0.15s;
    }

    .login-google-btn:hover {
      transform: translateY(-2px);
      box-shadow: 0 8px 28px rgba(0, 0, 0, 0.4);
    }

    .login-google-btn svg {
      width: 20px;
      height: 20px;
      flex-shrink: 0;
    }

    .login-privacy {
      margin-top: 14px;
      color: rgba(255, 255, 255, 0.3);
      font-size: 11px;
    }

    .login-loading {
      display: none;
      flex-direction: column;
      align-items: center;
      gap: 12px;
      padding: 20px 0;
    }

    .login-spinner {
      width: 36px;
      height: 36px;
      border: 3px solid rgba(159, 203, 132, 0.2);
      border-top-color: #9fcb84;
      border-radius: 50%;
      animation: spin 0.8s linear infinite;
    }

    @keyframes spin {
      to {
        transform: rotate(360deg);
      }
    }

    .login-loading-text {
      color: rgba(255, 255, 255, 0.6);
      font-size: 13px;
    }

    .user-badge {
      display: none;
      align-items: center;
      gap: 6px;
      background: rgba(255, 255, 255, 0.12);
      border-radius: 20px;
      padding: 3px 10px 3px 4px;
      margin-left: 8px;
    }

    .user-badge.visible {
      display: flex;
    }

    .user-avatar {
      width: 22px;
      height: 22px;
      border-radius: 50%;
      object-fit: cover;
      border: 1.5px solid rgba(255, 255, 255, 0.3);
    }

    .user-name {
      font-size: 10px;
      font-weight: 600;
      color: rgba(255, 255, 255, 0.85);
      white-space: nowrap;
      max-width: 100px;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .user-signout {
      font-size: 9px;
      color: rgba(255, 255, 255, 0.5);
      background: none;
      border: none;
      cursor: pointer;
      padding: 2px 4px;
      border-radius: 4px;
      transition: background 0.15s, color 0.15s;
    }

    .user-signout:hover {
      background: rgba(255, 255, 255, 0.1);
      color: rgba(255, 255, 255, 0.8);
    }

    .drive-status {
      position: fixed;
      bottom: 50px;
      right: 14px;
      z-index: 990;
      background: rgba(0, 0, 0, 0.5);
      backdrop-filter: blur(8px);
      border-radius: 20px;
      padding: 5px 12px;
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 10px;
      color: rgba(255, 255, 255, 0.7);
      transition: opacity 0.4s;
      opacity: 0;
      pointer-events: none;
      border: 1px solid rgba(255, 255, 255, 0.1);
    }

    .drive-status.show {
      opacity: 1;
    }

    .drive-dot {
      width: 7px;
      height: 7px;
      border-radius: 50%;
      background: #9fcb84;
    }

    .drive-dot.syncing {
      animation: dotPulse 0.8s ease-in-out infinite;
      background: #5bc0de;
    }

    .drive-dot.error {
      background: #e74c3c;
    }

    @keyframes dotPulse {

      0%,
      100% {
        opacity: 1;
        transform: scale(1)
      }

      50% {
        opacity: 0.4;
        transform: scale(0.7)
      }
    }

    .config-notice {
      background: rgba(255, 193, 7, 0.12);
      border: 1px solid rgba(255, 193, 7, 0.25);
      border-radius: 10px;
      padding: 12px 14px;
      margin-top: 14px;
      color: rgba(255, 255, 255, 0.7);
      font-size: 11px;
      text-align: left;
      line-height: 1.6;
    }

    .config-notice strong {
      color: #ffd43b;
    }