/* ═══════════════════════════════════════════════════════
   三思即行 · 党建工作日历 — 样式表
   配色：红(#C41E3A) · 金(#D4A843) · 白(#FFFFFF)
   ═══════════════════════════════════════════════════════ */

:root {
  --red: #C41E3A;
  --red-dark: #8B0000;
  --red-light: #F8E8EB;
  --gold: #D4A843;
  --gold-light: #FBF3E0;
  --gold-dark: #B8860B;
  --bg: #FFFBF5;
  --bg-card: #FFFFFF;
  --text: #2C1810;
  --text-light: #6B5E55;
  --border: #E8DCC8;
  --border-light: #F2EBDE;
  --shadow: 0 2px 12px rgba(139,0,0,.08);
  --shadow-lg: 0 8px 32px rgba(139,0,0,.12);
  --radius: 10px;
  --radius-sm: 6px;
  --font: -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Hiragino Sans GB", sans-serif;
}

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

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  min-height: 100vh;
}

.app-container { min-height:100vh; display:flex; flex-direction:column; }

/* ── 头部 ───────────────────── */
.app-header {
  background: linear-gradient(135deg, var(--red-dark) 0%, var(--red) 60%, #D4455A 100%);
  color: #fff;
  padding: 12px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-shadow: 0 2px 8px rgba(0,0,0,.15);
  position: sticky;
  top: 0;
  z-index: 100;
}
.header-left { display:flex; align-items:baseline; gap:12px; }
.app-logo { font-size:22px; font-weight:800; letter-spacing:2px; }
.logo-icon { color: var(--gold); font-size:24px; margin-right:4px; }
.header-subtitle { font-size:13px; opacity:.85; letter-spacing:1px; }
.header-right { display:flex; align-items:center; gap:16px; }
.user-info { font-size:13px; opacity:.9; cursor:pointer; }
.nav-link { color:#fff; text-decoration:none; font-size:14px; padding:4px 12px;
  border-radius:20px; transition:background .2s; }
.nav-link:hover { background:rgba(255,255,255,.15); }
.btn-logout { background:rgba(255,255,255,.2); color:#fff; border:1px solid rgba(255,255,255,.3);
  padding:6px 14px; border-radius:20px; cursor:pointer; font-size:13px; transition:background .2s; }
.btn-logout:hover { background:rgba(255,255,255,.3); }

/* ── 主体 ───────────────────── */
.app-main { flex:1; padding:24px; max-width:1200px; margin:0 auto; width:100%; }

/* ── 底部 ───────────────────── */
.app-footer {
  text-align: center;
  padding: 16px;
  color: var(--text-light);
  font-size: 12px;
  border-top: 1px solid var(--border-light);
}
.app-footer span { display:block; }

/* ── 月导航 ─────────────────── */
.month-nav {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:20px;
  margin-bottom:16px;
}
.nav-arrow {
  width:44px; height:44px; border-radius:50%;
  border:2px solid var(--border);
  background: var(--bg-card);
  cursor: pointer;
  font-size: 18px;
  color: var(--red);
  transition: all .2s;
  display:flex; align-items:center; justify-content:center;
}
.nav-arrow:hover { border-color:var(--red); background:var(--red-light); }
.month-title { text-align:center; min-width:160px; }
.year-display { display:block; font-size:14px; color:var(--text-light); letter-spacing:4px; }
.month-display { display:block; font-size:32px; font-weight:800; color:var(--red-dark); letter-spacing:2px; }
.btn-today {
  padding:8px 18px;
  border:1px solid var(--red);
  background: var(--bg-card);
  color: var(--red);
  border-radius:20px;
  cursor: pointer;
  font-size:13px;
  transition: all .2s;
}
.btn-today:hover { background:var(--red); color:#fff; }

/* ── 统计条 ─────────────────── */
.stats-bar {
  display:flex;
  gap:16px;
  margin-bottom:16px;
  justify-content:center;
}
.stat-item {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:12px 24px;
  text-align:center;
  min-width:100px;
  box-shadow:var(--shadow);
}
.stat-num { display:block; font-size:28px; font-weight:800; color:var(--red); }
.stat-label { display:block; font-size:12px; color:var(--text-light); margin-top:2px; }

/* ── 图例 ───────────────────── */
.legend-bar {
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  justify-content:center;
  margin-bottom:20px;
}
.legend-item { font-size:12px; color:var(--text-light); display:flex; align-items:center; gap:4px; }
.dot { width:10px; height:10px; border-radius:50%; display:inline-block; }

/* ── 日历网格 ───────────────── */
.calendar-grid {
  display:grid;
  grid-template-columns: repeat(7, 1fr);
  gap:6px;
  background: var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:8px;
  box-shadow:var(--shadow);
}
.calendar-grid .weekday-header {
  text-align:center;
  padding:10px 4px;
  font-size:13px;
  font-weight:700;
  color:var(--text-light);
  border-bottom:2px solid var(--border-light);
}
.calendar-grid .weekday-header.weekend { color:var(--red); }
.calendar-grid .day-cell {
  min-height:90px;
  border:1px solid var(--border-light);
  border-radius:var(--radius-sm);
  padding:6px;
  cursor:pointer;
  transition:all .15s;
  background:var(--bg-card);
  position:relative;
  overflow:hidden;
}
.calendar-grid .day-cell:hover {
  border-color:var(--red);
  box-shadow:0 2px 8px rgba(196,30,58,.12);
  transform:translateY(-1px);
}
.calendar-grid .day-cell.empty { background:var(--bg); cursor:default; border:none; }
.calendar-grid .day-cell.empty:hover { transform:none; box-shadow:none; border:none; }
.calendar-grid .day-cell.today { border:2px solid var(--red); }
.calendar-grid .day-cell.weekend .day-num { color:var(--red); }
.day-num {
  font-size:14px;
  font-weight:700;
  color:var(--text);
  margin-bottom:2px;
}
.day-lunar {
  font-size:10px;
  color:var(--text-light);
  margin-bottom:4px;
}
.day-dot {
  display:inline-block;
  width:6px; height:6px;
  border-radius:50%;
  margin:1px 2px;
  vertical-align:middle;
}
.day-task-mini {
  font-size:10px;
  padding:1px 4px;
  border-radius:3px;
  margin:1px 0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  line-height:1.4;
}
.task-cat-主题党日 { background:var(--red-light); color:var(--red); }
.task-cat-三会一课 { background:#FFEBEE; color:var(--red-dark); }
.task-cat-重要节点 { background:var(--gold-light); color:var(--gold-dark); }
.task-cat-前置提醒 { background:#FFF8E1; color:#E8960C; }
.task-cat-组织生活 { background:#E8F5E9; color:#2E7D32; }
.task-cat-学习教育 { background:#E3F2FD; color:#1565C0; }
.task-cat-党员发展 { background:#F3E5F5; color:#7B1FA2; }
.day-note-icon { font-size:12px; color:var(--text-light); }

/* ── 弹窗 ───────────────────── */
.modal-overlay {
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.5);
  z-index:200;
  align-items:center;
  justify-content:center;
  padding:20px;
}
.modal-overlay.active { display:flex; }
.modal-card {
  background:var(--bg-card);
  border-radius:var(--radius);
  width:620px;
  max-width:95vw;
  max-height:85vh;
  overflow-y:auto;
  box-shadow:var(--shadow-lg);
}
.modal-header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:20px 24px;
  border-bottom:1px solid var(--border-light);
  background:linear-gradient(135deg, var(--red-light), #fff);
}
.modal-header h2 { font-size:20px; color:var(--red-dark); }
.modal-close {
  width:32px; height:32px;
  border:none; background:none;
  font-size:20px; color:var(--text-light);
  cursor:pointer; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
.modal-close:hover { background:rgba(0,0,0,.05); }
.modal-body { padding:20px 24px; }
.modal-footer { padding:16px 24px; border-top:1px solid var(--border-light); display:flex; gap:10px; justify-content:flex-end; }

/* 任务列表 */
.task-list { display:flex; flex-direction:column; gap:12px; }
.task-card {
  padding:14px 16px;
  border-radius:var(--radius-sm);
  border-left:4px solid;
  background:var(--bg);
}
.task-card.cat-主题党日 { border-left-color:var(--red); background:var(--red-light); }
.task-card.cat-三会一课 { border-left-color:var(--red-dark); background:#FFEBEE; }
.task-card.cat-重要节点 { border-left-color:var(--gold); background:var(--gold-light); }
.task-card.cat-前置提醒 { border-left-color:#E8960C; background:#FFF8E1; }
.task-card.cat-组织生活 { border-left-color:#2E7D32; background:#E8F5E9; }
.task-card.cat-学习教育 { border-left-color:#1565C0; background:#E3F2FD; }
.task-card.cat-党员发展 { border-left-color:#7B1FA2; background:#F3E5F5; }
.task-card-header { display:flex; align-items:center; gap:8px; margin-bottom:6px; }
.task-card-cat {
  font-size:11px;
  padding:2px 8px;
  border-radius:10px;
  color:#fff;
  font-weight:600;
}
.cat-badge-主题党日 { background:var(--red); }
.cat-badge-三会一课 { background:var(--red-dark); }
.cat-badge-重要节点 { background:var(--gold); }
.cat-badge-前置提醒 { background:#E8960C; }
.cat-badge-组织生活 { background:#2E7D32; }
.cat-badge-学习教育 { background:#1565C0; }
.cat-badge-党员发展 { background:#7B1FA2; }
.task-card-title { font-size:15px; font-weight:700; color:var(--text); }
.task-card-desc { font-size:13px; color:var(--text-light); white-space:pre-line; line-height:1.7; }
.task-card-remind {
  margin-top:6px;
  font-size:11px;
  color:#E8960C;
  padding:4px 8px;
  background:#FFF8E1;
  border-radius:4px;
  display:inline-block;
}
.holiday-tag {
  display:inline-block;
  background:var(--red);
  color:#fff;
  padding:4px 12px;
  border-radius:12px;
  font-size:13px;
  margin-bottom:12px;
}
.note-hint {
  text-align:center;
  padding:24px;
  color:var(--text-light);
  font-size:14px;
}

/* ── 评论 ───────────────────── */
.comment-section {
  border-top:1px solid var(--border-light);
  padding:20px 24px;
}
.comment-section h3 { font-size:15px; color:var(--text); margin-bottom:12px; }
.comment-list { display:flex; flex-direction:column; gap:10px; max-height:250px; overflow-y:auto; margin-bottom:12px; }
.comment-item { padding:10px 12px; background:var(--bg); border-radius:var(--radius-sm); }
.comment-meta { font-size:11px; color:var(--text-light); margin-bottom:4px; }
.comment-meta strong { color:var(--red); }
.comment-content { font-size:13px; color:var(--text); line-height:1.6; }
.comment-form { display:flex; gap:8px; align-items:flex-end; }
.comment-form textarea {
  flex:1;
  padding:10px;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  font-size:13px;
  font-family:var(--font);
  resize:none;
}
.comment-form textarea:focus { outline:none; border-color:var(--red); }
.btn-comment {
  padding:10px 20px;
  background:var(--red);
  color:#fff;
  border:none;
  border-radius:var(--radius-sm);
  font-size:13px;
  cursor:pointer;
  white-space:nowrap;
  font-weight:600;
}
.btn-comment:hover { background:var(--red-dark); }

/* ── 通用按钮 ───────────────── */
.btn-primary {
  padding:10px 24px;
  background:linear-gradient(135deg,var(--red),var(--red-dark));
  color:#fff;
  border:none;
  border-radius:var(--radius-sm);
  font-size:14px;
  font-weight:600;
  cursor:pointer;
}
.btn-primary:hover { opacity:.9; }
.btn-secondary {
  padding:8px 16px;
  background:var(--bg-card);
  color:var(--red);
  border:1px solid var(--red);
  border-radius:var(--radius-sm);
  font-size:13px;
  cursor:pointer;
}
.btn-secondary:hover { background:var(--red-light); }
.btn-danger {
  padding:8px 16px;
  background:#fff;
  color:#d32f2f;
  border:1px solid #d32f2f;
  border-radius:var(--radius-sm);
  font-size:13px;
  cursor:pointer;
}
.btn-danger:hover { background:#ffebee; }
.btn-sm { padding:6px 14px; font-size:12px; }

/* ── 管理面板 ───────────────── */
.admin-container { max-width:1000px; margin:0 auto; }
.admin-tabs { display:flex; gap:4px; margin-bottom:20px; }
.admin-tab {
  padding:10px 24px;
  border:1px solid var(--border);
  background:var(--bg-card);
  cursor:pointer;
  font-size:14px;
  border-radius:var(--radius-sm) var(--radius-sm) 0 0;
  transition:all .2s;
}
.admin-tab.active { background:var(--red); color:#fff; border-color:var(--red); }
.admin-tab:hover:not(.active) { background:var(--red-light); }
.admin-panel { background:var(--bg-card); border:1px solid var(--border); border-radius:0 var(--radius) var(--radius) var(--radius); padding:20px; }
.panel-toolbar { display:flex; gap:12px; margin-bottom:16px; align-items:center; }
.panel-toolbar select { padding:6px 12px; border:1px solid var(--border); border-radius:var(--radius-sm); font-size:13px; }

.entry-list, .user-list { display:flex; flex-direction:column; gap:8px; }
.entry-row, .user-row {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 14px;
  background:var(--bg);
  border-radius:var(--radius-sm);
  border:1px solid var(--border-light);
}
.entry-row:hover, .user-row:hover { border-color:var(--red); }
.entry-date { font-weight:700; color:var(--red-dark); min-width:100px; }
.entry-summary { flex:1; font-size:13px; color:var(--text-light); margin:0 12px; }
.entry-actions, .user-actions { display:flex; gap:6px; }

.form-group { margin-bottom:14px; }
.form-group label { display:block; font-size:13px; font-weight:600; margin-bottom:4px; color:var(--text); }
.form-input {
  width:100%;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  font-size:14px;
  font-family:var(--font);
}
.form-input:focus { outline:none; border-color:var(--red); }

.entry-items-editor { display:flex; flex-direction:column; gap:10px; margin-bottom:12px; }
.entry-item-row {
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:12px;
  background:var(--bg);
}
.entry-item-row .form-input { margin-bottom:6px; }
.entry-item-row select.form-input { margin-bottom:6px; }

/* ── 加载 ───────────────────── */
.loading-msg { text-align:center; padding:40px; color:var(--text-light); grid-column:1/-1; }

/* ── 响应式 ─────────────────── */
@media (max-width: 768px) {
  .app-main { padding:12px; }
  .calendar-grid { gap:2px; padding:4px; }
  .day-cell { min-height:60px; padding:3px; }
  .day-num { font-size:12px; }
  .day-task-mini { font-size:8px; }
  .stats-bar { gap:6px; flex-wrap:wrap; justify-content:center; }
  .stat-item { padding:8px 10px; min-width:65px; }
  .stat-num { font-size:20px; }
  .month-display { font-size:22px; }
  .app-header { padding:10px 12px; gap:8px; }
  .app-logo { font-size:16px; }
  .header-subtitle { display:none; }
  .header-right { gap:8px; }
  .nav-link { font-size:12px; padding:3px 8px; }
  .btn-logout { padding:5px 10px; font-size:12px; }
  .modal-card { max-width:100vw; max-height:92vh; }
  .modal-body { padding:14px 16px; }
  .modal-header { padding:14px 16px; }
  .modal-header h2 { font-size:16px; }
  .legend-bar { gap:6px; }
  .legend-item { font-size:10px; }
}

/* ── 手机小屏：480px以下 ────────────────────────────── */
@media (max-width: 480px) {
  /* 顶部栏 */
  .app-header { padding:8px 10px; flex-wrap:nowrap; }
  .app-logo { font-size:15px; letter-spacing:1px; }
  .logo-icon { font-size:16px; }
  .user-info { display:none; }
  .nav-link { padding:3px 7px; font-size:11px; }
  .btn-logout { padding:4px 8px; font-size:11px; }

  /* 主体内边距 */
  .app-main { padding:8px; }

  /* 日历格子 —— 最小化 */
  .calendar-grid { gap:1px; padding:3px; }
  .day-cell { min-height:44px; padding:2px 3px; }
  .day-num { font-size:11px; }
  .day-task-mini { display:none; }    /* 手机上隐藏文字标签，保留颜色点 */
  .day-dot { width:5px; height:5px; }

  /* 统计条竖排 */
  .stats-bar { flex-wrap:wrap; gap:5px; }
  .stat-item { padding:6px 8px; min-width:calc(50% - 5px); flex:1; }
  .stat-num { font-size:18px; }
  .stat-label { font-size:10px; }

  /* 月份导航 */
  .month-display { font-size:20px; }
  .year-display { font-size:11px; letter-spacing:2px; }
  .nav-arrow { width:36px; height:36px; font-size:14px; }
  .btn-today { padding:5px 12px; font-size:11px; }

  /* 弹窗接近全屏 */
  .modal-card { max-width:100vw; max-height:95vh; border-radius:12px 12px 0 0; margin-top:auto; }
  .modal-overlay.active { align-items:flex-end; padding:0; }
  .modal-header { padding:12px 14px; }
  .modal-header h2 { font-size:15px; }
  .modal-body { padding:12px 14px; }
  .comment-section { padding:12px 14px; }
  .task-card { padding:10px 12px; }
  .task-card-title { font-size:13px; }
  .task-card-desc { font-size:12px; }

  /* 图例 */
  .legend-bar { gap:5px; }
  .legend-item { font-size:9px; }
  .dot { width:7px; height:7px; }

  /* 底部 */
  .app-footer { padding:10px; font-size:10px; }
}

/* ── 修改密码弹窗 ────────────────────────────────────── */
.modal-overlay {
  position: fixed; top:0; left:0; width:100%; height:100%;
  background: rgba(0,0,0,.45);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
}
.modal-box {
  background: var(--bg-card);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  padding: 28px 32px;
  width: 380px; max-width: 90vw;
  animation: fadeInUp .25s ease;
}
@keyframes fadeInUp {
  from { opacity:0; transform:translateY(16px); }
  to { opacity:1; transform:translateY(0); }
}
.modal-box h3 { font-size:18px; margin-bottom:20px; color: var(--red); }
.modal-box .form-group { margin-bottom:14px; }
.modal-box .form-group label {
  display: block; font-size:13px; color: var(--text-light); margin-bottom:4px;
}
.modal-box .form-group input {
  width: 100%; padding: 10px 12px; border: 1px solid var(--border);
  border-radius: var(--radius-sm); font-size:14px; outline: none;
  transition: border-color .2s;
}
.modal-box .form-group input:focus { border-color: var(--gold); }
.form-msg { font-size:13px; margin-bottom:8px; min-height:20px; }
.form-actions { display:flex; gap:10px; justify-content: flex-end; margin-top:6px; }
.btn-cancel {
  padding: 8px 20px; border: 1px solid var(--border);
  border-radius: var(--radius-sm); background: #fff; color: var(--text-light);
  cursor: pointer; font-size:14px;
}
.btn-primary {
  padding: 8px 20px; border: none; border-radius: var(--radius-sm);
  background: var(--red); color: #fff; cursor: pointer; font-size:14px;
  transition: background .2s;
}
.btn-primary:hover { background: var(--red-dark); }
.btn-primary:disabled { opacity:.6; cursor:not-allowed; }
