/* ═══════════════════════════════════════════════
   TIMEBOX PLANNER - Sunsama-inspired Warm Minimal
   Palette: cream background, forest green primary,
            terracotta accent, warm neutrals
   ═══════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* ── Notion Calendar / Cron 팔레트 ── */
  --bg-primary:   #FFFFFF;        /* 순백 - 메인 배경 */
  --bg-secondary: #FAFAF8;        /* 아주 연한 그레이 - 사이드/서브 */
  --bg-card:      #FFFFFF;
  --bg-hover:     #F4F3F0;
  --bg-slot:      #F7F6F3;        /* 채워진 시간 슬롯 배경 */

  /* ── Accent: Cron terracotta orange ── */
  --accent:       #EB5E3F;        /* Cron 시그니처 오렌지 */
  --accent-light: #F07A5E;
  --accent-dark:  #C84E32;
  --accent-soft:  #FDECE6;        /* 매우 연한 오렌지 배경 */

  /* ── Green (완료 전용, 극소량) ── */
  --green:        #0F7B4D;
  --green-light:  #2E9D6C;
  --green-soft:   #E6F4ED;

  /* ── Legacy aliases (기존 코드 호환) ── */
  --terra:        #EB5E3F;
  --terra-light:  #F07A5E;
  --terra-soft:   #FDECE6;
  --pink:         #EB5E3F;
  --pink-light:   #FDECE6;
  --mint:         #0F7B4D;
  --peach:        #F3E6D4;
  --lavender:     #EFEDE7;

  /* ── Text (Notion warm black) ── */
  --text-primary: #37352F;
  --text-main:    #37352F;
  --text-muted:   #8C8A83;
  --text-subtle:  #B8B5AD;

  /* ── Borders ── */
  --border:       #E8E7E4;
  --border-light: #F1F0ED;
  --border-strong:#D1CFCA;

  /* ── Semantic ── */
  --success:      #0F7B4D;
  --success-bg:   #E6F4ED;
  --warning:      #CB7B1F;
  --warning-bg:   #FCF0DE;
  --danger:       #CC3333;
  --danger-bg:    #FCE7E7;
  --info:         #3D7FBE;
  --info-bg:      #E5EEF7;

  /* ── Effects ── */
  --shadow:       0 1px 3px rgba(43, 38, 32, 0.04),
                  0 4px 16px rgba(43, 38, 32, 0.05);
  --shadow-md:    0 2px 8px rgba(43, 38, 32, 0.06),
                  0 8px 32px rgba(43, 38, 32, 0.08);
  --shadow-inset: inset 0 1px 2px rgba(43, 38, 32, 0.04);

  /* ── Radius ── */
  --radius:       10px;
  --radius-sm:    8px;
  --radius-lg:    14px;

  /* ── Transitions ── */
  --t-fast:       all 120ms ease-out;
  --t-base:       all 200ms ease-out;
}

html, body {
  min-height: 100vh;
  font-family: 'Inter', 'Inter Variable', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  font-feature-settings: 'cv11', 'ss01', 'ss03'; /* Inter stylistic alternates */
  background: var(--bg-primary);
  color: var(--text-primary);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: -0.005em;
}
html { height: auto; }

/* 숫자는 고정 너비로 (시계, 통계 등 자리 맞춤) */
.tabular, time, .stat-pill b, [class*="-count"], [class*="-num"] {
  font-variant-numeric: tabular-nums;
}

[data-theme="dark"] html, [data-theme="dark"] body { background: #0F1713; }

/* ─── Scrollbar ──────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg-secondary); }
::-webkit-scrollbar-thumb { background: var(--lavender); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent); }

/* ─── Typography ─────────────────────────────────── */
h1 {
  font-size: 1.75rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--text-primary);
}
h2 {
  font-size: 1.25rem;
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--text-primary);
}
h3 {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--text-primary);
}

/* ─── Buttons (Sunsama: 평평하고 미묘하게) ───────── */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px;
  border: 1px solid transparent;
  border-radius: 8px;                   /* 덜 둥글게 */
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: var(--t-fast);
  text-decoration: none;
  white-space: nowrap;
  font-family: inherit;
  letter-spacing: -0.005em;
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

.btn-primary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.btn-primary:hover:not(:disabled) {
  background: var(--accent-dark);
  border-color: var(--accent-dark);
}

.btn-danger  { background: var(--danger); color: #fff; border-color: var(--danger); }
.btn-danger:hover:not(:disabled) { background: #A1524B; }

.btn-success { background: var(--success); color: #fff; border-color: var(--success); }
.btn-success:hover:not(:disabled) { background: #3D6A4E; }

.btn-ghost {
  background: transparent;
  color: var(--text-muted);
  border: 1px solid var(--border);
}
.btn-ghost:hover:not(:disabled) {
  background: var(--bg-hover);
  color: var(--text-primary);
  border-color: var(--border-strong);
}

.btn-sm      { padding: 5px 12px; font-size: 12px; }
.btn-lg      { padding: 11px 22px; font-size: 14px; }
.btn-pink    { background: var(--terra); color: #fff; border-color: var(--terra); }
.btn-pink:hover:not(:disabled) { background: var(--accent-dark); }

/* ─── Inputs ─────────────────────────────────────── */
input, select, textarea {
  background: var(--bg-card);
  color: var(--text-primary);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 9px 13px;
  font-size: 13px;
  font-family: inherit;
  transition: var(--t-fast);
  outline: none;
  width: 100%;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
  background: var(--bg-card);
}
input::placeholder, textarea::placeholder {
  color: var(--text-subtle);
  font-weight: 400;
}
select option { background: var(--bg-card); color: var(--text-primary); }

/* ─── Cards (Sunsama: 거의 테두리 없고 숨구멍 많음) ──── */
.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 20px;
  box-shadow: 0 1px 2px rgba(43, 38, 32, 0.03);
  transition: var(--t-fast);
}

/* ─── Status badges (부드럽게) ──────────────────────── */
.badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px; border-radius: 6px;
  font-size: 11px; font-weight: 500; letter-spacing: 0;
  text-transform: none;
}
.badge-planned    { background: transparent; color: var(--text-muted); border: 1px solid var(--border); }
.badge-inprogress { background: var(--info-bg); color: var(--info); }
.badge-done       { background: var(--success-bg); color: var(--success); }
.badge-skipped    { background: transparent; color: var(--text-subtle); }

/* ─── Online indicator ───────────────────────────── */
.online-dot {
  width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex-shrink: 0;
}
.online-dot.online  { background: var(--success); box-shadow: 0 0 0 2px rgba(92,200,160,0.3); animation: pulse 2s infinite; }
.online-dot.offline { background: #C8C2BA; }

@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 2px rgba(92,200,160,0.3); }
  50%       { box-shadow: 0 0 0 5px rgba(92,200,160,0.1); }
}

/* ─── Progress bar ───────────────────────────────── */
.progress-bar {
  width: 100%; height: 8px; background: var(--bg-secondary);
  border-radius: 4px; overflow: hidden;
}
.progress-fill {
  height: 100%; border-radius: 4px; transition: width 0.5s ease;
  background: linear-gradient(90deg, var(--accent), var(--pink));
}

/* ─── Toast notifications ────────────────────────── */
#toast-container {
  position: fixed; bottom: 24px; right: 24px; z-index: 9999;
  display: flex; flex-direction: column; gap: 8px;
}
.toast {
  padding: 13px 20px; border-radius: var(--radius-sm); font-size: 13px; font-weight: 500;
  animation: slideUp 0.3s ease; min-width: 220px; max-width: 360px;
  box-shadow: var(--shadow-md); border-left: 4px solid; background: #fff;
}
.toast-success { border-color: var(--success); color: #3A9070; }
.toast-error   { border-color: var(--danger);  color: #C05060; }
.toast-info    { border-color: var(--accent);  color: var(--accent-dark); }

@keyframes slideUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── Navbar ─────────────────────────────────────── */
.navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  height: 56px;
  background: rgba(255, 255, 255, 0.92);    /* 순백 반투명 */
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; padding: 0 28px; gap: 14px;
  box-shadow: none;
}
.navbar-brand {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  text-decoration: none;
  letter-spacing: -0.015em;
}
.navbar-brand [data-lucide] {
  color: var(--accent);
  width: 18px; height: 18px;
}
.navbar-brand span { color: var(--text-muted); font-weight: 400; }
.navbar-spacer { flex: 1; }
.navbar-user { display: flex; align-items: center; gap: 10px; }

/* ─── Planner Status Bar ──────────────────────────────────────────────────── */
.status-bar-wrap {
  display: flex; align-items: center; gap: 8px; flex: 1;
  max-width: 680px; margin: 0 16px;
  background: var(--bg-secondary); border: 1.5px solid var(--border);
  border-radius: 50px; padding: 5px 14px; height: 38px;
}
.status-bar-label {
  font-size: 11px; font-weight: 700; color: var(--text-muted);
  white-space: nowrap; letter-spacing: 0.3px;
}
.status-quick-btns {
  display: flex; gap: 4px; flex-wrap: nowrap; overflow-x: auto;
}
.status-quick-btns::-webkit-scrollbar { display: none; }
.status-quick-btns button {
  background: none; border: 1px solid var(--border); border-radius: 20px;
  font-size: 11px; padding: 3px 9px; cursor: pointer; white-space: nowrap;
  color: var(--text-muted); transition: all 0.15s; font-family: inherit;
  width: auto;
}
.status-quick-btns button:hover { background: var(--lavender); border-color: var(--accent-light); color: var(--accent); }
.status-quick-btns button.active { background: var(--accent); border-color: var(--accent); color: #fff; }
#status-text-input {
  border: none; background: transparent; font-size: 12px; padding: 0 6px;
  min-width: 100px; flex: 1; height: auto; width: auto;
  box-shadow: none !important;
}
#status-text-input:focus { border: none; box-shadow: none; background: transparent; }
.user-avatar {
  width: 34px; height: 34px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 800; color: #fff; flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

/* ─── Main layout ────────────── */
.main-content {
  padding-top: 76px; padding-bottom: 48px;
  max-width: 1320px; margin: 0 auto; padding-left: 32px; padding-right: 32px;
}

/* ─── Top gradient bar (극도로 미묘) ─────  */
.page-gradient-bar {
  height: 1px;
  background: var(--border);
  position: fixed; top: 58px; left: 0; right: 0; z-index: 99;
}

/* ─── Language buttons ───────────────────────────── */
.lang-selector {
  display: flex; gap: 8px; justify-content: center; margin-bottom: 20px; flex-wrap: wrap;
}
.lang-mini {
  display: inline-flex; gap: 2px; align-items: center;
  background: var(--bg-hover);
  padding: 2px;
  border-radius: 8px;
}
.lang-btn {
  background: transparent; border: none;
  border-radius: 6px; padding: 3px 8px; font-size: 11px;
  font-weight: 500;
  cursor: pointer; color: var(--text-muted); font-family: inherit;
  transition: var(--t-fast); white-space: nowrap; width: auto; line-height: 1.4;
  min-width: 28px;
}
.lang-btn:hover { color: var(--text-primary); }
.lang-btn.active {
  background: var(--bg-card);
  color: var(--accent);
  box-shadow: 0 1px 2px rgba(43, 38, 32, 0.06);
}

/* ─── LOGIN PAGE ─────────────────────────────────── */
.login-container {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: radial-gradient(ellipse at 30% 40%, #F5EDE6 0%, #FAF0EA 50%, #FAF8F5 100%);
  position: relative; overflow: hidden;
}
.login-container::before {
  content: '';
  position: absolute; width: 500px; height: 500px; border-radius: 50%;
  background: radial-gradient(circle, rgba(244,167,195,0.2) 0%, transparent 70%);
  top: -100px; right: -100px; pointer-events: none;
}
.login-container::after {
  content: '';
  position: absolute; width: 400px; height: 400px; border-radius: 50%;
  background: radial-gradient(circle, rgba(168,230,207,0.2) 0%, transparent 70%);
  bottom: -80px; left: -80px; pointer-events: none;
}
.login-box {
  width: 100%; max-width: 420px; position: relative; z-index: 1;
  background: rgba(255,255,255,0.9); border: 1.5px solid var(--border);
  border-radius: 20px; padding: 44px 40px; box-shadow: var(--shadow-md);
  backdrop-filter: blur(8px);
}
.login-logo { text-align: center; margin-bottom: 32px; }
.login-logo .logo-icon {
  width: 64px; height: 64px; border-radius: 18px;
  background: linear-gradient(135deg, var(--accent), var(--pink));
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; margin: 0 auto 14px; box-shadow: 0 4px 16px rgba(196,123,90,0.35);
}
.login-logo h1 {
  font-size: 1.7rem; font-weight: 800;
  background: linear-gradient(135deg, var(--accent), #F4A7C3);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.login-logo p { color: var(--text-muted); font-size: 13px; margin-top: 5px; }
.form-group { margin-bottom: 16px; }
.form-group label {
  display: block; margin-bottom: 7px; font-size: 12px; font-weight: 700;
  color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.6px;
}
.login-btn { width: 100%; padding: 13px; font-size: 15px; margin-top: 8px; }
.login-hint {
  margin-top: 20px; padding: 14px 16px; background: var(--bg-secondary);
  border-radius: var(--radius-sm); font-size: 12px; color: var(--text-muted);
  line-height: 1.8;
}
.login-hint code { color: var(--accent-dark); font-weight: 700; background: #F5EDE6; padding: 1px 5px; border-radius: 4px; }

/* ─── PLANNER PAGE ───────────────────────────────── */
.date-nav { display: flex; align-items: center; gap: 10px; }
.date-display {
  font-size: 1.5rem;              /* 크게 키움 */
  font-weight: 600;
  letter-spacing: -0.02em;
  min-width: 180px; text-align: center;
  color: var(--text-primary);
  font-feature-settings: 'tnum';
}

/* Top bar — Sunsama: 박스가 아니라 공간 */
.planner-topbar {
  display: flex; align-items: center; gap: 20px; margin-bottom: 24px;
  flex-wrap: wrap;
  background: transparent;         /* 배경 카드 제거 */
  border: none;
  padding: 8px 0;
  box-shadow: none;
  border-bottom: 1px solid var(--border);
  padding-bottom: 18px;
}

/* Compact stats strip — 미묘하게 */
.stats-strip {
  display: flex; align-items: center; gap: 14px; flex: 1; flex-wrap: wrap;
}
.stat-pill {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 500; padding: 4px 10px;
  border-radius: 99px; white-space: nowrap;
  background: transparent;
  color: var(--text-muted);
  border: 1px solid var(--border);
  transition: var(--t-fast);
}
.stat-pill:hover { background: var(--bg-hover); }
.stat-pill b { font-size: 13px; font-weight: 600; color: var(--text-primary); font-variant-numeric: tabular-nums; }
.stat-pill.done     { color: var(--success);  border-color: var(--success-bg); }
.stat-pill.done b   { color: var(--success); }
.stat-pill.progress { color: var(--info);     border-color: var(--info-bg); }
.stat-pill.progress b { color: var(--info); }
.stat-pill.planned  { color: var(--accent);   border-color: var(--accent-soft); }
.stat-pill.planned b { color: var(--accent); }
.stat-pill.skipped  { color: var(--text-subtle); }

.progress-bar-mini {
  flex: 1; min-width: 100px; height: 4px;
  background: var(--bg-secondary);
  border-radius: 2px; overflow: hidden;
}
.progress-fill {
  height: 100%; background: var(--accent);
  transition: width 0.3s ease-out;
}
.rate-badge {
  font-size: 13px; font-weight: 600; color: var(--text-primary);
  min-width: 38px; text-align: right;
  font-variant-numeric: tabular-nums;
}

/* Two-column layout — Sunsama: 넉넉하게 */
.planner-body {
  display: flex; gap: 28px; align-items: flex-start;
}
.planner-left  { width: 28%; min-width: 220px; display: flex; flex-direction: column; gap: 20px; }
.planner-right { flex: 1; min-width: 0; }

/* Left panel cards — Sunsama: 헤더 미묘하게 */
.left-card { padding: 20px; }
.left-card-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 14px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px;
}
.left-card-title [data-lucide] {
  color: var(--accent);
  width: 14px; height: 14px;
}
.todo-count-badge {
  font-size: 11px; font-weight: 700; background: var(--accent);
  color: #fff; border-radius: 10px; padding: 1px 7px; min-width: 20px; text-align: center;
}

/* Todoist-style checklist */
.todo-add-row {
  display: flex; gap: 6px; margin-bottom: 10px;
}
.todo-add-row input {
  flex: 1; padding: 7px 10px; font-size: 13px; border-radius: 8px;
}
.todo-list { display: flex; flex-direction: column; gap: 4px; max-height: 260px; overflow-y: auto; }
.todo-item {
  display: flex; align-items: center; gap: 8px; padding: 7px 8px;
  border-radius: 8px; transition: background 0.15s; group: true;
}
.todo-item:hover { background: var(--bg-hover); }
.todo-item:hover .todo-delete { opacity: 1; }
.todo-checkbox {
  width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid var(--border); cursor: pointer; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s; background: #fff;
}
.todo-checkbox.checked {
  background: var(--success); border-color: var(--success); color: #fff;
  font-size: 10px;
}
.todo-checkbox:hover:not(.checked) { border-color: var(--accent); background: #F5EDE6; }
.todo-text {
  flex: 1; font-size: 13px; color: var(--text-primary);
  cursor: pointer; word-break: break-all; line-height: 1.4;
}
.todo-text.done {
  text-decoration: line-through; color: var(--text-muted);
}
.todo-delete {
  opacity: 0; transition: opacity 0.15s; background: none; border: none;
  color: var(--text-muted); cursor: pointer; font-size: 16px; padding: 0 2px;
  line-height: 1;
}
.todo-delete:hover { color: var(--danger); }
.todo-empty {
  text-align: center; padding: 20px 10px;
  font-size: 12px; color: var(--text-muted);
}

/* Memo */
.memo-card textarea {
  width: 100%; height: 160px; resize: vertical; font-size: 13px;
  border-radius: 8px; line-height: 1.6;
}
.memo-save-hint {
  font-size: 11px; color: var(--text-muted); margin-top: 6px; min-height: 16px;
  text-align: right;
}

/* ════════════════════════════════════════════════════════
   Notion Calendar (Cron) 스타일 타임라인
   — 진짜 캘린더 격자 느낌
   — 빈 슬롯: 얇은 구분선
   — 채워진 슬롯: 왼쪽 컬러 바 + 배경
   ════════════════════════════════════════════════════════ */

.timeline-card {
  padding: 0;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: none;
  overflow: hidden;
}
.timeline-header {
  display: none;
}
.timeline-body {
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
  padding: 0;
}

/* Now indicator line — Cron의 상징 빨간 줄 */
.now-line {
  position: absolute; left: 0; right: 0; height: 2px;
  background: var(--accent);
  z-index: 5; pointer-events: none;
}
.now-line::before {
  content: ''; position: absolute; left: 60px; top: -4px;
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--accent);
}

/* === 각 시간 슬롯 === */
.time-row {
  display: grid;
  grid-template-columns: 72px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 0 16px 0 12px;
  min-height: 40px;
  transition: var(--t-fast);
  background: transparent;
  border: none;
  border-top: 1px solid var(--border-light);
  border-radius: 0;
  box-shadow: none;
  position: relative;
}
.time-row:first-child { border-top: none; }

/* 시간 정각 = 조금 더 진한 구분선 */
.time-row.hour-mark {
  border-top: 1px solid var(--border);
}

/* hover */
.time-row:hover {
  background: var(--bg-hover);
  transform: none;
  box-shadow: none;
}

/* 과거 슬롯 */
.time-row.past { opacity: 0.45; }
.time-row.past:hover { opacity: 0.7; }

/* 🔒 1시간 이상 지난 블록 — 편집 불가 */
.time-row.locked {
  opacity: 0.35;
  background: rgba(120, 120, 120, 0.04);
}
.time-row.locked:hover { opacity: 0.55; }
.time-row.locked input[data-field="task"] {
  cursor: not-allowed;
  color: var(--text-muted);
  background: transparent;
}
.time-row.locked .status-btn,
.time-row.locked .save-dot {
  cursor: not-allowed !important;
  opacity: 0.5;
}
.time-row.locked::after {
  content: '🔒';
  position: absolute;
  right: 8px; top: 50%;
  transform: translateY(-50%);
  font-size: 11px;
  opacity: 0.6;
  pointer-events: none;
}
.time-row.locked { position: relative; }

/* 🍱 점심시간 (12:00~12:59) — 친근한 메시지 */
.time-row.lunch {
  background: linear-gradient(90deg, rgba(251,191,36,0.08), rgba(236,72,153,0.06));
  border-left: 3px solid #fbbf24;
}
.time-row.lunch .time-label {
  color: #fbbf24;
  font-weight: 700;
}
.time-lunch {
  padding: 8px 14px;
  color: var(--text-primary);
  font-size: 13px;
  cursor: default;
  display: flex;
  align-items: center;
  gap: 8px;
  line-height: 1.5;
}
.time-lunch b { color: #fbbf24; font-weight: 600; }

/* 현재 시간 슬롯 — 강조 */
.time-row.current-hour {
  background: var(--accent-soft);
}
.time-row.current-hour::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--accent);
}

/* === 할 일 있는 슬롯 (has-task) — 컬러 블록 === */
.time-row.has-task {
  background: var(--bg-slot);
}
.time-row.has-task::before {
  content: '';
  position: absolute;
  left: 0; top: 4px; bottom: 4px;
  width: 3px;
  background: var(--text-muted);
  border-radius: 2px;
}
.time-row.has-task.status-done {
  background: var(--success-bg);
}
.time-row.has-task.status-done::before { background: var(--success); }

.time-row.has-task.status-in-progress {
  background: var(--info-bg);
}
.time-row.has-task.status-in-progress::before { background: var(--info); }

.time-row.has-task.status-skipped {
  background: transparent;
  opacity: 0.5;
}
.time-row.has-task.status-skipped::before { background: var(--text-subtle); }

/* current-hour + has-task 조합 */
.time-row.current-hour.has-task {
  background: var(--accent-soft);
}
.time-row.current-hour.has-task::before { background: var(--accent); }

/* 시간 라벨 */
.time-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  font-family: 'Inter', system-ui, sans-serif;
  white-space: nowrap;
}
.time-row.hour-mark .time-label {
  color: var(--text-primary);
  font-weight: 600;
  font-size: 13px;
}
.time-row.current-hour .time-label {
  color: var(--accent);
  font-weight: 600;
}

/* 할 일 입력 */
.time-task {
  min-width: 0;
}
.time-task input {
  background: transparent;
  border: none;
  padding: 2px 0;
  font-size: 13.5px;
  color: var(--text-primary);
  font-family: inherit;
  font-weight: 400;
  width: 100%;
  transition: var(--t-fast);
  outline: none;
  line-height: 1.4;
}
.time-task input::placeholder {
  color: var(--text-subtle);
  font-size: 12.5px;
  font-weight: 400;
}
.time-row.has-task .time-task input {
  font-weight: 500;
}
.time-row.has-task.status-done .time-task input {
  color: var(--text-muted);
  text-decoration: line-through;
  text-decoration-color: var(--text-subtle);
}

/* 상태 버튼 */
.time-status { display: flex; align-items: center; justify-content: flex-end; gap: 4px; }

.time-status select,
.status-btn {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 500;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  transition: var(--t-fast);
  font-family: inherit;
  height: 22px;
}
.time-status select.planned, .status-btn.planned {
  color: var(--text-subtle);
  border-color: transparent;
}
.time-status select.in-progress, .status-btn.in-progress {
  background: var(--info-bg);
  color: var(--info);
}
.time-status select.done, .status-btn.done {
  background: var(--success-bg);
  color: var(--success);
}
.time-status select.skipped, .status-btn.skipped {
  color: var(--text-subtle);
}
.status-btn:hover { transform: none; opacity: 0.85; background: var(--bg-hover); }
.status-btn:active { transform: none; }

/* 기본 상태에서는 "예정" 숨기고 hover 시에만 보이게 (Cron 느낌) */
.time-row:not(.has-task):not(:hover):not(.current-hour) .status-btn.planned {
  opacity: 0;
}

/* ─── 상태 드롭다운 버튼 + 팝업 ──────────────────── */
.status-btn {
  padding: 4px 10px; border-radius: 20px; font-size: 11px;
  font-weight: 700; border: none; cursor: pointer;
  font-family: inherit; white-space: nowrap;
  transition: opacity 0.15s, transform 0.1s;
}
.status-btn:hover  { opacity: 0.82; transform: scale(1.04); }
.status-btn:active { transform: scale(0.97); }
.status-btn.planned     { background: #F5EDE6; color: var(--accent); }
.status-btn.in-progress { background: var(--info-bg); color: #4A9FE8; }
.status-btn.done        { background: var(--success-bg); color: var(--success); }
.status-btn.skipped     { background: #F5F2EF; color: #9B9590; }

.status-picker {
  position: fixed; z-index: 9000;
  background: #fff; border: 1.5px solid var(--border);
  border-radius: 12px; padding: 6px;
  box-shadow: 0 8px 28px rgba(44,40,36,0.15);
  display: flex; flex-direction: column; gap: 4px; min-width: 115px;
  animation: fadeIn 0.12s ease;
}
.status-pick-btn {
  padding: 7px 13px; border-radius: 20px; border: none;
  cursor: pointer; font-size: 12px; font-weight: 700;
  font-family: inherit; text-align: left;
  transition: opacity 0.12s, transform 0.1s;
}
.status-pick-btn:hover  { opacity: 0.78; transform: translateX(2px); }
.status-pick-btn.planned     { background: #F5EDE6; color: var(--accent); }
.status-pick-btn.in-progress { background: var(--info-bg); color: #4A9FE8; }
.status-pick-btn.done        { background: var(--success-bg); color: var(--success); }
.status-pick-btn.skipped     { background: #F5F2EF; color: #9B9590; }
.time-actions { display: flex; justify-content: center; }
.save-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--warning); display: none; cursor: pointer;
  box-shadow: 0 0 0 2px rgba(244,164,78,0.3);
}
.save-dot.visible { display: block; }

/* Report section — Cron 스타일 */
.report-section {
  margin-top: 28px;
  padding: 24px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: none;
}
.report-section h3 {
  margin-bottom: 6px;
  color: var(--text-primary);
  display: inline-flex; align-items: center; gap: 8px;
}
.report-section h3 [data-lucide] {
  color: var(--accent);
  width: 18px; height: 18px;
}
.report-section textarea { height: 80px; resize: vertical; }
.report-actions { display: flex; gap: 10px; margin-top: 14px; justify-content: flex-end; }
.report-submitted-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; background: var(--success-bg);
  color: var(--success); border-radius: 6px; font-size: 12px; font-weight: 500;
  border: 1px solid transparent;
}

/* Responsive */
@media (max-width: 900px) {
  .planner-body { flex-direction: column; }
  .planner-left { width: 100%; }
  .timeline-header, .time-row { grid-template-columns: 52px 1fr auto 40px; }
  .time-row .time-actions { display: none; }
}

/* ─── MASTER DASHBOARD ───────────────────────────── */
.master-stats {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 14px;
  margin-bottom: 24px;
}
.master-stat {
  background: var(--bg-card); border: 1.5px solid var(--border);
  border-radius: var(--radius-sm); padding: 18px; text-align: center;
  box-shadow: var(--shadow); transition: transform 0.2s;
}
.master-stat:hover { transform: translateY(-2px); }
.master-stat .number { font-size: 2.2rem; font-weight: 800; }
.master-stat .label  { font-size: 11px; color: var(--text-muted); margin-top: 3px; font-weight: 600; }

.users-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 16px;
  margin-bottom: 24px;
}
.user-card {
  background: var(--bg-card); border: 1.5px solid var(--border);
  border-radius: var(--radius); padding: 18px;
  transition: all 0.2s; box-shadow: var(--shadow);
}
.user-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.user-card.online  { border-color: rgba(92,200,160,0.4); }
.user-card.offline { opacity: 0.75; }
.user-card-header {
  display: flex; align-items: center; gap: 12px; margin-bottom: 12px;
}
.user-card-header .user-avatar { width: 42px; height: 42px; font-size: 16px; }
.user-info { flex: 1; }
.user-info .name { font-weight: 700; color: var(--text-primary); }
.user-info .status-text { font-size: 12px; color: var(--text-muted); display: flex; align-items: center; gap: 5px; }
.current-task-bar {
  background: var(--bg-secondary); border-radius: 10px; padding: 9px 13px;
  font-size: 12px; margin-bottom: 10px; min-height: 38px; display: flex;
  align-items: center; gap: 8px; border: 1px solid var(--border-light);
}
.current-task-bar .task-name { flex: 1; font-weight: 600; color: var(--text-primary); }
.task-category { font-size: 11px; color: var(--text-muted); }
.user-mini-grid {
  display: flex; gap: 2px; flex-wrap: wrap; margin-top: 8px;
}
.mini-block {
  width: 14px; height: 14px; border-radius: 4px; cursor: default;
  position: relative;
}
.mini-block[title]:hover::after {
  content: attr(title);
  position: absolute; bottom: 18px; left: 50%; transform: translateX(-50%);
  background: #1a1a2e; color: #f1f1f1;
  padding: 4px 8px; border-radius: 6px; font-size: 11px; white-space: nowrap;
  z-index: 10; pointer-events: none; box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.mini-block.planned     { background: #DDD4FF; }
.mini-block.in-progress { background: #BFDFFF; }
.mini-block.done        { background: #AEECD4; }
.mini-block.skipped     { background: #F5EDE6; }
.mini-block.empty       { background: var(--bg-secondary); border: 1px solid var(--border); }
.mini-block.current     { box-shadow: 0 0 0 2px var(--accent); }

/* ─── Monitor view (master dashboard) ───────────────────────────────────────── */
.monitor-card-header {
  display: flex; align-items: center; gap: 10px; margin-bottom: 10px;
}
.monitor-screen {
  background: linear-gradient(135deg, #1a1035 0%, #2a1a5e 50%, #1e1040 100%);
  border-radius: 10px; padding: 14px 16px; min-height: 72px;
  display: flex; flex-direction: column; justify-content: center;
  border: 1px solid rgba(196,123,90,0.3); position: relative; overflow: hidden;
}
.monitor-screen::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--pink), var(--mint));
}
.monitor-screen.offline {
  background: #2a2a3a; border-color: rgba(100,100,130,0.3);
}
.monitor-screen.offline::before { background: #444; }
.monitor-status-text {
  font-size: 15px; font-weight: 700; color: #fff;
  letter-spacing: 0.3px; line-height: 1.3;
}
.monitor-task-main {
  font-size: 14px; font-weight: 700; color: #fff; line-height: 1.3;
}
.monitor-task-sub {
  font-size: 11px; color: rgba(255,255,255,0.6); margin-top: 4px;
}
.monitor-browser-row {
  display: flex; align-items: center; gap: 6px;
}
.monitor-browser-title {
  font-size: 13px; font-weight: 700; color: #fff; line-height: 1.3;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 190px;
}
.monitor-browser-domain {
  font-size: 11px; color: var(--accent-light); margin-top: 2px;
}
.monitor-task-cat {
  font-size: 11px; color: var(--accent-light); margin-top: 2px;
}
.monitor-elapsed {
  font-size: 11px; color: var(--mint); margin-top: 4px; font-weight: 600;
}
.monitor-idle {
  font-size: 13px; color: rgba(255,255,255,0.35); font-style: italic;
  animation: blink 2.5s infinite;
}
.monitor-offline {
  font-size: 13px; color: rgba(200,200,220,0.4); font-style: italic;
}
@keyframes blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

/* Reports panel */
.reports-panel { margin-top: 24px; }
.reports-panel h2 { margin-bottom: 16px; color: var(--text-primary); }
.report-cards { display: flex; flex-direction: column; gap: 14px; }
.report-card {
  background: var(--bg-card); border: 1.5px solid var(--border);
  border-radius: var(--radius-sm); padding: 18px; box-shadow: var(--shadow);
}
.report-card-header {
  display: flex; align-items: center; gap: 12px; margin-bottom: 12px;
}
.report-card-user { flex: 1; }
.report-card-user .name { font-weight: 700; color: var(--text-primary); }
.report-card-user .time { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.completion-badge {
  display: inline-block; padding: 5px 12px; border-radius: 20px;
  font-size: 12px; font-weight: 800;
}
.completion-high   { background: var(--success-bg); color: var(--success); }
.completion-mid    { background: var(--warning-bg); color: var(--warning); }
.completion-low    { background: var(--danger-bg);  color: var(--danger);  }
.report-summary    { font-size: 13px; color: var(--text-muted); margin-bottom: 10px; font-style: italic; }
.report-mini-blocks { display: flex; gap: 2px; flex-wrap: wrap; }
.crm-open-btn {
  flex-shrink: 0; padding: 5px 12px; border-radius: 20px; border: none; cursor: pointer;
  font-size: 11px; font-weight: 700; background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  color: #fff; transition: opacity .15s, transform .1s;
}
.crm-open-btn:hover { opacity: .85; transform: translateY(-1px); }

/* ─── 채팅 사이드패널 ────────────────────────────────────────────────────────── */
body.has-chat { padding-right: 0; }

#chat-panel {
  position: fixed; right: 18px; bottom: 80px;
  width: 340px; height: 480px; max-height: calc(100vh - 120px);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 16px;
  display: none; flex-direction: column;
  z-index: 300; box-shadow: 0 8px 40px rgba(0,0,0,.25);
  overflow: hidden;
}
#chat-panel.chat-open { display: flex; }
.chat-panel-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 14px; border-bottom: 1.5px solid var(--border);
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  color: #fff; font-weight: 700; font-size: 13px; flex-shrink: 0;
  gap: 8px;
}
.chat-panel-header > span:last-child { font-size: 10px; opacity: .8; font-weight: 400; }

/* 채팅 닫기 버튼 (항상 표시) */
.chat-close-btn {
  display: block; background: none; border: none;
  color: rgba(255,255,255,.9); font-size: 22px; line-height: 1;
  cursor: pointer; padding: 0 2px; margin-left: auto; flex-shrink: 0;
}

/* 채팅 FAB 버튼 (항상 표시) */
#chat-fab {
  display: flex;
  position: fixed; bottom: 22px; right: 18px;
  width: 54px; height: 54px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  color: #fff; font-size: 24px; border: none; cursor: pointer;
  box-shadow: 0 4px 18px rgba(196,123,90,.4);
  z-index: 299; align-items: center; justify-content: center;
  transition: transform .15s; flex-shrink: 0;
}
#chat-fab:active { transform: scale(.9); }
#chat-fab-badge {
  position: absolute; top: -3px; right: -3px;
  background: #e74c3c; color: #fff; border-radius: 50%;
  width: 20px; height: 20px; font-size: 11px; font-weight: 700;
  display: none; align-items: center; justify-content: center;
  pointer-events: none;
}

/* ── 모바일 반응형 (채팅) ── */
@media (max-width: 767px) {
  body.has-chat { padding-right: 0 !important; }

  #chat-panel {
    right: 0 !important; bottom: 0 !important;
    width: 100% !important; height: 100dvh !important;
    max-height: 100dvh !important;
    border-radius: 0 !important;
  }
}

/* 메시지 목록 */
.chat-messages {
  flex: 1; overflow-y: auto; padding: 10px 8px;
  display: flex; flex-direction: column; gap: 2px;
  scroll-behavior: smooth;
}
.chat-messages::-webkit-scrollbar { width: 3px; }
.chat-messages::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

/* 카카오톡 스타일 메시지 */
.cm { display: flex; max-width: 100%; animation: cmIn .12s ease; }
.cm-other { align-items: flex-start; gap: 6px; margin-top: 6px; }
.cm-mine  { justify-content: flex-end; margin-top: 4px; }

.cm-avatar {
  width: 32px; height: 32px; border-radius: 10px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700; color: #fff;
}
.cm-avatar-gap { width: 32px; flex-shrink: 0; }

.cm-right { display: flex; flex-direction: column; max-width: 200px; }
.cm-name {
  font-size: 10px; color: var(--text-muted); font-weight: 600;
  margin-bottom: 3px; padding-left: 2px;
  display: flex; align-items: center; gap: 4px;
}
.cm-real { color: var(--accent); font-size: 9px; }

.cm-row { display: flex; align-items: flex-end; gap: 4px; }
.cm-mine { flex-direction: row-reverse; }

.cm-bubble {
  padding: 7px 11px; border-radius: 4px 16px 16px 16px;
  font-size: 13px; line-height: 1.45; word-break: break-word;
  background: var(--bg-secondary); color: var(--text-primary);
  max-width: 185px;
}
.cm-bubble-mine {
  background: var(--accent); color: #fff;
  border-radius: 16px 4px 16px 16px;
}
.cm-bubble-anon {
  background: #F5EDE6; border: 1px dashed #D4C4B0;
  color: var(--text-muted); font-style: italic;
}
.cm-time {
  font-size: 9px; color: var(--text-muted);
  white-space: nowrap; flex-shrink: 0; padding-bottom: 2px;
}

/* 내 메시지 래퍼 */
div.cm.cm-mine {
  display: flex; align-items: flex-end;
  gap: 4px; justify-content: flex-end;
}

/* 입력 영역 */
.chat-input-area {
  padding: 10px; border-top: 1.5px solid var(--border);
  display: flex; flex-direction: column; gap: 6px; flex-shrink: 0;
}
#chat-input {
  width: 100%; padding: 8px 10px; border: 1.5px solid var(--border);
  border-radius: 10px; font-size: 13px; resize: none;
  background: var(--bg-secondary); color: var(--text-primary);
  font-family: inherit; outline: none; height: 38px; max-height: 90px;
  box-sizing: border-box; line-height: 1.4;
}
#chat-input:focus { border-color: var(--accent); }
.chat-input-row { display: flex; align-items: center; justify-content: space-between; }
.chat-anon-toggle {
  display: flex; align-items: center; gap: 4px;
  font-size: 11px; color: var(--text-muted); cursor: pointer; user-select: none;
}
.chat-anon-toggle input { cursor: pointer; accent-color: var(--accent); }
.chat-send-btn {
  padding: 6px 16px; border: none; border-radius: 10px;
  background: var(--accent); color: #fff; font-size: 12px;
  font-weight: 700; cursor: pointer; transition: opacity .15s;
}
.chat-send-btn:hover { opacity: .85; }

@keyframes cmIn {
  from { opacity: 0; transform: translateY(3px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Tabs */
.tabs {
  display: flex; gap: 2px; margin-bottom: 22px;
  background: var(--bg-secondary); padding: 4px; border-radius: 12px;
  width: fit-content;
}
.tab-btn {
  padding: 8px 20px; background: transparent; border: none;
  color: var(--text-muted); font-size: 13px; font-weight: 600;
  cursor: pointer; border-radius: 9px; transition: all 0.2s;
}
.tab-btn:hover  { color: var(--accent); background: rgba(196,123,90,0.1); }
.tab-btn.active { color: var(--accent-dark); background: #fff; box-shadow: 0 2px 8px rgba(120,90,200,0.12); }
.tab-panel { display: none; }
.tab-panel.active { display: block; }

/* Activity feed */
.activity-feed { display: flex; flex-direction: column; gap: 6px; max-height: 200px; overflow-y: auto; }
.activity-item {
  display: flex; gap: 10px; font-size: 12px;
  padding: 8px 12px; background: var(--bg-secondary); border-radius: 8px;
  border: 1px solid var(--border-light);
}
.activity-item .time { color: var(--accent); font-weight: 700; flex-shrink: 0; }
.activity-item .msg  { color: var(--text-primary); }

/* Responsive */
@media (max-width: 768px) {
  .time-row { grid-template-columns: 55px 1fr auto 50px; }
  .time-row .time-actions { display: none; }
  .users-grid { grid-template-columns: 1fr; }
  .main-content { padding-left: 14px; padding-right: 14px; }
  .tabs { width: 100%; }
  .tab-btn { padding: 8px 12px; font-size: 12px; }
}

/* ─── Supervisor (관리직원) 보고서 열람 ─────────── */
.supervisor-tab-bar {
  display: flex; gap: 4px; padding: 10px 0 6px; margin-bottom: 4px;
}
.sv-tab-btn {
  padding: 8px 20px; border: 1.5px solid var(--border); border-radius: 10px;
  background: var(--bg-card); color: var(--text); font-size: 13px; font-weight: 600;
  cursor: pointer; transition: all .15s;
}
.sv-tab-btn.active {
  background: var(--primary); color: #fff; border-color: var(--primary);
}
.sv-toolbar {
  display: flex; align-items: center; gap: 10px; padding: 10px 0; flex-wrap: wrap;
}
.sv-toolbar label { font-size: 13px; color: var(--text-muted); font-weight: 600; }
.sv-toolbar input[type="date"] {
  background: var(--bg-card); border: 1.5px solid var(--border); border-radius: 8px;
  padding: 6px 10px; color: var(--text); font-size: 13px;
}
.sv-report-count { font-size: 12px; color: var(--text-muted); margin-left: auto; }
.sv-report-card {
  background: var(--bg-card); border: 1.5px solid var(--border); border-radius: 14px;
  padding: 16px; margin-bottom: 12px; transition: border-color .15s;
}
.sv-report-card:hover { border-color: var(--primary); }
.sv-report-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.sv-user-info { display: flex; align-items: center; gap: 10px; }
.sv-user-avatar {
  width: 32px; height: 32px; border-radius: 50%; display: flex;
  align-items: center; justify-content: center; color: #fff; font-weight: 700; font-size: 14px;
}
.sv-rate-wrap { display: flex; align-items: center; gap: 8px; }
.sv-rate-bar {
  width: 80px; height: 8px; background: var(--border); border-radius: 4px; overflow: hidden;
}
.sv-rate-fill { height: 100%; border-radius: 4px; transition: width .3s; }
.sv-rate-text { font-size: 14px; font-weight: 700; min-width: 36px; text-align: right; }
.sv-summary {
  font-size: 13px; color: var(--text-muted); padding: 8px 12px;
  background: var(--bg-main); border-radius: 8px; margin-bottom: 8px; line-height: 1.5;
}
.sv-block-details { margin-top: 6px; }
.sv-block-details summary {
  font-size: 12px; color: var(--text-muted); cursor: pointer; padding: 4px 0;
}
.sv-block-table {
  width: 100%; border-collapse: collapse; font-size: 12px; margin-top: 6px;
}
.sv-block-table th {
  text-align: left; padding: 6px 8px; border-bottom: 1.5px solid var(--border);
  color: var(--text-muted); font-weight: 600;
}
.sv-block-table td { padding: 5px 8px; border-bottom: 1px solid var(--border); }
.sv-submitted-at { font-size: 11px; color: var(--text-muted); text-align: right; margin-top: 6px; }
.sv-empty { text-align: center; padding: 40px 20px; color: var(--text-muted); font-size: 14px; }

/* ─── 모바일 네브바 ─────────────────────────────── */
@media (max-width: 600px) {
  .navbar {
    position: relative !important;
    height: auto !important;
    min-height: 48px;
    flex-wrap: wrap;
    padding: 8px 12px;
    gap: 6px;
  }
  .page-gradient-bar {
    position: relative !important;
    top: auto !important;
  }
  .main-content {
    padding-top: 16px !important;
  }

  /* 브랜드 텍스트 축약 */
  .navbar-brand span { display: none; }
  .navbar-brand { font-size: 0.95rem; }
  /* spacer를 줄바꿈 역할로 변환 */
  .navbar-spacer { flex-basis: 100%; height: 0; }

  /* 검색바 숨김 */
  .search-widget { display: none !important; }
  /* 계산기 버튼 숨김 */
  .calc-toggle-btn { display: none !important; }
  /* 이름 텍스트 숨김 */
  #nav-name { display: none !important; }
  /* 토큰 복사 버튼 숨김 */
  button[onclick="copyMyToken()"] { display: none !important; }
  /* 식물 위젯 간소화 */
  .plant-xp-info { display: none; }
  .plant-widget { padding: 5px 6px; gap: 0; }
  #plant-emoji { font-size: 20px; }

  /* navbar-user 간격 축소 */
  .navbar-user { gap: 4px; }
  /* 언어 버튼 간격 축소 */
  .lang-mini { gap: 1px; }
  .lang-btn { padding: 2px 3px; font-size: 14px; }

  /* 게임/운세 버튼 크기 축소 */
  .game-launch-btn { padding: 5px 7px; font-size: 16px; }

  /* topbar-widgets 간격 축소 */
  .topbar-widgets { gap: 4px; }

  /* 로그아웃 버튼 강조 */
  button[onclick="logout()"] {
    padding: 5px 8px;
    font-size: 12px;
    white-space: nowrap;
  }
}

/* Animations */
.fade-in { animation: fadeIn 0.3s ease; }
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.section-title {
  font-size: 11px; font-weight: 800; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 1px; margin-bottom: 14px;
}

/* Schedule table */
table th { color: var(--text-muted); font-weight: 700; font-size: 12px; }
table td { vertical-align: middle; }

/* Master badge */
.master-badge {
  font-size: 11px; font-weight: 800; padding: 3px 10px; border-radius: 20px;
  background: linear-gradient(135deg, var(--pink-light), var(--lavender));
  color: var(--accent-dark); letter-spacing: 0.5px;
}

/* Empty states */
.empty-state {
  text-align: center; padding: 48px 24px; color: var(--text-muted);
}
.empty-state .empty-icon { font-size: 40px; margin-bottom: 12px; display: block; }
.empty-state p { font-size: 13px; }

/* ─── TourPik 신규예약 섹션 ─────────────────────────────────────────────────── */
.tourpik-card { border-left: 3px solid #e53e3e; }
.tourpik-item {
  padding: 8px 10px; border-bottom: 1px solid var(--border);
  transition: background 0.15s;
}
.tourpik-item:last-child { border-bottom: none; }
.tourpik-item:hover { background: var(--bg-hover, rgba(0,0,0,0.03)); }
.tourpik-item-main { display: flex; align-items: center; gap: 6px; margin-bottom: 3px; }
.tourpik-cat-emoji { font-size: 14px; flex-shrink: 0; line-height: 1; }
.tourpik-booking-id {
  font-weight: 700; font-size: 13px; color: #e53e3e;
  background: none; border: none; padding: 0; cursor: pointer;
  text-decoration: none; font-family: inherit;
}
.tourpik-booking-id:hover { text-decoration: underline; }
.tourpik-customer { font-size: 13px; color: var(--text-main); }
.tourpik-item-sub { display: flex; gap: 10px; font-size: 11px; color: var(--text-muted); }
.tourpik-product { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tourpik-date { flex-shrink: 0; }
.tourpik-item.checking { background: rgba(255, 200, 0, 0.08); border-left-color: #f6ad55; }
.tourpik-checking-badge {
  display: inline-block; margin-top: 4px;
  font-size: 11px; color: #c05621;
  background: rgba(246,173,85,0.15); border-radius: 4px;
  padding: 1px 6px; font-weight: 600;
}

/* ─── 작업기록 모달 ──────────────────────────────── */
#booking-note-modal {
  display: none; position: fixed; inset: 0; z-index: 9999;
  align-items: center; justify-content: center;
}
.bnn-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.45); backdrop-filter: blur(2px);
}
.bnn-dialog {
  position: relative; z-index: 1;
  background: #fff; border-radius: 14px;
  padding: 24px 28px; width: 420px; max-width: 92vw;
  box-shadow: 0 20px 60px rgba(0,0,0,0.2);
  display: flex; flex-direction: column; gap: 14px;
}
.bnn-title { font-size: 16px; font-weight: 700; color: var(--text-main); }
.bnn-desc  { font-size: 12px; color: var(--text-muted); margin-top: 4px; }
.bnn-info  {
  display: flex; flex-wrap: wrap; gap: 6px;
  background: #F5EDE6; border-radius: 8px; padding: 10px 12px;
}
.bnn-bid      { font-weight: 700; font-size: 13px; color: #e53e3e; }
.bnn-customer { font-size: 13px; color: var(--text-main); }
.bnn-product  { font-size: 12px; color: var(--text-muted); width: 100%; }
#bnn-input {
  width: 100%; border: 1.5px solid var(--border); border-radius: 8px;
  padding: 10px 12px; font-size: 13px; font-family: inherit;
  resize: vertical; outline: none; transition: border-color 0.15s;
}
#bnn-input:focus { border-color: var(--accent); }
.bnn-btn {
  background: var(--accent); color: #fff; border: none; border-radius: 8px;
  padding: 11px 0; font-size: 14px; font-weight: 600; cursor: pointer;
  transition: background 0.15s; width: 100%;
}
.bnn-btn:hover:not(:disabled) { background: var(--accent-dark); }
.bnn-btn:disabled { background: #D4B8A0; cursor: not-allowed; }

/* ─── 타임블록 멀티라인 표시 + 상세 팝업 ─── */
.time-task-multi {
  display: flex; align-items: center; gap: 6px;
  cursor: pointer; padding: 0 4px; height: 100%;
  overflow: hidden;
}
.time-task-preview {
  flex: 1; overflow: hidden; text-overflow: ellipsis;
  white-space: nowrap; font-size: 12px; color: var(--text-main);
}
.time-task-more {
  flex-shrink: 0; font-size: 11px; color: var(--accent);
  font-weight: 600; white-space: nowrap;
}
.time-task-multi:hover .time-task-more { text-decoration: underline; }

#block-detail-modal {
  display: none; position: fixed; inset: 0; z-index: 9998;
  align-items: center; justify-content: center;
}
.bdm-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.4); backdrop-filter: blur(2px);
}
.bdm-dialog {
  position: relative; z-index: 1;
  background: #fff; border-radius: 14px;
  padding: 20px 24px; width: 460px; max-width: 92vw;
  box-shadow: 0 20px 60px rgba(0,0,0,0.2);
  max-height: 80vh; display: flex; flex-direction: column; gap: 14px;
}
.bdm-header {
  display: flex; align-items: center; justify-content: space-between;
}
.bdm-time { font-size: 15px; font-weight: 700; color: var(--text-main); }
.bdm-close {
  background: none; border: none; font-size: 16px;
  cursor: pointer; color: var(--text-muted); padding: 2px 6px;
  border-radius: 6px; transition: background 0.15s;
}
.bdm-close:hover { background: #f0f0f0; }
.bdm-list {
  overflow-y: auto; display: flex; flex-direction: column; gap: 8px;
}
.bdm-entry {
  display: flex; align-items: flex-start; gap: 8px;
  background: #F5EDE6; border-radius: 8px; padding: 8px 10px;
}
.bdm-num {
  flex-shrink: 0; width: 20px; height: 20px; margin-top: 4px;
  background: var(--accent); color: #fff; border-radius: 50%;
  font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.bdm-input {
  flex: 1; border: 1.5px solid transparent; border-radius: 6px;
  padding: 4px 6px; font-size: 13px; font-family: inherit;
  background: transparent; resize: none; outline: none;
  line-height: 1.5; overflow: hidden; min-height: 28px;
  transition: border-color 0.15s, background 0.15s;
}
.bdm-input:focus { border-color: var(--accent); background: #fff; }
.bdm-del {
  flex-shrink: 0; background: none; border: none; cursor: pointer;
  font-size: 14px; padding: 2px 4px; border-radius: 4px;
  opacity: 0.4; transition: opacity 0.15s;
}
.bdm-del:hover { opacity: 1; }
.bdm-save-btn {
  background: var(--accent); color: #fff; border: none; border-radius: 8px;
  padding: 10px 0; font-size: 14px; font-weight: 600; cursor: pointer;
  transition: background 0.15s; width: 100%; margin-top: 4px;
}
.bdm-save-btn:hover:not(:disabled) { background: var(--accent-dark); }
.bdm-save-btn:disabled { background: #D4B8A0; cursor: not-allowed; }

/* ─── Dark Theme (Cron 다크 — 딥 뉴트럴 + 오렌지 포인트) ─────── */
[data-theme="dark"] {
  --bg-primary:   #191919;
  --bg-secondary: #1F1F1F;
  --bg-card:      #252525;
  --bg-hover:     #2D2D2D;
  --bg-slot:      #222222;

  --text-primary: #E6E6E4;
  --text-main:    #E6E6E4;
  --text-muted:   #9B9A95;
  --text-subtle:  #6A6963;

  --border:       rgba(230, 230, 228, 0.08);
  --border-light: rgba(230, 230, 228, 0.04);
  --border-strong:rgba(230, 230, 228, 0.14);

  --accent:       #F07A5E;
  --accent-light: #F39276;
  --accent-dark:  #D45A3D;
  --accent-soft:  rgba(235, 94, 63, 0.12);

  --terra:        #F07A5E;
  --terra-light:  #F39276;
  --terra-soft:   rgba(235, 94, 63, 0.12);

  --green:        #4CAF7A;
  --green-light:  #6FC594;
  --green-soft:   rgba(76, 175, 122, 0.14);

  --lavender:     #2E2923;

  --success:      #7EB08C;
  --success-bg:   rgba(126, 176, 140, 0.12);
  --warning:      #D6987A;
  --warning-bg:   rgba(214, 152, 122, 0.14);
  --danger:       #C97A74;
  --danger-bg:    rgba(201, 122, 116, 0.14);
  --info:         #8BA8C5;
  --info-bg:      rgba(139, 168, 197, 0.12);

  --shadow:       0 2px 8px rgba(0,0,0,0.25), 0 8px 32px rgba(0,0,0,0.3);
  --shadow-md:    0 4px 16px rgba(0,0,0,0.35), 0 16px 48px rgba(0,0,0,0.4);
}
[data-theme="dark"] body {
  background: var(--bg-primary);
  color: var(--text-primary);
}
[data-theme="dark"] .navbar {
  background: rgba(43,42,39,0.95);
  border-bottom-color: var(--border);
}
[data-theme="dark"] .btn-ghost {
  background: rgba(255,255,255,0.06);
  color: var(--text-muted);
  border-color: var(--border);
}
[data-theme="dark"] .btn-ghost:hover:not(:disabled) {
  background: var(--bg-hover);
  color: var(--accent-light);
  border-color: var(--accent-light);
}
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea {
  background: var(--bg-secondary);
  color: var(--text-primary);
  border-color: var(--border);
}
[data-theme="dark"] input:focus,
[data-theme="dark"] select:focus,
[data-theme="dark"] textarea:focus {
  background: #4A4843;
}
[data-theme="dark"] .card { background: var(--bg-card); border-color: var(--border); }
[data-theme="dark"] .planner-topbar { background: var(--bg-card); border-color: var(--border); }
[data-theme="dark"] .timeline-header { background: var(--bg-secondary); border-bottom-color: var(--border); }
[data-theme="dark"] .time-row { border-bottom-color: var(--border-light); }
[data-theme="dark"] .time-row:hover { background: var(--bg-hover); }
[data-theme="dark"] .time-task input { color: var(--text-primary); }
[data-theme="dark"] .time-task input:hover { background: var(--bg-secondary); border-color: var(--border); }
[data-theme="dark"] .time-task input:focus { background: #4A4843; }
[data-theme="dark"] .status-picker { background: var(--bg-card); border-color: var(--border); }
[data-theme="dark"] .report-section { background: var(--bg-card); border-color: var(--border); }
[data-theme="dark"] .tabs { background: var(--bg-secondary); }
[data-theme="dark"] .tab-btn.active { background: var(--bg-card); }
[data-theme="dark"] .user-card { background: var(--bg-card); border-color: var(--border); }
[data-theme="dark"] .current-task-bar { background: var(--bg-secondary); border-color: var(--border-light); }
[data-theme="dark"] .master-stat { background: var(--bg-card); border-color: var(--border); }
[data-theme="dark"] .report-card { background: var(--bg-card); border-color: var(--border); }
[data-theme="dark"] .activity-item { background: var(--bg-secondary); border-color: var(--border-light); }
[data-theme="dark"] .toast { background: var(--bg-card); }
[data-theme="dark"] .bnn-dialog,
[data-theme="dark"] .bdm-dialog { background: var(--bg-card); }
[data-theme="dark"] .bnn-info { background: var(--bg-secondary); }
[data-theme="dark"] .bdm-entry { background: var(--bg-secondary); }
[data-theme="dark"] .bdm-input:focus { background: #4A4843; }
[data-theme="dark"] .bdm-close:hover,
[data-theme="dark"] .bnn-close:hover { background: rgba(255,255,255,0.08); }
[data-theme="dark"] .lang-btn { border-color: var(--border); color: var(--text-muted); }
[data-theme="dark"] .lang-btn:hover { background: var(--bg-hover); color: var(--accent-light); }
[data-theme="dark"] .mini-block.empty { background: var(--bg-secondary); border-color: var(--border); }
[data-theme="dark"] .login-container {
  background: radial-gradient(ellipse at 30% 40%, #343330 0%, #2F2E2B 50%, #2B2A27 100%);
}
[data-theme="dark"] .login-container::before {
  background: radial-gradient(circle, rgba(196,123,90,0.08) 0%, transparent 70%);
}
[data-theme="dark"] .login-container::after {
  background: radial-gradient(circle, rgba(143,184,160,0.06) 0%, transparent 70%);
}
[data-theme="dark"] .login-box {
  background: rgba(61,60,56,0.95); border-color: var(--border);
}
[data-theme="dark"] .bdm-entry { background: var(--bg-secondary); }
[data-theme="dark"] .bnn-info { background: var(--bg-secondary); }

/* ─── User Report History Modal ──────────────────── */
#user-report-modal {
  display: none; position: fixed; inset: 0; z-index: 9997;
  align-items: center; justify-content: center;
}
.urm-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.5); backdrop-filter: blur(2px);
}
.urm-dialog {
  position: relative; z-index: 1;
  background: var(--bg-card); border-radius: 14px;
  padding: 20px 24px; width: 580px; max-width: 96vw;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  max-height: 88vh; display: flex; flex-direction: column; gap: 10px;
}
.urm-header {
  display: flex; align-items: center; justify-content: space-between; flex-shrink: 0;
}
.urm-nav { display: flex; align-items: center; gap: 10px; }
.urm-nav-btn {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 6px; padding: 3px 10px; cursor: pointer;
  color: var(--text-primary); font-size: 13px;
}
.urm-nav-btn:hover:not(:disabled) { background: var(--accent); color: #fff; }
.urm-nav-btn:disabled { opacity: 0.3; cursor: default; }
.urm-title { font-size: 14px; font-weight: 700; color: var(--text-primary); min-width: 180px; text-align: center; }
.urm-name { font-size: 13px; color: var(--text-muted); flex-shrink: 0; }
.urm-close {
  background: none; border: none; font-size: 16px; cursor: pointer;
  color: var(--text-muted); padding: 2px 6px; border-radius: 6px;
}
.urm-close:hover { background: rgba(0,0,0,0.08); }
.urm-stat-bar {
  display: flex; justify-content: space-between;
  font-size: 12px; font-weight: 600; color: var(--accent-light);
  padding: 4px 0; flex-shrink: 0;
}
.urm-report-summary { font-size: 12px; color: var(--text-muted); font-style: italic; flex-shrink: 0; }
.urm-body { overflow-y: auto; display: flex; flex-direction: column; gap: 3px; flex: 1; }
.urm-task-list { display: flex; flex-direction: column; gap: 3px; }
.urm-task-row {
  display: flex; align-items: flex-start; gap: 8px;
  padding: 5px 8px; border-radius: 6px; font-size: 13px;
}
.urm-task-row.urm-status-done { background: rgba(46,204,113,0.08); border-left: 3px solid #2ecc71; }
.urm-task-row.urm-status-in-progress { background: rgba(243,156,18,0.08); border-left: 3px solid #f39c12; }
.urm-task-row.urm-status-planned { background: var(--bg-secondary); border-left: 3px solid var(--border); }
.urm-task-row.urm-status-empty { border-left: 3px solid transparent; opacity: 0.4; }
.urm-task-time { color: var(--text-muted); font-size: 11px; min-width: 90px; padding-top: 2px; white-space: nowrap; }
.urm-task-status { font-size: 13px; min-width: 20px; }
.urm-task-text { color: var(--text-primary); line-height: 1.5; word-break: break-all; }
.urm-empty-text { color: var(--text-muted); }
.urm-no-task { color: var(--text-muted); font-size: 12px; text-align: center; padding: 8px 0; }

/* ─── PC 모니터링 ─────────────────────────────────────────────────────────────── */
.mon-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px; flex-shrink: 0;
}
.mon-last-update { font-size: 11px; color: var(--text-muted); }
.mon-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}
.mon-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; padding: 14px; display: flex; flex-direction: column; gap: 10px;
  transition: box-shadow .2s;
}
.mon-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.12); }
.mon-card.mon-stale { opacity: 0.55; }
.mon-card-header {
  display: flex; align-items: center; gap: 8px;
}
.mon-user-dot {
  width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
}
.mon-user-name { font-weight: 700; font-size: 14px; color: var(--text-primary); flex: 1; }
.mon-time-ago { font-size: 11px; color: var(--accent-light); }
.mon-time-ago.stale { color: #e74c3c; }
.mon-tab-count {
  font-size: 11px; background: var(--bg-secondary); border-radius: 99px;
  padding: 1px 8px; color: var(--text-muted);
}
.mon-active-tab {
  display: flex; align-items: flex-start; gap: 10px;
  background: var(--bg-secondary); border-radius: 8px; padding: 10px;
  border-left: 3px solid var(--accent);
}
.mon-favicon {
  width: 18px; height: 18px; border-radius: 3px; flex-shrink: 0; margin-top: 2px;
}
.mon-favicon-placeholder { font-size: 18px; flex-shrink: 0; }
.mon-active-info { min-width: 0; }
.mon-active-title {
  font-size: 13px; font-weight: 600; color: var(--text-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 220px;
}
.mon-active-url {
  font-size: 11px; color: var(--text-muted); margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 220px;
}
.mon-tab-list {
  display: flex; flex-direction: column; gap: 3px; max-height: 180px; overflow-y: auto;
}
.mon-tab-item {
  display: flex; align-items: center; gap: 7px;
  padding: 4px 6px; border-radius: 6px; font-size: 12px;
  color: var(--text-secondary);
  text-decoration: none; cursor: pointer;
}
.mon-tab-item:hover { background: var(--bg-secondary); color: var(--text-primary); }
.mon-tab-item.mon-tab-active {
  background: rgba(108,99,255,0.1); color: var(--text-primary); font-weight: 500;
}
.mon-tab-favicon { width: 14px; height: 14px; border-radius: 2px; flex-shrink: 0; }
.mon-tab-title {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 210px;
}
.mon-tab-more {
  font-size: 11px; color: var(--text-muted); text-align: center; padding: 4px 0;
}
.mon-section-label {
  font-size: 11px; font-weight: 600; color: var(--text-muted);
  display: flex; align-items: center; gap: 6px; margin-bottom: 4px;
}
.mon-time-badge {
  font-size: 10px; font-weight: 400; color: var(--accent-light);
}
.mon-time-badge.stale { color: #e74c3c; }
.mon-online-dot {
  width: 8px; height: 8px; border-radius: 50%; margin-left: auto; flex-shrink: 0;
}
.mon-online-dot.online { background: #2ecc71; box-shadow: 0 0 6px #2ecc71; }
.mon-online-dot.offline { background: #95a5a6; }
.mon-native-active { border-left-color: #f39c12; }
.mon-active-link { text-decoration: none; color: inherit; cursor: pointer; transition: opacity .15s; }
.mon-active-link:hover { opacity: .75; }
.mon-native-icon { font-size: 20px; flex-shrink: 0; }
.mon-app-chips {
  display: flex; flex-wrap: wrap; gap: 4px; margin-top: 4px;
}
.mon-app-chip {
  font-size: 11px; background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 99px; padding: 2px 8px; color: var(--text-secondary);
  white-space: nowrap; max-width: 140px; overflow: hidden; text-overflow: ellipsis;
  cursor: default;
}
.mon-no-native {
  font-size: 12px; color: var(--text-muted); padding: 6px 0;
  text-align: center; border: 1px dashed var(--border); border-radius: 8px;
}

/* ═══════════════════════════════════════════════════
   🌱 가상식물 + XP 위젯
   ═══════════════════════════════════════════════════ */
.topbar-widgets {
  display: flex; align-items: center; gap: 6px; margin: 0 8px;
}
.plant-widget {
  display: flex; align-items: center; gap: 7px;
  background: transparent; border: 1px solid var(--border);
  border-radius: 8px; padding: 5px 12px; height: 34px; cursor: default;
  transition: var(--t-fast);
}
.plant-widget:hover { background: var(--bg-hover); }
#plant-emoji {
  font-size: 18px; display: inline-block;
  transition: transform 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
.plant-xp-info {
  display: flex; flex-direction: column; gap: 1px;
}
#plant-level-label {
  font-size: 10px; font-weight: 800; color: var(--accent);
  line-height: 1;
}
.xp-bar-wrap {
  width: 70px; height: 5px; background: var(--border); border-radius: 3px; overflow: hidden;
}
.xp-bar-fill {
  height: 100%; background: linear-gradient(90deg, var(--mint), var(--accent));
  border-radius: 3px; transition: width 0.4s ease;
}
#plant-xp-label {
  font-size: 9px; color: var(--text-muted); line-height: 1;
}

/* ═══════════════════════════════════════════════════
   🔍 구글 검색바
   ═══════════════════════════════════════════════════ */
.search-widget {
  display: flex; align-items: center; gap: 8px;
  background: var(--bg-hover); border: 1px solid transparent;
  border-radius: 8px; padding: 5px 12px; height: 34px;
  transition: var(--t-fast);
}
.search-widget:focus-within {
  background: var(--bg-card);
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.search-icon-lbl { color: var(--text-muted); display: inline-flex; flex-shrink: 0; }
.search-widget input {
  border: none; background: transparent; font-size: 13px;
  width: 160px; height: auto; padding: 0; box-shadow: none !important;
  color: var(--text-primary);
}
.search-widget input::placeholder { color: var(--text-muted); }
.search-widget input:focus { border: none; box-shadow: none; background: transparent; }

/* ═══════════════════════════════════════════════════
   🧮 미니 계산기
   ═══════════════════════════════════════════════════ */
.calc-toggle-btn,
.game-launch-btn {
  background: transparent;
  border: 1px solid transparent;
  border-radius: 8px;
  width: 34px; height: 34px;
  color: var(--text-muted);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: var(--t-fast);
  padding: 0; flex-shrink: 0;
}
.calc-toggle-btn:hover,
.game-launch-btn:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
  transform: none;
}
.game-leaderboard {
  border-top: 1px solid #2a2a4a;
  margin-top: 8px; padding-top: 4px; min-width: 400px;
}

.calc-popup {
  position: fixed; z-index: 9000;
  background: var(--bg-card); border: 1.5px solid var(--border);
  border-radius: 16px; box-shadow: var(--shadow-md);
  padding: 16px; width: 210px;
  animation: fadeIn 0.15s ease;
}
.calc-display {
  background: var(--bg-secondary); border-radius: 10px;
  padding: 10px 14px; font-size: 22px; font-weight: 700;
  text-align: right; color: var(--text-primary);
  margin-bottom: 10px; min-height: 44px; word-break: break-all;
  letter-spacing: -0.5px;
}
.calc-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px;
}
.calc-btn {
  background: var(--bg-secondary); border: none; border-radius: 10px;
  height: 42px; font-size: 15px; font-weight: 600;
  cursor: pointer; transition: all 0.1s; color: var(--text-primary);
  font-family: inherit;
}
.calc-btn:hover { background: var(--lavender); }
.calc-btn:active { transform: scale(0.95); }
.calc-fn { color: var(--accent); }
.calc-op { background: var(--lavender); color: var(--accent-dark); }
.calc-op:hover { background: var(--accent); color: #fff; }
.calc-eq {
  background: var(--accent); color: #fff; grid-column: span 1;
}
.calc-eq:hover { background: var(--accent-dark); }
.calc-zero { grid-column: span 2; }

/* ═══════════════════════════════════════════════════
   🌐 번역기 카드
   ═══════════════════════════════════════════════════ */
.translator-card { display: flex; flex-direction: column; gap: 10px; }
.tl-lang-row {
  display: flex; align-items: center; gap: 6px;
}
.tl-lang-row select {
  flex: 1; padding: 6px 8px; border-radius: 8px; font-size: 12px;
  border: 1.5px solid var(--border); background: var(--bg-secondary);
  color: var(--text-primary); cursor: pointer; font-family: inherit;
}
.tl-swap-btn {
  background: var(--lavender); border: none; border-radius: 8px;
  width: 30px; height: 30px; font-size: 14px; font-weight: 700;
  cursor: pointer; color: var(--accent-dark); flex-shrink: 0;
  transition: all 0.15s;
}
.tl-swap-btn:hover { background: var(--accent); color: #fff; transform: rotate(180deg); }
.translator-card textarea {
  width: 100%; resize: vertical; min-height: 80px;
  border: 1.5px solid var(--border); border-radius: 10px;
  padding: 10px; font-size: 13px; background: var(--bg-secondary);
  color: var(--text-primary); font-family: inherit; line-height: 1.5;
}
.translator-card textarea:focus { border-color: var(--accent-light); outline: none; }
.tl-translate-btn { width: 100%; }
.tl-output {
  min-height: 60px; padding: 10px 12px;
  background: var(--bg-secondary); border-radius: 10px;
  font-size: 13px; color: var(--text-primary); line-height: 1.6;
  border: 1.5px solid var(--border); white-space: pre-wrap;
  word-break: break-word;
}
.tl-loading { color: var(--text-muted); font-style: italic; }
.tl-error   { color: var(--danger); }

/* ═══════════════════════════════════════════════════
   🏆 팀 랭킹
   ═══════════════════════════════════════════════════ */
.ranking-item {
  display: flex; align-items: center; gap: 14px;
  background: var(--bg-card); border: 1.5px solid var(--border);
  border-radius: 14px; padding: 14px 18px; margin-bottom: 10px;
  transition: box-shadow 0.2s;
}
.ranking-item:hover { box-shadow: var(--shadow); }
.ranking-top {
  border-color: #F4D03F; background: linear-gradient(135deg, #FFFDE7, #FFF8E1);
  box-shadow: 0 2px 12px rgba(244,208,63,0.2);
}
[data-theme="dark"] .ranking-top { background: linear-gradient(135deg, #3D3C38, #2B2A27); }
.ranking-medal {
  font-size: 28px; flex-shrink: 0; width: 36px; text-align: center;
}
.ranking-info {
  flex: 1; min-width: 0;
}
.ranking-name {
  font-weight: 700; font-size: 14px; margin-bottom: 6px;
}
.ranking-bar-wrap {
  height: 6px; background: var(--border); border-radius: 3px; overflow: hidden;
}
.ranking-bar-fill {
  height: 100%; border-radius: 3px; transition: width 0.6s ease;
}
.ranking-stats { text-align: right; flex-shrink: 0; }
.ranking-done {
  font-size: 12px; color: var(--text-muted); margin-bottom: 2px;
}
.ranking-rate {
  font-size: 18px; font-weight: 800;
}

/* ─── 할일 팝업 에디터 ─────────────────────────────────────────────────────── */
.task-popup {
  position: absolute;
  display: none;
  background: var(--bg-card);
  border: 2px solid var(--accent);
  border-radius: 12px;
  padding: 10px;
  z-index: 2000;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18);
  min-width: 280px;
}
.task-popup-ta {
  width: 100%;
  min-height: 90px;
  border: none;
  outline: none;
  background: transparent;
  color: var(--text-primary);
  font-size: 14px;
  font-family: inherit;
  resize: vertical;
  line-height: 1.6;
}
.task-popup-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 6px;
  border-top: 1px solid var(--border);
  padding-top: 6px;
}
.task-popup-hint {
  font-size: 11px;
  color: var(--text-muted);
}
.task-popup-save {
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 3px 12px;
  font-size: 12px;
  cursor: pointer;
  font-weight: 600;
}
.task-popup-save:hover { opacity: 0.85; }
/* 입력칸 readonly 스타일 — 클릭 유도 */
.time-task input[readonly] { cursor: pointer; }
.time-task input[readonly]:hover { background: var(--bg-secondary); }

/* ─── Gmail 받은편지함 위젯 ──────────────────────────────────────────────────── */
.gmail-updated {
  font-size: 11px; color: var(--text-muted); margin-bottom: 6px;
}
.gmail-list { display: flex; flex-direction: column; gap: 2px; max-height: 300px; overflow-y: auto; }
.gmail-item {
  display: flex; align-items: flex-start; gap: 8px;
  padding: 7px 6px; border-radius: 8px; text-decoration: none;
  color: var(--text-secondary); transition: background .15s;
}
.gmail-item:hover { background: var(--bg-secondary); }
.gmail-item.gmail-unread { color: var(--text-primary); }
.gmail-avatar {
  width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
  background: var(--accent); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
}
.gmail-content { flex: 1; min-width: 0; }
.gmail-sender { font-size: 12px; font-weight: 600; truncate: ellipsis; white-space: nowrap; overflow: hidden; }
.gmail-item.gmail-unread .gmail-sender { color: #d93025; }
.gmail-subject { font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gmail-item.gmail-unread .gmail-subject { font-weight: 600; }
.gmail-snippet { font-size: 11px; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gmail-time { font-size: 11px; color: var(--text-muted); white-space: nowrap; flex-shrink: 0; margin-top: 1px; }

/* ── Report sub-tabs ─────────────────────────────────────────── */
.report-sub-tabs {
  display: flex; gap: 4px;
  background: var(--bg-secondary); border-radius: 20px; padding: 3px;
}
.report-sub-btn {
  border: none; background: transparent; cursor: pointer;
  padding: 5px 14px; border-radius: 16px; font-size: 13px;
  color: var(--text-muted); font-weight: 500; transition: all .2s;
}
.report-sub-btn.active {
  background: var(--bg-card); color: var(--accent); font-weight: 700;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
}

/* ── Auto Analysis Cards ─────────────────────────────────────── */
.analysis-card {
  background: var(--bg-card); border-radius: 14px;
  border: 1px solid var(--border); padding: 16px 18px;
  margin-bottom: 12px; transition: box-shadow .2s;
}
.analysis-card:hover { box-shadow: 0 2px 12px rgba(196,123,90,.12); }
.ana-header {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 12px; flex-wrap: wrap;
}
.ana-name { font-weight: 700; font-size: 15px; color: var(--text-primary); flex: 1; min-width: 80px; }
.ana-time-range { font-size: 12px; color: var(--text-muted); }
.ana-total-badge {
  background: var(--accent); color: #fff;
  border-radius: 20px; padding: 2px 10px; font-size: 12px; font-weight: 600;
}
.ana-row {
  display: flex; align-items: flex-start; gap: 8px;
  margin-bottom: 8px; flex-wrap: wrap;
}
.ana-label { font-size: 12px; color: var(--text-muted); min-width: 60px; padding-top: 3px; flex-shrink: 0; }
.ana-tags { display: flex; flex-wrap: wrap; gap: 5px; }
.ana-tag {
  display: inline-flex; align-items: center; gap: 4px;
  border-radius: 10px; padding: 2px 9px; font-size: 12px; font-weight: 500;
}
.ana-app  { background: var(--bg-secondary); color: var(--text-primary); }
.ana-site { background: #e8f4fd; color: #1a6898; }
[data-theme="dark"] .ana-site { background: #3D3C38; color: #6a9BBF; }
.ana-tag small { font-size: 11px; opacity: .7; }

.ana-blocks-detail {
  margin-top: 10px; border-top: 1px solid var(--border); padding-top: 10px;
}
.ana-blocks-detail summary {
  font-size: 12px; color: var(--text-muted); cursor: pointer; list-style: none;
  padding: 2px 0; user-select: none;
}
.ana-blocks-detail summary::-webkit-details-marker { display: none; }
.ana-block-list { margin-top: 8px; display: flex; flex-direction: column; gap: 4px; }
.ana-block-row {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; padding: 3px 0;
}
.ana-block-time  { color: var(--text-muted); min-width: 42px; flex-shrink: 0; }
.ana-block-status { min-width: 18px; flex-shrink: 0; }
.ana-block-task  { flex: 1; color: var(--text-primary); overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.ana-actual {
  font-size: 11px; background: #fff3cd; color: #856404; border-radius: 6px;
  padding: 1px 6px; flex-shrink: 0;
}
[data-theme="dark"] .ana-actual { background: #4A4540; color: #D4944E; }

.ana-nodata-row {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
  padding: 10px 14px; background: var(--bg-secondary); border-radius: 10px;
  margin-top: 8px;
}
.ana-nodata-user {
  font-size: 12px; border-radius: 20px; padding: 2px 10px; font-weight: 500;
}

/* ── Score boxes ──────────────────────────────────────────────── */
.ana-scores {
  display: flex; gap: 10px; margin-bottom: 14px; flex-wrap: wrap;
}
.ana-score-box {
  flex: 1; min-width: 80px;
  border: 2px solid; border-radius: 12px;
  padding: 10px 12px; text-align: center; background: var(--bg-card);
}
.ana-score-num  { font-size: 26px; font-weight: 800; line-height: 1.1; }
.ana-score-name { font-size: 11px; color: var(--text-muted); margin: 2px 0; }
.ana-score-lbl  { font-size: 12px; font-weight: 600; }

/* ── Time distribution bar ───────────────────────────────────── */
.ana-bar {
  display: flex; height: 14px; border-radius: 7px; overflow: hidden;
  background: var(--bg-secondary); width: 100%;
}
.ana-bar-seg { height: 100%; transition: width .3s; }
.ana-legend  { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.ana-legend-item { display: flex; align-items: center; gap: 4px; font-size: 12px; color: var(--text-muted); }
.ana-legend-dot  { width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
.ana-legend-item b { color: var(--text-primary); }

/* ── Ghost block warning ─────────────────────────────────────── */
.ana-ghost-alert {
  background: #fff0f0; border: 1px solid #f07b8a; border-radius: 8px;
  padding: 8px 12px; font-size: 12px; color: #c0392b; margin-bottom: 10px;
}
[data-theme="dark"] .ana-ghost-alert { background: #3D3530; border-color: #C4605A; color: #E08A82; }
.ana-ghost-warn {
  font-size: 11px; background: #fff0f0; color: #c0392b;
  border-radius: 6px; padding: 1px 6px; flex-shrink: 0; white-space: nowrap;
}
.ana-block-row.ana-ghost { background: #fff5f5; border-radius: 6px; padding: 2px 4px; }
[data-theme="dark"] .ana-block-row.ana-ghost { background: #3A3230; }

/* ════════════════════════════════════════════════════════════
   종합 리포트 모달
   ════════════════════════════════════════════════════════════ */
#combined-report-modal {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 2000;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  overflow-y: auto;
  padding: 24px 16px;
}
.crm-dialog {
  background: var(--bg-card);
  border-radius: 18px;
  width: 100%;
  max-width: 880px;
  margin: auto;
  box-shadow: 0 8px 48px rgba(0,0,0,0.25);
  overflow: hidden;
}

/* 헤더 */
.crm-header {
  padding: 20px 28px 16px;
  display: flex; align-items: center; gap: 14px;
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0;
  background: var(--bg-card);
  z-index: 10;
}
.crm-header-info { flex: 1; }
.crm-header-name  { font-size: 18px; font-weight: 800; }
.crm-header-meta  { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.crm-header-actions { display: flex; gap: 8px; }
.crm-print-btn {
  padding: 6px 14px; border-radius: 8px;
  background: var(--accent); color: #fff;
  border: none; font-size: 12px; font-weight: 600; cursor: pointer;
}
.crm-close-btn {
  width: 30px; height: 30px; border-radius: 50%;
  border: none; background: var(--bg-secondary);
  font-size: 16px; cursor: pointer; color: var(--text-muted);
  display: flex; align-items: center; justify-content: center;
}
.crm-close-btn:hover { background: var(--danger-bg); color: var(--danger); }

/* AI 분석 버튼 */
.crm-ai-btn {
  padding: 6px 14px; border-radius: 8px;
  background: linear-gradient(135deg, #10a37f, #1a7f5a);
  color: #fff; border: none; font-size: 12px; font-weight: 600;
  cursor: pointer; transition: opacity .15s;
}
.crm-ai-btn:hover { opacity: .85; }

/* AI 분석 섹션 */
.crm-ai-section { border-left: 3px solid #10a37f; }
.crm-ai-model {
  font-size: 10px; font-weight: 400; color: #10a37f;
  background: #10a37f18; border-radius: 4px; padding: 1px 6px; margin-left: 6px;
}
.crm-ai-loading {
  display: flex; align-items: center; gap: 10px;
  color: var(--text-muted); font-size: 13px; padding: 8px 0;
}
.crm-ai-spinner {
  width: 16px; height: 16px; border-radius: 50%;
  border: 2px solid #10a37f44; border-top-color: #10a37f;
  animation: spin .7s linear infinite; flex-shrink: 0;
}
@keyframes spin { to { transform: rotate(360deg); } }
.crm-ai-body {
  font-size: 13px; line-height: 1.75; color: var(--text);
}
.crm-ai-para   { margin: 10px 0 4px; }
.crm-ai-header { display: inline-block; margin-top: 4px; font-weight: 700; font-size: 13px; }
.crm-ai-emoji  { font-size: 15px; margin-right: 4px; }
.crm-ai-meta  { font-size: 10px; color: var(--text-muted); font-weight: 400; margin-left: 8px; }
.crm-ai-redo-btn {
  margin-left: auto; font-size: 11px; font-weight: 600;
  background: none; border: 1px solid #10a37f55; color: #10a37f;
  border-radius: 6px; padding: 2px 8px; cursor: pointer;
  transition: background .15s;
}
.crm-ai-redo-btn:hover { background: #10a37f18; }

/* AI 사용량 위젯 */
#ai-usage-widget {
  position: fixed;
  bottom: 18px;
  right: 18px;
  z-index: 200;
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg-card);
  border: 1px solid #10a37f44;
  border-radius: 20px;
  padding: 6px 12px 6px 8px;
  box-shadow: 0 2px 12px rgba(16,163,127,.15);
  font-size: 11px;
  color: var(--text-primary);
  backdrop-filter: blur(4px);
  transition: opacity .2s, transform .2s;
  cursor: default;
}
#ai-usage-widget:hover { opacity: 1; transform: translateY(-1px); }
.auw-icon { font-size: 14px; line-height: 1; }
.auw-body { display: flex; flex-direction: column; gap: 1px; }
.auw-tokens { font-weight: 700; font-size: 11px; color: var(--text-primary); }
.auw-cost   { font-size: 12px; font-weight: 800; color: #10a37f; letter-spacing: .5px; }
.auw-model  {
  font-size: 9px; font-weight: 700; color: #10a37f99;
  background: #10a37f15; border-radius: 4px; padding: 1px 5px;
  letter-spacing: .5px; text-transform: uppercase;
}

/* 채팅 FAB과 겹치지 않게 (모바일) */
@media (max-width: 767px) {
  #ai-usage-widget { bottom: 80px; right: 14px; }
}

/* 채팅 패널이 열려있을 때 위젯 위치 조정 */
body.has-chat #ai-usage-widget { right: 298px; }
@media (max-width: 767px) {
  body.has-chat #ai-usage-widget { right: 14px; }
}

/* 점수 카드 */
.crm-scores {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  padding: 20px 28px;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
}
.crm-score-card {
  background: var(--bg-card);
  border-radius: 12px;
  padding: 14px;
  text-align: center;
  border: 2px solid var(--border);
}
.crm-score-num  { font-size: 28px; font-weight: 800; line-height: 1; margin-bottom: 2px; }
.crm-score-name { font-size: 11px; color: var(--text-muted); margin-bottom: 6px; }
.crm-grade-badge {
  display: inline-block;
  width: 32px; height: 32px; border-radius: 50%;
  font-size: 16px; font-weight: 900;
  line-height: 32px;
}

/* 섹션 */
.crm-section { padding: 20px 28px; border-bottom: 1px solid var(--border-light); }
.crm-section:last-child { border-bottom: none; }
.crm-section-title {
  font-size: 13px; font-weight: 700;
  color: var(--text-muted); letter-spacing: 0.5px;
  text-transform: uppercase; margin-bottom: 14px;
  display: flex; align-items: center; gap: 6px;
}

/* 시간 분포 바 */
.crm-time-bar {
  height: 22px; border-radius: 6px;
  display: flex; overflow: hidden;
  margin-bottom: 8px;
}
.crm-time-seg { height: 100%; transition: width 0.4s; }
.crm-time-legend { display: flex; flex-wrap: wrap; gap: 8px; }
.crm-legend-item { display: flex; align-items: center; gap: 5px; font-size: 12px; }
.crm-legend-dot  { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }

/* 상위 사이트 태그 */
.crm-site-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.crm-site-tag {
  display: flex; align-items: center; gap: 5px;
  padding: 4px 10px; border-radius: 20px;
  font-size: 12px; font-weight: 500;
}

/* 앱 리스트 */
.crm-app-list { display: flex; flex-wrap: wrap; gap: 8px; }
.crm-app-item {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: 8px;
  background: var(--bg-secondary); font-size: 12px;
}
.crm-app-bar {
  height: 4px; border-radius: 2px;
  background: var(--accent); margin-top: 2px;
}

/* 블록 비교 테이블 */
.crm-block-table { width: 100%; border-collapse: collapse; }
.crm-block-table th {
  text-align: left; font-size: 11px; color: var(--text-muted);
  padding: 7px 10px; border-bottom: 2px solid var(--border);
  font-weight: 600; text-transform: uppercase;
}
.crm-block-table td { padding: 8px 10px; font-size: 12px; border-bottom: 1px solid var(--border-light); vertical-align: middle; }
.crm-block-table tr:hover td { background: var(--bg-hover); }
.crm-block-table tr.row-ghost td { background: var(--danger-bg); }
.crm-block-table tr.row-done  td { }
.crm-block-table tr.row-skip  td { opacity: 0.55; }

/* 상태 배지 */
.crm-status-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 99px;
}
.crm-cat-badge {
  display: inline-block; font-size: 10px; font-weight: 600;
  padding: 1px 7px; border-radius: 4px;
}

/* 블록별 멀티사이트 pill 요약 */
.crm-td-activity { min-width: 220px; max-width: 320px; }
.crm-site-pills { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 3px; }
.crm-site-pill {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 11px; padding: 2px 8px; border-radius: 20px;
  white-space: nowrap; line-height: 1.4;
}
.crm-site-pill b { font-weight: 700; }
.crm-site-pill-more {
  font-size: 11px; color: var(--text-muted);
  padding: 2px 5px; align-self: center;
}

/* 펼치기 URL 목록 */
.crm-url-details { margin-top: 2px; }
.crm-url-details summary {
  font-size: 11px; color: var(--text-muted);
  cursor: pointer; user-select: none;
  list-style: none; outline: none;
  padding: 2px 0;
}
.crm-url-details summary:hover { color: var(--accent); }
.crm-url-details[open] summary { color: var(--accent); }
.crm-url-list {
  margin-top: 5px; display: flex; flex-direction: column; gap: 1px;
  max-height: 180px; overflow-y: auto;
  border-left: 2px solid var(--border-light);
  padding-left: 8px;
}
.crm-url-row {
  display: grid; grid-template-columns: 38px 90px 1fr;
  gap: 5px; align-items: center;
  font-size: 11px; padding: 2px 4px; border-radius: 4px;
}
.crm-url-row:hover { background: var(--bg-hover); }
.crm-url-time   { color: var(--text-muted); font-variant-numeric: tabular-nums; }
.crm-url-domain { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.crm-url-mins   { font-size: 10px; font-weight: 700; opacity: 0.75; margin-left: 2px; }
.crm-url-title  { color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.crm-url-link   { color: inherit; text-decoration: none; }
.crm-url-link:hover { color: var(--accent); text-decoration: underline; }

/* 종합 평가 */
.crm-eval-list { display: flex; flex-direction: column; gap: 8px; }
.crm-eval-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 14px; border-radius: 10px;
  font-size: 13px;
}
.crm-eval-good    { background: var(--success-bg); color: #2d8a6a; }
.crm-eval-warning { background: var(--warning-bg); color: #c07020; }
.crm-eval-danger  { background: var(--danger-bg);  color: #c03050; }
.crm-eval-info    { background: var(--info-bg);    color: #3070c0; }

/* 요약 인용구 */
.crm-summary-quote {
  background: var(--bg-secondary);
  border-left: 4px solid var(--accent);
  padding: 12px 16px; border-radius: 0 10px 10px 0;
  font-size: 13px; color: var(--text-primary);
  margin-bottom: 12px;
  font-style: italic;
}

/* 인쇄 */
@media print {
  /* 모달 뒤 모든 요소 숨김 */
  body > *:not(#combined-report-modal) { display: none !important; }
  body { background: #fff !important; margin: 0; padding: 0; }

  /* 모달 오버레이 제거 → 다이얼로그만 출력 */
  #combined-report-modal {
    position: static !important;
    background: none !important;
    padding: 0 !important;
    display: block !important;
    overflow: visible !important;
  }
  .crm-dialog {
    box-shadow: none !important;
    border-radius: 0 !important;
    max-width: 100% !important;
    max-height: none !important;
    overflow: visible !important;
    padding: 20px !important;
  }
  /* 버튼 숨김 */
  .crm-header-actions { display: none !important; }
  /* 페이지 나눔 */
  .crm-section { page-break-inside: avoid; }
}

/* ─── 🎨 그림 맞추기 게임 ───────────────────────────────────────── */
#draw-modal {
  backdrop-filter: blur(10px) brightness(0.55);
  -webkit-backdrop-filter: blur(10px) brightness(0.55);
  background: rgba(0,0,0,.55) !important;
}

.draw-dialog {
  background: var(--bg-card);
  border-radius: 16px;
  padding: 16px 20px;
  box-shadow: 0 12px 60px rgba(0,0,0,.7);
  width: 90vw;
  max-width: 90vw;
  max-height: 90vh;
  overflow-y: auto;
  margin: auto;
}

.draw-dialog-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  font-size: 16px;
  font-weight: 800;
  color: var(--text);
}

.draw-tab-btn {
  padding: 4px 10px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text-muted);
  font-size: 12px;
  cursor: pointer;
  transition: all .15s;
}
.draw-tab-btn.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.draw-phase-label {
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 8px;
  text-align: center;
}

.draw-countdown {
  font-size: 32px;
  font-weight: 900;
  color: var(--accent);
  text-align: center;
  margin-bottom: 14px;
  font-variant-numeric: tabular-nums;
  letter-spacing: -1px;
}

.draw-volunteer-btn {
  font-size: 15px;
  padding: 10px 32px;
}

/* 단어 선택 */
.draw-word-select {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 12px;
}
.draw-word-btn {
  padding: 10px 14px;
  border-radius: 10px;
  border: 2px solid var(--border);
  background: var(--bg-secondary);
  color: var(--text);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  text-align: left;
  transition: all .15s;
}
.draw-word-btn:hover {
  border-color: var(--accent);
  background: rgba(108,99,255,.12);
}

/* 캔버스 */
.draw-canvas-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 8px;
}
.draw-canvas-wrap canvas {
  border: 2px solid var(--border);
  border-radius: 8px;
  cursor: crosshair;
  touch-action: none;
  width: 100%;
  /* 너비와 높이 모두 화면 안에 들어오도록: vw/vh 양쪽 모두 제약 */
  max-width: min(480px, calc(90vw - 60px), calc(90vh - 290px));
  height: auto;
  aspect-ratio: 1;
  display: block;
}

/* 도구 */
.draw-tools { display: flex; flex-direction: column; gap: 6px; }
.draw-tool-row {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}
.draw-tool-btn {
  padding: 5px 10px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--bg-secondary);
  color: var(--text);
  font-size: 12px;
  cursor: pointer;
  transition: all .15s;
}
.draw-tool-btn.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
#draw-color-pick {
  width: 36px;
  height: 30px;
  border-radius: 6px;
  border: 1px solid var(--border);
  padding: 2px;
  cursor: pointer;
  background: var(--bg-card);
}
#draw-size-sel {
  font-size: 12px;
  padding: 3px 6px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--bg-card);
  color: var(--text);
}

/* 투표 선택지 */
.draw-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin: 10px 0;
}
.draw-option-btn {
  padding: 10px 8px;
  border-radius: 10px;
  border: 2px solid var(--border);
  background: var(--bg-secondary);
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  text-align: center;
  transition: all .15s;
  line-height: 1.4;
}
.draw-option-btn:not(.result-opt):hover { border-color: var(--accent); }
.draw-option-btn.selected  { border-color: var(--accent); background: rgba(196,123,90,.15); }
.draw-option-btn.correct   { border-color: #2ecc71; background: rgba(46,204,113,.15); color: #2ecc71; }
.draw-option-btn.wrong     { border-color: var(--border); opacity: .6; }
.draw-option-btn.my-vote   { box-shadow: 0 0 0 2px var(--accent) inset; }

.draw-confirm-btn {
  width: 100%;
  margin-top: 8px;
  font-size: 14px;
  padding: 10px;
}
.draw-confirm-btn:disabled {
  opacity: .45;
  cursor: not-allowed;
}

/* 결과 이미지 */
.draw-result-img {
  width: 100%;
  max-width: min(480px, calc(90vw - 60px), calc(90vh - 290px));
  border: 2px solid var(--border);
  border-radius: 8px;
  display: block;
  margin: 0 auto 10px;
}

/* 준비 버튼 */
.draw-ready-btn {
  font-size: 16px;
  padding: 12px 48px;
  border-radius: 12px;
}
.draw-ready-cancel-btn {
  font-size: 13px;
  padding: 8px 20px;
  border-radius: 10px;
  border: 2px solid #5CC8A0;
  color: #5CC8A0;
  background: rgba(92,200,160,.1);
  cursor: pointer;
}
.draw-volunteer-btn {
  font-size: 20px;
  padding: 16px 60px;
  border-radius: 14px;
}

@keyframes drawPulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(108,99,255,.5); }
  50%       { transform: scale(1.04); box-shadow: 0 0 0 8px rgba(108,99,255,0); }
}

/* 히스토리 */
.draw-history-item {
  margin-bottom: 14px;
  padding: 12px;
  background: var(--bg-secondary);
  border-radius: 10px;
  border: 1px solid var(--border);
}
.draw-history-item img {
  width: 100%;
  border-radius: 6px;
  margin-bottom: 6px;
}

/* 뱃지 */
#draw-fab-badge {
  display: none;
  position: absolute;
  top: -4px; right: -4px;
  background: #e74c3c;
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  border-radius: 8px;
  padding: 1px 5px;
  line-height: 1.4;
  pointer-events: none;
}
.draw-nav-btn { position: relative; }

@keyframes drawBounce {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-6px); }
}

/* ─── Chart Grid ──────────────────────────────────────── */
.chart-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.chart-card {
  background: var(--bg-card);
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 18px;
  box-shadow: var(--shadow);
}
.chart-card-wide {
  grid-column: 1 / -1;
}
.chart-title {
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--text-primary);
}

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

body.km-theme .chart-card {
  background: var(--km-surface) !important;
  border-color: rgba(245,197,24,0.08) !important;
}
body.km-theme .chart-title {
  color: var(--km-gold) !important;
}

/* ─── Range Filter ─────────────────────────────────── */
.range-filter {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
.range-btn {
  padding: 5px 12px; border-radius: 8px; border: 1.5px solid var(--border);
  background: var(--bg-secondary); color: var(--text-primary);
  font-size: 12px; font-weight: 600; cursor: pointer;
  transition: all .15s;
}
.range-btn:hover { border-color: var(--accent); color: var(--accent); }
.range-btn.active {
  background: var(--accent); color: #fff; border-color: var(--accent);
}
.range-filter input[type="date"] {
  padding: 4px 8px; border-radius: 6px; border: 1.5px solid var(--border);
  background: var(--bg-card); color: var(--text-primary); font-size: 12px;
}
/* km-theme overrides */
body.km-theme .range-btn {
  border-color: rgba(245,197,24,0.15); background: var(--km-surface);
  color: var(--km-text);
}
body.km-theme .range-btn:hover { border-color: var(--km-gold); color: var(--km-gold); }
body.km-theme .range-btn.active {
  background: linear-gradient(135deg, #F5C518, #D4A017);
  color: #000; border-color: transparent;
}
body.km-theme .range-filter input[type="date"] {
  background: var(--km-surface); color: var(--km-text);
  border-color: rgba(245,197,24,0.15);
}
@media (max-width: 480px) {
  .range-filter { gap: 4px; }
  .range-btn { padding: 4px 8px; font-size: 11px; }
}

/* ── Notification Bell ────────────────────────────── */
.notif-bell {
  position: relative; cursor: pointer; font-size: 18px;
  background: none; border: none; padding: 4px 6px;
  color: var(--text-muted); transition: color .15s;
}
.notif-bell:hover { color: var(--accent); }
.notif-bell.notif-on { color: var(--warning); }
.notif-bell .notif-dot {
  position: absolute; top: 2px; right: 2px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--danger); display: none;
}
.notif-bell.notif-on .notif-dot { display: block; }
body.km-theme .notif-bell:hover { color: var(--km-gold); }
body.km-theme .notif-bell.notif-on { color: var(--km-gold); }

/* ══════════════════════════════════════════════════════
   마스터/킹마스터 모바일 최적화
   ══════════════════════════════════════════════════════ */

/* ── 태블릿 (768px 이하) ── */
@media (max-width: 768px) {
  /* 통계 바 */
  .master-stats {
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
    gap: 8px; margin-bottom: 16px;
  }
  .master-stat { padding: 12px 8px; }
  .master-stat .number { font-size: 1.5rem; }
  .master-stat .label { font-size: 10px; }

  /* 탭 버튼 스크롤 가능 */
  .tabs {
    flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch;
    scrollbar-width: none; gap: 4px; padding-bottom: 4px;
  }
  .tabs::-webkit-scrollbar { display: none; }
  .tab-btn { white-space: nowrap; flex-shrink: 0; padding: 7px 10px; font-size: 11px; }

  /* 날짜 네비 */
  .date-nav { flex-wrap: nowrap; }
  .date-display { font-size: 13px; }

  /* 보고서 서브탭 */
  .report-sub-tabs { flex-wrap: nowrap; overflow-x: auto; gap: 4px; }
  .report-sub-btn { white-space: nowrap; flex-shrink: 0; font-size: 11px; padding: 5px 10px; }

  /* 유저 그리드 1열 */
  .users-grid { grid-template-columns: 1fr; }

  /* 유저 카드 */
  .user-card { padding: 12px; gap: 10px; }

  /* 모니터링 그리드 */
  .mon-grid { grid-template-columns: 1fr !important; }

  /* 분석 카드 */
  .analysis-card { padding: 12px; }
  .ana-scores { gap: 6px; }
  .ana-score-box { padding: 8px 6px; min-width: 70px; }
  .ana-score-num { font-size: 18px; }
  .ana-tags { gap: 4px; }
  .ana-tag { font-size: 10px; padding: 2px 6px; }

  /* 보고서 카드 */
  .report-card { padding: 12px; }

  /* 회원 관리 카드 간격 */
  .member-card { flex-wrap: wrap; gap: 8px; }
}

/* ── 모바일 (480px 이하) ── */
@media (max-width: 480px) {
  /* 통계 바 2열 */
  .master-stats {
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
  }
  .master-stat { padding: 10px 6px; }
  .master-stat .number { font-size: 1.3rem; }

  /* 메인 콘텐츠 패딩 */
  .main-content { padding: 10px 8px !important; }

  /* 탭 더 작게 */
  .tab-btn { padding: 6px 8px; font-size: 10px; }

  /* 분석 점수 세로 배치 */
  .ana-scores { flex-direction: column; }
  .ana-score-box { flex-direction: row; justify-content: space-between; min-width: unset; }

  /* 킹마스터 탭 */
  .km-tabs { gap: 3px; }
  .km-tab-btn { padding: 6px 10px; font-size: 11px; }

  /* XP 관리 행 */
  .km-xp-row { padding: 10px 12px; gap: 8px; }
  .km-xp-controls { gap: 4px; }
  .km-xp-chip { padding: 3px 7px; font-size: 11px; }

  /* 경보 대시보드 */
  .km-alert-summary { grid-template-columns: 1fr; }
  .km-alert-user-row { padding: 8px 10px; }

  /* 테이블 스크롤 */
  .km-log-table { font-size: 11px; }
  .km-log-table th, .km-log-table td { padding: 6px 8px; }
}

/* ── 마스터/킹마스터 navbar 모바일 fix ── */
@media (max-width: 768px) {
  /* master/kingmaster 페이지: navbar fixed 해제 → 컨텐츠 가림 방지 */
  body.master-page .navbar,
  body.km-theme .navbar {
    position: relative !important;
    height: auto !important;
    min-height: 48px;
    flex-wrap: wrap;
    padding: 8px 12px;
    gap: 6px;
  }
  body.master-page .page-gradient-bar,
  body.km-theme .page-gradient-bar {
    position: relative !important;
    top: auto !important;
  }
  body.master-page .main-content,
  body.km-theme .main-content {
    padding-top: 16px !important;
  }
  body.master-page .navbar .navbar-spacer,
  body.km-theme .navbar .navbar-spacer { flex-basis: 100%; height: 0; }
  body.master-page .navbar .lang-mini,
  body.km-theme .navbar .lang-mini { margin-left: 0 !important; }
  body.master-page .navbar .btn,
  body.km-theme .navbar .btn { margin-left: 0 !important; }
}

/* ── 킹마스터 페이지 전용 모바일 ── */
@media (max-width: 768px) {
  body.km-theme .km-badge { font-size: 9px; padding: 2px 6px; }
  body.km-theme .tabs-divider { margin: 16px 0 2px 0; }
  body.km-theme .master-card { flex-wrap: wrap; padding: 12px; gap: 10px; }
  body.km-theme .mc-avatar { width: 36px; height: 36px; font-size: 15px; }
  body.km-theme .mc-detail { font-size: 11px; }
}
