/* ═══════════════════════════════════════════════════════════════
   components.css — Main UI components
   - Tabs, Room Cards, Task items, Time summary
   - Spinner result tips, Achievements, Stats, History
   - Toast notifications, Level overlay, Confetti canvas
   - Tools view, Settings, Wait timers, Collapsible rooms
   ═══════════════════════════════════════════════════════════════ */

  /* ─── Tabs ─── */
  .tabs {
    display: flex; gap: 6px; margin-bottom: 18px; flex-wrap: wrap;
    justify-content: center;
  }
  .tab-btn {
    background: var(--bg-card); backdrop-filter: blur(8px);
    border: 1px solid var(--border); color: var(--text-dim);
    border-radius: 100px; padding: 10px 20px;
    font-size: 14px; font-weight: 700;
    font-family: 'Heebo', sans-serif;
    cursor: pointer; transition: all 0.25s;
  }
  .tab-btn:hover { background: var(--bg-card-hover); color: var(--text); transform: translateY(-1px); }
  .tab-btn.active {
    background: linear-gradient(135deg, var(--pink), var(--purple));
    border-color: var(--pink);
    color: #fff;
    box-shadow: 0 0 25px var(--pink-glow);
    transform: translateY(-1px);
  }

  .view { display: none; }
  .view.active { display: block; animation: viewIn 0.3s ease-out; }
  @keyframes viewIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

  /* ─── Room Cards ─── */
  .room-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 14px; }

  .room-card {
    background: var(--bg-card); backdrop-filter: blur(12px);
    border: 1px solid var(--border);
    border-radius: var(--radius); overflow: hidden;
    transition: all 0.3s cubic-bezier(.22,.68,0,.98);
    position: relative;
  }
  .room-card::before {
    content: ''; position: absolute; top: 0; right: 0; left: 0; height: 3px;
    background: linear-gradient(90deg, var(--pink), var(--purple), var(--cyan));
    opacity: 0.6;
  }
  .room-card:hover {
    border-color: rgba(178,77,255,0.3);
    transform: translateY(-3px);
    box-shadow: 0 8px 30px rgba(178,77,255,0.15);
  }
  .room-card.completed::before {
    background: linear-gradient(90deg, var(--lime), var(--cyan));
    opacity: 1;
    height: 4px;
  }
  .room-card.completed {
    border-color: rgba(125,255,107,0.25);
    box-shadow: 0 0 25px var(--lime-glow);
  }

  .room-header {
    display: flex; align-items: center; gap: 10px;
    padding: 14px 16px 8px;
  }
  .room-icon { font-size: 26px; }
  .room-name {
    font-size: 16px; font-weight: 900; flex: 1;
    color: var(--text);
  }
  .room-progress-text { font-size: 12px; color: var(--text-dim); font-weight: 700; }

  /* Musical staff progress bar */
  .room-bar-wrap {
    margin: 4px 16px 10px; position: relative; height: 22px;
  }
  .staff-bg {
    position: absolute; inset: 0;
    background:
      repeating-linear-gradient(
        180deg,
        transparent 0px, transparent 3px,
        rgba(178,77,255,0.08) 3px, rgba(178,77,255,0.08) 4px
      );
    border-radius: 4px;
  }
  .room-bar-track {
    position: absolute; inset: 0;
    background: rgba(255,255,255,0.04);
    border-radius: 8px; overflow: hidden;
    border: 1px solid rgba(178,77,255,0.1);
  }
  .room-bar-fill {
    height: 100%; border-radius: 8px;
    background: linear-gradient(90deg, var(--purple), var(--pink));
    transition: width 0.5s cubic-bezier(.22,.68,0,.98);
    position: relative;
  }
  .room-card.completed .room-bar-fill {
    background: linear-gradient(90deg, var(--lime), var(--cyan));
  }
  .room-bar-fill::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(255,255,255,0.25) 0%, transparent 50%);
    border-radius: 8px;
  }
  /* Sliding note on room bar */
  .room-bar-note {
    position: absolute; top: -3px; font-size: 14px; z-index: 2;
    transition: right 0.5s cubic-bezier(.22,.68,0,.98);
    filter: drop-shadow(0 0 4px var(--pink-glow));
  }

  .task-list { padding: 2px 10px 12px; }
  .task-item {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 8px; border-radius: 12px;
    cursor: pointer; user-select: none;
    position: relative;
    transition: all 0.2s;
  }
  .task-item:hover { background: var(--glass); }
  .task-item:active { transform: scale(0.98); }

  .task-check {
    width: 26px; height: 26px; border-radius: 50%;
    border: 2px solid var(--purple);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: all 0.3s cubic-bezier(.22,.68,0,.98);
    font-size: 14px; color: transparent;
    background: rgba(178,77,255,0.08);
  }
  .task-item.done .task-check {
    background: linear-gradient(135deg, var(--pink), var(--orange));
    border-color: var(--pink);
    color: #fff;
    box-shadow: 0 0 15px var(--pink-glow);
    animation: checkPop 0.4s cubic-bezier(.22,.68,0,.98);
  }
  @keyframes checkPop {
    0% { transform: scale(0.5); }
    60% { transform: scale(1.2); }
    100% { transform: scale(1); }
  }

  .task-label {
    font-size: 13px; flex: 1; font-weight: 500;
    color: var(--text); transition: all 0.25s; line-height: 1.5;
  }
  .task-item.done .task-label { color: var(--text-dim); text-decoration: line-through; }
  .task-item.skipped { opacity: 0.4; }
  .task-item.skipped .task-label { text-decoration: line-through; color: var(--text-dim); }
  .task-item.skipped .task-check { border-color: rgba(255,255,255,0.15); background: rgba(255,255,255,0.03); }
  .task-item.skipped .task-xp { opacity: 0.4; }
  .task-edit-form { display: flex; flex-direction: column; gap: 8px; margin-bottom: 10px; }
  .task-edit-form input, .task-edit-form textarea {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    color: var(--text); border-radius: 8px;
    padding: 8px 10px; font-size: 13px;
    font-family: 'Heebo', sans-serif; direction: rtl;
    outline: none; transition: border-color 0.2s;
  }
  .task-edit-form input:focus, .task-edit-form textarea:focus {
    border-color: var(--cyan);
  }
  .task-edit-form textarea { resize: vertical; min-height: 50px; }
  .task-edit-form .edit-row { display: flex; gap: 8px; }
  .task-edit-form .edit-row input { flex: 1; }
  .task-edit-actions { display: flex; gap: 8px; }
  .task-edit-actions button {
    flex: 1; padding: 8px 0; border-radius: 8px;
    font-size: 13px; font-weight: 600; font-family: inherit;
    cursor: pointer; transition: all 0.2s; border: none;
  }
  .edit-save-btn {
    background: linear-gradient(135deg, var(--cyan), var(--lime));
    color: #fff;
  }
  .edit-save-btn:hover { box-shadow: 0 0 15px rgba(0,229,255,0.3); }
  .edit-cancel-btn {
    background: rgba(255,255,255,0.05);
    color: var(--text-dim); border: 1px solid rgba(255,255,255,0.1) !important;
  }
  .edit-cancel-btn:hover { background: rgba(255,255,255,0.1); }
  .task-edit-link {
    font-size: 11px; color: var(--text-dim);
    background: none; border: none; cursor: pointer;
    font-family: inherit; padding: 0;
    text-decoration: underline; transition: color 0.2s;
    align-self: flex-start;
  }
  .task-edit-link:hover { color: var(--cyan); }

  .task-skip-btn {
    width: 100%; font-size: 12px; font-weight: 500; font-family: inherit;
    color: var(--text-dim); background: none;
    border: 1px dashed rgba(255,255,255,0.1); border-radius: 8px; padding: 7px 0;
    cursor: pointer; transition: all 0.25s; margin-top: 6px;
  }
  .task-skip-btn:hover { border-color: rgba(255,255,255,0.25); color: var(--text); }
  .task-restore-btn {
    width: 100%; font-size: 13px; font-weight: 600; font-family: inherit;
    color: var(--cyan); background: rgba(0,229,255,0.06);
    border: 1px solid rgba(0,229,255,0.15); border-radius: 10px; padding: 8px 0;
    cursor: pointer; transition: all 0.25s;
  }
  .task-restore-btn:hover { background: rgba(0,229,255,0.12); border-color: var(--cyan); }

  .task-detail {
    max-height: 0; overflow: hidden;
    transition: max-height 0.4s cubic-bezier(.22,.68,0,.98), padding 0.3s ease, opacity 0.3s ease;
    opacity: 0; padding: 0 12px 0 12px;
  }
  .task-detail.open {
    max-height: 400px; opacity: 1;
    padding: 6px 12px 12px 12px;
  }
  .task-detail-inner {
    background: rgba(0,229,255,0.05);
    border: 1px solid rgba(0,229,255,0.12);
    border-radius: 12px; padding: 12px 14px;
  }
  .task-tip-text {
    font-size: 12.5px; line-height: 1.7; color: var(--cyan);
    margin-bottom: 12px;
  }
  .task-tip-text::before { content: '\1F4A1 '; }
  .task-timer-area {
    display: flex; align-items: center; gap: 10px;
    flex-wrap: wrap; margin-bottom: 10px;
  }
  .task-time-est {
    font-size: 12px; color: var(--text-dim);
    background: rgba(255,255,255,0.04);
    padding: 4px 10px; border-radius: 8px;
    border: 1px solid rgba(255,255,255,0.06);
  }
  .task-start-btn {
    font-size: 12px; font-weight: 700; font-family: inherit;
    color: #fff; background: linear-gradient(135deg, var(--purple), var(--pink));
    border: none; border-radius: 8px; padding: 6px 14px;
    cursor: pointer; transition: all 0.25s;
  }
  .task-start-btn:hover { transform: scale(1.05); box-shadow: 0 0 15px var(--pink-glow); }
  .task-timer-display {
    display: flex; align-items: center; gap: 6px;
    font-size: 16px; font-weight: 700;
    font-variant-numeric: tabular-nums;
  }
  .timer-elapsed { color: var(--lime); }
  .timer-elapsed.overtime { color: var(--orange); }
  .timer-target { color: var(--text-dim); font-size: 13px; }
  .task-pause-btn {
    font-size: 14px; font-weight: 700; font-family: inherit;
    color: var(--yellow); background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.12); border-radius: 8px;
    padding: 4px 10px; cursor: pointer; transition: all 0.2s;
  }
  .task-pause-btn:hover { background: rgba(255,200,0,0.15); border-color: var(--yellow); }
  .task-resume-btn {
    font-size: 12px; font-weight: 700; font-family: inherit;
    color: #fff; background: linear-gradient(135deg, var(--lime), var(--cyan));
    border: none; border-radius: 8px; padding: 6px 14px;
    cursor: pointer; transition: all 0.25s;
  }
  .task-resume-btn:hover { transform: scale(1.05); box-shadow: 0 0 15px rgba(125,255,107,0.3); }
  .task-paused-info {
    font-size: 12px; font-weight: 700; color: var(--yellow);
    padding: 4px 0;
  }
  .task-item.paused .task-check { color: var(--yellow); }
  .task-item.paused .task-xp { color: var(--yellow); font-size: 11px; font-weight: 700; }
  .task-done-btn {
    width: 100%; font-size: 14px; font-weight: 700; font-family: inherit;
    color: #fff; background: linear-gradient(135deg, var(--lime), var(--cyan));
    border: none; border-radius: 10px; padding: 10px 0;
    cursor: pointer; transition: all 0.25s;
    text-shadow: 0 1px 2px rgba(0,0,0,0.3);
  }
  .task-done-btn:hover { transform: scale(1.02); box-shadow: 0 0 20px rgba(125,255,107,0.3); }
  .task-undo-detail-btn {
    width: 100%; font-size: 13px; font-weight: 600; font-family: inherit;
    color: var(--text-dim); background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1); border-radius: 10px; padding: 8px 0;
    cursor: pointer; transition: all 0.25s;
  }
  .task-undo-detail-btn:hover { background: rgba(255,45,120,0.1); border-color: var(--pink); color: var(--pink); }

  .task-search-wrap {
    padding: 0 0 14px;
  }
  .task-search {
    width: 100%; box-sizing: border-box;
    font-size: 14px; font-family: inherit;
    color: var(--text); background: var(--glass);
    border: 1.5px solid rgba(255,255,255,0.08);
    border-radius: 14px; padding: 10px 16px;
    outline: none; transition: all 0.25s;
    backdrop-filter: blur(10px);
    direction: rtl;
  }
  .task-search::placeholder { color: var(--text-dim); }
  .task-search:focus {
    border-color: var(--cyan);
    box-shadow: 0 0 20px rgba(0,229,255,0.15);
    background: rgba(0,229,255,0.05);
  }

  /* ─── Time Filter Slider ─── */
  .time-filter-wrap { padding: 0 0 14px; }
  .time-filter-row {
    display: flex; align-items: center; gap: 12px; direction: rtl;
  }
  .time-filter-label {
    font-size: 13px; font-weight: 600; color: var(--text-dim);
    white-space: nowrap; min-width: 90px;
  }
  .time-filter-label span { color: var(--cyan); font-weight: 700; }
  .time-filter-slider {
    -webkit-appearance: none; appearance: none;
    width: 100%; height: 6px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 3px; outline: none; cursor: pointer;
    direction: ltr;
  }
  .time-filter-slider::-webkit-slider-thumb {
    -webkit-appearance: none; appearance: none;
    width: 20px; height: 20px; border-radius: 50%;
    background: linear-gradient(135deg, var(--cyan), var(--purple));
    border: 2px solid rgba(255,255,255,0.2);
    cursor: pointer;
    box-shadow: 0 0 12px var(--cyan-glow);
    transition: box-shadow 0.2s, transform 0.2s;
  }
  .time-filter-slider::-webkit-slider-thumb:hover {
    box-shadow: 0 0 20px var(--cyan-glow); transform: scale(1.15);
  }
  .time-filter-slider::-moz-range-thumb {
    width: 20px; height: 20px; border-radius: 50%;
    background: linear-gradient(135deg, var(--cyan), var(--purple));
    border: 2px solid rgba(255,255,255,0.2);
    cursor: pointer;
    box-shadow: 0 0 12px var(--cyan-glow);
  }
  .time-filter-slider::-moz-range-track {
    height: 6px; background: rgba(255,255,255,0.06);
    border-radius: 3px; border: 1px solid rgba(255,255,255,0.08);
  }

  .tool-filter-btn {
    background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
    color: var(--text-dim); font-size: 12px; font-weight: 700;
    font-family: 'Heebo', sans-serif;
    padding: 6px 14px; border-radius: 100px; cursor: pointer;
    transition: all 0.2s; white-space: nowrap;
  }
  .tool-filter-btn:hover { background: rgba(255,255,255,0.1); }
  .tool-filter-btn.active {
    background: linear-gradient(135deg, rgba(0,229,255,0.15), rgba(178,77,255,0.15));
    border-color: var(--cyan);
    color: var(--cyan);
    box-shadow: 0 0 10px rgba(0,229,255,0.15);
  }

  .time-summary {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 8px; margin-bottom: 14px;
  }
  .time-stat {
    background: var(--glass);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 12px; padding: 10px 12px;
    text-align: center; backdrop-filter: blur(8px);
  }
  .time-stat-value {
    font-size: 18px; font-weight: 700;
    font-variant-numeric: tabular-nums;
    margin-bottom: 2px;
  }
  .time-stat-label {
    font-size: 11px; color: var(--text-dim); line-height: 1.4;
  }
  .ts-remaining .time-stat-value { color: var(--yellow); }
  .ts-worked .time-stat-value { color: var(--lime); }
  .ts-estimated .time-stat-value { color: var(--cyan); }
  .ts-pace .time-stat-value { color: var(--pink); }
  .time-summary-bar {
    grid-column: 1 / -1;
    background: rgba(255,255,255,0.03);
    border-radius: 8px; height: 8px;
    overflow: hidden; position: relative;
    border: 1px solid rgba(255,255,255,0.05);
  }
  .time-bar-estimated {
    position: absolute; top: 0; right: 0; height: 100%;
    background: rgba(0,229,255,0.25);
    border-radius: 8px;
    transition: width 0.5s ease;
  }
  .time-bar-actual {
    position: absolute; top: 0; right: 0; height: 100%;
    background: linear-gradient(90deg, var(--lime), var(--cyan));
    border-radius: 8px;
    transition: width 0.5s ease;
  }

  .sr-tip {
    font-size: 12px; line-height: 1.6; color: var(--cyan);
    background: rgba(0,229,255,0.08);
    border: 1px solid rgba(0,229,255,0.15);
    border-radius: 10px; padding: 10px 14px;
    margin-top: 10px; text-align: right;
  }
  .sr-tip::before { content: '\1F4A1 '; }
  .sr-time {
    font-size: 12px; color: var(--text-dim);
    margin-top: 6px;
  }

  .task-xp {
    font-size: 11px; font-weight: 700; color: var(--yellow);
    background: rgba(255,225,86,0.1); padding: 3px 10px;
    border-radius: 100px; white-space: nowrap;
    border: 1px solid rgba(255,225,86,0.15);
  }
  .task-item.done .task-xp {
    color: var(--lime); background: rgba(125,255,107,0.1);
    border-color: rgba(125,255,107,0.15);
  }

  .task-bonus {
    position: absolute; left: 70px; top: 50%; transform: translateY(-50%);
    font-size: 13px; font-weight: 900; color: var(--cyan);
    opacity: 0; pointer-events: none;
    text-shadow: 0 0 10px var(--cyan-glow);
  }
  .task-bonus.show { animation: bonusPop 1.2s ease-out forwards; }
  @keyframes bonusPop {
    0%   { opacity: 0; transform: translateY(-50%) scale(0.5); }
    15%  { opacity: 1; transform: translateY(-80%) scale(1.2); }
    100% { opacity: 0; transform: translateY(-140%) scale(0.8); }
  }

  /* ─── Achievements ─── */
  .achievements-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px; }
  .achievement-card {
    background: var(--bg-card); backdrop-filter: blur(10px);
    border: 1px solid var(--border);
    border-radius: var(--radius); padding: 16px;
    display: flex; gap: 12px; align-items: center;
    opacity: 0.4; transition: all 0.3s;
    filter: grayscale(0.6);
  }
  .achievement-card.unlocked {
    opacity: 1; filter: grayscale(0);
    border-color: rgba(255,225,86,0.3);
    box-shadow: 0 0 20px rgba(255,225,86,0.1);
  }
  .ach-icon { font-size: 32px; flex-shrink: 0; }
  .ach-info { flex: 1; }
  .ach-name { font-size: 14px; font-weight: 900; margin-bottom: 2px; color: var(--text); }
  .ach-desc { font-size: 11px; color: var(--text-dim); line-height: 1.5; }
  .ach-badge {
    font-size: 10px; font-weight: 700; color: var(--bg-deep);
    background: linear-gradient(135deg, var(--yellow), var(--orange));
    padding: 4px 10px; border-radius: 100px; white-space: nowrap;
  }

  /* ─── Stats ─── */
  .stats-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 12px;
    margin-bottom: 18px;
  }
  .stat-card {
    background: var(--bg-card); backdrop-filter: blur(10px);
    border: 1px solid var(--border);
    border-radius: var(--radius); padding: 18px 12px; text-align: center;
  }
  .stat-card .big-num {
    font-size: 28px; font-weight: 900;
    margin-bottom: 4px;
  }
  .stat-card .stat-label { font-size: 11px; color: var(--text-dim); font-weight: 500; }

  .history-log {
    background: var(--bg-card); backdrop-filter: blur(10px);
    border: 1px solid var(--border);
    border-radius: var(--radius); padding: 16px;
    max-height: 350px; overflow-y: auto;
  }
  .history-log h3 { font-size: 15px; margin-bottom: 12px; font-weight: 900; }
  .log-entry {
    display: flex; align-items: flex-start; gap: 10px;
    padding: 7px 0; border-bottom: 1px solid rgba(178,77,255,0.08);
    font-size: 12px;
  }
  .log-entry:last-child { border-bottom: none; }
  .log-entry.clickable { cursor: pointer; border-radius: 6px; padding: 7px 6px; margin: 0 -6px; }
  .log-entry.clickable:active { background: rgba(255,255,255,0.05); }
  .log-time { color: var(--text-dim); font-size: 11px; min-width: 50px; }
  .log-text { flex: 1; line-height: 1.5; }
  .log-entry.clickable .log-text { text-decoration: underline; text-decoration-color: rgba(255,255,255,0.2); text-underline-offset: 2px; }
  .log-xp { color: var(--yellow); font-weight: 700; }

  /* ─── Toast ─── */
  #toast-container {
    position: fixed; top: 16px; left: 16px; z-index: 9999;
    display: flex; flex-direction: column; gap: 10px;
    pointer-events: none;
  }
  .toast {
    background: var(--bg-card-solid);
    backdrop-filter: blur(16px);
    border: 1px solid var(--border);
    border-radius: 14px; padding: 12px 18px;
    font-family: 'Heebo', sans-serif;
    font-size: 13px; font-weight: 700;
    display: flex; align-items: center; gap: 10px;
    box-shadow: 0 8px 30px rgba(0,0,0,0.5);
    animation: toastIn 0.4s cubic-bezier(.22,.68,0,.98), toastOut 0.4s ease-in 2.6s forwards;
    pointer-events: auto; max-width: 360px;
    color: var(--text);
    line-height: 1.5;
  }
  .toast.t-level {
    border-color: rgba(255,225,86,0.4);
    box-shadow: 0 0 40px var(--yellow-glow), 0 8px 30px rgba(0,0,0,0.4);
  }
  .toast.t-ach {
    border-color: rgba(255,45,120,0.4);
    box-shadow: 0 0 40px var(--pink-glow), 0 8px 30px rgba(0,0,0,0.4);
  }
  .toast .t-icon { font-size: 20px; }
  @keyframes toastIn {
    from { opacity: 0; transform: translateX(-50px) scale(0.9); }
    to   { opacity: 1; transform: translateX(0) scale(1); }
  }
  @keyframes toastOut {
    from { opacity: 1; transform: translateX(0); }
    to   { opacity: 0; transform: translateX(-50px); }
  }

  /* ─── Level Up Overlay ─── */
  .level-overlay {
    position: fixed; inset: 0; z-index: 10000;
    background: rgba(13,2,33,0.85); backdrop-filter: blur(12px);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none;
    transition: opacity 0.3s;
  }
  .level-overlay.show { opacity: 1; pointer-events: auto; }
  .level-overlay-content {
    text-align: center;
    animation: levelPop 0.6s cubic-bezier(.22,.68,0,.98);
  }
  .level-overlay-content .level-text {
    font-size: 22px; font-weight: 900; color: var(--text);
    margin-bottom: 4px;
    text-shadow: 0 0 30px var(--pink-glow);
  }
  .level-overlay-content .big-level {
    font-family: 'Bungee Shade', cursive;
    font-size: 80px;
    background: linear-gradient(180deg, var(--yellow), var(--orange));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 0 40px var(--yellow-glow));
    animation: levelPulse 1s ease-in-out infinite alternate;
  }
  @keyframes levelPulse {
    from { filter: drop-shadow(0 0 30px var(--yellow-glow)); transform: scale(1); }
    to { filter: drop-shadow(0 0 60px var(--yellow-glow)); transform: scale(1.05); }
  }
  .level-overlay-content .title-text {
    font-size: 16px; color: var(--text-dim); margin-bottom: 28px; font-weight: 700;
  }
  .level-overlay-content .overlay-notes {
    font-size: 28px; margin-bottom: 20px; letter-spacing: 8px;
    animation: notesFloat 2s ease-in-out infinite;
    filter: drop-shadow(0 0 12px var(--pink-glow));
  }
  @keyframes notesFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
  }
  .level-overlay-content button {
    background: linear-gradient(135deg, var(--pink), var(--orange));
    color: #fff; border: none;
    border-radius: 100px; padding: 14px 36px;
    font-size: 16px; font-weight: 900;
    font-family: 'Heebo', sans-serif;
    cursor: pointer;
    box-shadow: 0 0 30px var(--pink-glow);
    transition: all 0.2s;
  }
  .level-overlay-content button:hover { transform: scale(1.05); box-shadow: 0 0 40px var(--pink-glow); }
  .level-overlay-content button:active { transform: scale(0.98); }
  @keyframes levelPop {
    from { transform: scale(0.5) rotate(-5deg); opacity: 0; }
    to   { transform: scale(1) rotate(0); opacity: 1; }
  }

  /* ─── Confetti Canvas ─── */
  #confetti-canvas { position: fixed; inset: 0; z-index: 10001; pointer-events: none; }

  /* ─── Tools ─── */
  .tools-grid { }
  .tools-cat-title {
    font-size: 15px; font-weight: 900; margin: 0 0 12px;
    padding-bottom: 8px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .tools-cat-title:not(:first-child) { margin-top: 22px; }
  .tool-card {
    display: flex; gap: 12px; align-items: flex-start;
    padding: 12px; margin-bottom: 8px;
    background: var(--glass);
    border: 1px solid rgba(255,255,255,0.05);
    border-radius: 14px;
    transition: all 0.2s;
  }
  .tool-card:hover { background: rgba(255,255,255,0.06); }
  .tool-card-icon {
    font-size: 26px; flex-shrink: 0;
    width: 40px; height: 40px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,0.04);
    border-radius: 10px;
  }
  .tool-card-info { flex: 1; min-width: 0; }
  .tool-card-name {
    font-size: 14px; font-weight: 700; color: var(--text);
    margin-bottom: 3px;
  }
  .tool-card-desc {
    font-size: 12px; line-height: 1.6; color: var(--text-dim);
  }
  .tool-card-tasks {
    display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px;
  }
  .tool-card-task-chip {
    font-size: 10px; padding: 2px 7px; border-radius: 6px;
    background: rgba(0,229,255,0.08); color: var(--cyan);
    border: 1px solid rgba(0,229,255,0.12);
    white-space: nowrap;
  }
  .tool-card.have { border-color: rgba(125,255,107,0.2); }
  .tool-card.have .tool-card-name::after {
    content: ' \2713'; color: var(--lime); font-size: 12px;
  }
  .tool-have-btn {
    padding: 4px 8px; border-radius: 6px;
    font-size: 11px; font-family: inherit;
    background: rgba(125,255,107,0.08); border: 1px solid rgba(125,255,107,0.15);
    color: var(--lime); cursor: pointer;
    transition: all 0.2s; flex-shrink: 0; align-self: center;
  }
  .tool-have-btn:hover { background: rgba(125,255,107,0.15); }
  .tool-have-btn.owned {
    background: rgba(125,255,107,0.15); border-color: var(--lime);
  }
  .tool-missing-count {
    font-size: 13px; color: var(--text-dim);
    margin-bottom: 14px; line-height: 1.6;
  }
  .tool-missing-count span { color: var(--yellow); font-weight: 700; }

  .task-tools-row {
    display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 10px;
  }
  .task-tool-chip {
    display: inline-flex; align-items: center; gap: 3px;
    font-size: 11px; padding: 3px 8px; border-radius: 6px;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.06);
    color: var(--text-dim); cursor: pointer;
    transition: all 0.2s;
  }
  .task-tool-chip:hover {
    background: rgba(0,229,255,0.1); border-color: rgba(0,229,255,0.2);
    color: var(--cyan);
  }
  .task-tool-chip .ttc-icon { font-size: 13px; }

  /* ─── Settings ─── */
  .settings-section { margin-bottom: 24px; }
  .settings-section h3 { font-size: 15px; margin-bottom: 12px; font-weight: 900; }
  .custom-task-form { display: flex; gap: 8px; flex-wrap: wrap; }
  .custom-task-form select,
  .custom-task-form input,
  .custom-task-form button {
    background: var(--bg-card-solid);
    border: 1px solid var(--border);
    color: var(--text);
    border-radius: 12px; padding: 10px 14px;
    font-size: 13px; font-family: 'Heebo', sans-serif;
    direction: rtl;
  }
  .custom-task-form input { flex: 1; min-width: 150px; }
  .custom-task-form input::placeholder { color: var(--text-dim); }
  .custom-task-form input:focus, .custom-task-form select:focus {
    outline: none; border-color: var(--purple);
    box-shadow: 0 0 15px var(--purple-glow);
  }
  .custom-task-form button {
    background: linear-gradient(135deg, var(--pink), var(--purple));
    border-color: var(--pink);
    color: #fff; font-weight: 700; cursor: pointer;
    transition: all 0.2s;
  }
  .custom-task-form button:hover { box-shadow: 0 0 20px var(--pink-glow); transform: translateY(-1px); }

  .export-btn, .import-btn {
    background: rgba(0,229,255,0.08); border: 1px solid rgba(0,229,255,0.2);
    color: var(--cyan); border-radius: 12px;
    padding: 10px 20px; font-size: 13px; font-weight: 700;
    font-family: 'Heebo', sans-serif;
    cursor: pointer; transition: all 0.2s;
    display: inline-flex; align-items: center; gap: 6px;
  }
  .export-btn:hover, .import-btn:hover { background: rgba(0,229,255,0.15); }
  .import-btn {
    background: rgba(178,77,255,0.08); border-color: rgba(178,77,255,0.2);
    color: var(--purple);
  }
  .import-btn:hover { background: rgba(178,77,255,0.15); }

  .reset-section { margin-top: 32px; }
  .reset-btn {
    background: rgba(255,45,120,0.08);
    border: 1px solid rgba(255,45,120,0.2);
    color: var(--pink); border-radius: 12px;
    padding: 10px 20px; font-size: 13px; font-weight: 700;
    font-family: 'Heebo', sans-serif;
    cursor: pointer; transition: all 0.2s;
  }
  .reset-btn:hover { background: rgba(255,45,120,0.15); }

  /* ─── Wait Timers ─── */
  .wait-timers-bar {
    position: fixed; bottom: 96px; right: 16px; left: 16px; z-index: 998;
    display: flex; flex-direction: column; gap: 6px;
    pointer-events: none;
  }
  .wait-timer-item {
    display: flex; align-items: center; gap: 10px;
    background: var(--bg-card-solid);
    border: 1px solid rgba(255,225,86,0.25);
    border-radius: 14px; padding: 10px 14px;
    font-size: 12px; font-weight: 600;
    box-shadow: 0 4px 20px rgba(0,0,0,0.3);
    pointer-events: auto;
    animation: viewIn 0.3s ease-out;
  }
  .wait-timer-item.done {
    border-color: rgba(125,255,107,0.3);
    box-shadow: 0 4px 20px rgba(125,255,107,0.15);
    cursor: pointer;
  }
  .wt-icon { font-size: 18px; }
  .wt-info { flex: 1; min-width: 0; }
  .wt-label { color: var(--text); font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .wt-sub { color: var(--text-dim); font-size: 11px; margin-top: 2px; }
  .wt-time { font-variant-numeric: tabular-nums; color: var(--yellow); font-weight: 700; font-size: 14px; }
  .wait-timer-item.done .wt-time { color: var(--lime); }
  .wt-dismiss {
    background: none; border: none; color: var(--text-dim);
    font-size: 16px; cursor: pointer; padding: 4px;
    transition: color 0.2s;
  }
  .wt-dismiss:hover { color: var(--pink); }

  .task-item.waiting { background: rgba(255,225,86,0.06); }
  .task-item.waiting .task-check {
    border-color: var(--yellow);
    background: rgba(255,225,86,0.15);
    color: var(--yellow); font-size: 12px;
  }
  .task-item.waiting .task-xp {
    color: var(--yellow);
    background: rgba(255,225,86,0.1);
    border-color: rgba(255,225,86,0.15);
    font-size: 10px;
  }

  .task-soak-btn {
    font-size: 12px; font-weight: 700; font-family: inherit;
    color: var(--yellow); background: rgba(255,225,86,0.08);
    border: 1px solid rgba(255,225,86,0.2); border-radius: 8px;
    padding: 6px 14px; cursor: pointer; transition: all 0.25s;
  }
  .task-soak-btn:hover { background: rgba(255,225,86,0.15); transform: scale(1.03); }

  .task-soak-status {
    font-size: 12px; padding: 8px 12px; border-radius: 8px;
    margin-bottom: 10px; line-height: 1.6;
  }
  .task-soak-status.running {
    color: var(--yellow); background: rgba(255,225,86,0.06);
    border: 1px solid rgba(255,225,86,0.15);
  }
  .task-soak-status.complete {
    color: var(--lime); background: rgba(125,255,107,0.06);
    border: 1px solid rgba(125,255,107,0.15);
  }

  .missing-tools-warn {
    font-size: 12px; line-height: 1.7; color: var(--orange);
    background: rgba(255,140,66,0.06);
    border: 1px solid rgba(255,140,66,0.15);
    border-radius: 10px; padding: 10px 14px;
    margin-bottom: 10px;
  }
  .missing-tools-warn::before { content: '\26A0\FE0F '; }
  .mtw-item { margin-bottom: 4px; }
  .mtw-alt { color: var(--text-dim); font-size: 11px; display: block; margin-top: 2px; padding-right: 20px; }

  .task-tool-chip.chip-missing {
    background: rgba(255,140,66,0.1);
    border-color: rgba(255,140,66,0.2);
    color: var(--orange);
  }
  .task-tool-chip.chip-have {
    border-color: rgba(125,255,107,0.15);
  }

  /* Tool status tri-state button */
  .tool-status-btn {
    padding: 4px 10px; border-radius: 6px;
    font-size: 11px; font-family: inherit;
    cursor: pointer; transition: all 0.2s;
    flex-shrink: 0; align-self: center;
    border: 1px solid;
  }
  .tool-status-btn.ts-unfilled {
    background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.1);
    color: var(--text-dim);
  }
  .tool-status-btn.ts-unfilled:hover { background: rgba(255,255,255,0.08); }
  .tool-status-btn.ts-have {
    background: rgba(125,255,107,0.15); border-color: var(--lime);
    color: var(--lime);
  }
  .tool-status-btn.ts-have:hover { background: rgba(125,255,107,0.2); }
  .tool-status-btn.ts-missing {
    background: rgba(255,140,66,0.12); border-color: var(--orange);
    color: var(--orange);
  }
  .tool-status-btn.ts-missing:hover { background: rgba(255,140,66,0.18); }

  .shopping-list {
    background: rgba(255,140,66,0.05);
    border: 1px solid rgba(255,140,66,0.15);
    border-radius: var(--radius); padding: 16px;
    margin-bottom: 18px;
  }
  .shopping-header {
    display: flex; align-items: center; justify-content: space-between;
    cursor: pointer; user-select: none;
  }
  .shopping-header:hover { opacity: 0.85; }
  .shopping-list h3 {
    font-size: 15px; font-weight: 900; margin: 0;
    color: var(--orange);
  }
  .shopping-count { font-weight: 400; font-size: 12px; color: var(--text-dim); }
  .shopping-toggle {
    font-size: 14px; color: var(--text-dim);
    transition: transform 0.3s ease;
  }
  .shopping-list.collapsed .shopping-toggle { transform: rotate(180deg); }
  .shopping-items {
    margin-top: 12px;
    transition: max-height 0.4s cubic-bezier(.22,.68,0,.98), opacity 0.3s ease, margin 0.3s ease;
    max-height: 2000px; overflow: hidden;
  }
  .shopping-list.collapsed .shopping-items {
    max-height: 0; opacity: 0; margin-top: 0;
  }
  .shopping-item {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,0.04);
    font-size: 13px; transition: opacity 0.3s;
  }
  .shopping-item:last-child { border-bottom: none; }
  .shopping-item.ordered { opacity: 0.55; }
  .shopping-item.ordered .shopping-item-name { text-decoration: line-through; }
  .shopping-item-icon { font-size: 18px; }
  .shopping-item-name { flex: 1; color: var(--text); }
  .shopping-item-alt { font-size: 11px; color: var(--text-dim); }
  .shopping-item-link { cursor: pointer; transition: color 0.2s; }
  .shopping-item-link:hover { color: var(--cyan); text-decoration: underline; }
  .ordered-badge {
    font-size: 10px; background: rgba(125,255,107,0.15); color: var(--lime);
    padding: 1px 6px; border-radius: 8px; font-weight: 700;
  }
  .shopping-check {
    position: relative; cursor: pointer; display: flex;
    align-items: center; justify-content: center;
    width: 22px; height: 22px; flex-shrink: 0;
  }
  .shopping-check input {
    position: absolute; opacity: 0; width: 0; height: 0;
  }
  .shopping-checkmark {
    width: 20px; height: 20px; border-radius: 5px;
    border: 2px solid var(--orange); background: transparent;
    transition: all 0.2s;
    display: flex; align-items: center; justify-content: center;
  }
  .shopping-check input:checked + .shopping-checkmark {
    background: var(--lime); border-color: var(--lime);
  }
  .shopping-check input:checked + .shopping-checkmark::after {
    content: '\2713'; color: #0d0221; font-size: 13px; font-weight: 900;
  }

  .shopping-arrived-btn {
    width: 100%; margin-top: 10px; padding: 10px;
    background: linear-gradient(135deg, rgba(125,255,107,0.15), rgba(0,229,255,0.12));
    border: 1px solid rgba(125,255,107,0.3);
    color: var(--lime); font-size: 13px; font-weight: 700;
    font-family: 'Heebo', sans-serif;
    border-radius: 10px; cursor: pointer; transition: all 0.25s;
  }
  .shopping-arrived-btn:hover {
    background: linear-gradient(135deg, rgba(125,255,107,0.25), rgba(0,229,255,0.2));
    transform: translateY(-1px); box-shadow: 0 4px 15px rgba(125,255,107,0.15);
  }

  /* ─── Collapsible Rooms ─── */
  .room-header { cursor: pointer; transition: all 0.2s; }
  .room-header:hover { background: rgba(255,255,255,0.03); }
  .room-toggle {
    font-size: 14px; color: var(--text-dim);
    transition: transform 0.3s ease;
    flex-shrink: 0;
  }
  .room-card.collapsed .room-toggle { transform: rotate(180deg); }
  .room-card.collapsed .task-list {
    max-height: 0; overflow: hidden; padding: 0 10px;
    transition: max-height 0.4s cubic-bezier(.22,.68,0,.98), padding 0.3s ease;
  }
  .room-card:not(.collapsed) .task-list {
    max-height: 5000px;
    transition: max-height 0.4s cubic-bezier(.22,.68,0,.98);
  }

  /* ─── Stat Popup ─── */
  .stat-popup-overlay {
    position: fixed; inset: 0; z-index: 2000;
    background: rgba(13,2,33,0.8); backdrop-filter: blur(6px);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none;
    transition: opacity 0.3s ease;
  }
  .stat-popup-overlay.show { opacity: 1; pointer-events: auto; }
  .stat-popup {
    background: var(--bg-card-solid); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 28px 24px;
    max-width: 400px; width: 90%; max-height: 80vh; overflow-y: auto;
    position: relative;
    transform: scale(0.9); transition: transform 0.3s ease;
    box-shadow: 0 20px 60px rgba(0,0,0,0.5);
  }
  .stat-popup-overlay.show .stat-popup { transform: scale(1); }
  .stat-popup-close {
    position: absolute; top: 10px; left: 10px;
    background: none; border: none; color: var(--text-dim);
    font-size: 22px; cursor: pointer; padding: 4px 8px;
    transition: color 0.2s;
  }
  .stat-popup-close:hover { color: var(--pink); }
  .stat-popup-icon { font-size: 42px; text-align: center; margin-bottom: 8px; }
  .stat-popup-title {
    font-size: 18px; font-weight: 900; color: var(--text);
    text-align: center; margin-bottom: 12px;
  }
  .stat-popup-desc {
    font-size: 13px; color: var(--text-dim); line-height: 1.7;
    text-align: center; margin-bottom: 16px;
    padding: 0 8px;
  }
  .stat-popup-value {
    font-size: 13px; font-weight: 700; color: var(--cyan);
    text-align: center; margin-bottom: 16px;
    background: rgba(0,229,255,0.06); border-radius: 8px;
    padding: 10px 12px;
  }
  .stat-popup-history { max-height: 200px; overflow-y: auto; }
  .stat-log-title {
    font-size: 12px; font-weight: 700; color: var(--text-dim);
    margin-bottom: 8px; padding-bottom: 4px;
    border-bottom: 1px solid var(--border);
  }
  .stat-log-entry {
    display: flex; align-items: center; gap: 8px;
    padding: 4px 0; font-size: 11px;
    border-bottom: 1px solid rgba(255,255,255,0.02);
  }
  .stat-log-entry.clickable { cursor: pointer; border-radius: 6px; padding: 4px 6px; margin: 0 -6px; }
  .stat-log-entry.clickable:active { background: rgba(255,255,255,0.05); }
  .stat-log-time { color: var(--text-dim); flex-shrink: 0; }
  .stat-log-text { flex: 1; color: var(--text); }
  .stat-log-entry.clickable .stat-log-text { text-decoration: underline; text-decoration-color: rgba(255,255,255,0.2); text-underline-offset: 2px; }
  .stat-log-xp { color: var(--lime); font-weight: 700; flex-shrink: 0; }

  /* ─── Music ─── */
  .music-toggle-section {
    margin-bottom: 16px;
  }
  .music-toggle-label {
    display: flex; align-items: center; justify-content: space-between;
    background: var(--glass); border: 1px solid rgba(255,255,255,0.06);
    border-radius: 12px; padding: 12px 16px;
  }
  .music-toggle-label span { font-size: 14px; font-weight: 700; }
  .music-toggle-btn {
    font-size: 12px; font-weight: 700; font-family: inherit;
    padding: 6px 14px; border-radius: 8px; cursor: pointer;
    border: 1px solid rgba(255,255,255,0.1);
    background: rgba(255,255,255,0.05); color: var(--text-dim);
    transition: all 0.25s;
  }
  .music-toggle-btn.active {
    background: linear-gradient(135deg, var(--lime), var(--cyan));
    border-color: var(--lime); color: #fff;
  }
  .music-test-section {
    display: flex; align-items: center; justify-content: space-between;
    background: var(--glass); border: 1px solid rgba(255,255,255,0.06);
    border-radius: 12px; padding: 10px 16px; margin-bottom: 16px;
  }
  .music-test-status {
    display: flex; align-items: center; gap: 8px;
    font-size: 13px; font-weight: 600; color: var(--text);
  }
  .mts-dot {
    width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
  }
  .mts-dot.ok { background: var(--lime); box-shadow: 0 0 6px var(--lime); }
  .mts-dot.wait { background: var(--orange); box-shadow: 0 0 6px var(--orange); animation: pulse 1.5s ease-in-out infinite; }
  @keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }
  .music-test-btn {
    font-size: 12px; font-weight: 700; font-family: inherit;
    padding: 6px 16px; border-radius: 8px; cursor: pointer;
    border: 1px solid rgba(255,255,255,0.1);
    background: linear-gradient(135deg, rgba(178,77,255,0.2), rgba(255,45,120,0.2));
    color: var(--text); transition: all 0.25s;
  }
  .music-test-btn:hover {
    background: linear-gradient(135deg, rgba(178,77,255,0.35), rgba(255,45,120,0.35));
    transform: translateY(-1px); box-shadow: 0 4px 12px rgba(178,77,255,0.15);
  }
  .music-cookie-tip {
    margin-bottom: 16px;
  }
  .music-cookie-tip details {
    background: rgba(255,165,0,0.08); border: 1px solid rgba(255,165,0,0.15);
    border-radius: 10px; padding: 10px 14px;
  }
  .music-cookie-tip summary {
    font-size: 13px; font-weight: 700; color: var(--orange); cursor: pointer;
  }
  .music-cookie-tip p {
    font-size: 12px; color: var(--text-dim); margin: 8px 0 0; line-height: 1.6;
  }
  .music-cookie-tip code {
    background: rgba(255,255,255,0.08); padding: 1px 5px; border-radius: 4px;
    font-size: 11px; direction: ltr; display: inline-block;
  }
  .music-section-title {
    font-size: 15px; font-weight: 900; margin: 0 0 12px;
  }
  .music-genre-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 10px; margin-bottom: 18px;
  }
  .music-genre-btn {
    display: flex; flex-direction: column; align-items: center; gap: 4px;
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 14px 8px;
    cursor: pointer; transition: all 0.25s;
    font-family: inherit;
  }
  .music-genre-btn:hover {
    border-color: rgba(178,77,255,0.3); transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(178,77,255,0.1);
  }
  .music-genre-btn.active {
    border-color: var(--pink);
    background: linear-gradient(135deg, rgba(255,45,120,0.15), rgba(178,77,255,0.15));
    box-shadow: 0 0 20px var(--pink-glow);
  }
  .mgb-icon { font-size: 28px; }
  .mgb-name { font-size: 13px; font-weight: 700; color: var(--text); }
  .mgb-count { font-size: 10px; color: var(--text-dim); }

  .music-track-list {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 14px;
    max-height: 300px; overflow-y: auto;
  }
  .music-track-list h4 {
    font-size: 14px; font-weight: 900; margin: 0 0 10px;
  }
  .music-track-item {
    display: flex; align-items: center; gap: 10px;
    padding: 6px 0; border-bottom: 1px solid rgba(255,255,255,0.04);
    font-size: 12px;
  }
  .music-track-item:last-child { border-bottom: none; }
  .mti-num { color: var(--text-dim); min-width: 20px; text-align: center; font-weight: 700; }
  .mti-name { flex: 1; color: var(--text); font-weight: 600; }
  .mti-artist { color: var(--text-dim); }

  /* Music Player Bar (fixed bottom) */
  .music-player-bar {
    position: fixed; bottom: 0; right: 0; left: 0; z-index: 999;
    background: var(--bg-card-solid); backdrop-filter: blur(16px);
    border-top: 1px solid rgba(178,77,255,0.2);
    padding: 8px 16px;
    display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
    box-shadow: 0 -4px 20px rgba(0,0,0,0.3);
    transform: translateY(100%);
    transition: transform 0.3s ease;
  }
  .music-player-bar.show { transform: translateY(0); }
  .mpb-info {
    display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0;
  }
  .mpb-note { font-size: 16px; animation: notesFloat 2s ease-in-out infinite; }
  .mpb-track {
    font-size: 13px; font-weight: 700; color: var(--text);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  .mpb-artist {
    font-size: 11px; color: var(--text-dim);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  .mpb-counter {
    font-size: 10px; color: var(--text-dim); flex-shrink: 0;
  }
  .mpb-controls {
    display: flex; gap: 4px; flex-shrink: 0;
  }
  .mpb-btn {
    background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
    color: var(--text); border-radius: 8px; padding: 4px 10px;
    font-size: 14px; cursor: pointer; transition: all 0.2s;
    font-family: inherit;
  }
  .mpb-btn:hover { background: rgba(255,255,255,0.12); transform: scale(1.05); }
  .mpb-pause { color: var(--yellow); }
  .mpb-open { color: var(--cyan); font-size: 12px; }
  .mpb-collapse {
    background: none; border: none; color: var(--text-dim);
    font-size: 18px; cursor: pointer; padding: 2px 6px;
    line-height: 1; transition: color 0.2s;
    flex-shrink: 0;
  }
  .mpb-collapse:hover { color: var(--text); }
  .mpb-embed {
    width: 100%; border-radius: 8px; overflow: hidden;
  }

  /* ─── House Presets ─── */
  .preset-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 10px; margin-bottom: 10px;
  }
  .preset-btn {
    display: flex; flex-direction: column; align-items: center; gap: 4px;
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 14px 8px;
    cursor: pointer; transition: all 0.25s;
    font-family: inherit; color: var(--text);
  }
  .preset-btn:hover {
    border-color: rgba(178,77,255,0.3); transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(178,77,255,0.1);
  }
  .preset-btn.active {
    border-color: var(--cyan);
    background: linear-gradient(135deg, rgba(0,229,255,0.15), rgba(178,77,255,0.15));
    box-shadow: 0 0 20px rgba(0,229,255,0.15);
  }
  .preset-icon { font-size: 24px; }
  .preset-name { font-size: 13px; font-weight: 700; }
  .preset-desc { font-size: 10px; color: var(--text-dim); }

  .preset-custom-rooms {
    display: flex; flex-wrap: wrap; gap: 8px;
    margin-top: 10px; padding: 10px;
    background: rgba(255,255,255,0.03); border-radius: var(--radius);
  }
  .preset-room-check {
    display: flex; align-items: center; gap: 6px;
    padding: 6px 12px; border-radius: 20px;
    background: var(--bg-card); border: 1px solid var(--border);
    cursor: pointer; font-size: 13px; transition: all 0.2s;
  }
  .preset-room-check.on {
    border-color: var(--cyan);
    background: rgba(0,229,255,0.1);
  }
  .preset-room-check input { display: none; }
  .prc-icon { font-size: 16px; }
  .prc-name { font-weight: 600; }

