/* ===== RESET & BASE ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --taskbar-h: 52px;
  --accent: #5b8cff;
  --accent2: #ff7c5b;
  --bg-glass: rgba(30,30,50,0.82);
  --win-radius: 10px;
  --win-header-h: 36px;
  --font: 'Segoe UI', system-ui, sans-serif;
  --sat: env(safe-area-inset-top, 0px);
  --sab: env(safe-area-inset-bottom, 0px);
  --sal: env(safe-area-inset-left, 0px);
  --sar: env(safe-area-inset-right, 0px);
  /* Theme colors (light defaults) */
  --win-bg: #f0f0f0;
  --win-body-bg: #fff;
  --toolbar-bg: #f5f5f5;
  --surface-bg: #f8f8f8;
  --input-bg: #fff;
  --text-primary: #333;
  --text-secondary: #555;
  --text-muted: #888;
  --border-color: #ddd;
  --border-light: #eee;
  --hover-bg: #e8e8e8;
  --context-bg: #fff;
  --scrollbar-thumb: rgba(0,0,0,0.25);
}

[data-theme="dark"] {
  --win-bg: #2a2a3e;
  --win-body-bg: #1e1e2e;
  --toolbar-bg: #2a2a3e;
  --surface-bg: #252538;
  --input-bg: #1a1a2e;
  --text-primary: #e8e8e8;
  --text-secondary: #bbb;
  --text-muted: #888;
  --border-color: #3a3a5e;
  --border-light: #2a2a4a;
  --hover-bg: #3a3a5e;
  --context-bg: #2a2a3e;
  --scrollbar-thumb: rgba(255,255,255,0.25);
}

html, body {
  width: 100%; height: 100%;
  font-family: var(--font);
  overflow: hidden;
  user-select: none;
  touch-action: none; /* prevent browser pan/zoom interfering with OS interactions */
  -webkit-tap-highlight-color: transparent;
}

/* Restore scrolling inside scrollable panels */
.kc-messages, .kc-contact-list, .kc-edit-list, .kc-gallery-grid,
.kf-content, .fm-files, .win-body, .settings-panel, .kc-dialog,
#kc-contact-list, #kc-edit-list {
  touch-action: pan-y;
  -webkit-overflow-scrolling: touch;
}

/* Titlebar drag area — capture touch */
.win-titlebar { touch-action: none; }

/* Paint canvas — no browser gestures at all */
#paint-canvas { touch-action: none; }

/* ===== BOOT SCREEN ===== */
#boot-screen {
  position: fixed; inset: 0; z-index: 9999;
  background: #1a1a2e;
  display: flex; align-items: center; justify-content: center;
  transition: opacity 0.8s;
}
#boot-screen.fade-out { opacity: 0; pointer-events: none; }

#boot-content { text-align: center; color: #fff; }
#boot-logo { font-size: 80px; animation: pulse 1.5s infinite; }
#boot-title { font-size: 48px; font-weight: 700; margin: 10px 0 4px; color: #5b8cff; }
#boot-subtitle { font-size: 18px; color: #aaa; margin-bottom: 30px; }
#boot-bar-wrap {
  width: 260px; height: 8px; background: rgba(255,255,255,0.15);
  border-radius: 4px; overflow: hidden; margin: 0 auto;
}
#boot-bar {
  height: 100%; width: 0; background: #5b8cff;
  border-radius: 4px; transition: width 0.1s;
}

@keyframes pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.1)} }

/* ===== DESKTOP ===== */
#desktop {
  width: 100vw; height: 100vh;
  background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
  background-size: cover; background-position: center;
  position: relative; overflow: hidden;
}

/* ===== DESKTOP ICONS ===== */
#desktop-icons {
  position: absolute; top: calc(16px + var(--sat)); left: calc(16px + var(--sal));
  bottom: calc(var(--taskbar-h) + 16px);
  display: flex; flex-direction: column; flex-wrap: wrap; gap: 12px;
  z-index: 10;
}

.desktop-icon {
  display: flex; flex-direction: column; align-items: center;
  width: 80px; cursor: pointer; padding: 8px 4px;
  border-radius: 8px; transition: background 0.15s;
}
.desktop-icon:hover { background: rgba(255,255,255,0.15); }
.desktop-icon:active { background: rgba(255,255,255,0.25); }
.desktop-icon .icon-img { font-size: 36px; line-height: 1; }
.desktop-icon span {
  margin-top: 4px; font-size: 12px; color: #fff;
  text-shadow: 0 1px 3px rgba(0,0,0,0.8);
  text-align: center; word-break: break-word;
}

/* ===== TASKBAR ===== */
#taskbar {
  position: absolute; bottom: 0; left: 0; right: 0;
  height: calc(var(--taskbar-h) + var(--sab));
  background: var(--bg-glass);
  backdrop-filter: blur(12px);
  border-top: 1px solid rgba(255,255,255,0.12);
  display: flex; align-items: center;
  padding: 0 calc(12px + var(--sal)) var(--sab) calc(12px + var(--sar));
  gap: 8px; z-index: 100;
}

#taskbar-left { display: flex; align-items: center; }
#taskbar-center { flex: 1; display: flex; align-items: center; gap: 6px; padding: 0 8px; overflow: hidden; }
#taskbar-right { display: flex; align-items: center; }
.tbtn-icon { margin-right: 4px; }

#app-menu-btn {
  background: var(--accent); border: none;
  color: #fff; font-size: 14px; font-weight: 600;
  padding: 6px 14px; border-radius: 8px;
  cursor: pointer; transition: filter 0.15s;
  display: flex; align-items: center; gap: 6px;
}
#app-menu-btn:hover { filter: brightness(1.15); }

.taskbar-app-btn {
  background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.18);
  color: #fff; font-size: 13px; padding: 4px 12px;
  border-radius: 6px; cursor: pointer; max-width: 140px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  transition: background 0.15s;
}
.taskbar-app-btn:hover { background: rgba(255,255,255,0.22); }
.taskbar-app-btn.active { background: rgba(91,140,255,0.35); border-color: var(--accent); }
.taskbar-app-btn.minimized { opacity: 0.6; }

#taskbar-clock {
  display: flex; flex-direction: column; align-items: center;
  color: #fff; font-size: 13px; line-height: 1.3; padding: 0 8px;
}
#clock-time { font-weight: 700; font-size: 15px; }
#clock-date { font-size: 11px; color: #ccc; }

/* ===== APP MENU ===== */
#app-menu {
  position: absolute; bottom: calc(var(--taskbar-h) + 8px); left: 12px;
  width: 280px; background: var(--bg-glass);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 12px; z-index: 200;
  overflow: hidden; box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
#app-menu.hidden { display: none; }

.app-menu-header {
  padding: 14px 16px; background: rgba(91,140,255,0.2);
  border-bottom: 1px solid rgba(255,255,255,0.1);
  color: #fff; font-size: 15px; font-weight: 600;
}

.app-menu-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 2px; padding: 8px;
}

.menu-app-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: 8px;
  color: #fff; font-size: 14px; cursor: pointer;
  transition: background 0.15s;
}
.menu-app-item:hover { background: rgba(255,255,255,0.15); }
.menu-app-item span { font-size: 20px; }

.app-menu-footer {
  padding: 10px 16px; border-top: 1px solid rgba(255,255,255,0.1);
}
.app-menu-footer button {
  background: rgba(255,80,80,0.2); border: 1px solid rgba(255,80,80,0.3);
  color: #ff9a9a; padding: 7px 16px; border-radius: 8px;
  cursor: pointer; font-size: 14px; width: 100%;
  transition: background 0.15s;
}
.app-menu-footer button:hover { background: rgba(255,80,80,0.35); }

/* ===== WINDOWS ===== */
#windows-container { position: absolute; inset: 0; bottom: var(--taskbar-h); z-index: 20; pointer-events: none; }
.window { pointer-events: all; }

.window {
  position: absolute;
  min-width: 300px; min-height: 200px;
  background: var(--win-bg); border-radius: var(--win-radius);
  box-shadow: 0 8px 40px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.08);
  display: flex; flex-direction: column;
  overflow: hidden; transition: box-shadow 0.15s;
}
.window.focused { box-shadow: 0 12px 50px rgba(0,0,0,0.6), 0 0 0 2px var(--accent); }
.window.minimized { display: none; }
.window.maximized {
  top: 0 !important; left: 0 !important;
  width: 100% !important; height: 100% !important;
  border-radius: 0;
}

/* Window titlebar */
.win-titlebar {
  height: var(--win-header-h);
  background: linear-gradient(90deg, #2a2a4a, #3a3a6a);
  display: flex; align-items: center;
  padding: 0 10px; gap: 8px; flex-shrink: 0;
  cursor: grab; user-select: none;
}
.win-titlebar:active { cursor: grabbing; }

.win-controls { display: flex; gap: 4px; align-items: center; }
.win-btn {
  width: 28px; height: 22px; border-radius: 4px;
  border: none; cursor: pointer; font-size: 11px; font-weight: 700;
  color: rgba(255,255,255,0.7);
  display: flex; align-items: center; justify-content: center;
  transition: background 0.12s, color 0.12s;
  background: transparent;
}
.win-btn:hover { color: #fff; }
.win-btn.minimize:hover { background: rgba(255,255,255,0.15); }
.win-btn.maximize:hover { background: rgba(255,255,255,0.15); }
.win-btn.close:hover { background: #e81123; color: #fff; }

.win-title {
  flex: 1; color: #fff; font-size: 13px; font-weight: 600;
  text-align: left; pointer-events: none;
}
.win-title-icon { font-size: 16px; }

/* Window body */
.win-body {
  flex: 1; overflow: auto; background: var(--win-body-bg);
  display: flex; flex-direction: column;
  color: var(--text-primary);
}

/* Resize handle */
.win-resize {
  position: absolute; bottom: 0; right: 0;
  width: 16px; height: 16px; cursor: nw-resize;
  background: linear-gradient(135deg, transparent 50%, rgba(0,0,0,0.2) 50%);
}

/* ===== SCROLLBAR STYLES ===== */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 3px; }

/* ===== UTILITY ===== */
.hidden { display: none !important; }
button { font-family: var(--font); }


/* ===== SHUTDOWN OVERLAY ===== */
#shutdown-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: #000; color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 32px; opacity: 0;
  transition: opacity 1s;
  pointer-events: none;
}
#shutdown-overlay.show { opacity: 1; pointer-events: all; }

/* ===== APPS ===== */

/* --- Calculator --- */
.calc-wrap { padding: 12px; background: #1e1e2e; height: 100%; display: flex; flex-direction: column; gap: 8px; }
.calc-display {
  background: #2a2a3e; border-radius: 8px; padding: 10px 14px;
  text-align: right; color: #fff;
}
.calc-display .calc-expr { font-size: 13px; color: #888; min-height: 18px; }
.calc-display .calc-result { font-size: 32px; font-weight: 700; }
.calc-buttons { display: grid; grid-template-columns: repeat(4,1fr); gap: 6px; flex: 1; }
.calc-btn {
  border: none; border-radius: 8px; font-size: 18px; font-weight: 600;
  cursor: pointer; padding: 0; aspect-ratio: unset;
  transition: filter 0.1s, transform 0.1s;
}
.calc-btn:active { filter: brightness(0.85); transform: scale(0.95); }
.calc-btn.num { background: #3a3a5e; color: #fff; }
.calc-btn.op  { background: #5b8cff; color: #fff; }
.calc-btn.eq  { background: #ff7c5b; color: #fff; }
.calc-btn.clear { background: #ff5f57; color: #fff; }
.calc-btn.zero { grid-column: span 2; }
.calc-btn.fn { background: #44445e; color: #ccc; font-size: 14px; }

/* --- Notepad --- */
.notepad-wrap { display: flex; flex-direction: column; height: 100%; }
.notepad-toolbar {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 10px; background: var(--toolbar-bg); border-bottom: 1px solid var(--border-color);
  flex-wrap: wrap;
}
.notepad-toolbar button, .notepad-toolbar select, .notepad-toolbar input[type=color] {
  padding: 4px 10px; border-radius: 6px; border: 1px solid var(--border-color);
  background: var(--input-bg); cursor: pointer; font-size: 13px; color: var(--text-primary);
}
.notepad-toolbar input[type=color] { width: 32px; padding: 2px; }
.notepad-toolbar button:hover { background: var(--hover-bg); }
#notepad-area, .notepad-ta {
  flex: 1; border: none; outline: none; resize: none;
  padding: 14px; font-size: 15px; line-height: 1.6;
  font-family: 'Consolas', monospace; background: var(--win-body-bg); color: var(--text-primary);
}
.notepad-statusbar {
  padding: 4px 12px; background: var(--surface-bg); border-top: 1px solid var(--border-color);
  font-size: 12px; color: var(--text-muted);
}

/* --- File Manager --- */
.fm-wrap { display: flex; flex-direction: column; height: 100%; }
.fm-toolbar {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; background: var(--toolbar-bg); border-bottom: 1px solid var(--border-color);
}
.fm-toolbar button {
  padding: 5px 12px; border-radius: 6px; border: 1px solid var(--border-color);
  background: var(--input-bg); cursor: pointer; font-size: 13px; color: var(--text-primary);
}
.fm-toolbar button:hover { background: var(--hover-bg); }
.fm-path {
  flex: 1; padding: 5px 10px; border: 1px solid var(--border-color); border-radius: 6px;
  font-size: 13px; background: var(--input-bg); color: var(--text-primary);
}
.fm-body { flex: 1; display: flex; overflow: hidden; }
.fm-sidebar {
  width: 140px; background: var(--surface-bg); border-right: 1px solid var(--border-color);
  padding: 8px; display: flex; flex-direction: column; gap: 2px;
}
.fm-sidebar-item {
  padding: 7px 10px; border-radius: 6px; cursor: pointer;
  font-size: 13px; color: var(--text-primary); display: flex; align-items: center; gap: 6px;
}
.fm-sidebar-item:hover { background: var(--hover-bg); }
.fm-sidebar-item.active { background: var(--accent); color: #fff; }
.fm-files {
  flex: 1; padding: 12px; overflow-y: auto;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
  gap: 8px; align-content: start;
}
.fm-file {
  display: flex; flex-direction: column; align-items: center;
  padding: 10px 6px; border-radius: 8px; cursor: pointer;
  text-align: center; font-size: 12px; color: var(--text-primary);
  transition: background 0.15s;
}
.fm-file:hover { background: rgba(91,140,255,0.12); }
.fm-file.selected { background: rgba(91,140,255,0.25); }
.fm-file .file-icon { font-size: 32px; margin-bottom: 4px; }
.fm-file span { word-break: break-word; line-height: 1.3; }
.fm-statusbar {
  padding: 5px 12px; background: var(--surface-bg); border-top: 1px solid var(--border-color);
  font-size: 12px; color: var(--text-muted);
}

/* Context menu */
.context-menu {
  position: fixed; background: var(--context-bg); border: 1px solid var(--border-color);
  border-radius: 8px; box-shadow: 0 4px 16px rgba(0,0,0,0.15);
  z-index: 9000; min-width: 160px; overflow: hidden;
}
.context-menu-item {
  padding: 9px 16px; font-size: 13px; cursor: pointer;
  display: flex; align-items: center; gap: 8px; color: var(--text-primary);
}
.context-menu-item:hover { background: var(--hover-bg); }
.context-menu-sep { height: 1px; background: var(--border-light); margin: 2px 0; }

/* --- Paint --- */
.paint-wrap { display: flex; flex-direction: column; height: 100%; background: var(--hover-bg); }
.paint-toolbar {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  padding: 6px 10px; background: var(--toolbar-bg); border-bottom: 1px solid var(--border-color);
}
.paint-tool-btn {
  width: 34px; height: 34px; border: 2px solid transparent;
  border-radius: 6px; background: var(--input-bg); cursor: pointer;
  font-size: 16px; display: flex; align-items: center; justify-content: center;
  transition: all 0.15s; color: var(--text-primary);
}
.paint-tool-btn:hover { background: var(--hover-bg); }
.paint-tool-btn.active { border-color: var(--accent); background: var(--hover-bg); }
.paint-sep { width: 1px; height: 28px; background: var(--border-color); margin: 0 4px; }
.paint-color-btn {
  width: 26px; height: 26px; border-radius: 50%; border: 2px solid #fff;
  cursor: pointer; transition: transform 0.1s;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}
.paint-color-btn:hover { transform: scale(1.2); }
.paint-color-btn.active { border-color: #333; transform: scale(1.15); }
#paint-color-picker { width: 30px; height: 30px; border: none; padding: 0; cursor: pointer; border-radius: 50%; }
.paint-size-label { font-size: 12px; color: var(--text-secondary); }
#paint-size { width: 70px; }
.paint-canvas-wrap {
  flex: 1; overflow: auto; display: flex;
  align-items: flex-start; justify-content: flex-start;
  padding: 12px; background: var(--border-color);
}
#paint-canvas {
  background: #fff; cursor: crosshair;
  box-shadow: 0 2px 12px rgba(0,0,0,0.2);
  touch-action: none;
}
.paint-actions { display: flex; gap: 6px; }
.paint-action-btn {
  padding: 5px 12px; border-radius: 6px; border: 1px solid var(--border-color);
  background: var(--input-bg); cursor: pointer; font-size: 13px; color: var(--text-primary);
}
.paint-action-btn:hover { background: var(--hover-bg); }

/* --- Snake Game --- */
.snake-wrap { display: flex; flex-direction: column; align-items: center; height: 100%; padding: 16px; background: #1a1a2e; gap: 12px; overflow-y: auto; }
.snake-canvas-wrap { position: relative; }
.snake-score { color: #fff; font-size: 18px; font-weight: 700; }
.snake-score span { color: #5b8cff; }
#snake-canvas { border: 3px solid #5b8cff; border-radius: 6px; background: #0a0a1a; }
.snake-controls { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.snake-play-btn {
  padding: 8px 24px; background: #5b8cff; color: #fff;
  border: none; border-radius: 8px; cursor: pointer; font-size: 15px; font-weight: 600;
}
.snake-play-btn:hover { background: #7aa3ff; }
.snake-dpad {
  display: grid; grid-template-columns: 44px 44px 44px; grid-template-rows: 44px 44px 44px;
  gap: 3px; width: 140px; height: 140px;
  background: rgba(255,255,255,0.06);
  border-radius: 50%; place-items: center;
  border: 2px solid rgba(91,140,255,0.25);
}
.snake-dpad-btn {
  width: 40px; height: 40px; border: none; border-radius: 50%;
  background: rgba(91,140,255,0.15); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.1s, transform 0.1s; user-select: none; -webkit-user-select: none;
  position: relative;
}
.snake-dpad-btn::after {
  content: ''; display: block; width: 12px; height: 12px;
  border-right: 2.5px solid #8ab4ff; border-bottom: 2.5px solid #8ab4ff;
}
.snake-dpad-btn:hover { background: rgba(91,140,255,0.3); }
.snake-dpad-btn:active { background: rgba(91,140,255,0.5); transform: scale(0.88); }
.snake-dpad-up    { grid-column: 2; grid-row: 1; }
.snake-dpad-left  { grid-column: 1; grid-row: 2; }
.snake-dpad-right { grid-column: 3; grid-row: 2; }
.snake-dpad-down  { grid-column: 2; grid-row: 3; }
.snake-dpad-up::after    { transform: rotate(-135deg) translateY(-1px); }
.snake-dpad-right::after { transform: rotate(-45deg) translateX(-1px); }
.snake-dpad-down::after  { transform: rotate(45deg) translateY(1px); }
.snake-dpad-left::after  { transform: rotate(135deg) translateX(1px); }

/* --- Memory Game --- */
.memory-wrap { display: flex; flex-direction: column; align-items: center; height: 100%; padding: 16px; background: #1a1a2e; gap: 12px; }
.memory-info { display: flex; gap: 24px; }
.memory-info span { color: #fff; font-size: 16px; }
.memory-info span b { color: #5b8cff; }
#memory-grid {
  display: grid; grid-template-columns: repeat(4, 80px);
  gap: 10px; justify-content: center;
}
.mem-card {
  width: 80px; height: 80px; border-radius: 10px;
  background: #2a2a4e; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 36px; border: 2px solid #3a3a6e;
  transition: transform 0.3s, background 0.3s;
  transform-style: preserve-3d;
  perspective: 600px;
}
.mem-card.flipped { background: #3a3a6e; transform: rotateY(0deg); }
.mem-card.matched { background: rgba(40,202,65,0.25); border-color: #28ca41; }
.mem-card.hidden-face .card-face { display: none; }
.card-face { font-size: 36px; }
.memory-btn {
  padding: 8px 24px; background: #5b8cff; color: #fff;
  border: none; border-radius: 8px; cursor: pointer; font-size: 15px; font-weight: 600;
}
.memory-btn:hover { background: #7aa3ff; }
.memory-msg { color: #ffbd2e; font-size: 18px; font-weight: 700; min-height: 26px; }

/* --- Minesweeper --- */
.ms-dbtn {
  padding: 5px 14px; border-radius: 20px; border: 2px solid var(--border-color);
  background: var(--input-bg); cursor: pointer; font-size: 13px; font-weight: 600;
  color: var(--text-secondary); transition: all 0.15s; font-family: var(--font);
}
.ms-dbtn:hover { background: var(--hover-bg); border-color: var(--accent); }
.ms-dbtn.active { background: var(--accent); color: #fff; border-color: var(--accent); }

.ms-wrap {
  display: flex; flex-direction: column; align-items: center;
  height: 100%; padding: 12px 10px; background: var(--win-bg); gap: 8px; overflow-y: auto;
}
.ms-topbar {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; background: #d4d0c8; border: 2px solid;
  border-color: #fff #808080 #808080 #fff;
  padding: 6px 12px; border-radius: 4px;
}
.ms-counter {
  font-size: 20px; font-weight: 700; color: #cc0000;
  background: #000; padding: 4px 10px; border-radius: 4px;
  font-family: 'Courier New', monospace; min-width: 70px; text-align: center;
}
.ms-face-btn {
  font-size: 28px; background: #d4d0c8; border: 2px solid;
  border-color: #fff #808080 #808080 #fff;
  width: 44px; height: 44px; cursor: pointer; border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  transition: border-color 0.1s;
}
.ms-face-btn:active { border-color: #808080 #fff #fff #808080; }

.ms-difficulty { display: flex; gap: 6px; }
.ms-diff-btn {
  padding: 5px 14px; border-radius: 20px; border: 2px solid var(--border-color);
  background: var(--input-bg); cursor: pointer; font-size: 13px; font-weight: 600;
  color: var(--text-secondary); transition: all 0.15s;
}
.ms-diff-btn:hover { background: var(--hover-bg); border-color: var(--accent); }
.ms-diff-btn.active { background: var(--accent); color: #fff; border-color: var(--accent); }

.ms-flagrow { display: flex; align-items: center; gap: 10px; }
.ms-flag-toggle {
  padding: 6px 16px; border-radius: 20px; border: none;
  background: var(--accent); color: #fff; cursor: pointer;
  font-size: 13px; font-weight: 600; transition: background 0.15s;
}
.ms-flag-hint { font-size: 11px; color: var(--text-muted); }

.ms-grid-wrap { overflow: auto; max-width: 100%; }
.ms-grid {
  display: grid; gap: 2px;
  background: #bdbdbd; padding: 3px;
  border: 3px solid; border-color: #808080 #fff #fff #808080;
  border-radius: 2px;
}

/* Cells */
.ms-cell {
  display: flex; align-items: center; justify-content: center;
  border-radius: 2px; cursor: pointer; font-family: var(--font);
  transition: filter 0.05s; user-select: none;
}
.ms-cell.hidden {
  background: #d4d0c8;
  border: 2px solid; border-color: #fff #808080 #808080 #fff;
}
.ms-cell.hidden:hover { filter: brightness(1.08); }
.ms-cell.hidden:active { border-color: #808080 #fff #fff #808080; filter: brightness(0.95); }
.ms-cell.revealed {
  background: #bdbdbd; border: 1px solid #9e9e9e;
}
.ms-cell.flagged {
  background: #d4d0c8; border: 2px solid; border-color: #fff #808080 #808080 #fff;
}
.ms-cell.mine { background: #bdbdbd; }
.ms-cell.death { background: #ff4444; }

.ms-message {
  font-size: 16px; font-weight: 700; color: var(--text-primary);
  min-height: 24px; text-align: center;
}

/* --- eJob --- */
.ej-wrap { display: flex; flex-direction: column; height: 100%; overflow: hidden; }

/* Stats bar */
.ej-stats {
  display: flex; align-items: center; gap: 12px;
  padding: 8px 14px; background: var(--toolbar-bg); border-bottom: 1px solid var(--border-color);
  flex-shrink: 0; flex-wrap: wrap;
}
.ej-score { font-size: 16px; font-weight: 700; color: var(--text-primary); }
.ej-combo { font-size: 14px; font-weight: 700; color: #ff6b35; animation: ej-pulse 0.6s infinite; }
@keyframes ej-pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.1)} }
.ej-rank { font-size: 13px; color: var(--text-secondary); margin-left: auto; }
.ej-timer { font-size: 15px; font-weight: 700; color: var(--text-primary); }
.ej-timer-low { color: #e53935; animation: ej-pulse 0.5s infinite; }

/* Body: sidebar + view */
.ej-body { display: flex; flex: 1; overflow: hidden; }

/* Inbox sidebar */
.ej-inbox {
  width: 140px; min-width: 140px; background: #1e1e2e;
  display: flex; flex-direction: column; border-right: 1px solid rgba(255,255,255,0.08);
}
.ej-inbox-title {
  padding: 10px 12px; color: #fff; font-size: 12px; font-weight: 700;
  letter-spacing: 1px; background: rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.ej-inbox-list { flex: 1; overflow-y: auto; padding: 4px 0; }
.ej-inbox-item {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 10px; font-size: 12px; color: #ccc;
}
.ej-inbox-item.ej-current { background: rgba(91,140,255,0.2); color: #fff; }
.ej-inbox-item.ej-done { opacity: 0.5; }
.ej-inbox-status { width: 16px; text-align: center; font-size: 11px; }
.ej-inbox-emoji { font-size: 14px; }
.ej-inbox-name { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Email view */
.ej-view {
  flex: 1; display: flex; flex-direction: column;
  padding: 14px; gap: 10px; overflow-y: auto;
  position: relative; background: var(--win-body-bg);
}
.ej-email-header { display: flex; align-items: center; gap: 10px; }
.ej-sender-emoji { font-size: 28px; }
.ej-sender-name { font-size: 15px; font-weight: 700; color: var(--text-primary); }
.ej-subject { font-size: 12px; color: var(--text-muted); }
.ej-email-body {
  background: var(--surface-bg); border: 1px solid var(--border-light);
  border-radius: 8px; padding: 10px 14px; font-size: 13px;
  color: var(--text-secondary); line-height: 1.5; font-style: italic;
}

/* Reply section */
.ej-reply-section { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.ej-reply-label { font-size: 11px; color: var(--text-muted); text-align: center; letter-spacing: 1px; }
.ej-reply-text {
  background: var(--input-bg); border: 1px solid var(--border-color);
  border-radius: 8px; padding: 10px 14px; font-size: 13px;
  color: var(--text-primary); line-height: 1.5; min-height: 48px;
  font-family: 'Consolas', 'Courier New', monospace;
}
.ej-cursor { animation: ej-blink 0.6s infinite; color: var(--accent); font-weight: 700; }
@keyframes ej-blink { 0%,100%{opacity:1} 50%{opacity:0} }

/* Progress bar */
.ej-progress-wrap {
  height: 8px; background: var(--hover-bg); border-radius: 4px; overflow: hidden;
}
.ej-progress-bar {
  height: 100%; background: var(--accent); border-radius: 4px;
  transition: width 0.1s;
}
.ej-progress-pct { font-size: 11px; color: var(--text-muted); text-align: right; }

/* Persistent animation overlay (lives on window element, survives render cycles) */
.ej-overlay {
  position: absolute;
  top: var(--win-header-h); left: 0; right: 0; bottom: 0;
  pointer-events: none; z-index: 5; overflow: hidden;
}

/* Sent flash */
.ej-sent-flash {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(0);
  font-size: 36px; font-weight: 800; color: #4caf50;
  pointer-events: none; opacity: 0; text-align: center;
  text-shadow: 0 2px 12px rgba(76,175,80,0.5);
  line-height: 1.3; white-space: nowrap;
}
.ej-flash-anim {
  animation: ej-flash 1.8s cubic-bezier(0.17, 0.67, 0.3, 1.2);
}
@keyframes ej-flash {
  0% { opacity: 1; transform: translate(-50%, -50%) scale(0.3) rotate(-5deg); }
  15% { opacity: 1; transform: translate(-50%, -50%) scale(1.6) rotate(2deg); }
  30% { opacity: 1; transform: translate(-50%, -50%) scale(1.4) rotate(-1deg); }
  60% { opacity: 1; transform: translate(-50%, -52%) scale(1.45) rotate(0deg); }
  80% { opacity: 0.7; transform: translate(-50%, -58%) scale(1.5) rotate(0deg); }
  100% { opacity: 0; transform: translate(-50%, -68%) scale(1.6); }
}

/* Combo popup */
.ej-combo-pop {
  position: absolute; top: 35%; left: 50%; transform: translate(-50%, -50%) scale(0);
  font-size: 32px; font-weight: 800; color: #ff6b35;
  pointer-events: none; opacity: 0; text-align: center;
  text-shadow: 0 2px 16px rgba(255,107,53,0.5);
  line-height: 1.3; white-space: nowrap;
}
.ej-pop-anim {
  animation: ej-pop 2s cubic-bezier(0.17, 0.67, 0.3, 1.2);
}
@keyframes ej-pop {
  0% { opacity: 1; transform: translate(-50%, -50%) scale(0.3) rotate(5deg); }
  12% { opacity: 1; transform: translate(-50%, -50%) scale(1.8) rotate(-3deg); }
  25% { opacity: 1; transform: translate(-50%, -55%) scale(1.5) rotate(1deg); }
  55% { opacity: 1; transform: translate(-50%, -60%) scale(1.55) rotate(0deg); }
  80% { opacity: 0.6; transform: translate(-50%, -75%) scale(1.5) rotate(0deg); }
  100% { opacity: 0; transform: translate(-50%, -90%) scale(1.2); }
}

/* Zero score special win */
.ej-zero-win { font-size: 48px; margin-bottom: 8px; animation: ej-zero-bounce 1s infinite; }
@keyframes ej-zero-bounce { 0%,100%{transform:scale(1) rotate(0deg)} 25%{transform:scale(1.15) rotate(-5deg)} 50%{transform:scale(1) rotate(0deg)} 75%{transform:scale(1.15) rotate(5deg)} }
.ej-zero-title {
  font-size: 22px; font-weight: 800; color: #ff6b35;
  text-shadow: 0 2px 8px rgba(255,107,53,0.4);
  animation: ej-zero-glow 1.5s infinite alternate;
}
@keyframes ej-zero-glow { 0%{text-shadow:0 2px 8px rgba(255,107,53,0.4)} 100%{text-shadow:0 2px 20px rgba(255,107,53,0.8)} }

/* Tap zone */
.ej-tap-zone {
  padding: 12px; text-align: center; font-size: 14px; font-weight: 600;
  color: var(--text-muted); background: var(--surface-bg);
  border-top: 1px solid var(--border-color); cursor: pointer;
  flex-shrink: 0; user-select: none; -webkit-user-select: none;
  transition: background 0.15s;
}
.ej-tap-zone:active { background: var(--hover-bg); }

/* Idle screen */
.ej-idle {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; flex: 1; padding: 24px; text-align: center; gap: 8px;
}
.ej-idle-icon { font-size: 56px; }
.ej-idle-title { font-size: 32px; font-weight: 800; color: var(--text-primary); }
.ej-idle-subtitle { font-size: 14px; color: var(--text-muted); margin-bottom: 8px; }
.ej-idle-desc { font-size: 13px; color: var(--text-secondary); max-width: 360px; line-height: 1.5; }
.ej-idle-rules {
  display: flex; flex-direction: column; gap: 4px;
  font-size: 13px; color: var(--text-secondary); margin: 12px 0;
}
.ej-start-btn {
  padding: 12px 32px; background: var(--accent); color: #fff;
  border: none; border-radius: 10px; cursor: pointer;
  font-size: 16px; font-weight: 700; font-family: var(--font);
  transition: filter 0.15s;
}
.ej-start-btn:hover { filter: brightness(1.15); }
.ej-hi-score { font-size: 14px; color: var(--text-muted); margin-top: 8px; }

/* Game over screen */
.ej-gameover {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; flex: 1; padding: 24px; text-align: center; gap: 8px;
}
.ej-go-rank { font-size: 24px; font-weight: 700; color: var(--text-primary); }
.ej-go-title { font-size: 28px; font-weight: 800; color: var(--text-primary); margin-bottom: 12px; }
.ej-go-stats { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-bottom: 16px; }
.ej-go-stat {
  background: var(--surface-bg); border: 1px solid var(--border-light);
  border-radius: 10px; padding: 12px 18px; min-width: 110px;
  display: flex; flex-direction: column; gap: 4px;
}
.ej-go-stat span { font-size: 12px; color: var(--text-muted); }
.ej-go-stat strong { font-size: 20px; color: var(--text-primary); }

/* --- Soundboard --- */
.sb-wrap {
  height: 100%; padding: 16px; background: #1a1a2e;
  display: flex; align-items: center; justify-content: center;
}
.sb-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 10px; width: 100%; max-width: 380px;
}
.sb-btn {
  aspect-ratio: 1; border: none; border-radius: 14px;
  cursor: pointer; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 4px;
  transition: transform 0.1s, filter 0.1s;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}
.sb-btn:hover { filter: brightness(1.15); transform: scale(1.05); }
.sb-btn:active, .sb-btn.sb-pressed { transform: scale(0.9); filter: brightness(1.4); }
.sb-emoji { font-size: 32px; line-height: 1; }
.sb-label { font-size: 11px; font-weight: 700; color: #fff; text-shadow: 0 1px 2px rgba(0,0,0,0.4); }

/* --- Kidflix --- */
.kf-wrap { display:flex; flex-direction:column; height:100%; background:#141414; overflow:hidden; }

.kf-header {
  display:flex; align-items:center; gap:12px; padding:10px 16px;
  background:#141414; border-bottom:1px solid #2a2a2a; flex-shrink:0;
}
.kf-logo {
  font-size:20px; font-weight:900; letter-spacing:2px;
  background:linear-gradient(180deg,#e50914,#b20710); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  text-shadow:none;
}
.kf-search {
  flex:1; max-width:220px; padding:6px 12px; border-radius:4px;
  border:1px solid #444; background:#2a2a2a; color:#fff;
  font-size:13px; outline:none; font-family:var(--font);
}
.kf-search::placeholder { color:#888; }
.kf-search:focus { border-color:#e50914; }

.kf-tabs {
  display:flex; gap:4px; padding:8px 16px; background:#141414; flex-shrink:0;
  overflow-x:auto; scrollbar-width:none;
}
.kf-tabs::-webkit-scrollbar { display:none; }
.kf-tab {
  padding:5px 14px; border-radius:16px; border:1px solid #444;
  background:transparent; color:#aaa; font-size:12px; font-weight:600;
  cursor:pointer; white-space:nowrap; font-family:var(--font);
  transition:all 0.15s;
}
.kf-tab:hover { border-color:#888; color:#fff; }
.kf-tab-active { background:#e50914; border-color:#e50914; color:#fff; }

.kf-content { flex:1; overflow-y:auto; padding:12px 16px; }

.kf-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:16px;
}

.kf-empty { color:#888; text-align:center; padding:40px; font-size:15px; grid-column:1/-1; }

.kf-card { cursor:pointer; transition:transform 0.15s; }
.kf-card:hover { transform:scale(1.04); }

.kf-poster {
  position:relative; border-radius:8px; overflow:hidden;
  box-shadow:0 4px 12px rgba(0,0,0,0.4);
}
.kf-poster-canvas { width:100%; height:auto; display:block; }
.kf-play-overlay {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,0); font-size:36px; color:#fff; opacity:0;
  transition:all 0.2s; pointer-events:none;
}
.kf-card:hover .kf-play-overlay { opacity:1; background:rgba(0,0,0,0.35); }

.kf-card-info { padding:8px 2px 0; }
.kf-card-title { color:#fff; font-size:13px; font-weight:600; line-height:1.3; }
.kf-card-meta { display:flex; gap:8px; margin-top:3px; }
.kf-card-genre { font-size:11px; color:#e50914; font-weight:600; }
.kf-card-year { font-size:11px; color:#888; }

/* Player view */
.kf-player { display:flex; flex-direction:column; gap:12px; }

.kf-back-btn {
  align-self:flex-start; padding:6px 14px; border-radius:6px;
  border:1px solid #444; background:#2a2a2a; color:#ccc;
  font-size:13px; cursor:pointer; font-family:var(--font);
  transition:all 0.15s;
}
.kf-back-btn:hover { background:#444; color:#fff; }

.kf-video-wrap { border-radius:8px; overflow:hidden; background:#000; }
.kf-video { width:100%; display:block; max-height:300px; background:#000; }

.kf-movie-info { padding:4px 0 16px; }
.kf-movie-header { display:flex; align-items:flex-start; gap:12px; }
.kf-movie-emoji { font-size:40px; line-height:1; flex-shrink:0; }
.kf-movie-titles { flex:1; }
.kf-movie-title { color:#fff; font-size:20px; font-weight:700; margin:0 0 6px; }
.kf-movie-meta { display:flex; align-items:center; gap:10px; flex-wrap:wrap; color:#aaa; font-size:13px; }
.kf-badge {
  padding:2px 10px; border-radius:4px; font-size:11px; font-weight:700;
  background:#e50914; color:#fff;
}
.kf-rating { color:#fdd835; font-weight:700; }

.kf-like-btn {
  font-size:24px; background:none; border:none; cursor:pointer;
  padding:4px; transition:transform 0.15s; flex-shrink:0;
}
.kf-like-btn:hover { transform:scale(1.2); }

.kf-movie-desc { color:#ccc; font-size:14px; line-height:1.6; margin:12px 0 8px; }
.kf-movie-parody { color:#666; font-size:12px; font-style:italic; }

/* --- Kidstagram --- */
.kg-wrap { display:flex; flex-direction:column; height:100%; background:var(--surface-bg); overflow:hidden; }

.kg-nav {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 16px; background:var(--win-body-bg); border-bottom:1px solid var(--border-light); flex-shrink:0;
}
.kg-nav-logo { font-size:17px; font-weight:800; background:linear-gradient(90deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.kg-nav-count { font-size:14px; font-weight:700; color:#e91e8c; }

/* Stories */
.kg-stories {
  display:flex; gap:12px; padding:12px 14px; overflow-x:auto;
  background:var(--win-body-bg); border-bottom:1px solid var(--border-light); flex-shrink:0;
}
.kg-stories::-webkit-scrollbar { height:0; }
.kg-story { display:flex; flex-direction:column; align-items:center; gap:4px; cursor:pointer; }
.kg-story-ring {
  padding:2px; border-radius:50%;
  background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
}
.kg-story-av {
  width:48px; height:48px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:24px; border:2px solid var(--win-body-bg);
}
.kg-story-name { font-size:10px; color:var(--text-secondary); white-space:nowrap; max-width:58px; overflow:hidden; text-overflow:ellipsis; text-align:center; }

/* Feed */
.kg-feed { flex:1; overflow-y:auto; }

.kg-post { background:var(--win-body-bg); border-bottom:8px solid var(--toolbar-bg); }

.kg-post-header {
  display:flex; align-items:center; gap:10px; padding:10px 12px;
}
.kg-post-av {
  width:36px; height:36px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:20px;
}
.kg-post-info { flex:1; }
.kg-post-username { font-size:13px; font-weight:700; color:var(--text-primary); }
.kg-post-time { font-size:11px; color:var(--text-muted); }
.kg-post-type-badge {
  font-size:10px; font-weight:700; padding:3px 8px; border-radius:10px; white-space:nowrap;
}
.kg-type-drawing { background:#fce4ec; color:#c2185b; }
.kg-type-pet     { background:#f3e5f5; color:#7b1fa2; }
.kg-type-game    { background:#e3f2fd; color:#1565c0; }
.kg-type-outdoor { background:#e8f5e9; color:#2e7d32; }

.kg-img-wrap { width:100%; line-height:0; }
.kg-canvas   { width:100%; display:block; }

.kg-actions {
  display:flex; align-items:center; gap:8px; padding:8px 12px 4px;
}
.kg-like-btn {
  display:flex; align-items:center; gap:5px; padding:6px 12px;
  border:none; background:var(--win-body-bg); cursor:pointer; font-size:15px;
  border-radius:20px; font-weight:700; color:var(--text-secondary);
  transition:transform 0.15s, background 0.15s;
}
.kg-like-btn:hover   { background:var(--hover-bg); }
.kg-like-btn.liked   { color:#e91e8c; }
.kg-comment-toggle {
  padding:6px 12px; border:none; background:var(--win-body-bg); cursor:pointer;
  font-size:14px; border-radius:20px; font-weight:700; color:var(--text-secondary);
  transition:background 0.15s;
}
.kg-comment-toggle:hover { background:var(--hover-bg); }

.kg-caption {
  padding:2px 12px 8px; font-size:13px; color:var(--text-primary); line-height:1.5;
}
.kg-tags { display:block; font-size:12px; color:#3897f0; margin-top:2px; }

/* Comments section */
.kg-comments { padding:0 12px 10px; border-top:1px solid var(--border-light); }
.kg-comments-list { display:flex; flex-direction:column; gap:6px; padding:8px 0; max-height:120px; overflow-y:auto; }
.kg-comment {
  display:flex; align-items:flex-start; gap:8px; font-size:13px; color:var(--text-primary); line-height:1.4;
}
.kg-comment-av { font-size:16px; flex-shrink:0; }
.kg-comment.kg-comment-new { animation:kg-fadein 0.3s; }
@keyframes kg-fadein { from{opacity:0;transform:translateY(4px)} to{opacity:1;transform:none} }
.kg-comment-input-row {
  display:flex; gap:6px; padding-top:8px; border-top:1px solid var(--border-light);
}
.kg-comment-input {
  flex:1; padding:7px 12px; border:1px solid var(--border-color); border-radius:20px;
  font-size:12px; outline:none; font-family:var(--font); background:var(--input-bg); color:var(--text-primary);
}
.kg-comment-input:focus { border-color:#3897f0; }
.kg-comment-send {
  padding:7px 14px; background:#3897f0; color:#fff; border:none;
  border-radius:20px; cursor:pointer; font-size:12px; font-weight:600;
}
.kg-comment-send:hover { background:#1565c0; }

/* --- KidsChat --- */
.kc-wrap { display: flex; height: 100%; overflow: hidden; }

/* Sidebar */
.kc-sidebar {
  width: 180px; min-width: 180px; background: #1e1e2e;
  display: flex; flex-direction: column; border-right: 1px solid rgba(255,255,255,0.08);
}
.kc-sidebar-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; background: rgba(255,255,255,0.06);
  color: #fff; font-size: 14px; font-weight: 700; border-bottom: 1px solid rgba(255,255,255,0.08);
}
.kc-add-btn {
  width: 26px; height: 26px; border-radius: 50%; border: none;
  background: #5b8cff; color: #fff; font-size: 18px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; line-height: 1;
}
.kc-add-btn:hover { background: #7aa3ff; }
.kc-contact-list { flex: 1; overflow-y: auto; padding: 6px 0; }
.kc-contact {
  display: flex; align-items: center; gap: 10px; padding: 10px 12px;
  cursor: pointer; transition: background 0.15s; border-radius: 0;
}
.kc-contact:hover { background: rgba(255,255,255,0.07); }
.kc-contact.active { background: rgba(91,140,255,0.25); }
.kc-contact-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; flex-shrink: 0;
}
.kc-contact-body { flex: 1; overflow: hidden; }
.kc-contact-name { color: #fff; font-size: 13px; font-weight: 600; }
.kc-contact-preview { color: #888; font-size: 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Main area */
.kc-main { flex: 1; display: flex; flex-direction: column; background: var(--surface-bg); overflow: hidden; }
.kc-empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; }

/* Chat panel */
.kc-chat-panel { display: flex; flex-direction: column; flex: 1; }
.kc-chat-header {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  background: var(--win-body-bg); border-bottom: 1px solid var(--border-color); flex-shrink: 0;
}
.kc-chat-header-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0;
}
.kc-chat-header-info { flex: 1; }
.kc-chat-header-name { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.kc-chat-header-status { font-size: 11px; color: #4caf50; }
.kc-edit-replies-btn {
  padding: 5px 12px; border-radius: 16px; border: 1px solid var(--border-color);
  background: var(--toolbar-bg); cursor: pointer; font-size: 12px; font-weight: 600;
  color: var(--text-secondary); transition: all 0.15s; white-space: nowrap;
}
.kc-edit-replies-btn:hover { background: var(--hover-bg); border-color: var(--accent); color: var(--accent); }

/* Messages */
.kc-messages { flex: 1; overflow-y: auto; padding: 14px 12px; display: flex; flex-direction: column; gap: 10px; }
.kc-no-messages { text-align: center; color: #aaa; font-size: 14px; margin: auto; }

.kc-msg-row { display: flex; align-items: flex-end; gap: 8px; }
.kc-msg-row.me { flex-direction: row-reverse; }
.kc-bubble-avatar {
  width: 28px; height: 28px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; flex-shrink: 0; margin-bottom: 16px;
}
.kc-bubble {
  max-width: 240px; padding: 9px 13px; border-radius: 18px;
  font-size: 13px; line-height: 1.5; word-break: break-word;
}
.kc-bubble.me {
  background: #5b8cff; color: #fff;
  border-bottom-right-radius: 4px;
}
.kc-bubble.them {
  background: var(--win-body-bg); color: var(--text-primary);
  border: 1px solid var(--border-light);
  border-bottom-left-radius: 4px;
}
.kc-msg-time { font-size: 10px; color: #bbb; margin-top: 3px; padding: 0 4px; }

/* Typing indicator */
.kc-typing {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 14px; font-size: 12px; color: #888; flex-shrink: 0;
}
.kc-dots span {
  display: inline-block; animation: kc-bounce 1.2s infinite;
  font-size: 16px; line-height: 1;
}
.kc-dots span:nth-child(2) { animation-delay: 0.2s; }
.kc-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes kc-bounce { 0%,60%,100%{transform:translateY(0)} 30%{transform:translateY(-4px)} }

/* Input bar */
.kc-input-bar {
  display: flex; gap: 8px; padding: 10px 12px;
  background: var(--win-body-bg); border-top: 1px solid var(--border-color); flex-shrink: 0;
}
.kc-input {
  flex: 1; padding: 9px 14px; border: 1px solid var(--border-color); border-radius: 20px;
  font-size: 13px; outline: none; font-family: var(--font);
  transition: border-color 0.15s;
  background: var(--input-bg); color: var(--text-primary);
}
.kc-input:focus { border-color: var(--accent); }
.kc-send-btn {
  padding: 9px 18px; background: var(--accent); color: #fff;
  border: none; border-radius: 20px; cursor: pointer;
  font-size: 13px; font-weight: 600; white-space: nowrap;
  transition: filter 0.15s;
}
.kc-send-btn:hover { filter: brightness(1.15); }

/* Edit Replies panel */
.kc-edit-panel { display: flex; flex-direction: column; flex: 1; background: var(--surface-bg); }
.kc-edit-header {
  display: flex; align-items: center; gap: 12px; padding: 12px 14px;
  background: var(--win-body-bg); border-bottom: 1px solid var(--border-light); flex-shrink: 0;
}
.kc-back-btn {
  padding: 5px 12px; border-radius: 16px; border: 1px solid var(--border-color);
  background: var(--toolbar-bg); cursor: pointer; font-size: 12px; font-weight: 600;
  color: var(--text-secondary); transition: all 0.15s;
}
.kc-back-btn:hover { background: var(--hover-bg); }
.kc-edit-header span { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.kc-edit-hint { padding: 10px 16px; font-size: 12px; color: var(--text-muted); background: var(--surface-bg); border-bottom: 1px solid var(--border-light); }
.kc-edit-list { flex: 1; overflow-y: auto; padding: 8px; display: flex; flex-direction: column; gap: 6px; }
.kc-edit-reply-row {
  display: flex; align-items: center; gap: 10px; padding: 9px 12px;
  background: var(--win-body-bg); border: 1px solid var(--border-light); border-radius: 10px;
}
.kc-edit-reply-avatar { font-size: 18px; flex-shrink: 0; }
.kc-edit-reply-text { flex: 1; font-size: 13px; color: var(--text-primary); }
.kc-edit-del-btn {
  width: 22px; height: 22px; border-radius: 50%; border: none;
  background: #ffebee; color: #f44336; cursor: pointer; font-size: 12px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.kc-edit-del-btn:hover { background: #f44336; color: #fff; }
.kc-edit-add-row {
  display: flex; gap: 8px; padding: 10px 12px;
  background: var(--win-body-bg); border-top: 1px solid var(--border-light); flex-shrink: 0;
}
.kc-edit-input {
  flex: 1; padding: 8px 14px; border: 1px solid var(--border-color); border-radius: 20px;
  font-size: 13px; outline: none; font-family: var(--font);
  background: var(--input-bg); color: var(--text-primary);
}
.kc-edit-input:focus { border-color: var(--accent); }
.kc-edit-add-btn {
  padding: 8px 16px; background: var(--accent); color: #fff;
  border: none; border-radius: 20px; cursor: pointer;
  font-size: 13px; font-weight: 600; white-space: nowrap;
}
.kc-edit-add-btn:hover { filter: brightness(1.15); }

/* Gallery picker */
.kc-gallery {
  display: flex; flex-direction: column; border-top: 1px solid var(--border-color);
  background: var(--win-body-bg); max-height: 220px; flex-shrink: 0;
}
.kc-gallery-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px; font-size: 13px; font-weight: 700; color: var(--text-primary);
  border-bottom: 1px solid var(--border-light);
}
.kc-gallery-close {
  width: 22px; height: 22px; border-radius: 50%; border: none;
  background: var(--toolbar-bg); cursor: pointer; font-size: 12px; color: var(--text-muted);
  display: flex; align-items: center; justify-content: center;
}
.kc-gallery-close:hover { background: var(--hover-bg); color: var(--text-primary); }
.kc-gallery-grid {
  display: flex; gap: 10px; padding: 10px 12px; overflow-x: auto; flex: 1;
}
.kc-gallery-item {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  cursor: pointer; flex-shrink: 0; border-radius: 10px; padding: 6px;
  transition: background 0.15s;
}
.kc-gallery-item:hover { background: var(--hover-bg); }
.kc-gallery-item span { font-size: 11px; color: var(--text-secondary); white-space: nowrap; }
.kc-gallery-canvas { border-radius: 8px; border: 1px solid var(--border-light); }
.kc-photo-btn {
  width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--border-color);
  background: var(--toolbar-bg); cursor: pointer; font-size: 16px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.15s;
}
.kc-photo-btn:hover { background: var(--hover-bg); border-color: var(--accent); }

/* Image bubbles */
.kc-bubble-img {
  border-radius: 14px; overflow: hidden; max-width: 200px;
}
.kc-bubble-img.me { border-bottom-right-radius: 4px; }
.kc-bubble-img.them { border-bottom-left-radius: 4px; border: 1px solid #e8e8e8; }
.kc-bubble-img canvas { display: block; width: 180px; height: 130px; }
.kc-img-label {
  padding: 4px 10px 6px; font-size: 11px; color: var(--text-secondary); background: var(--surface-bg);
}
.kc-bubble-img.me .kc-img-label { background: #4a7de6; color: #fff; }

/* Contact dialog */
.kc-dialog-overlay {
  position: absolute; inset: 0; z-index: 10;
  background: rgba(0,0,0,0.4);
  display: flex; align-items: center; justify-content: center;
}
.kc-dialog {
  background: var(--context-bg); border-radius: 14px; padding: 20px 24px;
  width: 320px; max-height: 90%; overflow-y: auto;
  box-shadow: 0 8px 32px rgba(0,0,0,0.25);
}
.kc-dialog h3 { font-size: 17px; font-weight: 700; color: var(--text-primary); margin-bottom: 16px; }
.kc-dialog-field { margin-bottom: 14px; }
.kc-dialog-field label { display: block; font-size: 12px; font-weight: 600; color: var(--text-secondary); margin-bottom: 6px; }
.kc-dialog-field input {
  width: 100%; padding: 8px 12px; border: 1px solid var(--border-color); border-radius: 8px;
  font-size: 14px; outline: none; font-family: var(--font);
  background: var(--input-bg); color: var(--text-primary);
}
.kc-dialog-field input:focus { border-color: var(--accent); }
.kc-avatar-grid {
  display: grid; grid-template-columns: repeat(8, 1fr); gap: 4px;
}
.kc-avatar-opt {
  width: 34px; height: 34px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; cursor: pointer; border: 2px solid transparent;
  transition: all 0.15s; background: var(--toolbar-bg);
}
.kc-avatar-opt:hover { background: var(--hover-bg); }
.kc-avatar-opt.selected { border-color: var(--accent); background: var(--hover-bg); }
.kc-color-grid {
  display: flex; gap: 6px; flex-wrap: wrap;
}
.kc-color-opt {
  width: 28px; height: 28px; border-radius: 50%; cursor: pointer;
  border: 3px solid transparent; transition: all 0.15s;
}
.kc-color-opt:hover { transform: scale(1.15); }
.kc-color-opt.selected { border-color: #222; transform: scale(1.15); }
.kc-dialog-btns {
  display: flex; gap: 8px; justify-content: flex-end; margin-top: 18px;
}
.kc-dialog-cancel {
  padding: 8px 18px; border-radius: 8px; border: 1px solid var(--border-color);
  background: var(--toolbar-bg); cursor: pointer; font-size: 13px; font-weight: 600; color: var(--text-secondary);
}
.kc-dialog-cancel:hover { background: var(--hover-bg); }
.kc-dialog-save {
  padding: 8px 18px; border-radius: 8px; border: none;
  background: var(--accent); color: #fff; cursor: pointer; font-size: 13px; font-weight: 600;
}
.kc-dialog-save:hover { filter: brightness(1.15); }

/* --- Settings --- */
.settings-wrap { display: flex; height: 100%; }
.settings-sidebar {
  width: 160px; background: var(--toolbar-bg); border-right: 1px solid var(--border-color);
  padding: 10px; display: flex; flex-direction: column; gap: 2px;
}
.settings-sidebar-item {
  padding: 9px 12px; border-radius: 8px; cursor: pointer;
  font-size: 14px; color: var(--text-primary); display: flex; align-items: center; gap: 8px;
  transition: background 0.15s;
}
.settings-sidebar-item:hover { background: var(--hover-bg); }
.settings-sidebar-item.active { background: var(--accent); color: #fff; }
.settings-panel { flex: 1; padding: 20px; overflow-y: auto; display: none; background: var(--win-body-bg); }
.settings-panel.active { display: block; }
.settings-panel h2 { font-size: 20px; font-weight: 700; margin-bottom: 16px; color: var(--text-primary); }
.settings-group { margin-bottom: 20px; }
.settings-group label {
  display: block; font-size: 14px; color: var(--text-secondary); margin-bottom: 6px; font-weight: 600;
}
.settings-group input[type=text], .settings-group input[type=time],
.settings-group input[type=date], .settings-group select {
  width: 100%; padding: 8px 12px; border: 1px solid var(--border-color); border-radius: 8px;
  font-size: 14px; outline: none; transition: border-color 0.15s;
  background: var(--input-bg); color: var(--text-primary);
}
.settings-group input:focus, .settings-group select:focus { border-color: var(--accent); }
.settings-btn {
  padding: 9px 20px; background: var(--accent); color: #fff;
  border: none; border-radius: 8px; cursor: pointer; font-size: 14px; font-weight: 600;
  transition: filter 0.15s;
}
.settings-btn:hover { filter: brightness(1.15); }
.wallpaper-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-bottom: 12px;
}
.wp-option {
  aspect-ratio: 16/9; border-radius: 8px; cursor: pointer;
  border: 3px solid transparent; transition: border-color 0.15s;
  background-size: cover; background-position: center;
}
.wp-option.selected { border-color: var(--accent); }

/* Theme options */
.theme-options {
  display: flex; gap: 8px;
}
.theme-option {
  flex: 1; padding: 12px; border-radius: 8px; cursor: pointer;
  border: 2px solid var(--border-color); background: var(--input-bg);
  text-align: center; font-size: 14px; font-weight: 600;
  color: var(--text-primary); transition: all 0.15s;
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.theme-option:hover { border-color: var(--accent); }
.theme-option.active { border-color: var(--accent); background: var(--hover-bg); }

/* Accent color options */
.accent-options {
  display: flex; gap: 10px; flex-wrap: wrap;
}
.accent-option {
  width: 36px; height: 36px; border-radius: 50%; cursor: pointer;
  border: 3px solid transparent; transition: all 0.15s;
  box-shadow: 0 2px 6px rgba(0,0,0,0.2);
}
.accent-option:hover { transform: scale(1.15); }
.accent-option.active { border-color: var(--text-primary); transform: scale(1.15); }

/* Storage panel */
.storage-usage-list { display: flex; flex-direction: column; gap: 8px; }
.storage-row { display: flex; align-items: center; gap: 8px; }
.storage-label { font-size: 13px; width: 130px; flex-shrink: 0; }
.storage-bar-wrap {
  flex: 1; height: 10px; background: var(--hover-bg); border-radius: 5px; overflow: hidden;
}
.storage-bar { height: 100%; background: var(--accent); border-radius: 5px; transition: width 0.3s; }
.storage-size { font-size: 12px; color: var(--text-muted); width: 60px; text-align: right; flex-shrink: 0; }
.storage-total { margin-top: 8px; font-size: 13px; color: var(--text-secondary); text-align: right; }
.settings-btn-danger {
  background: #d32f2f; color: #fff;
}
.settings-btn-danger:hover { background: #e25555; filter: none; }
.wp-option:hover { border-color: #aaa; }

/* ===== SNACKDASH ===== */
.sd-wrap { display: flex; flex-direction: column; height: 100%; background: var(--surface-bg); }
.sd-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: #ff6b00; color: #fff; gap: 8px; flex-shrink: 0; }
.sd-logo { font-weight: 700; font-size: 18px; }
.sd-points { font-size: 13px; background: rgba(255,255,255,0.2); padding: 3px 10px; border-radius: 20px; }
.sd-back { background: none; border: none; color: #fff; font-size: 20px; cursor: pointer; padding: 0 4px; }
.sd-header-title { font-weight: 600; font-size: 15px; flex: 1; text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sd-cart-badge { background: rgba(255,255,255,0.25); border: none; color: #fff; padding: 3px 10px; border-radius: 20px; font-size: 13px; cursor: pointer; }
.sd-content { flex: 1; overflow-y: auto; padding: 12px; display: flex; flex-direction: column; gap: 10px; }

/* Home */
.sd-mood-section { text-align: center; }
.sd-mood-label { font-size: 14px; color: var(--text-secondary); margin-bottom: 6px; }
.sd-mood-row { display: flex; justify-content: center; gap: 8px; }
.sd-mood-btn { background: var(--win-body-bg); border: 2px solid var(--border-color); border-radius: 12px; padding: 8px 14px; font-size: 22px; cursor: pointer; transition: all 0.15s; }
.sd-mood-btn small { font-size: 10px; display: block; color: var(--text-muted); }
.sd-mood-active { border-color: #ff6b00; background: #fff3e0; }
[data-theme="dark"] .sd-mood-active { background: #3d2800; }
.sd-big-btn { background: #ff6b00; color: #fff; border: none; padding: 14px; border-radius: 12px; font-size: 16px; font-weight: 600; cursor: pointer; transition: filter 0.15s; }
.sd-big-btn:hover { filter: brightness(1.1); }
.sd-track-btn { background: #4caf50; }
.sd-vault-btn { background: var(--win-body-bg); color: var(--text-primary); border: 2px solid var(--border-color); }
.sd-banner { background: var(--win-body-bg); padding: 10px 14px; border-radius: 10px; font-size: 13px; color: var(--text-secondary); text-align: center; border: 1px solid var(--border-light); }
.sd-deal { background: linear-gradient(135deg, #ff9800, #ff6b00); color: #fff; border-radius: 12px; padding: 12px; cursor: pointer; position: relative; overflow: hidden; }
.sd-deal-tag { position: absolute; top: 6px; right: 8px; background: #f44336; font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 8px; }
.sd-deal-body { display: flex; align-items: center; gap: 10px; }
.sd-deal-emoji { font-size: 32px; }
.sd-deal-name { font-weight: 600; font-size: 14px; }
.sd-deal-price { font-size: 13px; opacity: 0.9; }
.sd-deal-price s { opacity: 0.6; }
.sd-badges-row { display: flex; gap: 6px; justify-content: center; flex-wrap: wrap; }
.sd-badge { font-size: 24px; }

/* Restaurants */
.sd-restaurant-card { display: flex; align-items: center; gap: 12px; background: var(--win-body-bg); padding: 12px; border-radius: 12px; cursor: pointer; border: 1px solid var(--border-light); transition: border-color 0.15s; }
.sd-restaurant-card:hover { border-color: #ff6b00; }
.sd-rest-emoji { font-size: 32px; flex-shrink: 0; }
.sd-rest-info { flex: 1; min-width: 0; }
.sd-rest-name { font-weight: 600; font-size: 14px; color: var(--text-primary); }
.sd-rest-meta { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 4px; }
.sd-tag { font-size: 10px; padding: 2px 8px; border-radius: 10px; background: #fff3e0; color: #e65100; font-weight: 500; }
[data-theme="dark"] .sd-tag { background: #3d2800; color: #ffab40; }
.sd-rest-bottom { display: flex; gap: 12px; margin-top: 4px; font-size: 12px; color: var(--text-muted); }

/* Menu */
.sd-menu-item { background: var(--win-body-bg); padding: 12px; border-radius: 12px; border: 1px solid var(--border-light); }
.sd-item-top { display: flex; gap: 10px; }
.sd-item-emoji { font-size: 28px; flex-shrink: 0; }
.sd-item-info { flex: 1; }
.sd-item-name { font-weight: 600; font-size: 14px; color: var(--text-primary); }
.sd-item-desc { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.sd-item-price { font-size: 13px; font-weight: 600; color: #ff6b00; margin-top: 4px; }
.sd-addons { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 8px; }
.sd-addon-pill { font-size: 11px; padding: 3px 10px; border-radius: 20px; border: 1px solid var(--border-color); background: var(--surface-bg); color: var(--text-secondary); cursor: pointer; transition: all 0.15s; }
.sd-addon-active { background: #ff6b00; color: #fff; border-color: #ff6b00; }
.sd-add-btn { width: 100%; margin-top: 8px; padding: 8px; border: none; border-radius: 8px; background: #ff6b00; color: #fff; font-weight: 600; font-size: 13px; cursor: pointer; transition: all 0.15s; }
.sd-add-btn:hover { filter: brightness(1.1); }
.sd-added { background: #4caf50 !important; }
.sd-cart-footer { background: #ff6b00; color: #fff; text-align: center; padding: 12px; font-weight: 600; font-size: 14px; cursor: pointer; flex-shrink: 0; }

/* Cart */
.sd-cart-item { display: flex; align-items: center; gap: 10px; background: var(--win-body-bg); padding: 10px 12px; border-radius: 10px; border: 1px solid var(--border-light); }
.sd-cart-item-emoji { font-size: 24px; flex-shrink: 0; }
.sd-cart-item-info { flex: 1; min-width: 0; }
.sd-cart-item-name { font-weight: 600; font-size: 13px; color: var(--text-primary); }
.sd-cart-item-addons { font-size: 11px; color: var(--text-muted); }
.sd-cart-item-price { font-size: 13px; color: #ff6b00; font-weight: 600; }
.sd-qty-controls { display: flex; align-items: center; gap: 6px; }
.sd-qty-btn { width: 28px; height: 28px; border-radius: 50%; border: 1px solid var(--border-color); background: var(--surface-bg); font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--text-primary); }
.sd-qty-num { font-weight: 600; min-width: 20px; text-align: center; color: var(--text-primary); }
.sd-section-label { font-size: 13px; font-weight: 600; color: var(--text-secondary); margin-top: 4px; }
.sd-currency-row { display: flex; gap: 6px; flex-wrap: wrap; }
.sd-currency-pill { font-size: 11px; padding: 5px 10px; border-radius: 20px; border: 1px solid var(--border-color); background: var(--surface-bg); color: var(--text-secondary); cursor: pointer; transition: all 0.15s; }
.sd-currency-active { background: #ff6b00; color: #fff; border-color: #ff6b00; }
.sd-tip-row { display: flex; gap: 6px; }
.sd-tip-btn { flex: 1; padding: 6px 0; border-radius: 10px; border: 1px solid var(--border-color); background: var(--surface-bg); font-size: 18px; cursor: pointer; text-align: center; transition: all 0.15s; }
.sd-tip-btn br + * { font-size: 11px; }
.sd-tip-active { border-color: #ff6b00; background: #fff3e0; }
[data-theme="dark"] .sd-tip-active { background: #3d2800; }
.sd-total { display: flex; justify-content: space-between; align-items: center; padding: 12px; background: var(--win-body-bg); border-radius: 10px; font-size: 16px; color: var(--text-primary); border: 1px solid var(--border-light); }
.sd-pay-btn { width: 100%; padding: 14px; border: none; border-radius: 12px; background: #4caf50; color: #fff; font-size: 16px; font-weight: 700; cursor: pointer; transition: filter 0.15s; }
.sd-pay-btn:hover { filter: brightness(1.1); }
.sd-disclaimer { font-size: 10px; color: var(--text-muted); text-align: center; }

/* Paying */
.sd-paying-screen { justify-content: center; align-items: center; }
.sd-pay-spinner { font-size: 56px; animation: sd-spin 1s linear infinite; }
.sd-pay-msg { font-size: 14px; color: var(--text-secondary); text-align: center; margin-top: 12px; }
@keyframes sd-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/* Tracking */
.sd-driver { display: flex; align-items: center; gap: 10px; background: var(--win-body-bg); padding: 12px; border-radius: 12px; border: 1px solid var(--border-light); }
.sd-driver-emoji { font-size: 36px; }
.sd-driver-info { flex: 1; }
.sd-driver-name { font-weight: 600; font-size: 14px; color: var(--text-primary); }
.sd-driver-vehicle { font-size: 12px; color: var(--text-muted); }
.sd-driver-eta { font-weight: 700; font-size: 16px; color: #ff6b00; }
.sd-timeline { position: relative; padding-left: 20px; display: flex; flex-direction: column; gap: 0; }
.sd-waypoint { display: flex; align-items: flex-start; gap: 10px; padding: 8px 0; position: relative; }
.sd-waypoint::before { content: ''; position: absolute; left: -14px; top: 22px; bottom: -8px; width: 2px; background: var(--border-color); }
.sd-waypoint:last-child::before { display: none; }
.sd-wp-dot { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; margin-top: 4px; position: absolute; left: -20px; }
.sd-wp-done .sd-wp-dot { background: #4caf50; }
.sd-wp-current .sd-wp-dot { background: #ff6b00; animation: sd-pulse 1s ease-in-out infinite; }
.sd-wp-future .sd-wp-dot { background: var(--border-color); }
.sd-wp-done::before { border-color: #4caf50; background: #4caf50; }
.sd-wp-info { display: flex; align-items: flex-start; gap: 6px; }
.sd-wp-emoji { font-size: 18px; flex-shrink: 0; }
.sd-wp-place { font-size: 13px; font-weight: 500; color: var(--text-primary); }
.sd-wp-msg { font-size: 11px; color: #ff6b00; font-style: italic; margin-top: 2px; }
.sd-wp-future .sd-wp-place { color: var(--text-muted); }
@keyframes sd-pulse { 0%, 100% { transform: scale(1); opacity: 1; } 50% { transform: scale(1.4); opacity: 0.7; } }
.sd-honk-btn { width: 100%; padding: 12px; border: none; border-radius: 12px; background: #ffc107; color: #333; font-size: 16px; font-weight: 700; cursor: pointer; transition: transform 0.1s; }
.sd-honk-btn:active { transform: scale(0.95); }
.sd-honk-text { display: inline-block; animation: sd-honk 0.3s ease-in-out; font-size: 18px; }
@keyframes sd-honk { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.3) rotate(-5deg); } }

/* Delivered */
.sd-delivered { justify-content: center; align-items: center; text-align: center; }
.sd-delivered-emoji { font-size: 56px; animation: sd-bounce 0.6s ease-in-out infinite alternate; }
@keyframes sd-bounce { from { transform: translateY(0); } to { transform: translateY(-12px); } }
.sd-delivered-title { font-size: 22px; font-weight: 700; color: var(--text-primary); margin-top: 8px; }
.sd-delivered-driver { font-size: 14px; color: var(--text-muted); }
.sd-delivered-points { font-size: 20px; font-weight: 700; color: #ff6b00; margin-top: 8px; }
.sd-delivered-badges { margin-top: 8px; }
.sd-delivered-badges > div:first-child { font-size: 13px; font-weight: 600; color: var(--text-secondary); }
.sd-new-badge { font-size: 16px; margin-top: 4px; color: var(--text-primary); }

/* Vault */
.sd-vault-stats { display: flex; gap: 8px; }
.sd-vault-stat { flex: 1; text-align: center; background: var(--win-body-bg); padding: 14px 8px; border-radius: 12px; border: 1px solid var(--border-light); }
.sd-vault-stat-num { font-size: 24px; font-weight: 700; color: #ff6b00; }
.sd-vault-stat-label { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.sd-vault-badges { display: flex; gap: 8px; flex-wrap: wrap; }
.sd-vault-badge { text-align: center; font-size: 24px; background: var(--win-body-bg); padding: 8px 12px; border-radius: 10px; border: 1px solid var(--border-light); }
.sd-vault-badge small { display: block; font-size: 10px; color: var(--text-muted); }
.sd-order-card { background: var(--win-body-bg); padding: 10px 12px; border-radius: 10px; border: 1px solid var(--border-light); }
.sd-order-top { display: flex; justify-content: space-between; font-size: 12px; color: var(--text-muted); }
.sd-order-items { font-size: 13px; color: var(--text-primary); margin-top: 4px; }
.sd-order-total { font-size: 12px; color: #ff6b00; font-weight: 600; margin-top: 2px; }

/* Empty state */
.sd-empty { justify-content: center; align-items: center; text-align: center; color: var(--text-muted); }
.sd-empty-emoji { font-size: 48px; margin-bottom: 8px; }
.sd-empty-sub { font-size: 13px; color: var(--text-muted); }

/* ===== Zoomer ===== */
.zm-wrap { display: flex; flex-direction: column; height: 100%; background: var(--surface-bg); }
.zm-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: #5c6bc0; color: #fff; gap: 8px; flex-shrink: 0; }
[data-theme="dark"] .zm-header { background: #3f51b5; }
.zm-header-nav { background: #5c6bc0; }
[data-theme="dark"] .zm-header-nav { background: #3f51b5; }
.zm-logo { font-weight: 700; font-size: 18px; }
.zm-back { background: none; border: none; color: #fff; font-size: 20px; cursor: pointer; padding: 0 4px; }
.zm-header-title { font-weight: 600; font-size: 15px; flex: 1; text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.zm-content { flex: 1; overflow-y: auto; padding: 12px; display: flex; flex-direction: column; gap: 10px; }
.zm-center { align-items: center; justify-content: center; text-align: center; }

/* Search bar */
.zm-search-bar { display: flex; align-items: center; gap: 8px; padding: 12px 14px; background: var(--win-body-bg); border: 2px solid var(--border-light); border-radius: 12px; }
.zm-search-icon { font-size: 16px; opacity: .6; }
.zm-search-text { font-size: 14px; color: var(--text-muted); }

/* Destinations */
.zm-dest-list { display: flex; flex-direction: column; gap: 8px; }
.zm-dest-btn { display: flex; align-items: center; gap: 12px; padding: 14px 12px; background: var(--win-body-bg); border: 1px solid var(--border-light); border-radius: 12px; cursor: pointer; transition: border-color .15s, transform .1s; text-align: left; font-family: inherit; font-size: inherit; color: inherit; }
.zm-dest-btn:hover { border-color: #5c6bc0; transform: translateY(-1px); }
.zm-dest-emoji { font-size: 28px; flex-shrink: 0; }
.zm-dest-info { flex: 1; min-width: 0; }
.zm-dest-name { font-weight: 600; font-size: 14px; color: var(--text-primary); }
.zm-dest-addr { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.zm-dest-arrow { font-size: 20px; color: var(--text-muted); font-weight: 700; }
.zm-disclaimer { font-size: 10px; color: var(--text-muted); text-align: center; margin-top: auto; }

/* Destination banner */
.zm-dest-banner { text-align: center; padding: 10px; background: linear-gradient(135deg, #e8eaf6, #c5cae9); border-radius: 10px; font-size: 14px; color: #283593; }
[data-theme="dark"] .zm-dest-banner { background: linear-gradient(135deg, #283593, #3949ab); color: #c5cae9; }

/* Vehicles */
.zm-vehicle-list { display: flex; flex-direction: column; gap: 10px; }
.zm-vehicle-card { background: var(--win-body-bg); border: 1px solid var(--border-light); border-radius: 12px; padding: 12px; transition: border-color .15s; }
.zm-vehicle-card:hover { border-color: #5c6bc0; }
.zm-vehicle-top { display: flex; gap: 10px; align-items: center; }
.zm-vehicle-emoji { font-size: 32px; flex-shrink: 0; }
.zm-vehicle-info { flex: 1; }
.zm-vehicle-name { font-weight: 600; font-size: 14px; color: var(--text-primary); }
.zm-vehicle-desc { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.zm-request-btn { width: 100%; margin-top: 8px; padding: 8px; border: none; border-radius: 8px; background: #5c6bc0; color: #fff; font-weight: 600; font-size: 13px; cursor: pointer; transition: filter .15s; }
.zm-request-btn:hover { filter: brightness(1.1); }

/* Fake map */
.zm-map { position: relative; height: 140px; background: #e8eaf6; border-radius: 14px; overflow: hidden; }
[data-theme="dark"] .zm-map { background: #1a237e; }
.zm-map-grid { position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(92,107,192,.15) 1px, transparent 1px); background-size: 20px 20px; }
.zm-map-road { position: absolute; top: 50%; left: 10%; right: 10%; height: 4px; background: #9fa8da; border-radius: 2px; transform: translateY(-50%); }
[data-theme="dark"] .zm-map-road { background: #5c6bc0; }
.zm-map-driver { position: absolute; top: 50%; transform: translate(-50%, -50%); font-size: 28px; transition: left .4s ease; z-index: 2; }
.zm-map-you { position: absolute; top: 50%; right: 10%; transform: translate(50%, -50%); font-size: 24px; z-index: 2; }
.zm-map-label-you { position: absolute; top: 68%; right: 4%; font-size: 10px; font-weight: 600; color: #5c6bc0; }
[data-theme="dark"] .zm-map-label-you { color: #9fa8da; }

/* ETA & Progress */
.zm-eta { text-align: center; font-size: 14px; font-weight: 600; color: var(--text-primary); }
.zm-progress-wrap { height: 6px; background: var(--border-light); border-radius: 3px; overflow: hidden; }
.zm-progress-bar { height: 100%; background: #5c6bc0; border-radius: 3px; transition: width .4s; }

/* Status message */
.zm-status-msg { display: flex; align-items: flex-start; gap: 8px; padding: 10px 12px; background: var(--win-body-bg); border-radius: 10px; border: 1px solid var(--border-light); font-size: 13px; color: var(--text-secondary); font-style: italic; }
.zm-status-dot { width: 8px; height: 8px; border-radius: 50%; background: #5c6bc0; flex-shrink: 0; margin-top: 5px; animation: zm-pulse 1.2s ease-in-out infinite; }
@keyframes zm-pulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: .5; transform: scale(1.3); } }

/* Honk */
.zm-honk-btn { width: 100%; padding: 12px; border: none; border-radius: 12px; background: #ffc107; color: #333; font-size: 15px; font-weight: 700; cursor: pointer; transition: transform .1s; }
.zm-honk-btn:active { transform: scale(0.95); }
.zm-honk-msg { text-align: center; font-size: 13px; color: #5c6bc0; font-weight: 600; padding: 6px; background: #e8eaf6; border-radius: 8px; animation: zm-fade-in .3s; }
[data-theme="dark"] .zm-honk-msg { background: #283593; color: #9fa8da; }
@keyframes zm-fade-in { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }

/* Trip map */
.zm-trip-map { position: relative; height: 100px; background: #e8eaf6; border-radius: 14px; overflow: hidden; }
[data-theme="dark"] .zm-trip-map { background: #1a237e; }
.zm-trip-road { position: absolute; top: 50%; left: 10%; right: 10%; height: 4px; background: #9fa8da; border-radius: 2px; transform: translateY(-50%); border-top: 2px dashed #7986cb; }
[data-theme="dark"] .zm-trip-road { background: #5c6bc0; border-color: #7986cb; }
.zm-trip-start { position: absolute; top: 50%; left: 8%; transform: translate(-50%, -50%); font-size: 20px; }
.zm-trip-end { position: absolute; top: 50%; right: 4%; transform: translate(50%, -50%); font-size: 20px; }
.zm-trip-car { position: absolute; top: 50%; transform: translate(-50%, -50%); font-size: 22px; transition: left .4s ease; z-index: 2; }
.zm-trip-progress-wrap { height: 6px; background: var(--border-light); border-radius: 3px; overflow: hidden; }
.zm-trip-progress-bar { height: 100%; background: linear-gradient(90deg, #5c6bc0, #7986cb); border-radius: 3px; transition: width .4s; }
.zm-trip-time { text-align: center; font-size: 14px; font-weight: 600; color: var(--text-primary); }
.zm-trip-rider { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: var(--win-body-bg); border-radius: 10px; border: 1px solid var(--border-light); }
.zm-trip-rider-emoji { font-size: 28px; }
.zm-trip-rider-info { flex: 1; }
.zm-trip-rider-text { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.zm-trip-rider-sub { font-size: 11px; color: var(--text-muted); }

/* Trip complete / Rating */
.zm-complete-stamp { font-size: 22px; font-weight: 800; color: #5c6bc0; background: #e8eaf6; padding: 12px 20px; border-radius: 14px; letter-spacing: 1px; }
[data-theme="dark"] .zm-complete-stamp { background: #283593; color: #9fa8da; }
.zm-arrived-text { font-size: 16px; color: var(--text-primary); margin-top: 8px; }
.zm-rating-label { font-size: 14px; font-weight: 600; color: var(--text-secondary); margin-top: 4px; }
.zm-rating-list { display: flex; flex-direction: column; gap: 8px; width: 100%; }
.zm-rating-btn { display: flex; align-items: center; gap: 10px; padding: 10px 14px; background: var(--win-body-bg); border: 2px solid var(--border-light); border-radius: 10px; cursor: pointer; transition: border-color .15s, transform .1s; font-family: inherit; font-size: inherit; color: inherit; text-align: left; }
.zm-rating-btn:hover { border-color: #5c6bc0; transform: translateX(4px); }
.zm-rating-stars { font-size: 14px; flex-shrink: 0; }
.zm-rating-text { font-size: 13px; color: var(--text-primary); }

/* Thank you */
.zm-thankyou-emoji { font-size: 56px; animation: zm-bounce .6s ease-in-out infinite alternate; }
@keyframes zm-bounce { from { transform: translateY(0); } to { transform: translateY(-12px); } }
.zm-thankyou-text { font-size: 15px; color: var(--text-primary); margin-top: 8px; max-width: 280px; line-height: 1.5; }
.zm-done-btn { margin-top: 16px; padding: 14px 40px; border: none; border-radius: 12px; background: #5c6bc0; color: #fff; font-size: 16px; font-weight: 700; cursor: pointer; transition: filter .15s; }
.zm-done-btn:hover { filter: brightness(1.1); }

/* ===== TinyBank ===== */
.tb-wrap { display: flex; flex-direction: column; height: 100%; background: var(--win-body-bg); font-family: inherit; overflow: hidden; position: relative; }
.tb-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: #2e7d32; color: #fff; flex-shrink: 0; gap: 8px; }
[data-theme="dark"] .tb-header { background: #1b5e20; }
.tb-logo { font-weight: 700; font-size: 16px; }
.tb-header-title { font-weight: 700; font-size: 15px; flex: 1; text-align: center; }
.tb-bal-pill { font-size: 12px; font-weight: 600; background: rgba(255,255,255,.2); padding: 3px 10px; border-radius: 20px; white-space: nowrap; }
.tb-back { background: none; border: none; color: #fff; font-size: 14px; cursor: pointer; padding: 2px 4px; font-weight: 600; }
.tb-scroll, .tb-home-scroll { flex: 1; overflow-y: auto; padding: 14px; }
.tb-loading { display: flex; align-items: center; justify-content: center; height: 100%; color: var(--text-muted); }

/* Home */
.tb-hero { text-align: center; padding: 18px 0 12px; }
.tb-hero-label { font-size: 12px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; }
.tb-hero-amount { font-size: 36px; font-weight: 800; color: #2e7d32; margin: 4px 0; }
[data-theme="dark"] .tb-hero-amount { color: #66bb6a; }
.tb-hero-unit { font-size: 13px; color: var(--text-muted); }
.tb-daily-msg { text-align: center; font-size: 12px; color: var(--text-muted); font-style: italic; padding: 6px 12px 14px; }
.tb-section-title { font-size: 13px; font-weight: 700; margin-bottom: 8px; color: var(--text-color); }
.tb-missions { margin-bottom: 14px; }
.tb-mission { font-size: 13px; padding: 4px 0; color: var(--text-color); }
.tb-mission-done { text-decoration: line-through; opacity: .6; }
.tb-nav-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 14px; }
.tb-nav-btn { display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 14px 8px; border: 1px solid var(--border-color, #e0e0e0); border-radius: 12px; background: var(--win-body-bg); cursor: pointer; font-size: 12px; font-weight: 600; color: var(--text-color); transition: background .15s, transform .1s; }
.tb-nav-btn span { font-size: 22px; }
.tb-nav-btn:hover { background: rgba(46,125,50,.08); }
.tb-nav-btn:active { transform: scale(.96); }
.tb-badges-row { margin-top: 4px; }
.tb-badges-icons { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 6px; align-items: center; }
.tb-badge-mini { font-size: 20px; }
.tb-link { background: none; border: none; color: #2e7d32; font-size: 12px; cursor: pointer; padding: 0; font-weight: 600; }
[data-theme="dark"] .tb-link { color: #66bb6a; }
.tb-muted { font-size: 12px; color: var(--text-muted); }

/* Buttons */
.tb-btn { padding: 8px 16px; border: none; border-radius: 8px; background: #2e7d32; color: #fff; font-size: 13px; font-weight: 600; cursor: pointer; transition: background .15s, transform .1s; }
[data-theme="dark"] .tb-btn { background: #388e3c; }
.tb-btn:hover { background: #1b5e20; }
.tb-btn:active { transform: scale(.96); }
.tb-btn-sm { padding: 5px 12px; font-size: 12px; }
.tb-btn-raise { width: 100%; padding: 10px; font-size: 14px; }
.tb-btn-danger { background: #d32f2f; }
.tb-btn-danger:hover { background: #b71c1c; }
.tb-btn-outline { background: transparent; border: 1px solid #2e7d32; color: #2e7d32; }
[data-theme="dark"] .tb-btn-outline { border-color: #66bb6a; color: #66bb6a; }
.tb-btn-outline:hover { background: rgba(46,125,50,.1); }

/* Earn */
.tb-earn-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.tb-earn-item { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px; border-radius: 10px; background: var(--card-bg, rgba(46,125,50,.05)); border: 1px solid var(--border-color, #e0e0e0); }
.tb-earn-claimed { opacity: .5; }
.tb-earn-left { display: flex; align-items: center; gap: 10px; }
.tb-earn-emoji { font-size: 22px; }
.tb-earn-name { font-size: 13px; font-weight: 600; color: var(--text-color); }
.tb-earn-coins { font-size: 12px; color: #2e7d32; font-weight: 600; }
[data-theme="dark"] .tb-earn-coins { color: #66bb6a; }
.tb-earn-check { font-size: 18px; }
.tb-raise-section { padding: 14px 0; }
.tb-raise-result { margin-top: 10px; padding: 10px; border-radius: 8px; background: rgba(46,125,50,.08); text-align: center; }
.tb-raise-text { font-size: 13px; color: var(--text-color); }
.tb-raise-coins { font-size: 14px; font-weight: 700; color: #2e7d32; margin-top: 4px; }
[data-theme="dark"] .tb-raise-coins { color: #66bb6a; }

/* Save */
.tb-save-msg { text-align: center; font-size: 13px; padding: 8px; border-radius: 8px; background: rgba(46,125,50,.1); color: #2e7d32; margin-bottom: 10px; font-weight: 600; animation: tb-fadein .3s; }
[data-theme="dark"] .tb-save-msg { color: #66bb6a; background: rgba(102,187,106,.15); }
@keyframes tb-fadein { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }
.tb-jars { display: flex; flex-direction: column; gap: 10px; }
.tb-jar { padding: 12px; border-radius: 10px; border: 1px solid var(--border-color, #e0e0e0); background: var(--win-body-bg); }
.tb-jar-top { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.tb-jar-emoji { font-size: 26px; }
.tb-jar-name { font-size: 14px; font-weight: 600; color: var(--text-color); }
.tb-jar-bal { font-size: 12px; color: #2e7d32; font-weight: 600; }
[data-theme="dark"] .tb-jar-bal { color: #66bb6a; }
.tb-jar-btns { display: flex; gap: 6px; }

/* Goals */
.tb-goals { display: flex; flex-direction: column; gap: 12px; }
.tb-goal { padding: 12px; border-radius: 10px; border: 1px solid var(--border-color, #e0e0e0); }
.tb-goal-done { border-color: #2e7d32; background: rgba(46,125,50,.05); }
[data-theme="dark"] .tb-goal-done { border-color: #66bb6a; background: rgba(102,187,106,.1); }
.tb-goal-top { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.tb-goal-emoji { font-size: 26px; }
.tb-goal-name { font-size: 14px; font-weight: 600; color: var(--text-color); }
.tb-goal-deadline { font-size: 11px; color: var(--text-muted); font-style: italic; }
.tb-progress { height: 10px; border-radius: 5px; background: var(--border-color, #e0e0e0); overflow: hidden; margin-bottom: 8px; }
.tb-progress-bar { height: 100%; background: #2e7d32; border-radius: 5px; transition: width .3s; }
[data-theme="dark"] .tb-progress-bar { background: #66bb6a; }
.tb-goal-bottom { display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: var(--text-muted); }
.tb-goal-complete { color: #2e7d32; font-weight: 700; }
[data-theme="dark"] .tb-goal-complete { color: #66bb6a; }

/* History */
.tb-history-summary { padding: 10px 12px; border-radius: 10px; background: rgba(46,125,50,.06); margin-bottom: 12px; }
.tb-summary-row { display: flex; justify-content: space-between; font-size: 13px; margin-top: 4px; }
.tb-summary-in { color: #2e7d32; font-weight: 600; }
[data-theme="dark"] .tb-summary-in { color: #66bb6a; }
.tb-summary-out { color: #d32f2f; font-weight: 600; }
.tb-history-list { display: flex; flex-direction: column; gap: 6px; }
.tb-history-item { display: flex; align-items: center; justify-content: space-between; padding: 8px 10px; border-radius: 8px; border: 1px solid var(--border-color, #e0e0e0); }
.tb-history-left { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0; }
.tb-history-emoji { font-size: 18px; flex-shrink: 0; }
.tb-history-text { font-size: 12px; font-weight: 600; color: var(--text-color); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tb-history-date { font-size: 11px; color: var(--text-muted); }
.tb-history-amount { font-size: 13px; font-weight: 700; white-space: nowrap; margin-left: 8px; }
.tb-green { color: #2e7d32; }
[data-theme="dark"] .tb-green { color: #66bb6a; }
.tb-red { color: #d32f2f; }
.tb-empty { text-align: center; padding: 24px; color: var(--text-muted); font-size: 13px; }

/* Card */
.tb-card-scroll { display: flex; flex-direction: column; align-items: center; }
.tb-card { width: 100%; max-width: 340px; aspect-ratio: 1.586; border-radius: 14px; padding: 20px; display: flex; flex-direction: column; justify-content: space-between; color: #fff; position: relative; overflow: hidden; box-shadow: 0 4px 16px rgba(0,0,0,.2); margin-bottom: 16px; }
.tb-card-frozen { position: absolute; inset: 0; background: rgba(144,202,249,.6); display: flex; align-items: center; justify-content: center; font-size: 32px; font-weight: 800; letter-spacing: 4px; backdrop-filter: blur(2px); z-index: 1; }
.tb-card-top { display: flex; justify-content: space-between; align-items: flex-start; }
.tb-card-logo { font-size: 16px; font-weight: 700; }
.tb-card-type { font-size: 11px; opacity: .9; }
.tb-card-number { font-size: 18px; font-weight: 600; letter-spacing: 2px; text-align: center; text-shadow: 0 1px 2px rgba(0,0,0,.3); }
.tb-card-bottom { display: flex; justify-content: space-between; }
.tb-card-label { font-size: 9px; text-transform: uppercase; opacity: .7; letter-spacing: 1px; }
.tb-card-value { font-size: 12px; font-weight: 600; }
.tb-card-section { width: 100%; margin-bottom: 14px; }
.tb-skin-row { display: flex; flex-wrap: wrap; gap: 6px; }
.tb-skin-btn { padding: 6px 10px; border: 1px solid var(--border-color, #e0e0e0); border-radius: 8px; background: var(--win-body-bg); font-size: 11px; cursor: pointer; color: var(--text-color); transition: border-color .15s; }
.tb-skin-active { border-color: #2e7d32; background: rgba(46,125,50,.1); }
[data-theme="dark"] .tb-skin-active { border-color: #66bb6a; background: rgba(102,187,106,.15); }

/* Give */
.tb-give-total { text-align: center; font-size: 14px; padding: 10px; margin-bottom: 12px; border-radius: 8px; background: rgba(46,125,50,.06); color: var(--text-color); }
.tb-give-total strong { color: #2e7d32; }
[data-theme="dark"] .tb-give-total strong { color: #66bb6a; }
.tb-give-list { display: flex; flex-direction: column; gap: 10px; }
.tb-give-card { padding: 12px; border-radius: 10px; border: 1px solid var(--border-color, #e0e0e0); }
.tb-give-top { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.tb-give-emoji { font-size: 26px; }
.tb-give-name { font-size: 14px; font-weight: 600; color: var(--text-color); }
.tb-give-desc { font-size: 12px; color: var(--text-muted); }
.tb-give-btns { display: flex; gap: 6px; }

/* Overlay (badges, fraud) */
.tb-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.5); z-index: 10; display: flex; align-items: center; justify-content: center; padding: 16px; }
.tb-overlay-box { background: var(--win-body-bg); border-radius: 14px; padding: 20px; max-width: 340px; width: 100%; max-height: 80%; overflow-y: auto; text-align: center; }
.tb-overlay-title { font-size: 18px; font-weight: 700; margin-bottom: 14px; color: var(--text-color); }
.tb-badge-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 14px; }
.tb-badge-card { padding: 12px 8px; border-radius: 10px; border: 1px solid var(--border-color, #e0e0e0); text-align: center; }
.tb-badge-unlocked { border-color: #2e7d32; background: rgba(46,125,50,.06); }
[data-theme="dark"] .tb-badge-unlocked { border-color: #66bb6a; background: rgba(102,187,106,.1); }
.tb-badge-locked { opacity: .45; }
.tb-badge-icon { font-size: 28px; margin-bottom: 4px; }
.tb-badge-name { font-size: 12px; font-weight: 700; color: var(--text-color); }
.tb-badge-desc { font-size: 10px; color: var(--text-muted); }
.tb-fraud-alert-emoji, .tb-fraud-result-emoji { font-size: 42px; margin-bottom: 10px; }
.tb-fraud-alert-text, .tb-fraud-result-text { font-size: 14px; font-weight: 600; color: var(--text-color); margin-bottom: 14px; }
.tb-fraud-btns { display: flex; flex-direction: column; gap: 8px; }

/* ===== ChoreQuest ===== */
.cq-wrap { display: flex; flex-direction: column; height: 100%; background: var(--win-body-bg); font-family: inherit; overflow-y: auto; }
.cq-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; background: #ef6c00; color: #fff; flex-shrink: 0; }
.cq-title { font-weight: 700; font-size: 16px; }
.cq-header-right { display: flex; align-items: center; gap: 8px; }
.cq-streak { font-size: 13px; font-weight: 600; background: rgba(255,255,255,.2); padding: 3px 10px; border-radius: 20px; }
.cq-edit-btn { background: rgba(255,255,255,.2); border: none; border-radius: 8px; padding: 4px 8px; font-size: 16px; cursor: pointer; line-height: 1; }
.cq-edit-btn:hover { background: rgba(255,255,255,.35); }
.cq-edit-done-btn { background: #fff; color: #ef6c00; border: none; border-radius: 8px; padding: 5px 14px; font: 700 13px sans-serif; cursor: pointer; }
.cq-edit-done-btn:hover { background: #ffe0b2; }

/* Empty state */
.cq-empty { text-align: center; padding: 40px 20px; }
.cq-empty-emoji { font-size: 48px; margin-bottom: 8px; }
.cq-empty-text { font-size: 15px; color: var(--text-muted); font-weight: 600; }

/* Edit screen */
.cq-edit-info { padding: 10px 16px; font-size: 13px; color: var(--text-secondary); background: var(--surface-bg); }
.cq-edit-info b { color: #ef6c00; }
.cq-edit-row { display: flex; align-items: center; gap: 10px; padding: 9px 12px; margin: 0 16px 4px; border-radius: 10px; border: 1.5px solid var(--border-light); cursor: pointer; transition: background .15s, border-color .15s; }
.cq-edit-row:hover { background: var(--surface-bg); }
.cq-edit-row.cq-edit-on { border-color: #a5d6a7; background: #e8f5e9; }
[data-theme="dark"] .cq-edit-row.cq-edit-on { background: rgba(76,175,80,.12); border-color: rgba(76,175,80,.3); }
.cq-edit-name { flex: 1; font-size: 14px; font-weight: 600; color: var(--text-primary); }
.cq-toggle { width: 40px; height: 22px; border-radius: 11px; background: #ccc; position: relative; flex-shrink: 0; transition: background .2s; }
.cq-toggle-on { background: #4caf50; }
.cq-toggle-knob { position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; border-radius: 50%; background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.2); transition: left .2s; }
.cq-toggle-on .cq-toggle-knob { left: 20px; }
[data-theme="dark"] .cq-toggle { background: #555; }
.cq-edit-reset-btn { background: none; border: 1px solid var(--text-muted); border-radius: 8px; padding: 6px 16px; font-size: 13px; color: var(--text-muted); cursor: pointer; }
.cq-edit-reset-btn:hover { background: var(--surface-bg); }

/* Progress */
.cq-progress-wrap { padding: 10px 16px; flex-shrink: 0; }
.cq-progress { height: 14px; background: var(--border-light); border-radius: 7px; overflow: hidden; }
.cq-progress-bar { height: 100%; background: #ef6c00; border-radius: 7px; transition: width .4s ease; }
.cq-progress-text { font-size: 12px; color: var(--text-muted); margin-top: 4px; text-align: right; }

/* Sections */
.cq-section { padding: 0 16px 8px; }
.cq-section-title { font-weight: 700; font-size: 13px; color: #ef6c00; margin: 10px 0 6px; text-transform: uppercase; letter-spacing: .5px; }

/* Chore cards */
.cq-chore { background: var(--win-body-bg); border: 1.5px solid var(--border-light); border-radius: 10px; margin-bottom: 6px; padding: 8px 10px; transition: background .2s, border-color .2s; }
.cq-chore-done { background: #e8f5e9; border-color: #a5d6a7; }
[data-theme="dark"] .cq-chore-done { background: #1b3a1b; border-color: #2e7d32; }
.cq-chore-main { display: flex; align-items: center; gap: 8px; }
.cq-chore-emoji { font-size: 22px; flex-shrink: 0; }
.cq-chore-info { flex: 1; min-width: 0; }
.cq-chore-name { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.cq-chore-done .cq-chore-name { text-decoration: line-through; opacity: .7; }
.cq-chore-hint { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.cq-chore-actions { flex-shrink: 0; }
.cq-done-btn { background: #ef6c00; color: #fff; border: none; border-radius: 8px; padding: 6px 14px; font-size: 13px; font-weight: 700; cursor: pointer; }
.cq-done-btn:hover { background: #e65100; }
.cq-timer-btn { background: #ff9800; color: #fff; border: none; border-radius: 8px; padding: 6px 10px; font-size: 12px; font-weight: 600; cursor: pointer; }
.cq-timer-btn:hover { background: #ef6c00; }
.cq-check-mark { font-size: 20px; }
.cq-hint-toggle { background: none; border: none; color: #ef6c00; font-size: 11px; cursor: pointer; padding: 2px 0 0; }
.cq-hint-toggle:hover { text-decoration: underline; }

/* Timer overlay */
.cq-timer { background: linear-gradient(135deg, #fff3e0, #ffe0b2); border: 2px solid #ef6c00; border-radius: 14px; margin: 0 16px 10px; padding: 20px; text-align: center; animation: cq-pulse 1.5s ease-in-out infinite; }
[data-theme="dark"] .cq-timer { background: linear-gradient(135deg, #3e2723, #4e342e); }
.cq-timer-emoji { font-size: 36px; }
.cq-timer-label { font-weight: 700; font-size: 16px; color: #ef6c00; margin: 4px 0; }
.cq-timer-display { font-size: 48px; font-weight: 800; color: #e65100; font-variant-numeric: tabular-nums; }
[data-theme="dark"] .cq-timer-display { color: #ffb74d; }
.cq-timer-hint { font-size: 13px; color: var(--text-muted); margin: 4px 0 10px; }
.cq-early-btn { background: #4caf50; color: #fff; border: none; border-radius: 8px; padding: 8px 22px; font: 700 15px sans-serif; cursor: pointer; margin-bottom: 8px; animation: cq-early-glow 1.2s ease infinite alternate; }
.cq-early-btn:active { transform: scale(.95); }
@keyframes cq-early-glow { 0%{box-shadow:0 0 6px rgba(76,175,80,.4)} 100%{box-shadow:0 0 18px rgba(76,175,80,.7)} }
.cq-timer-cancel { background: none; border: 1px solid var(--text-muted); border-radius: 8px; padding: 4px 14px; font-size: 12px; color: var(--text-muted); cursor: pointer; }

/* Awesome early-finish popup */
.cq-awesome-overlay { position: absolute; inset: 0; z-index: 10; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,.45); backdrop-filter: blur(3px); transition: opacity .4s; }
.cq-awesome-overlay.cq-awesome-fade { opacity: 0; }
.cq-awesome-popup { text-align: center; padding: 28px 32px 22px; }
.cq-awesome-emoji { font-size: 64px; animation: cq-awesome-bounce .6s ease; }
.cq-awesome-title { font: 900 32px/1.1 sans-serif; color: #ff6d00; text-shadow: 0 2px 16px rgba(255,109,0,.5); margin: 6px 0; animation: cq-awesome-scale .5s .1s ease both; }
.cq-awesome-msg { font: 600 15px/1.4 sans-serif; color: #fff; margin: 4px 0 10px; animation: cq-awesome-scale .5s .2s ease both; }
.cq-awesome-sub { font: 900 22px/1 sans-serif; color: #ffd600; text-shadow: 0 0 20px rgba(255,214,0,.6); letter-spacing: 2px; animation: cq-awesome-pulse 1s .4s ease infinite alternate; }
@keyframes cq-awesome-bounce { 0%{transform:scale(0) rotate(-20deg)} 50%{transform:scale(1.3) rotate(5deg)} 100%{transform:scale(1) rotate(0)} }
@keyframes cq-awesome-scale { 0%{transform:scale(0);opacity:0} 100%{transform:scale(1);opacity:1} }
@keyframes cq-awesome-pulse { 0%{transform:scale(1)} 100%{transform:scale(1.1)} }
[data-theme="light"] .cq-awesome-overlay { background: rgba(255,255,255,.55); }
[data-theme="light"] .cq-awesome-msg { color: #37474f; }
[data-theme="light"] .cq-awesome-sub { color: #e65100; text-shadow: 0 0 16px rgba(230,81,0,.3); }

@keyframes cq-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239,108,0,.3); }
  50% { box-shadow: 0 0 0 8px rgba(239,108,0,0); }
}

/* Victory screen */
.cq-victory { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; text-align: center; padding: 20px; position: relative; overflow: hidden; }
.cq-confetti { position: absolute; top: 0; left: 0; width: 100%; height: 100%; pointer-events: none; overflow: hidden; }
.cq-confetti-piece { position: absolute; top: -30px; font-size: 22px; animation: cq-confetti-fall linear infinite; }
@keyframes cq-confetti-fall {
  0% { transform: translateY(-30px) rotate(0deg); opacity: 1; }
  100% { transform: translateY(520px) rotate(360deg); opacity: 0; }
}
.cq-stamp { font-size: 28px; font-weight: 900; color: #ef6c00; animation: cq-stamp-pop .5s ease-out; position: relative; z-index: 1; }
@keyframes cq-stamp-pop {
  0% { transform: scale(0); opacity: 0; }
  60% { transform: scale(1.3); }
  100% { transform: scale(1); opacity: 1; }
}
.cq-compliment { font-size: 16px; color: var(--text-primary); margin: 12px 0; font-weight: 600; position: relative; z-index: 1; }
.cq-sticker-earned { background: #fff3e0; border-radius: 14px; padding: 14px 20px; margin: 10px 0; position: relative; z-index: 1; }
[data-theme="dark"] .cq-sticker-earned { background: #3e2723; }
.cq-sticker-earned-label { font-size: 12px; color: var(--text-muted); margin-bottom: 4px; }
.cq-sticker-earned-icon { font-size: 40px; }
.cq-sticker-earned-name { font-size: 14px; font-weight: 700; color: #ef6c00; margin-top: 4px; }
.cq-victory-streak { font-size: 15px; font-weight: 600; color: var(--text-primary); margin: 8px 0; position: relative; z-index: 1; }
.cq-victory-total { font-size: 12px; color: var(--text-muted); margin-bottom: 12px; position: relative; z-index: 1; }
.cq-victory-btn { background: #ef6c00; color: #fff; border: none; border-radius: 12px; padding: 12px 28px; font-size: 15px; font-weight: 700; cursor: pointer; position: relative; z-index: 1; }
.cq-victory-btn:hover { background: #e65100; }

/* Footer */
.cq-footer { padding: 10px 16px 14px; text-align: center; flex-shrink: 0; }
.cq-sticker-count { font-size: 13px; font-weight: 600; color: #ef6c00; }
.cq-streak-msg { font-size: 12px; color: var(--text-muted); margin-top: 4px; }
.cq-best-streak { font-size: 11px; color: var(--text-muted); margin-top: 2px; }

/* ===== Treasure Mapper ===== */
.tm-wrap { display: flex; flex-direction: column; height: 100%; background: var(--win-body-bg); font-family: inherit; }
.tm-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; background: #2e7d32; color: #fff; flex-shrink: 0; }
.tm-header-nav { background: #1b5e20; }
.tm-logo { font-weight: 700; font-size: 16px; }
.tm-coins { font-size: 14px; font-weight: 600; background: rgba(255,255,255,.18); padding: 3px 10px; border-radius: 20px; }
.tm-back { background: none; border: none; color: #fff; font-size: 20px; cursor: pointer; padding: 0 4px; }
.tm-header-title { font-weight: 600; font-size: 15px; }
.tm-content { flex: 1; overflow-y: auto; padding: 12px 14px; display: flex; flex-direction: column; gap: 12px; }

/* Search */
.tm-search-wrap { position: relative; }
.tm-search { width: 100%; padding: 10px 14px; border: 2px solid var(--border-light); border-radius: 12px; font-size: 14px; background: var(--win-body-bg); color: var(--text-primary); box-sizing: border-box; outline: none; }
.tm-search:focus { border-color: #2e7d32; }

/* Places Grid */
.tm-places-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.tm-places-grid-full { grid-template-columns: 1fr 1fr; }
.tm-place-card { background: var(--win-body-bg); border: 1px solid var(--border-light); border-radius: 12px; padding: 12px 8px; text-align: center; cursor: pointer; transition: transform .15s, box-shadow .15s; }
.tm-place-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,.1); }
.tm-place-card-emoji { font-size: 32px; }
.tm-place-card-name { font-size: 12px; font-weight: 600; color: var(--text-primary); margin-top: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tm-place-card-status { font-size: 10px; color: #2e7d32; margin-top: 2px; }

/* Quick actions */
.tm-quick-row { display: flex; gap: 8px; }
.tm-quick-btn { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 10px 6px; border: 1px solid var(--border-light); border-radius: 12px; background: var(--win-body-bg); cursor: pointer; font-size: 12px; font-weight: 600; color: var(--text-primary); transition: background .15s; }
.tm-quick-btn:hover { background: rgba(46,125,50,.08); }
.tm-quick-btn span { font-size: 22px; }
.tm-bottom-row { display: flex; gap: 8px; }
.tm-bottom-btn { flex: 1; padding: 10px; border: 1px solid var(--border-light); border-radius: 10px; background: var(--win-body-bg); cursor: pointer; font-size: 13px; font-weight: 600; color: var(--text-primary); text-align: center; }
.tm-bottom-btn:hover { background: rgba(46,125,50,.08); }

/* Banner & Traffic */
.tm-banner { background: linear-gradient(135deg, #e8f5e9, #c8e6c9); padding: 10px 12px; border-radius: 10px; font-size: 12px; color: #2e7d32; font-weight: 500; }
.tm-traffic { font-size: 11px; color: var(--text-muted); padding: 6px 10px; background: var(--win-body-bg); border: 1px dashed var(--border-light); border-radius: 8px; text-align: center; }
.tm-traffic-nav { margin-top: auto; }
.tm-badges-row { display: flex; gap: 4px; flex-wrap: wrap; }
.tm-badge-small { font-size: 20px; }

/* Place Detail */
.tm-place-hero { text-align: center; padding: 12px 0; }
.tm-place-hero-emoji { font-size: 64px; }
.tm-place-hero-status { font-size: 13px; color: #2e7d32; font-weight: 500; margin-top: 4px; }
.tm-place-desc { font-size: 13px; color: var(--text-secondary); line-height: 1.5; }
.tm-action-row { display: flex; gap: 8px; }
.tm-action-btn { flex: 1; padding: 10px 6px; border: none; border-radius: 10px; font-size: 12px; font-weight: 600; cursor: pointer; color: #fff; text-align: center; }
.tm-action-navigate { background: #2e7d32; }
.tm-action-save { background: #1565c0; }
.tm-action-sv { background: #6a1b9a; }
.tm-action-btn:hover { opacity: .85; }

/* Hazard */
.tm-hazard { display: flex; gap: 10px; align-items: flex-start; background: #fff3e0; padding: 10px 12px; border-radius: 10px; border: 1px solid #ffe0b2; }
[data-theme="dark"] .tm-hazard { background: #3e2723; border-color: #5d4037; }
.tm-hazard-emoji { font-size: 28px; flex-shrink: 0; }
.tm-hazard-name { font-size: 13px; font-weight: 600; color: #e65100; }
[data-theme="dark"] .tm-hazard-name { color: #ffab40; }
.tm-hazard-msg { font-size: 12px; color: var(--text-secondary); margin-top: 2px; }

/* Reviews */
.tm-reviews-title { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.tm-review { background: var(--win-body-bg); border: 1px solid var(--border-light); border-radius: 10px; padding: 10px 12px; }
.tm-review-header { display: flex; justify-content: space-between; align-items: center; }
.tm-review-user { font-size: 12px; font-weight: 600; color: var(--text-primary); }
.tm-review-stars { font-size: 11px; }
.tm-review-text { font-size: 12px; color: var(--text-secondary); margin-top: 4px; line-height: 1.4; }

/* Routes */
.tm-dest-banner { text-align: center; padding: 10px; background: linear-gradient(135deg, #e8f5e9, #c8e6c9); border-radius: 10px; font-size: 14px; font-weight: 600; color: #1b5e20; }
[data-theme="dark"] .tm-dest-banner { background: linear-gradient(135deg, #1b5e20, #2e7d32); color: #e8f5e9; }
.tm-section-label { font-size: 12px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: .5px; }
.tm-routes-list { display: flex; flex-direction: column; gap: 6px; }
.tm-route-card { display: flex; gap: 10px; align-items: center; padding: 10px 12px; border: 2px solid var(--border-light); border-radius: 10px; cursor: pointer; transition: border-color .15s; }
.tm-route-card:hover { border-color: #66bb6a; }
.tm-route-selected { border-color: #2e7d32; background: rgba(46,125,50,.06); }
[data-theme="dark"] .tm-route-selected { background: rgba(46,125,50,.2); }
.tm-route-emoji { font-size: 24px; flex-shrink: 0; }
.tm-route-name { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.tm-route-desc { font-size: 11px; color: var(--text-muted); }
.tm-voice-row { display: flex; gap: 6px; }
.tm-voice-btn { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 8px 4px; border: 2px solid var(--border-light); border-radius: 10px; background: var(--win-body-bg); cursor: pointer; transition: border-color .15s; }
.tm-voice-btn span { font-size: 22px; }
.tm-voice-btn small { font-size: 10px; color: var(--text-muted); }
.tm-voice-selected { border-color: #2e7d32; background: rgba(46,125,50,.06); }
[data-theme="dark"] .tm-voice-selected { background: rgba(46,125,50,.2); }
.tm-start-btn { padding: 14px; background: #2e7d32; color: #fff; border: none; border-radius: 12px; font-size: 15px; font-weight: 700; cursor: pointer; text-align: center; width: 100%; }
.tm-start-btn:hover { background: #1b5e20; }
.tm-start-btn:disabled { background: #a5d6a7; cursor: not-allowed; }

/* Navigation */
.tm-nav-step-count { font-size: 12px; opacity: .8; }
.tm-nav-progress { height: 8px; background: rgba(255,255,255,.2); border-radius: 4px; overflow: hidden; }
.tm-nav-progress-bar { height: 100%; background: #66bb6a; border-radius: 4px; transition: width .4s; }
.tm-nav-voice-info { text-align: center; }
.tm-nav-voice-avatar { font-size: 48px; }
.tm-nav-voice-name { font-size: 14px; font-weight: 600; color: var(--text-primary); margin-top: 4px; }
.tm-nav-instruction { font-size: 16px; font-weight: 500; color: var(--text-primary); text-align: center; line-height: 1.6; background: var(--win-body-bg); padding: 16px; border-radius: 12px; border: 1px solid var(--border-light); min-height: 80px; display: flex; align-items: center; justify-content: center; }
.tm-nav-hazard { background: #fff3e0; padding: 8px 12px; border-radius: 8px; font-size: 12px; color: #e65100; text-align: center; }
[data-theme="dark"] .tm-nav-hazard { background: #3e2723; color: #ffab40; }
.tm-next-btn { padding: 14px; background: #2e7d32; color: #fff; border: none; border-radius: 12px; font-size: 15px; font-weight: 700; cursor: pointer; text-align: center; width: 100%; }
.tm-next-btn:hover { background: #1b5e20; }

/* Arrived */
.tm-arrived { align-items: center; text-align: center; justify-content: center; }
.tm-arrived-emoji { font-size: 72px; }
.tm-arrived-title { font-size: 24px; font-weight: 700; color: var(--text-primary); }
.tm-arrived-place { font-size: 14px; color: var(--text-secondary); }
.tm-arrived-details { display: flex; gap: 12px; justify-content: center; font-size: 13px; color: var(--text-muted); }
.tm-arrived-coins { font-size: 22px; font-weight: 700; color: #2e7d32; margin-top: 4px; }
.tm-arrived-badges { margin-top: 8px; }
.tm-arrived-badges > div:first-child { font-size: 13px; font-weight: 600; color: var(--text-secondary); }
.tm-new-badge { font-size: 16px; margin-top: 4px; color: var(--text-primary); }

/* Treasure Hunt */
.tm-hunt-step-indicator { display: flex; gap: 8px; justify-content: center; }
.tm-hunt-dot { width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; background: var(--border-light); color: var(--text-muted); }
.tm-hunt-dot-active { background: #2e7d32; color: #fff; }
.tm-hunt-dot-done { background: #66bb6a; color: #fff; }
.tm-hunt-step-title { text-align: center; font-size: 16px; font-weight: 700; color: var(--text-primary); }
.tm-hunt-field { display: flex; flex-direction: column; gap: 6px; }
.tm-hunt-field label { font-size: 12px; font-weight: 600; color: var(--text-muted); text-transform: uppercase; }
.tm-input { padding: 10px 12px; border: 2px solid var(--border-light); border-radius: 10px; font-size: 14px; background: var(--win-body-bg); color: var(--text-primary); outline: none; box-sizing: border-box; }
.tm-input:focus { border-color: #2e7d32; }
.tm-hunt-places { display: flex; flex-wrap: wrap; gap: 6px; }
.tm-treasure-btn { padding: 8px 12px; border: 1px solid var(--border-light); border-radius: 8px; background: var(--win-body-bg); cursor: pointer; font-size: 12px; color: var(--text-primary); text-align: left; }
.tm-treasure-btn:hover { border-color: #66bb6a; }
.tm-treasure-btn-active { border-color: #2e7d32; background: rgba(46,125,50,.08); }
[data-theme="dark"] .tm-treasure-btn-active { background: rgba(46,125,50,.25); }
.tm-clue-item { display: flex; justify-content: space-between; align-items: center; padding: 8px 10px; background: var(--win-body-bg); border: 1px solid var(--border-light); border-radius: 8px; font-size: 12px; color: var(--text-primary); }
.tm-clue-remove { background: none; border: none; color: #e53935; cursor: pointer; font-size: 14px; }
.tm-clue-templates { display: flex; flex-direction: column; gap: 4px; }
.tm-treasure-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.tm-treasure-pick { display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 12px 8px; border: 2px solid var(--border-light); border-radius: 12px; background: var(--win-body-bg); cursor: pointer; }
.tm-treasure-pick:hover { border-color: #66bb6a; }
.tm-treasure-pick-active { border-color: #2e7d32; background: rgba(46,125,50,.08); }
[data-theme="dark"] .tm-treasure-pick-active { background: rgba(46,125,50,.25); }
.tm-treasure-pick-emoji { font-size: 32px; }
.tm-treasure-pick-name { font-size: 11px; font-weight: 600; color: var(--text-primary); text-align: center; }
.tm-hunt-summary { display: flex; flex-direction: column; gap: 8px; background: var(--win-body-bg); padding: 14px; border-radius: 12px; border: 1px solid var(--border-light); }
.tm-hunt-summary-row { font-size: 13px; color: var(--text-primary); }
.tm-hunt-summary-row strong { color: var(--text-muted); }

/* Navigation Map */
.tm-map-canvas { width: 100%; border-radius: 4px; border: none; display: block; background: transparent; }

/* Explore */
.tm-explore-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.tm-explore-card { background: var(--win-body-bg); border: 1px solid var(--border-light); border-radius: 12px; padding: 16px 8px; text-align: center; cursor: pointer; transition: transform .15s; }
.tm-explore-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,.1); }
.tm-explore-emoji { font-size: 32px; }
.tm-explore-name { font-size: 13px; font-weight: 600; color: var(--text-primary); margin-top: 6px; }

/* Lists */
.tm-list-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: var(--win-body-bg); border: 1px solid var(--border-light); border-radius: 10px; cursor: pointer; }
.tm-list-item:hover { background: rgba(46,125,50,.04); }
.tm-list-emoji { font-size: 24px; flex-shrink: 0; }
.tm-list-name { flex: 1; font-size: 13px; font-weight: 600; color: var(--text-primary); }
.tm-list-remove { background: none; border: none; color: #e53935; cursor: pointer; font-size: 14px; padding: 4px; }
.tm-list-clues { font-size: 11px; color: var(--text-muted); }
.tm-empty { text-align: center; color: var(--text-muted); font-size: 13px; padding: 20px; }

/* Vault */
.tm-vault-stats { display: flex; gap: 8px; }
.tm-vault-stat { flex: 1; text-align: center; background: var(--win-body-bg); padding: 14px 8px; border-radius: 12px; border: 1px solid var(--border-light); }
.tm-vault-stat-num { font-size: 22px; font-weight: 700; color: #2e7d32; }
.tm-vault-stat-label { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.tm-vault-badges { display: flex; gap: 8px; flex-wrap: wrap; }
.tm-vault-badge { text-align: center; font-size: 24px; background: var(--win-body-bg); padding: 8px 12px; border-radius: 10px; border: 1px solid var(--border-light); min-width: 70px; }
.tm-vault-badge small { display: block; font-size: 10px; color: var(--text-muted); }
.tm-badge-locked { opacity: .4; filter: grayscale(1); }
.tm-quest-card { display: flex; gap: 10px; align-items: center; padding: 12px 14px; background: var(--win-body-bg); border: 1px solid var(--border-light); border-radius: 10px; font-size: 13px; color: var(--text-primary); }
.tm-quest-done { background: #e8f5e9; border-color: #a5d6a7; }
[data-theme="dark"] .tm-quest-done { background: #1b5e20; border-color: #2e7d32; }
.tm-trip-card { display: flex; gap: 8px; align-items: center; padding: 8px 12px; background: var(--win-body-bg); border: 1px solid var(--border-light); border-radius: 8px; font-size: 13px; color: var(--text-primary); }

/* Animations */
@keyframes tm-bounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-16px); }
}
@keyframes tm-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .7; }
}
.tm-bounce { animation: tm-bounce 1s ease-in-out infinite; }
.tm-pulse { animation: tm-pulse 1.5s ease-in-out infinite; }

/* ===== TinyScanner ===== */
.ts-app { height: 100%; display: flex; flex-direction: column; background: #1a2332; font-family: inherit; }

/* Home / Camera */
.ts-camera { flex: 1; display: flex; flex-direction: column; position: relative; overflow: hidden; }
#ts-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.ts-hud { flex: 1; position: relative; display: flex; align-items: center; justify-content: center; z-index: 1; }
.ts-has-photo { background-size: cover; background-position: center; }
.ts-photo-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.6); z-index: 0; }
.ts-has-photo .ts-scan-anim,
.ts-has-photo .ts-scan-info,
.ts-has-photo .ts-result-header,
.ts-has-photo .ts-result-text,
.ts-has-photo .ts-result-parts,
.ts-has-photo .ts-result-actions,
.ts-has-photo .ts-badge-earned,
.ts-has-photo .ts-serious-header,
.ts-has-photo .ts-serious-footer { position: relative; z-index: 1; }
.ts-has-photo .ts-result-header { background: rgba(0,0,0,.7); padding: 8px 16px; border-radius: 8px; color: #fff; }
.ts-has-photo .ts-result-text { background: rgba(5,10,20,.92); border-color: rgba(0,188,212,.4); color: #fff; }
.ts-has-photo .ts-result-text.ts-rare { background: rgba(5,10,20,.92); color: #ffe082; }
.ts-has-photo .ts-result-text.ts-mystery-text { background: rgba(5,10,20,.92); color: #e1bee7; }
.ts-has-photo .ts-result-text.ts-serious { background: rgba(5,10,20,.92); color: #ffcc80; }
.ts-has-photo .ts-part { background: rgba(5,10,20,.92); border-color: rgba(0,188,212,.35); color: #fff; }
.ts-has-photo .ts-badge-earned { background: rgba(5,10,20,.92); color: #ffe082; }
.ts-has-photo .ts-scan-info { background: rgba(5,10,20,.85); padding: 16px; border-radius: 12px; }
.ts-has-photo .ts-beep { color: #fff; }
.ts-has-photo .ts-status { color: #e0e0e0; }
.ts-has-photo .ts-progress-label { color: #bdbdbd; }
.ts-has-photo .ts-serious-header { background: rgba(0,0,0,.7); padding: 6px 14px; border-radius: 8px; color: #ffcc80; }
.ts-has-photo .ts-serious-footer { background: rgba(0,0,0,.7); padding: 4px 12px; border-radius: 6px; color: #e0e0e0; }
.ts-crosshair { width: 120px; height: 120px; border: 3px solid #00bcd4; border-radius: 50%; position: relative; animation: ts-pulse 2s ease-in-out infinite; }
.ts-crosshair::before, .ts-crosshair::after { content: ''; position: absolute; background: #00bcd4; }
.ts-crosshair::before { width: 2px; height: 30px; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.ts-crosshair::after { width: 30px; height: 2px; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.ts-scan-lines { position: absolute; inset: 0; background: repeating-linear-gradient(0deg, transparent, transparent 3px, rgba(0,188,212,.04) 3px, rgba(0,188,212,.04) 4px); pointer-events: none; }
.ts-hud-text { position: absolute; bottom: 12px; left: 0; right: 0; text-align: center; font-size: 13px; color: #4dd0e1; opacity: .7; }
@keyframes ts-pulse { 0%, 100% { transform: scale(1); opacity: .8; } 50% { transform: scale(1.08); opacity: 1; } }

.ts-controls { padding: 16px; display: flex; flex-direction: column; gap: 10px; background: rgba(0,0,0,.3); z-index: 1; position: relative; }
.ts-toggles { display: flex; align-items: center; justify-content: space-between; }
.ts-toggle { display: flex; align-items: center; gap: 8px; font-size: 13px; color: #b0bec5; cursor: pointer; }
.ts-toggle-check { width: 18px; height: 18px; border-radius: 4px; border: 2px solid #546e7a; display: inline-flex; align-items: center; justify-content: center; transition: all .2s; }
.ts-toggle-check.active { background: #00bcd4; border-color: #00bcd4; }
.ts-toggle-check.active::after { content: '✓'; font-size: 12px; color: #fff; }
.ts-mystery-btn { background: none; border: 2px solid #546e7a; border-radius: 8px; font-size: 20px; padding: 4px 10px; cursor: pointer; transition: all .2s; }
.ts-mystery-btn:hover { border-color: #00bcd4; background: rgba(0,188,212,.15); }
.ts-scan-btn { padding: 16px; font-size: 22px; font-weight: 700; border: none; border-radius: 14px; background: linear-gradient(135deg, #00bcd4, #0097a7); color: #fff; cursor: pointer; letter-spacing: 1px; transition: transform .15s; }
.ts-scan-btn:active { transform: scale(.96); }
.ts-collection-btn { padding: 10px; font-size: 14px; border: none; border-radius: 10px; background: rgba(0,188,212,.15); color: #4dd0e1; cursor: pointer; }

/* Scanning */
.ts-scanning { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 24px; padding: 24px; }
.ts-scan-anim { width: 160px; height: 160px; border-radius: 50%; background: radial-gradient(circle, rgba(0,188,212,.15), transparent 70%); position: relative; display: flex; align-items: center; justify-content: center; }
.ts-scan-beam { width: 120px; height: 4px; background: linear-gradient(90deg, transparent, #00bcd4, transparent); border-radius: 2px; animation: ts-beam 1s ease-in-out infinite; }
@keyframes ts-beam { 0%, 100% { transform: translateY(-40px); opacity: .3; } 50% { transform: translateY(40px); opacity: 1; } }
.ts-scan-info { text-align: center; display: flex; flex-direction: column; gap: 10px; }
.ts-beep { font-size: 20px; font-weight: 700; color: #4dd0e1; letter-spacing: 2px; animation: ts-blink .6s steps(2) infinite; }
@keyframes ts-blink { 50% { opacity: .4; } }
.ts-status { font-size: 14px; color: #b0bec5; min-height: 20px; }
.ts-progress-wrap { width: 220px; height: 8px; background: rgba(255,255,255,.1); border-radius: 4px; overflow: hidden; }
.ts-progress-bar { height: 100%; background: linear-gradient(90deg, #00bcd4, #4dd0e1); border-radius: 4px; transition: width .4s ease; }
.ts-progress-label { font-size: 12px; color: #78909c; }

/* Result */
.ts-result { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; padding: 24px; text-align: center; }
.ts-result-header { font-size: 16px; font-weight: 700; color: #4dd0e1; text-transform: uppercase; letter-spacing: 2px; }
.ts-result-text { font-size: 17px; line-height: 1.6; color: #eceff1; padding: 16px; background: rgba(0,188,212,.08); border: 1px solid rgba(0,188,212,.2); border-radius: 12px; max-width: 340px; }
.ts-result-text.ts-rare { background: rgba(255,215,0,.1); border-color: rgba(255,215,0,.3); color: #ffd54f; animation: ts-glow 1.5s ease-in-out infinite; }
@keyframes ts-glow { 0%, 100% { box-shadow: 0 0 8px rgba(255,215,0,.2); } 50% { box-shadow: 0 0 20px rgba(255,215,0,.4); } }
.ts-result-text.ts-mystery-text { background: rgba(156,39,176,.1); border-color: rgba(156,39,176,.3); color: #ce93d8; }
.ts-result-parts { display: flex; flex-direction: column; gap: 8px; max-width: 340px; }
.ts-part { padding: 10px 16px; background: rgba(0,188,212,.08); border: 1px solid rgba(0,188,212,.15); border-radius: 10px; font-size: 16px; color: #e0f7fa; animation: ts-slidein .4s ease both; }
@keyframes ts-slidein { from { opacity: 0; transform: translateX(-20px); } to { opacity: 1; transform: none; } }

.ts-serious-header { font-size: 13px; font-weight: 700; color: #ff8a65; text-transform: uppercase; letter-spacing: 2px; }
.ts-result-text.ts-serious { border-color: rgba(255,138,101,.25); background: rgba(255,138,101,.08); font-family: 'Courier New', monospace; }
.ts-serious-footer { font-size: 12px; color: #78909c; font-style: italic; }

.ts-badge-earned { padding: 10px 16px; background: rgba(255,215,0,.12); border: 1px solid rgba(255,215,0,.3); border-radius: 10px; font-size: 14px; color: #ffd54f; animation: ts-slidein .4s ease both; }

.ts-result-actions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; margin-top: 8px; }
.ts-btn { padding: 10px 16px; font-size: 14px; font-weight: 600; border: none; border-radius: 10px; cursor: pointer; transition: transform .15s; }
.ts-btn:active { transform: scale(.95); }
.ts-btn-primary { background: linear-gradient(135deg, #00bcd4, #0097a7); color: #fff; }
.ts-btn-save { background: rgba(0,188,212,.15); color: #4dd0e1; }
.ts-btn-sticker { background: rgba(255,215,0,.15); color: #ffd54f; }

/* Sticker */
.ts-sticker-screen { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 20px; padding: 24px; }
.ts-sticker-title { font-size: 18px; font-weight: 700; color: #4dd0e1; }
.ts-sticker { background: #fff; color: #333; border-radius: 14px; padding: 20px 28px; text-align: center; max-width: 300px; box-shadow: 0 4px 20px rgba(0,0,0,.3); transform: rotate(-2deg); }
.ts-sticker-badge { font-size: 13px; font-weight: 700; color: #4caf50; letter-spacing: 2px; margin-bottom: 8px; }
.ts-sticker-label { font-size: 18px; font-weight: 700; color: #1a2332; line-height: 1.4; margin-bottom: 8px; }
.ts-sticker-footer { font-size: 11px; color: #999; }

/* Collection */
.ts-collection { flex: 1; display: flex; flex-direction: column; padding: 16px; overflow-y: auto; }
.ts-col-header { display: flex; align-items: center; gap: 10px; font-size: 16px; font-weight: 700; color: #4dd0e1; margin-bottom: 12px; }
.ts-back-btn { background: none; border: none; font-size: 18px; cursor: pointer; padding: 4px 8px; }
.ts-badges { display: flex; gap: 6px; margin-bottom: 10px; }
.ts-badge-icon { font-size: 22px; }
.ts-col-grid { display: flex; flex-direction: column; gap: 8px; }
.ts-scan-card { padding: 12px 14px; background: rgba(0,188,212,.06); border: 1px solid rgba(0,188,212,.12); border-radius: 10px; }
.ts-card-rare { border-color: rgba(255,215,0,.25); background: rgba(255,215,0,.06); }
.ts-card-text { font-size: 14px; color: #eceff1; line-height: 1.4; }
.ts-card-date { font-size: 11px; color: #78909c; margin-top: 4px; }
.ts-empty { text-align: center; padding: 40px 20px; color: #78909c; font-size: 14px; }

/* Light theme overrides */
[data-theme="light"] .ts-app { background: #e8f5f8; }
[data-theme="light"] .ts-controls { background: rgba(0,150,167,.08); }
[data-theme="light"] .ts-hud-text { color: #0097a7; }
[data-theme="light"] .ts-toggle { color: #546e7a; }
[data-theme="light"] .ts-collection-btn { background: rgba(0,150,167,.1); color: #00838f; }
[data-theme="light"] .ts-scanning { background: none; }
[data-theme="light"] .ts-beep { color: #00838f; }
[data-theme="light"] .ts-status { color: #546e7a; }
[data-theme="light"] .ts-progress-label { color: #90a4ae; }
[data-theme="light"] .ts-result-header { color: #00838f; }
[data-theme="light"] .ts-result-text { color: #37474f; background: rgba(0,150,167,.06); border-color: rgba(0,150,167,.15); }
[data-theme="light"] .ts-part { color: #263238; background: rgba(0,150,167,.06); border-color: rgba(0,150,167,.12); }
[data-theme="light"] .ts-scan-card { background: rgba(0,150,167,.05); border-color: rgba(0,150,167,.1); }
[data-theme="light"] .ts-card-text { color: #37474f; }
[data-theme="light"] .ts-back-btn { color: #37474f; }
[data-theme="light"] .ts-col-header { color: #00838f; }
[data-theme="light"] .ts-crosshair { border-color: #0097a7; }
[data-theme="light"] .ts-crosshair::before, [data-theme="light"] .ts-crosshair::after { background: #0097a7; }

/* ===== Update Popup ===== */
.update-popup-overlay {
  position: fixed; inset: 0; z-index: 10000;
  background: rgba(0,0,0,0.55); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .3s ease;
  pointer-events: none;
}
.update-popup-overlay.visible { opacity: 1; pointer-events: auto; }
.update-popup {
  background: #1e2a3a; border-radius: 18px; padding: 32px 36px 24px;
  max-width: 400px; width: 90%; text-align: center;
  box-shadow: 0 12px 48px rgba(0,0,0,.5);
  transform: translateY(30px) scale(.95); transition: transform .35s cubic-bezier(.22,1,.36,1);
}
.update-popup-overlay.visible .update-popup { transform: translateY(0) scale(1); }
.update-popup-icon { font-size: 56px; margin-bottom: 8px; animation: up-bounce 1.2s ease infinite alternate; }
@keyframes up-bounce { 0%{transform:translateY(0)} 100%{transform:translateY(-8px)} }
.update-popup-title { font: bold 20px/1.3 sans-serif; color: #fff; margin-bottom: 10px; }
.update-popup-body { font: 15px/1.5 sans-serif; color: #b0bec5; margin-bottom: 14px; }
.update-popup-version { font: 600 13px/1 monospace; color: #5b8cff; background: rgba(91,140,255,.12); border-radius: 8px; padding: 8px 14px; display: inline-block; margin-bottom: 18px; }
.update-popup-buttons { display: flex; gap: 12px; justify-content: center; margin-bottom: 12px; }
.update-popup-btn { border: none; border-radius: 10px; padding: 10px 24px; font: 600 15px sans-serif; cursor: pointer; transition: background .15s, transform .1s; }
.update-popup-btn:active { transform: scale(.96); }
.update-popup-later { background: #37474f; color: #b0bec5; }
.update-popup-later:hover { background: #455a64; }
.update-popup-go { background: #4caf50; color: #fff; }
.update-popup-go:hover { background: #43a047; }
.update-popup-go:disabled { background: #666; cursor: wait; }
.update-popup-note { font: 12px/1 sans-serif; color: #607d8b; }

[data-theme="light"] .update-popup { background: #fff; box-shadow: 0 12px 48px rgba(0,0,0,.18); }
[data-theme="light"] .update-popup-title { color: #1a237e; }
[data-theme="light"] .update-popup-body { color: #546e7a; }
[data-theme="light"] .update-popup-version { color: #1565c0; background: rgba(21,101,192,.08); }
[data-theme="light"] .update-popup-later { background: #e0e0e0; color: #546e7a; }
[data-theme="light"] .update-popup-later:hover { background: #ccc; }
[data-theme="light"] .update-popup-note { color: #90a4ae; }

/* ===== Breakout ===== */
.bo-wrap { display: flex; flex-direction: column; background: #1a1a2e; height: 100%; overflow: hidden; }
.bo-hud { display: flex; align-items: center; justify-content: center; gap: 16px; padding: 5px 10px; color: #b0bec5; font: 600 13px/1 sans-serif; flex-shrink: 0; }
.bo-hud b { color: #5b8cff; }
.bo-play-btn { background: #5b8cff; color: #fff; border: none; border-radius: 6px; padding: 4px 14px; font: 600 13px sans-serif; cursor: pointer; margin-left: 4px; transition: background .15s; }
.bo-play-btn:hover { background: #3a6ee8; }
.bo-play-btn:active { background: #2a56c6; }
#bo-canvas { flex: 1; width: 100%; min-height: 0; background: #1a1a2e; touch-action: none; }

[data-theme="light"] .bo-wrap { background: #e8eaf6; }
[data-theme="light"] .bo-hud { color: #546e7a; }
[data-theme="light"] .bo-hud b { color: #1565c0; }
[data-theme="light"] #bo-canvas { background: #e8eaf6; }

/* ===== SillySkies ===== */
.ss-wrap { display: flex; flex-direction: column; height: 100%; background: #fff8e1; overflow-y: auto; font-family: sans-serif; }
.ss-header { display: flex; align-items: center; gap: 8px; padding: 10px 14px; font: 700 15px/1.2 sans-serif; color: #e65100; background: linear-gradient(135deg, #fff8e1, #ffe0b2); border-bottom: 2px solid #ffcc80; flex-shrink: 0; }
.ss-header-icon { font-size: 20px; }
.ss-back { background: none; border: none; font-size: 20px; cursor: pointer; padding: 0 4px; line-height: 1; }

/* Place selector */
.ss-places { display: flex; gap: 6px; padding: 10px 14px; flex-wrap: wrap; }
.ss-place-btn { background: #fff; border: 2px solid #ffcc80; border-radius: 20px; padding: 6px 12px; font: 600 12px sans-serif; cursor: pointer; transition: all .15s; }
.ss-place-btn.ss-active { background: #ff9800; color: #fff; border-color: #ff9800; }
.ss-place-btn:hover { background: #ffe0b2; }
.ss-place-btn.ss-active:hover { background: #fb8c00; }

/* Today card */
.ss-today-card { text-align: center; padding: 10px 14px 14px; }
.ss-weather-icon { font-size: 56px; cursor: pointer; display: inline-block; line-height: 1.2; }
.ss-weather-name { font: 700 20px sans-serif; color: #e65100; margin: 4px 0; }
.ss-temp { font: 700 28px sans-serif; color: #ff6d00; }
.ss-feels { font: 13px sans-serif; color: #8d6e63; margin: 4px 0; }
.ss-warning { display: inline-block; background: #fff3e0; border: 1px solid #ffab40; border-radius: 8px; padding: 4px 10px; font: 600 12px sans-serif; color: #e65100; margin-top: 6px; }

/* Stats row */
.ss-stats { display: flex; gap: 6px; justify-content: center; flex-wrap: wrap; margin-top: 10px; }
.ss-stat { background: #fff; border: 1px solid #ffe0b2; border-radius: 8px; padding: 6px 10px; font: 12px sans-serif; color: #5d4037; }

/* Buttons */
.ss-actions { display: flex; gap: 8px; padding: 8px 14px; justify-content: center; }
.ss-btn { border: none; border-radius: 10px; padding: 10px 18px; font: 600 13px sans-serif; cursor: pointer; transition: all .15s; }
.ss-btn-primary { background: #ff9800; color: #fff; }
.ss-btn-primary:hover { background: #fb8c00; }
.ss-btn-secondary { background: #42a5f5; color: #fff; }
.ss-btn-secondary:hover { background: #1e88e5; }
.ss-nav-row { display: flex; justify-content: center; padding: 0 14px 12px; }
.ss-nav-btn { background: none; border: 2px dashed #ffcc80; border-radius: 10px; padding: 8px 16px; font: 600 13px sans-serif; color: #e65100; cursor: pointer; transition: all .15s; }
.ss-nav-btn:hover { background: #fff3e0; }

/* Forecast list */
.ss-forecast-list { padding: 8px 14px; display: flex; flex-direction: column; gap: 6px; }
.ss-forecast-card { display: flex; align-items: center; gap: 10px; background: #fff; border: 1px solid #ffe0b2; border-radius: 10px; padding: 10px 12px; cursor: pointer; transition: all .15s; }
.ss-forecast-card:hover { background: #fff3e0; transform: translateX(3px); }
.ss-fc-day { font: 700 13px sans-serif; color: #e65100; min-width: 70px; }
.ss-fc-icon { font-size: 28px; flex-shrink: 0; }
.ss-fc-info { flex: 1; min-width: 0; }
.ss-fc-name { font: 600 13px sans-serif; color: #333; }
.ss-fc-temp { font: 700 14px sans-serif; color: #ff6d00; }
.ss-fc-feels { font: 11px sans-serif; color: #8d6e63; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ss-fc-badge { font-size: 16px; flex-shrink: 0; }

/* Day details */
.ss-day-hero { text-align: center; padding: 14px; }
.ss-detail-section { padding: 6px 14px 8px; }
.ss-section-title { font: 700 13px sans-serif; color: #e65100; margin-bottom: 4px; }
.ss-joke { font: 13px sans-serif; color: #5d4037; background: #fff; border-left: 3px solid #ffcc80; padding: 6px 10px; margin: 4px 0; border-radius: 0 6px 6px 0; }
.ss-wear { font: 600 13px sans-serif; color: #ff6d00; background: #fff; border-radius: 8px; padding: 8px 10px; }
.ss-bring-list { background: #fff; border-radius: 8px; padding: 8px 10px; }
.ss-bring-item { font: 13px sans-serif; color: #5d4037; padding: 2px 0; }

/* Mixer */
.ss-mixer { padding: 10px 14px; }
.ss-mixer-group { margin-bottom: 12px; }
.ss-mixer-label { font: 700 13px sans-serif; color: #e65100; margin-bottom: 6px; }
.ss-mixer-pills { display: flex; gap: 6px; flex-wrap: wrap; }
.ss-pill { background: #fff; border: 2px solid #ffe0b2; border-radius: 16px; padding: 6px 12px; font: 12px sans-serif; cursor: pointer; transition: all .15s; }
.ss-pill.ss-active { background: #ff9800; color: #fff; border-color: #ff9800; }
.ss-pill:hover { background: #ffe0b2; }
.ss-pill.ss-active:hover { background: #fb8c00; }
.ss-generate-btn { width: 100%; margin-top: 4px; font-size: 15px; padding: 12px; }

/* Mix result */
.ss-mix-result { margin-top: 12px; background: #fff; border: 2px solid #ffcc80; border-radius: 12px; padding: 14px; text-align: center; }
.ss-mix-result-name { font: 700 18px sans-serif; color: #e65100; margin-bottom: 6px; }
.ss-mix-result-lines { font: 13px sans-serif; color: #5d4037; margin-bottom: 10px; }
.ss-mix-result-lines div { margin: 3px 0; }

/* Silliness meter */
.ss-silliness { display: flex; align-items: center; gap: 8px; justify-content: center; font: 600 12px sans-serif; color: #8d6e63; }
.ss-meter { width: 100px; height: 12px; background: #ffe0b2; border-radius: 6px; overflow: hidden; }
.ss-meter-fill { height: 100%; background: linear-gradient(90deg, #ffcc80, #ff9800, #ff6d00); border-radius: 6px; transition: width .3s; }
.ss-meter-label { font: 700 13px sans-serif; color: #ff6d00; }

/* Animations */
@keyframes ss-bounce { 0%,100% { transform: scale(1); } 30% { transform: scale(1.3); } 60% { transform: scale(0.9); } }
@keyframes ss-float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-6px); } }
.ss-bounce { animation: ss-bounce .4s ease; }
.ss-float { animation: ss-float 2s ease-in-out infinite; }

/* Dark theme */
[data-theme="dark"] .ss-wrap { background: #2a1f00; }
[data-theme="dark"] .ss-header { background: linear-gradient(135deg, #3e2c00, #4a3200); color: #ffcc80; border-color: #5d4037; }
[data-theme="dark"] .ss-place-btn { background: #3e2c00; color: #ffe0b2; border-color: #5d4037; }
[data-theme="dark"] .ss-place-btn.ss-active { background: #e65100; border-color: #e65100; color: #fff; }
[data-theme="dark"] .ss-place-btn:hover { background: #4a3200; }
[data-theme="dark"] .ss-today-card { color: #ffe0b2; }
[data-theme="dark"] .ss-weather-name { color: #ffcc80; }
[data-theme="dark"] .ss-temp { color: #ffab40; }
[data-theme="dark"] .ss-feels { color: #a1887f; }
[data-theme="dark"] .ss-warning { background: #3e2c00; border-color: #8d6e63; color: #ffcc80; }
[data-theme="dark"] .ss-stat { background: #3e2c00; border-color: #5d4037; color: #bcaaa4; }
[data-theme="dark"] .ss-forecast-card { background: #3e2c00; border-color: #5d4037; }
[data-theme="dark"] .ss-forecast-card:hover { background: #4a3200; }
[data-theme="dark"] .ss-fc-name { color: #ffe0b2; }
[data-theme="dark"] .ss-fc-feels { color: #a1887f; }
[data-theme="dark"] .ss-joke { background: #3e2c00; color: #bcaaa4; border-color: #8d6e63; }
[data-theme="dark"] .ss-wear { background: #3e2c00; color: #ffab40; }
[data-theme="dark"] .ss-bring-list { background: #3e2c00; }
[data-theme="dark"] .ss-bring-item { color: #bcaaa4; }
[data-theme="dark"] .ss-back { color: #ffcc80; }
[data-theme="dark"] .ss-pill { background: #3e2c00; color: #ffe0b2; border-color: #5d4037; }
[data-theme="dark"] .ss-pill.ss-active { background: #e65100; border-color: #e65100; color: #fff; }
[data-theme="dark"] .ss-pill:hover { background: #4a3200; }
[data-theme="dark"] .ss-mix-result { background: #3e2c00; border-color: #8d6e63; }
[data-theme="dark"] .ss-mix-result-name { color: #ffcc80; }
[data-theme="dark"] .ss-mix-result-lines { color: #bcaaa4; }
[data-theme="dark"] .ss-silliness { color: #a1887f; }
[data-theme="dark"] .ss-meter { background: #5d4037; }
[data-theme="dark"] .ss-nav-btn { border-color: #5d4037; color: #ffcc80; }
[data-theme="dark"] .ss-nav-btn:hover { background: #3e2c00; }
[data-theme="dark"] .ss-section-title { color: #ffcc80; }

/* ===== Giggle Coins Toast ===== */
.gc-toast {
  position: fixed; top: 18px; right: 18px; z-index: 10001;
  display: flex; align-items: center; gap: 10px;
  padding: 12px 18px; border-radius: 14px;
  background: linear-gradient(135deg, #ffd600, #ffab00);
  color: #3e2723; font-family: inherit;
  box-shadow: 0 4px 20px rgba(255,171,0,0.45);
  transform: translateX(120%); transition: none;
  pointer-events: none; max-width: 340px;
}
.gc-toast.gc-toast-in {
  transform: translateX(0);
  transition: transform .35s cubic-bezier(.22,1,.36,1);
}
.gc-toast-icon { font-size: 28px; flex-shrink: 0; }
.gc-toast-body { min-width: 0; }
.gc-toast-title { font-weight: 700; font-size: 15px; white-space: nowrap; }
.gc-toast-desc { font-size: 12px; opacity: .8; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.gc-toast-out {
  animation: gc-slide-out .3s ease-in forwards;
}
@keyframes gc-slide-out {
  to { transform: translateX(140%); opacity: 0; }
}
[data-theme="dark"] .gc-toast {
  background: linear-gradient(135deg, #5d4037, #4e342e);
  color: #ffe082; box-shadow: 0 4px 20px rgba(0,0,0,0.5);
}

/* ===== Captain Cardio ===== */
.cc-wrap {
  height: 100%; display: flex; flex-direction: column; overflow-y: auto;
  background: linear-gradient(160deg, #0d1b2a 0%, #1b2838 100%);
  color: #e0e0e0; font-family: var(--font);
}

/* Bridge */
.cc-bridge { padding: 16px; display: flex; flex-direction: column; gap: 12px; }
.cc-captain-bubble {
  display: flex; gap: 12px; align-items: flex-start;
  background: rgba(255,255,255,0.08); border-radius: 14px; padding: 14px;
}
.cc-captain-avatar { font-size: 36px; flex-shrink: 0; }
.cc-captain-text { font-size: 14px; line-height: 1.5; }
.cc-captain-text strong { color: #ffd600; }
.cc-theme-badge {
  text-align: center; padding: 8px 14px; border-radius: 20px;
  background: rgba(255,109,0,0.15); color: #ffab40; font-size: 13px; font-weight: 600;
}
.cc-rank { text-align: center; font-size: 13px; color: #90caf9; }
.cc-rank strong { color: #ffd600; }

/* Progress */
.cc-progress-section { display: flex; flex-direction: column; gap: 6px; }
.cc-progress-label { font-size: 13px; color: #b0bec5; }
.cc-progress-bar {
  height: 14px; border-radius: 7px; background: rgba(255,255,255,0.1); overflow: hidden;
}
.cc-progress-fill {
  height: 100%; border-radius: 7px; background: linear-gradient(90deg, #ff6d00, #ff9100);
  transition: width 0.4s ease;
}
.cc-progress-fill.cc-goal-met { background: linear-gradient(90deg, #66bb6a, #43a047); }

/* Goal pills */
.cc-goal-row { display: flex; gap: 8px; justify-content: center; }
.cc-goal-pill {
  padding: 6px 14px; border-radius: 16px; border: 2px solid rgba(255,255,255,0.15);
  background: transparent; color: #b0bec5; font-size: 13px; cursor: pointer;
  transition: all 0.2s;
}
.cc-goal-pill:hover { border-color: #ff9100; color: #fff; }
.cc-goal-pill.cc-goal-active {
  border-color: #ff6d00; background: rgba(255,109,0,0.2); color: #ffd600; font-weight: 700;
}

/* Streak */
.cc-streak-row { text-align: center; font-size: 13px; color: #ffab40; }
.cc-streak-row strong { color: #ffd600; }

/* Badges row */
.cc-badges-row { display: flex; gap: 6px; justify-content: center; flex-wrap: wrap; }
.cc-badge-mini { font-size: 22px; cursor: default; }

/* Start button */
.cc-start-btn {
  display: block; width: 100%; padding: 14px; border: none; border-radius: 14px;
  background: linear-gradient(135deg, #ff6d00, #ff9100); color: #fff;
  font-size: 17px; font-weight: 700; cursor: pointer; text-align: center;
  box-shadow: 0 4px 16px rgba(255,109,0,0.35); transition: transform 0.15s, box-shadow 0.15s;
}
.cc-start-btn:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(255,109,0,0.45); }
.cc-start-btn:active { transform: translateY(0); }

/* Recommended */
.cc-rec-section { display: flex; flex-direction: column; gap: 6px; }
.cc-rec-title { font-size: 12px; color: #78909c; text-transform: uppercase; letter-spacing: 0.5px; }
.cc-rec-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 14px; border-radius: 10px; border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04); color: #e0e0e0; font-size: 14px;
  cursor: pointer; text-align: left; width: 100%; transition: background 0.2s;
}
.cc-rec-item:hover { background: rgba(255,255,255,0.1); }
.cc-rec-item.cc-rec-done { opacity: 0.5; }
.cc-nav-link {
  display: block; text-align: center; padding: 10px; border: none;
  background: transparent; color: #64b5f6; font-size: 14px; cursor: pointer;
}
.cc-nav-link:hover { color: #90caf9; text-decoration: underline; }

/* Select screen */
.cc-select { padding: 12px; display: flex; flex-direction: column; gap: 12px; }
.cc-select-header {
  display: flex; align-items: center; gap: 12px; font-size: 16px; font-weight: 700; color: #ffd600;
}
.cc-back-btn {
  padding: 6px 12px; border-radius: 8px; border: 1px solid rgba(255,255,255,0.15);
  background: transparent; color: #90caf9; font-size: 13px; cursor: pointer;
}
.cc-back-btn:hover { background: rgba(255,255,255,0.08); }
.cc-pack-card {
  border-radius: 12px; border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04); overflow: hidden;
}
.cc-pack-header { padding: 12px 14px; font-size: 15px; line-height: 1.4; }
.cc-pack-vibe { font-size: 12px; color: #78909c; }
.cc-pack-missions { display: flex; flex-direction: column; }
.cc-mission-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 14px; border-top: 1px solid rgba(255,255,255,0.06);
  background: transparent; color: #e0e0e0; font-size: 14px; cursor: pointer;
  width: 100%; text-align: left; border-left: none; border-right: none; border-bottom: none;
  transition: background 0.15s;
}
.cc-mission-item:hover { background: rgba(255,255,255,0.08); }
.cc-mission-recommended { border-left: 3px solid #ff6d00 !important; }
.cc-mission-today { opacity: 0.55; }
.cc-mission-name { flex: 1; }
.cc-mission-meta { font-size: 13px; flex-shrink: 0; margin-left: 8px; }

/* Active mission */
.cc-active {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 24px 16px; gap: 16px; min-height: 100%; text-align: center;
}
.cc-phase-dots { display: flex; gap: 10px; justify-content: center; }
.cc-phase-dot {
  font-size: 20px; opacity: 0.3; transition: opacity 0.3s, transform 0.3s;
}
.cc-phase-dot-done { opacity: 0.7; }
.cc-phase-dot-active { opacity: 1; transform: scale(1.3); }
.cc-timer-section { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.cc-phase-name { font-size: 18px; font-weight: 700; color: #ffd600; }
.cc-timer-display {
  font-size: 64px; font-weight: 800; color: #ff6d00;
  font-variant-numeric: tabular-nums; line-height: 1;
}
.cc-instruction { font-size: 16px; color: #e0e0e0; max-width: 320px; line-height: 1.5; }

/* Pulse animation */
.cc-pulse { animation: cc-pulse 1.2s ease-in-out infinite; }
@keyframes cc-pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.06); }
}

/* Captain command bubble */
.cc-command-bubble {
  display: flex; align-items: center; gap: 10px;
  background: rgba(255,214,0,0.1); border-radius: 14px; padding: 10px 16px;
  max-width: 320px;
}
.cc-command-avatar { font-size: 28px; flex-shrink: 0; }
.cc-command-text { font-size: 14px; font-style: italic; color: #ffd600; }

/* Skip button */
.cc-skip-btn {
  padding: 10px 24px; border-radius: 10px; border: 2px solid rgba(255,255,255,0.15);
  background: transparent; color: #90caf9; font-size: 14px; cursor: pointer;
  transition: all 0.2s;
}
.cc-skip-btn:hover { border-color: #64b5f6; background: rgba(100,181,246,0.1); }

/* Complete screen */
.cc-complete {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 24px 16px; gap: 14px; min-height: 100%; text-align: center;
}
.cc-complete-emoji { font-size: 56px; }
.cc-complete-title { font-size: 24px; font-weight: 800; color: #ffd600; }
.cc-praise { font-size: 16px; color: #e0e0e0; max-width: 300px; line-height: 1.5; }
.cc-coins-display {
  font-size: 20px; font-weight: 700; color: #ffd600;
  background: rgba(255,214,0,0.12); padding: 10px 20px; border-radius: 12px;
}
.cc-new-badges { display: flex; flex-direction: column; gap: 6px; }
.cc-new-badge {
  padding: 8px 16px; border-radius: 10px;
  background: rgba(102,187,106,0.15); color: #a5d6a7; font-size: 14px;
}
.cc-hydrate {
  padding: 10px 16px; border-radius: 10px;
  background: rgba(66,165,245,0.12); color: #90caf9; font-size: 14px;
}
.cc-complete-btns { display: flex; flex-direction: column; gap: 8px; width: 100%; max-width: 300px; }

/* Captain's Log */
.cc-log { padding: 12px; display: flex; flex-direction: column; gap: 14px; }
.cc-log-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.cc-log-stat {
  text-align: center; padding: 14px 8px; border-radius: 12px;
  background: rgba(255,255,255,0.06);
}
.cc-log-stat-val { font-size: 28px; font-weight: 800; color: #ffd600; }
.cc-log-stat-label { font-size: 12px; color: #78909c; margin-top: 4px; }
.cc-log-rank { text-align: center; font-size: 14px; color: #90caf9; }
.cc-log-rank strong { color: #ffd600; }
.cc-log-section-title {
  font-size: 13px; color: #78909c; text-transform: uppercase;
  letter-spacing: 0.5px; border-bottom: 1px solid rgba(255,255,255,0.08); padding-bottom: 6px;
}
.cc-badge-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.cc-badge-card {
  text-align: center; padding: 12px 8px; border-radius: 12px;
  background: rgba(255,255,255,0.06); transition: transform 0.15s;
}
.cc-badge-card:hover { transform: translateY(-2px); }
.cc-badge-locked { opacity: 0.35; }
.cc-badge-emoji { font-size: 28px; }
.cc-badge-name { font-size: 13px; font-weight: 700; color: #e0e0e0; margin-top: 4px; }
.cc-badge-desc { font-size: 11px; color: #78909c; margin-top: 2px; }
.cc-log-pack {
  padding: 8px 12px; border-radius: 8px; background: rgba(255,255,255,0.04);
  font-size: 14px; color: #b0bec5;
}

/* Light theme — keep space feel but lighter */
[data-theme="light"] .cc-wrap { background: linear-gradient(160deg, #e8eaf6 0%, #c5cae9 100%); color: #333; }
[data-theme="light"] .cc-captain-bubble { background: rgba(0,0,0,0.05); }
[data-theme="light"] .cc-captain-text { color: #333; }
[data-theme="light"] .cc-captain-text strong { color: #e65100; }
[data-theme="light"] .cc-theme-badge { background: rgba(255,109,0,0.1); color: #e65100; }
[data-theme="light"] .cc-rank { color: #1565c0; }
[data-theme="light"] .cc-rank strong { color: #e65100; }
[data-theme="light"] .cc-progress-label { color: #555; }
[data-theme="light"] .cc-progress-bar { background: rgba(0,0,0,0.08); }
[data-theme="light"] .cc-goal-pill { border-color: rgba(0,0,0,0.12); color: #555; }
[data-theme="light"] .cc-goal-pill.cc-goal-active { border-color: #ff6d00; color: #e65100; background: rgba(255,109,0,0.08); }
[data-theme="light"] .cc-streak-row { color: #e65100; }
[data-theme="light"] .cc-streak-row strong { color: #bf360c; }
[data-theme="light"] .cc-rec-item { border-color: rgba(0,0,0,0.08); background: rgba(0,0,0,0.03); color: #333; }
[data-theme="light"] .cc-nav-link { color: #1565c0; }
[data-theme="light"] .cc-select-header { color: #e65100; }
[data-theme="light"] .cc-back-btn { border-color: rgba(0,0,0,0.12); color: #1565c0; }
[data-theme="light"] .cc-pack-card { border-color: rgba(0,0,0,0.08); background: rgba(255,255,255,0.6); }
[data-theme="light"] .cc-pack-header { color: #333; }
[data-theme="light"] .cc-mission-item { border-color: rgba(0,0,0,0.06); color: #333; }
[data-theme="light"] .cc-phase-name { color: #e65100; }
[data-theme="light"] .cc-timer-display { color: #ff6d00; }
[data-theme="light"] .cc-instruction { color: #333; }
[data-theme="light"] .cc-command-bubble { background: rgba(255,214,0,0.12); }
[data-theme="light"] .cc-command-text { color: #e65100; }
[data-theme="light"] .cc-skip-btn { border-color: rgba(0,0,0,0.15); color: #1565c0; }
[data-theme="light"] .cc-complete-title { color: #e65100; }
[data-theme="light"] .cc-praise { color: #333; }
[data-theme="light"] .cc-coins-display { color: #e65100; background: rgba(255,214,0,0.15); }
[data-theme="light"] .cc-new-badge { background: rgba(76,175,80,0.12); color: #2e7d32; }
[data-theme="light"] .cc-hydrate { background: rgba(33,150,243,0.1); color: #1565c0; }
[data-theme="light"] .cc-log-stat { background: rgba(0,0,0,0.04); }
[data-theme="light"] .cc-log-stat-val { color: #e65100; }
[data-theme="light"] .cc-log-stat-label { color: #666; }
[data-theme="light"] .cc-log-rank { color: #1565c0; }
[data-theme="light"] .cc-log-rank strong { color: #e65100; }
[data-theme="light"] .cc-log-section-title { color: #666; border-color: rgba(0,0,0,0.08); }
[data-theme="light"] .cc-badge-card { background: rgba(0,0,0,0.04); }
[data-theme="light"] .cc-badge-name { color: #333; }
[data-theme="light"] .cc-badge-desc { color: #666; }
[data-theme="light"] .cc-log-pack { background: rgba(0,0,0,0.03); color: #555; }

/* ===== Pebbles (Pet Rock) ===== */
.pb-wrap { display: flex; flex-direction: column; height: 100%; background: linear-gradient(135deg, #f5f0e8, #e8e0d0); overflow-y: auto; font-family: var(--font); }
[data-theme="dark"] .pb-wrap { background: linear-gradient(135deg, #3e2723, #4e342e); }
.pb-screen { flex: 1; padding: 16px; display: flex; flex-direction: column; align-items: center; gap: 10px; overflow-y: auto; padding-bottom: 60px; }
.pb-home-top { text-align: center; }
.pb-name-display { font-size: 22px; font-weight: 700; color: #5d4037; }
[data-theme="dark"] .pb-name-display { color: #ffcc80; }
.pb-mood { font-size: 13px; font-style: italic; color: #8d6e63; margin-top: 2px; }
[data-theme="dark"] .pb-mood { color: #bcaaa4; }
.pb-rock { position: relative; display: flex; align-items: center; justify-content: center; width: 120px; height: 120px; margin: 8px auto; }
.pb-rock-emoji { font-size: 72px; line-height: 1; transition: transform 0.3s; }
.pb-rock-bounce .pb-rock-emoji { animation: pbBounce 0.5s; }
@keyframes pbBounce { 0%,100% { transform: translateY(0); } 30% { transform: translateY(-8px); } 60% { transform: translateY(-3px); } }
.pb-rock-tilt .pb-rock-emoji { transform: rotate(3deg); }
.pb-rock-legendary .pb-rock-emoji { animation: pbLegendary 3s; }
@keyframes pbLegendary { 0%,100% { filter: drop-shadow(0 0 0 transparent); } 50% { filter: drop-shadow(0 0 16px #ffd54f); } }
.pb-acc { position: absolute; font-size: 24px; pointer-events: none; }
.pb-acc-eyes { top: 22px; left: 50%; transform: translateX(-50%); }
.pb-acc-top { top: 2px; left: 50%; transform: translateX(-50%); font-size: 28px; }
.pb-acc-bottom { bottom: 12px; left: 50%; transform: translateX(-50%); }
.pb-acc-behind { position: absolute; right: 4px; top: 20px; font-size: 32px; opacity: 0.7; }
.pb-bubble { position: absolute; bottom: -36px; left: 50%; transform: translateX(-50%); background: #fff; color: #333; border: 2px solid #8d6e63; border-radius: 12px; padding: 6px 14px; font-size: 13px; white-space: nowrap; max-width: 260px; overflow: hidden; text-overflow: ellipsis; opacity: 0; pointer-events: none; transition: opacity 0.3s; box-shadow: 0 2px 8px rgba(0,0,0,0.12); }
[data-theme="dark"] .pb-bubble { background: #4e342e; color: #ffe0b2; border-color: #8d6e63; }
.pb-bubble-show { opacity: 1; white-space: normal; }
.pb-trick-label { font-size: 13px; color: #795548; }
[data-theme="dark"] .pb-trick-label { color: #bcaaa4; }
.pb-trick-label strong { color: #5d4037; }
[data-theme="dark"] .pb-trick-label strong { color: #ffcc80; }
.pb-meters { width: 100%; max-width: 300px; display: flex; flex-direction: column; gap: 6px; }
.pb-meter { display: flex; align-items: center; gap: 8px; font-size: 12px; }
.pb-meter-label { width: 72px; font-weight: 600; color: #5d4037; text-align: right; }
[data-theme="dark"] .pb-meter-label { color: #bcaaa4; }
.pb-meter-track { flex: 1; height: 10px; background: #d7ccc8; border-radius: 5px; overflow: hidden; }
[data-theme="dark"] .pb-meter-track { background: #5d4037; }
.pb-meter-fill { height: 100%; border-radius: 5px; transition: width 0.5s; }
.pb-meter-desc { width: 100px; font-size: 11px; color: #a1887f; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
[data-theme="dark"] .pb-meter-desc { color: #8d6e63; }
.pb-encourage-btn { padding: 12px 28px; border: none; border-radius: 24px; background: linear-gradient(135deg, #8d6e63, #6d4c41); color: #fff; font-size: 16px; font-weight: 700; cursor: pointer; box-shadow: 0 3px 10px rgba(0,0,0,0.15); transition: transform 0.15s, box-shadow 0.15s; }
.pb-encourage-btn:hover { transform: scale(1.04); box-shadow: 0 4px 14px rgba(0,0,0,0.2); }
.pb-encourage-btn:active { transform: scale(0.97); }
.pb-big-btn { font-size: 20px; padding: 14px 36px; }
.pb-streak { font-size: 13px; color: #8d6e63; margin-top: 4px; }
[data-theme="dark"] .pb-streak { color: #bcaaa4; }
.pb-nav { display: flex; position: sticky; bottom: 0; background: rgba(141,110,99,0.12); border-top: 1px solid rgba(141,110,99,0.2); backdrop-filter: blur(8px); }
[data-theme="dark"] .pb-nav { background: rgba(62,39,35,0.8); border-color: rgba(141,110,99,0.3); }
.pb-nav-btn { flex: 1; border: none; background: none; padding: 8px 4px; display: flex; flex-direction: column; align-items: center; gap: 2px; font-size: 18px; cursor: pointer; color: #795548; transition: background 0.2s; }
.pb-nav-btn span { font-size: 10px; }
[data-theme="dark"] .pb-nav-btn { color: #bcaaa4; }
.pb-nav-active { background: rgba(141,110,99,0.2); color: #5d4037; font-weight: 700; }
[data-theme="dark"] .pb-nav-active { background: rgba(255,204,128,0.15); color: #ffcc80; }
.pb-train-header, .pb-games-header, .pb-profile-header { font-size: 18px; font-weight: 700; color: #5d4037; }
[data-theme="dark"] .pb-train-header, [data-theme="dark"] .pb-games-header, [data-theme="dark"] .pb-profile-header { color: #ffcc80; }
.pb-xp-section { width: 100%; max-width: 300px; text-align: center; }
.pb-xp-label { font-size: 13px; color: #795548; margin-bottom: 4px; }
[data-theme="dark"] .pb-xp-label { color: #bcaaa4; }
.pb-xp-label strong { color: #5d4037; }
[data-theme="dark"] .pb-xp-label strong { color: #ffcc80; }
.pb-xp-track { width: 100%; height: 14px; background: #d7ccc8; border-radius: 7px; overflow: hidden; }
[data-theme="dark"] .pb-xp-track { background: #5d4037; }
.pb-xp-fill { height: 100%; background: linear-gradient(90deg, #ffb74d, #ff9800); border-radius: 7px; transition: width 0.5s; }
.pb-trick-list { width: 100%; max-width: 320px; display: flex; flex-direction: column; gap: 4px; }
.pb-trick-item { display: flex; justify-content: space-between; align-items: center; padding: 8px 12px; border-radius: 8px; font-size: 13px; background: rgba(255,255,255,0.5); }
[data-theme="dark"] .pb-trick-item { background: rgba(255,255,255,0.06); }
.pb-trick-learned { color: #5d4037; }
[data-theme="dark"] .pb-trick-learned { color: #ffe0b2; }
.pb-trick-locked { color: #a1887f; }
[data-theme="dark"] .pb-trick-locked { color: #8d6e63; }
.pb-trick-active { border: 2px solid #ffb74d; }
.pb-trick-cost { font-size: 11px; color: #a1887f; }
.pb-trick-demo-btn { border: none; background: #8d6e63; color: #fff; padding: 3px 10px; border-radius: 10px; font-size: 11px; cursor: pointer; }
.pb-trick-demo-btn:hover { background: #6d4c41; }
.pb-game-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; width: 100%; max-width: 340px; }
.pb-game-card { background: rgba(255,255,255,0.6); border: 2px solid rgba(141,110,99,0.2); border-radius: 14px; padding: 16px 10px; text-align: center; cursor: pointer; transition: transform 0.15s, box-shadow 0.15s; }
[data-theme="dark"] .pb-game-card { background: rgba(255,255,255,0.06); border-color: rgba(141,110,99,0.3); }
.pb-game-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.12); }
.pb-game-emoji { font-size: 32px; }
.pb-game-name { font-size: 14px; font-weight: 700; color: #5d4037; margin: 4px 0; }
[data-theme="dark"] .pb-game-name { color: #ffcc80; }
.pb-game-desc { font-size: 11px; color: #8d6e63; }
[data-theme="dark"] .pb-game-desc { color: #bcaaa4; }
.pb-game-result { text-align: center; min-height: 0; overflow: hidden; max-height: 0; transition: max-height 0.3s, padding 0.3s; }
.pb-game-result-show { max-height: 300px; padding: 16px 0; }
.pb-game-anim { font-size: 20px; font-weight: 700; color: #5d4037; margin-bottom: 6px; }
[data-theme="dark"] .pb-game-anim { color: #ffcc80; }
.pb-game-big { font-size: 18px; font-weight: 700; color: #ff9800; margin: 6px 0; }
.pb-game-sub { font-size: 13px; color: #8d6e63; font-style: italic; }
[data-theme="dark"] .pb-game-sub { color: #bcaaa4; }
.pb-game-obstacles { font-size: 28px; letter-spacing: 8px; margin: 8px 0; }
.pb-name-edit { display: flex; align-items: center; gap: 8px; }
.pb-name-edit label { font-size: 14px; font-weight: 600; color: #5d4037; }
[data-theme="dark"] .pb-name-edit label { color: #bcaaa4; }
.pb-name-input { border: 2px solid #d7ccc8; border-radius: 8px; padding: 6px 10px; font-size: 14px; width: 160px; background: var(--input-bg); color: var(--text-primary); }
.pb-name-input:focus { outline: none; border-color: #8d6e63; }
.pb-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; width: 100%; max-width: 300px; }
.pb-stat { font-size: 13px; color: #795548; padding: 6px 10px; background: rgba(255,255,255,0.4); border-radius: 8px; }
[data-theme="dark"] .pb-stat { color: #bcaaa4; background: rgba(255,255,255,0.06); }
.pb-stat strong { color: #5d4037; }
[data-theme="dark"] .pb-stat strong { color: #ffcc80; }
.pb-affirm-btn { padding: 10px 22px; border: none; border-radius: 20px; background: linear-gradient(135deg, #ffb74d, #ff9800); color: #fff; font-size: 14px; font-weight: 700; cursor: pointer; box-shadow: 0 2px 8px rgba(0,0,0,0.12); }
.pb-affirm-btn:hover { transform: scale(1.04); }
.pb-section-title { font-size: 15px; font-weight: 700; color: #5d4037; margin-top: 10px; align-self: flex-start; }
[data-theme="dark"] .pb-section-title { color: #ffcc80; }
.pb-accessory-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; width: 100%; max-width: 320px; }
.pb-acc-card { background: rgba(255,255,255,0.5); border: 2px solid transparent; border-radius: 12px; padding: 10px 6px; text-align: center; cursor: pointer; transition: border-color 0.2s; }
[data-theme="dark"] .pb-acc-card { background: rgba(255,255,255,0.06); }
.pb-acc-card:hover { border-color: #8d6e63; }
.pb-acc-equipped { border-color: #ffb74d; background: rgba(255,183,77,0.15); }
.pb-acc-locked { opacity: 0.5; cursor: default; }
.pb-acc-emoji { font-size: 28px; }
.pb-acc-name { font-size: 11px; color: #5d4037; margin-top: 2px; }
[data-theme="dark"] .pb-acc-name { color: #bcaaa4; }
.pb-acc-tag { font-size: 10px; color: #8d6e63; margin-top: 2px; }

/* ===== Pocket Pal 3D ===== */
.pp-loading {
  display: flex; align-items: center; justify-content: center;
  height: 100%; color: #888; font-size: 16px;
}
.pp-wrap {
  display: flex; flex-direction: column; height: 100%; position: relative;
  background: #e8f5e9; overflow: hidden;
}
[data-theme="dark"] .pp-wrap { background: #1b2a1b; }

.pp-hud {
  position: absolute; top: 0; left: 0; right: 0; z-index: 3;
  padding: 8px 12px; background: rgba(255,255,255,0.85);
  backdrop-filter: blur(6px); border-bottom: 1px solid rgba(0,0,0,0.08);
}
[data-theme="dark"] .pp-hud {
  background: rgba(30,40,30,0.88); border-bottom-color: rgba(255,255,255,0.06);
}
.pp-pet-name {
  font-weight: 700; font-size: 15px; margin-bottom: 4px; color: #2e7d32;
}
[data-theme="dark"] .pp-pet-name { color: #81c784; }
.pp-stats { display: flex; gap: 6px; }
.pp-stat {
  display: flex; align-items: center; gap: 4px; flex: 1;
}
.pp-stat-icon { font-size: 13px; }
.pp-stat-bar {
  flex: 1; height: 8px; background: #c8e6c9; border-radius: 4px; overflow: hidden;
}
[data-theme="dark"] .pp-stat-bar { background: #2e4a2e; }
.pp-stat-fill {
  height: 100%; border-radius: 4px; transition: width 0.4s ease;
}
.pp-fill-hunger { background: linear-gradient(90deg, #ff9800, #ffb74d); }
.pp-fill-happy  { background: linear-gradient(90deg, #e91e63, #f48fb1); }
.pp-fill-clean  { background: linear-gradient(90deg, #00bcd4, #80deea); }
.pp-fill-energy { background: linear-gradient(90deg, #673ab7, #b39ddb); }

.pp-canvas-wrap {
  flex: 1; position: relative; cursor: pointer;
}
.pp-canvas-wrap canvas {
  display: block; width: 100% !important; height: 100% !important;
}

.pp-thought {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -120%);
  background: #fff; color: #333; padding: 8px 16px; border-radius: 16px;
  font-size: 14px; font-weight: 600; box-shadow: 0 2px 12px rgba(0,0,0,0.15);
  pointer-events: none; opacity: 0; transition: opacity 0.3s;
  z-index: 4; white-space: nowrap;
}
.pp-thought::after {
  content: ''; position: absolute; bottom: -8px; left: 50%;
  transform: translateX(-50%); width: 0; height: 0;
  border-left: 8px solid transparent; border-right: 8px solid transparent;
  border-top: 8px solid #fff;
}
[data-theme="dark"] .pp-thought { background: #2c3e2c; color: #e8f5e9; }
[data-theme="dark"] .pp-thought::after { border-top-color: #2c3e2c; }
.pp-thought-show { opacity: 1; }

.pp-overlay {
  position: absolute; bottom: 60px; left: 0; right: 0; z-index: 5;
  pointer-events: none;
}
.pp-overlay > * { pointer-events: auto; }

.pp-controls {
  display: flex; gap: 6px; padding: 8px 10px;
  background: rgba(255,255,255,0.9); backdrop-filter: blur(6px);
  border-top: 1px solid rgba(0,0,0,0.06); z-index: 5;
}
[data-theme="dark"] .pp-controls {
  background: rgba(30,40,30,0.92); border-top-color: rgba(255,255,255,0.06);
}
.pp-btn {
  flex: 1; display: flex; flex-direction: column; align-items: center; gap: 2px;
  padding: 8px 4px; border: 2px solid #a5d6a7; border-radius: 14px;
  background: linear-gradient(180deg, #e8f5e9, #c8e6c9);
  cursor: pointer; font-size: 22px; transition: all 0.15s;
  box-shadow: 0 2px 0 #81c784;
}
.pp-btn span { font-size: 11px; font-weight: 700; color: #2e7d32; }
.pp-btn:active {
  transform: translateY(2px); box-shadow: none;
}
[data-theme="dark"] .pp-btn {
  border-color: #2e7d32; background: linear-gradient(180deg, #1b3a1b, #2e4a2e);
  box-shadow: 0 2px 0 #1b5e20;
}
[data-theme="dark"] .pp-btn span { color: #81c784; }
.pp-btn-feed:hover  { border-color: #ff9800; }
.pp-btn-play:hover  { border-color: #e91e63; }
.pp-btn-clean:hover { border-color: #00bcd4; }
.pp-btn-sleep:hover { border-color: #673ab7; }

/* Trays (feed, play, clean menus) */
.pp-tray {
  background: rgba(255,255,255,0.95); backdrop-filter: blur(8px);
  border-radius: 18px 18px 0 0; padding: 14px; margin: 0 4px;
  box-shadow: 0 -4px 20px rgba(0,0,0,0.1);
  animation: pp-tray-in 0.25s ease;
}
[data-theme="dark"] .pp-tray {
  background: rgba(30,42,30,0.96); box-shadow: 0 -4px 20px rgba(0,0,0,0.3);
}
@keyframes pp-tray-in {
  from { transform: translateY(100%); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
.pp-tray-title {
  font-size: 16px; font-weight: 700; margin-bottom: 10px; color: #2e7d32;
}
[data-theme="dark"] .pp-tray-title { color: #81c784; }
.pp-tray-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); gap: 8px;
}
.pp-tray-item {
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 10px 6px; border: 2px solid #c8e6c9; border-radius: 12px;
  background: #f1f8e9; cursor: pointer; transition: all 0.15s;
}
[data-theme="dark"] .pp-tray-item {
  border-color: #2e4a2e; background: #1b3a1b;
}
.pp-tray-item:hover { border-color: #66bb6a; transform: scale(1.05); }
.pp-tray-emoji { font-size: 26px; }
.pp-tray-name { font-size: 12px; font-weight: 700; color: #333; }
[data-theme="dark"] .pp-tray-name { color: #c8e6c9; }
.pp-tray-desc { font-size: 10px; color: #777; }
[data-theme="dark"] .pp-tray-desc { color: #81c784; }
.pp-tray-back {
  margin-top: 10px; padding: 6px 16px; border: none; border-radius: 8px;
  background: #e0e0e0; cursor: pointer; font-size: 13px; color: #555;
}
[data-theme="dark"] .pp-tray-back { background: #333; color: #aaa; }
.pp-tray-back:hover { background: #ccc; }

/* Sleep overlay */
.pp-sleep-overlay {
  position: absolute; inset: 0; background: rgba(10,15,30,0.75);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; animation: pp-fade-in 0.5s ease;
}
@keyframes pp-fade-in { from { opacity: 0; } to { opacity: 1; } }
.pp-sleep-stars { font-size: 18px; letter-spacing: 4px; animation: pp-twinkle 2s ease-in-out infinite; }
@keyframes pp-twinkle { 0%,100% { opacity: 0.6; } 50% { opacity: 1; } }
.pp-sleep-text { font-size: 20px; font-weight: 700; color: #b39ddb; }
.pp-sleep-hint { font-size: 13px; color: #90a4ae; }

/* Name picker */
.pp-name-picker {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  height: 100%; padding: 20px; text-align: center; background: #e8f5e9;
}
[data-theme="dark"] .pp-name-picker { background: #1b2a1b; }
.pp-name-title { font-size: 28px; font-weight: 700; color: #2e7d32; margin-bottom: 6px; }
[data-theme="dark"] .pp-name-title { color: #81c784; }
.pp-name-subtitle { font-size: 14px; color: #666; margin-bottom: 16px; }
[data-theme="dark"] .pp-name-subtitle { color: #a5d6a7; }
.pp-name-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
  max-width: 340px; width: 100%; margin-bottom: 16px;
}
.pp-name-btn {
  padding: 10px 6px; border: 2px solid #a5d6a7; border-radius: 12px;
  background: #f1f8e9; cursor: pointer; font-size: 14px; font-weight: 600;
  color: #2e7d32; transition: all 0.15s;
}
[data-theme="dark"] .pp-name-btn {
  border-color: #2e7d32; background: #1b3a1b; color: #81c784;
}
.pp-name-btn:hover { border-color: #66bb6a; transform: scale(1.05); background: #c8e6c9; }
[data-theme="dark"] .pp-name-btn:hover { background: #2e4a2e; }
.pp-name-custom {
  display: flex; gap: 8px; max-width: 260px; width: 100%;
}
.pp-name-input {
  flex: 1; padding: 8px 12px; border: 2px solid #a5d6a7; border-radius: 10px;
  font-size: 14px; outline: none; background: #fff;
}
[data-theme="dark"] .pp-name-input {
  background: #1b3a1b; border-color: #2e7d32; color: #e8f5e9;
}
.pp-name-input:focus { border-color: #66bb6a; }
.pp-name-go {
  padding: 8px 18px; border: none; border-radius: 10px;
  background: #4caf50; color: #fff; font-weight: 700; cursor: pointer;
  font-size: 14px;
}
.pp-name-go:hover { background: #43a047; }

/* Game HUD */
.pp-game-hud {
  position: absolute; top: 80px; left: 0; right: 0; z-index: 6;
  display: flex; justify-content: center; gap: 20px;
  font-size: 16px; font-weight: 700; color: #fff;
  text-shadow: 0 1px 3px rgba(0,0,0,0.5); flex-wrap: wrap;
  padding: 4px 12px;
}
.pp-game-hud.pp-hidden { display: none; }
.pp-game-overlay {
  text-align: center; padding: 8px; font-size: 13px; color: #2e7d32; font-weight: 600;
}
[data-theme="dark"] .pp-game-overlay { color: #81c784; }
.pp-copyme-btns {
  display: flex; gap: 6px; justify-content: center; width: 100%; margin-top: 6px;
}
.pp-copyme-btn {
  padding: 6px 12px; border: 2px solid rgba(255,255,255,0.5); border-radius: 10px;
  background: rgba(255,255,255,0.2); color: #fff; font-size: 13px; font-weight: 700;
  cursor: pointer; backdrop-filter: blur(4px);
}
.pp-copyme-btn:hover { background: rgba(255,255,255,0.35); }

/* ===== RESPONSIVE — TABLET (≤1024px) ===== */
@media (max-width: 1024px) {
  :root { --taskbar-h: 56px; }
  .gc-toast {
    right: auto; left: 50%; top: 12px;
    transform: translateX(-50%) translateY(-120%);
    max-width: 90vw;
  }
  .gc-toast.gc-toast-in {
    transform: translateX(-50%) translateY(0);
  }
  .gc-toast-out {
    animation: gc-drop-out .3s ease-in forwards;
  }
  @keyframes gc-drop-out {
    to { transform: translateX(-50%) translateY(-140%); opacity: 0; }
  }

  /* Fix Android/iOS viewport — dvh accounts for browser chrome */
  #desktop {
    height: 100vh;        /* fallback */
    height: 100dvh;       /* dynamic viewport height - excludes browser chrome */
  }

  /* Taskbar — fixed so it's always in the visible viewport */
  #taskbar {
    position: fixed;
    bottom: 0; left: 0; right: 0;
  }

  /* Windows container — account for fixed taskbar + safe areas */
  #windows-container {
    position: fixed;
    top: var(--sat); left: var(--sal); right: var(--sar);
    bottom: calc(var(--taskbar-h) + var(--sab));
  }

  /* Desktop icons — 4-column launcher grid with large icons */
  #desktop-icons {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    top: calc(20px + var(--sat)); left: calc(20px + var(--sal)); right: calc(20px + var(--sar));
    width: auto;
    gap: 8px;
    max-height: calc(100dvh - var(--taskbar-h) - var(--sat) - var(--sab) - 40px);
    overflow-y: auto;
    justify-items: center;
    align-content: start;
  }
  .desktop-icon { width: 100%; max-width: 140px; padding: 14px 6px; }
  .desktop-icon .icon-img { font-size: 60px; }
  .desktop-icon span { font-size: 13px; margin-top: 6px; }

  /* Taskbar — icon-only app buttons on mobile */
  .tbtn-title { display: none; }
  .tbtn-icon { margin-right: 0; }
  .taskbar-app-btn { padding: 4px 8px; min-width: 36px; max-width: 40px; text-align: center; }
  #taskbar-center { overflow-x: auto; scrollbar-width: none; }
  #taskbar-center::-webkit-scrollbar { display: none; }
  #app-menu-btn { padding: 10px 18px; font-size: 15px; }

  /* App menu — full width bottom sheet above fixed taskbar */
  #app-menu {
    position: fixed;
    left: 0; right: 0; width: 100%;
    bottom: calc(var(--taskbar-h) + var(--sab));
    border-radius: 14px 14px 0 0;
    max-height: 80dvh; overflow-y: auto;
  }

  /* App menu grid — 3 columns on tablet for bigger touch targets */
  .app-menu-grid { grid-template-columns: repeat(3, 1fr); gap: 4px; }
  .menu-app-item { padding: 14px 12px; font-size: 15px; }
  .menu-app-item span { font-size: 24px; }

  /* Windows — no resize handle on touch */
  .win-resize { display: none; }

  /* Win controls — bigger touch targets */
  .win-btn { width: 40px; height: 32px; font-size: 14px; }
  .win-titlebar { height: 40px; }
  .win-title { font-size: 14px; }

  /* Memory game */
  #memory-grid { grid-template-columns: repeat(4, 70px); gap: 8px; }
  .mem-card { width: 70px; height: 70px; font-size: 30px; }
  .card-face { font-size: 30px; }

  /* eJob — narrower sidebar */
  .ej-inbox { width: 110px; min-width: 110px; }
  .ej-inbox-name { font-size: 11px; }

  /* KidsChat — narrower sidebar */
  .kc-sidebar { width: 140px; min-width: 140px; }
  .kc-contact-preview { display: none; }

  /* Minesweeper — scrollable grid */
  .ms-wrap { padding: 8px 6px; }
  .ms-grid-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* Kidflix — smaller grid on tablet */
  .kf-grid { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap:12px; }

  /* Taskbar clock — larger text */
  #clock-time { font-size: 16px; }
  #clock-date { font-size: 12px; }
}

/* ===== RESPONSIVE — MOBILE (≤768px) ===== */
@media (max-width: 768px) {
  #desktop-icons { grid-template-columns: repeat(4, 1fr); }
  .desktop-icon .icon-img { font-size: 52px; }
  .desktop-icon span { font-size: 12px; }

  /* Boot screen */
  #boot-logo { font-size: 56px; }
  #boot-title { font-size: 32px; }
  #boot-subtitle { font-size: 14px; }

  /* Memory game */
  #memory-grid { grid-template-columns: repeat(4, 62px); gap: 6px; }
  .mem-card { width: 62px; height: 62px; font-size: 26px; }
  .card-face { font-size: 26px; }

  /* KidsChat — narrower sidebar */
  .kc-sidebar { width: 120px; min-width: 120px; }

  /* App menu — 2 columns on mobile */
  .app-menu-grid { grid-template-columns: repeat(2, 1fr); }

  /* Kidflix — 2 columns on mobile */
  .kf-grid { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap:10px; }
  .kf-movie-title { font-size:17px; }
  .kf-video { max-height:220px; }
}

/* ===== RESPONSIVE — SMALL PHONE (≤480px) ===== */
@media (max-width: 480px) {
  /* Desktop icons — 4-column grid, slightly smaller on small phones */
  #desktop-icons { grid-template-columns: repeat(4, 1fr); gap: 4px; top: calc(12px + var(--sat)); left: calc(12px + var(--sal)); right: calc(12px + var(--sar)); }
  .desktop-icon { padding: 8px 2px; }
  .desktop-icon .icon-img { font-size: 44px; }
  .desktop-icon span { font-size: 11px; }

  /* Memory game — tighter */
  #memory-grid { grid-template-columns: repeat(4, 54px); gap: 4px; }
  .mem-card { width: 54px; height: 54px; font-size: 22px; }
  .card-face { font-size: 22px; }

  /* eJob — hide sidebar on small phones */
  .ej-inbox { display: none; }

  /* KidsChat — icon-only sidebar */
  .kc-sidebar { width: 58px; min-width: 58px; }
  .kc-contact-body { display: none; }
  .kc-contact { padding: 8px; justify-content: center; }
  .kc-sidebar-header span { display: none; }
  .kc-add-btn { margin: 0 auto; }

  /* App menu — single column */
  .app-menu-grid { grid-template-columns: 1fr; }

  /* Clock — time only */
  #clock-date { display: none; }

  /* Calc buttons — larger touch targets */
  .calc-btn { font-size: 18px; }
  .calc-display .calc-result { font-size: 28px; }
}
