/* =============================================
   admin.css — 관리자 페이지 전용 스타일
   ============================================= */

/* ── 로그인 화면 ─────────────────────────── */
#login-screen {
  position: fixed; inset: 0; z-index: 200;
  background: var(--color-hero);
  display: flex; align-items: center; justify-content: center;
}
.login-box {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  backdrop-filter: blur(12px);
  border-radius: 20px;
  padding: 52px 48px;
  width: 100%; max-width: 420px;
  text-align: center;
}
.login-icon { font-size: 2.8rem; margin-bottom: 16px; }
.login-title {
  font-family: var(--font-display);
  font-size: 1.5rem; font-weight: 800;
  color: #fff; margin-bottom: 6px;
}
.login-sub { font-size: .88rem; color: rgba(255,255,255,.45); margin-bottom: 36px; }
.login-input {
  width: 100%;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 12px;
  padding: 14px 18px;
  color: #fff;
  font-size: .97rem;
  font-family: var(--font-body);
  margin-bottom: 12px;
  transition: all .2s;
  outline: none;
}
.login-input::placeholder { color: rgba(255,255,255,.3); }
.login-input:focus { border-color: var(--color-accent); background: rgba(255,255,255,.1); }
.login-error { font-size: .82rem; color: #ff6b6b; margin-bottom: 12px; min-height: 20px; }
.login-btn {
  width: 100%;
  background: var(--color-accent);
  color: var(--color-hero);
  font-weight: 700; font-size: .97rem;
  padding: 14px;
  border-radius: 12px;
  transition: all .2s;
  font-family: var(--font-body);
}
.login-btn:hover { opacity: .9; transform: translateY(-1px); }

/* ── 대시보드 레이아웃 ───────────────────── */
#dashboard { display: none; min-height: 100vh; }
.admin-header {
  background: var(--color-hero);
  padding: 0 48px;
  display: flex; align-items: center; justify-content: space-between;
  height: 64px; position: sticky; top: 0; z-index: 100;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.admin-header-logo {
  font-family: var(--font-display);
  font-size: 1rem; font-weight: 700; color: #fff;
  display: flex; align-items: center; gap: 10px;
}
.admin-header-logo span { font-size: .7rem; color: var(--color-accent); font-weight: 600; letter-spacing: 1px; }
.admin-header-actions { display: flex; gap: 12px; align-items: center; }
.btn-logout {
  font-size: .82rem; font-weight: 600;
  color: rgba(255,255,255,.5);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  padding: 7px 18px; border-radius: 8px;
  transition: all .2s;
}
.btn-logout:hover { color: #fff; border-color: rgba(255,255,255,.25); }
.btn-view-site {
  font-size: .82rem; font-weight: 600;
  color: var(--color-accent);
  background: rgba(201,168,76,.1);
  border: 1px solid rgba(201,168,76,.3);
  padding: 7px 18px; border-radius: 8px;
  transition: all .2s;
}
.btn-view-site:hover { background: var(--color-accent); color: var(--color-hero); }

/* ── 탭 네비게이션 ───────────────────────── */
.admin-tabs {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  padding: 0 48px;
  display: flex; gap: 4px;
}
.admin-tab {
  font-size: .88rem; font-weight: 600;
  color: var(--color-text-sub);
  padding: 16px 20px;
  border: none; background: transparent;
  border-bottom: 2px solid transparent;
  transition: all .2s; cursor: pointer;
}
.admin-tab:hover { color: var(--color-primary); }
.admin-tab.active {
  color: var(--color-primary);
  border-bottom-color: var(--color-accent);
}

/* ── 어드민 콘텐츠 영역 ──────────────────── */
.admin-content { padding: 40px 48px; max-width: 960px; }
.admin-section { display: none; }

.admin-section-title {
  font-family: var(--font-display);
  font-size: 1.3rem; font-weight: 800;
  color: var(--color-primary);
  margin-bottom: 6px;
}
.admin-section-desc { font-size: .875rem; color: var(--color-text-sub); margin-bottom: 32px; }

/* ── 폼 공통 ─────────────────────────────── */
.form-group { margin-bottom: 20px; }
.form-label {
  display: block;
  font-size: .82rem; font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 7px; letter-spacing: .3px;
}
.form-input, .form-textarea {
  width: 100%;
  border: 1.5px solid var(--color-border);
  border-radius: 10px;
  padding: 11px 16px;
  font-size: .93rem; font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-bg);
  transition: border-color .2s;
  outline: none;
}
.form-input:focus, .form-textarea:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(201,168,76,.12);
}
.form-textarea { min-height: 100px; resize: vertical; line-height: 1.7; }
.form-hint { font-size: .77rem; color: var(--color-text-sub); margin-top: 5px; }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

.btn-save {
  background: var(--color-primary);
  color: #fff; font-weight: 700;
  font-size: .93rem; font-family: var(--font-body);
  padding: 12px 32px; border-radius: 10px;
  transition: all .2s;
}
.btn-save:hover { background: var(--color-secondary); transform: translateY(-1px); }

.btn-danger {
  background: transparent;
  color: #dc2626;
  border: 1.5px solid #dc2626;
  font-weight: 600; font-size: .88rem; font-family: var(--font-body);
  padding: 10px 24px; border-radius: 10px;
  transition: all .2s;
}
.btn-danger:hover { background: #dc2626; color: #fff; }

.form-actions { display: flex; gap: 12px; align-items: center; margin-top: 28px; flex-wrap: wrap; }

/* ── 테마 색상 폼 ────────────────────────── */
.theme-form-grid { display: flex; flex-direction: column; gap: 12px; margin-bottom: 32px; }
.theme-row {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 10px; padding: 14px 18px;
}
.theme-label { font-size: .88rem; font-weight: 600; color: var(--color-primary); }
.theme-inputs { display: flex; gap: 10px; align-items: center; }
.color-picker {
  width: 40px; height: 36px;
  border: 1.5px solid var(--color-border);
  border-radius: 8px; cursor: pointer;
  padding: 2px; background: var(--color-bg);
}
.color-text-input {
  width: 100px;
  border: 1.5px solid var(--color-border);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: .85rem; font-family: monospace;
  color: var(--color-text); background: var(--color-bg);
  outline: none; transition: border-color .2s;
}
.color-text-input:focus { border-color: var(--color-accent); }

/* ── 사역 목록 ───────────────────────────── */
.ministry-list-wrap { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }
.ministry-list-item {
  display: flex; align-items: center; gap: 14px;
  background: var(--color-bg);
  border: 1.5px solid var(--color-border);
  border-radius: 12px; padding: 14px 18px;
  transition: all .2s;
}
.ministry-list-item.inactive { opacity: .5; }
.ministry-list-item:hover { border-color: var(--color-accent); }
.ml-icon { font-size: 1.4rem; }
.ml-month { font-size: .78rem; font-weight: 700; color: var(--color-accent); min-width: 42px; }
.ml-name { font-size: .97rem; font-weight: 600; color: var(--color-primary); flex: 1; }
.ml-actions { display: flex; gap: 8px; }
.btn-edit {
  font-size: .78rem; font-weight: 700;
  color: var(--color-primary);
  background: rgba(26,58,92,.08);
  border: 1px solid rgba(26,58,92,.2);
  padding: 6px 16px; border-radius: 8px;
  transition: all .2s;
}
.btn-edit:hover { background: var(--color-primary); color: #fff; }
.btn-toggle {
  font-size: .78rem; font-weight: 600;
  color: var(--color-text-sub);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  padding: 6px 16px; border-radius: 8px;
  transition: all .2s;
}
.btn-toggle:hover { border-color: var(--color-text-sub); color: var(--color-text); }

/* ── 편집 모달 ───────────────────────────── */
#edit-modal {
  position: fixed; inset: 0; z-index: 300;
  background: rgba(0,0,0,.5);
  display: none; align-items: flex-start; justify-content: center;
  padding: 32px 16px;
  overflow-y: auto;
}
.edit-modal-box {
  background: var(--color-bg);
  border-radius: 20px;
  width: 100%; max-width: 680px;
  padding: 40px;
  box-shadow: 0 24px 80px rgba(0,0,0,.25);
  position: relative;
}
.edit-modal-title {
  font-family: var(--font-display);
  font-size: 1.2rem; font-weight: 800;
  color: var(--color-primary); margin-bottom: 28px;
}
.modal-close {
  position: absolute; top: 20px; right: 20px;
  width: 32px; height: 32px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; color: var(--color-text-sub);
  transition: all .2s;
}
.modal-close:hover { background: var(--color-border); }

/* ── 토스트 ──────────────────────────────── */
#toast {
  position: fixed; bottom: 32px; left: 50%;
  transform: translateX(-50%) translateY(80px);
  background: var(--color-primary);
  color: #fff; font-weight: 600;
  padding: 14px 32px; border-radius: 32px;
  font-size: .92rem;
  box-shadow: 0 8px 32px rgba(0,0,0,.2);
  transition: transform .3s cubic-bezier(.4,0,.2,1);
  z-index: 400; white-space: nowrap;
  pointer-events: none;
}
#toast.show { transform: translateX(-50%) translateY(0); }

/* ── 반응형 ──────────────────────────────── */
@media (max-width: 768px) {
  .admin-header { padding: 0 20px; }
  .admin-tabs { padding: 0 12px; overflow-x: auto; gap: 0; }
  .admin-tab { padding: 14px 14px; font-size: .82rem; white-space: nowrap; }
  .admin-content { padding: 24px 20px; }
  .form-row { grid-template-columns: 1fr; }
  .edit-modal-box { padding: 28px 20px; }
  .ministry-list-item { flex-wrap: wrap; }
  .ml-name { min-width: calc(100% - 100px); }
}

/* =============================================
   admin.css v2 추가
   ============================================= */

/* ── ① 공지/팝업 설정 블록 ──────────────── */
.notice-block {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 24px 28px;
  margin-bottom: 20px;
}
.notice-block-title {
  font-size: 1rem; font-weight: 700;
  color: var(--color-primary); margin-bottom: 18px;
}
.toggle-row {
  display: flex; align-items: center; justify-content: space-between;
}
.toggle-switch { position: relative; display: inline-block; width: 48px; height: 26px; }
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
  position: absolute; inset: 0;
  background: var(--color-border); border-radius: 26px;
  cursor: pointer; transition: .3s;
}
.toggle-slider::before {
  content: ''; position: absolute;
  width: 20px; height: 20px; left: 3px; bottom: 3px;
  background: #fff; border-radius: 50%; transition: .3s;
  box-shadow: 0 1px 4px rgba(0,0,0,.2);
}
.toggle-switch input:checked + .toggle-slider { background: var(--color-accent); }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(22px); }

/* ── ⑤ 드래그 정렬 ──────────────────────── */
.ml-drag {
  font-size: 1.1rem; color: var(--color-border);
  cursor: grab; padding: 0 4px; user-select: none;
  transition: color .2s;
}
.ministry-list-item:hover .ml-drag { color: var(--color-accent); }
.ministry-list-item.dragging { opacity: .4; }
.ministry-list-item.drag-over {
  border-color: var(--color-accent);
  background: rgba(201,168,76,.06);
}

/* ── 공지 버튼 ───────────────────────────── */
.btn-notice {
  font-size: .78rem; font-weight: 700;
  color: var(--color-secondary);
  background: rgba(45,106,159,.08);
  border: 1px solid rgba(45,106,159,.2);
  padding: 6px 14px; border-radius: 8px;
  transition: all .2s; cursor: pointer;
}
.btn-notice:hover { background: var(--color-secondary); color: #fff; }

.btn-danger-outline {
  background: transparent;
  color: #c0392b;
  border: 1.5px solid rgba(192,57,43,.35);
}
.btn-danger-outline:hover {
  background: rgba(192,57,43,.08);
  border-color: #c0392b;
}

/* ── ③ 공지사항 패널 ─────────────────────── */
.notice-panel-overlay {
  position: fixed; inset: 0; z-index: 300;
  background: rgba(0,0,0,.5);
  display: none; align-items: flex-start; justify-content: center;
  padding: 32px 16px; overflow-y: auto;
}
.notice-panel-box {
  background: var(--color-bg); border-radius: 20px;
  width: 100%; max-width: 600px; padding: 40px;
  box-shadow: 0 24px 80px rgba(0,0,0,.25); position: relative;
}
.notice-add-form {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md); padding: 20px 24px;
  margin-bottom: 28px;
}
.notice-add-label {
  font-size: .88rem; font-weight: 700;
  color: var(--color-primary); margin-bottom: 14px;
}
.notice-list-header {
  font-size: .82rem; font-weight: 700; color: var(--color-text-sub);
  letter-spacing: 1px; text-transform: uppercase;
  margin-bottom: 12px; padding-bottom: 8px;
  border-bottom: 1px solid var(--color-border);
}
.notice-admin-item {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 14px 16px; margin-bottom: 10px; position: relative;
}
.notice-admin-meta { font-size: .72rem; color: var(--color-text-sub); margin-bottom: 4px; }
.notice-admin-title { font-size: .93rem; font-weight: 700; color: var(--color-primary); margin-bottom: 4px; }
.notice-admin-body { font-size: .83rem; color: var(--color-text-sub); line-height: 1.6; }
.btn-del-notice {
  position: absolute; top: 12px; right: 12px;
  font-size: .72rem; color: #dc2626;
  background: rgba(220,38,38,.06); border: 1px solid rgba(220,38,38,.2);
  padding: 3px 10px; border-radius: 6px; cursor: pointer;
  transition: all .2s;
}
.btn-del-notice:hover { background: #dc2626; color: #fff; }
.notice-empty { font-size: .88rem; color: var(--color-text-sub); text-align: center; padding: 24px 0; }

/* ── 월 체크박스 ─────────────────────────── */
.months-wrap {
  display: flex; flex-wrap: wrap; gap: 8px;
  padding: 12px 0;
}
.month-cb-label {
  display: flex; align-items: center; gap: 5px;
  font-size: .82rem; font-weight: 600;
  color: var(--color-primary);
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  padding: 6px 12px; border-radius: 20px;
  cursor: pointer; transition: all .2s;
  user-select: none;
}
.month-cb-label:hover { border-color: var(--color-accent); }
.month-cb-label input[type=checkbox] { display: none; }
.month-cb-label:has(input:checked) {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: white;
}

/* ── 이미지 미리보기 ─────────────────────── */
.image-preview-box {
  margin-top: 12px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--color-border);
  max-height: 200px;
}
.image-preview-box img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
}
.preview-error {
  padding: 20px;
  text-align: center;
  font-size: .85rem;
  color: var(--color-text-sub);
}
.hero-text-preview-box {
  margin-top: 8px;
  padding: 36px 24px;
  border-radius: 12px;
  border: 1px solid var(--color-border);
  background:
    linear-gradient(rgba(13, 33, 55, 0.45), rgba(13, 33, 55, 0.45)),
    linear-gradient(135deg, #4a6741 0%, #2d4a6f 50%, #1a3a5c 100%);
  text-align: center;
}
.hero-text-preview-sample {
  font-family: 'Nanum Myeongjo', serif;
  font-size: 1.65rem;
  font-weight: 800;
  color: #fff;
  -webkit-text-stroke: var(--hero-text-stroke) #000;
  paint-order: stroke fill;
  text-shadow: var(--hero-text-shadow);
  margin-bottom: 10px;
}
.hero-text-preview-sample-sub {
  font-family: 'Noto Sans KR', sans-serif;
  font-size: .92rem;
  font-weight: 400;
  color: #fff;
  -webkit-text-stroke: var(--hero-text-stroke-sub) #000;
  paint-order: stroke fill;
  text-shadow: var(--hero-text-shadow-sub);
}
.form-range {
  width: 100%;
  accent-color: var(--color-accent);
  margin-top: 8px;
}

/* ── Cloudinary 업로드 ───────────────────── */
.input-with-upload {
  display: flex;
  gap: 10px;
  align-items: stretch;
}
.input-with-upload .form-input {
  flex: 1;
  min-width: 0;
}
.btn-upload {
  flex-shrink: 0;
  white-space: nowrap;
  background: var(--color-secondary);
  color: #fff;
  font-size: .85rem;
  font-weight: 700;
  padding: 0 18px;
  border-radius: 10px;
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  transition: all .2s;
}
.btn-upload:hover:not(:disabled) {
  background: var(--color-primary);
  transform: translateY(-1px);
}
.btn-upload:disabled {
  opacity: .6;
  cursor: wait;
}

/* ── 타임라인 chip 색상 편집 ─────────────── */
.chip-color-row {
  display: flex;
  align-items: center;
  gap: 12px;
}
.chip-color-row .color-picker {
  width: 48px;
  height: 40px;
  padding: 2px;
  border: 1.5px solid var(--color-border);
  border-radius: 10px;
  cursor: pointer;
  background: var(--color-bg);
}
.chip-color-row .color-text-input {
  flex: 1;
  max-width: 160px;
  font-family: monospace;
}
.chip-preview-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 12px;
}
.chip-preview-label {
  font-size: .78rem;
  color: var(--color-text-sub);
  font-weight: 600;
}
.chip-preview-chip {
  display: inline-block;
  font-size: .78rem;
  font-weight: 600;
  padding: 6px 14px;
  border-radius: 12px;
  border: 1px solid transparent;
}
.ml-chip-swatch {
  width: 14px;
  height: 14px;
  border-radius: 4px;
  flex-shrink: 0;
  border: 1px solid rgba(0,0,0,.08);
}

/* ── 고급 설정 (DB 초기화) ──────────────── */
.advanced-settings-wrap {
  margin-top: 40px;
  padding-top: 28px;
  border-top: 1px dashed var(--color-border);
}
.advanced-settings-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  background: none;
  border: none;
  font-family: var(--font-body);
  font-size: .88rem;
  font-weight: 600;
  color: var(--color-text-sub);
  cursor: pointer;
  padding: 8px 0;
  transition: color .2s;
}
.advanced-settings-toggle:hover { color: var(--color-primary); }
.advanced-settings-arrow {
  font-size: .7rem;
  width: 14px;
  text-align: center;
}
.advanced-settings-panel {
  margin-top: 16px;
  padding: 20px 24px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 14px;
}
.advanced-warning-box {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 20px 24px;
  margin-bottom: 20px;
}
.advanced-warning-box h4 {
  font-size: .92rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 10px;
}
.advanced-warning-box ul {
  font-size: .86rem;
  color: var(--color-text-sub);
  line-height: 1.9;
  padding-left: 20px;
}
.advanced-warning-box code {
  font-size: .82rem;
  background: var(--color-surface);
  padding: 2px 6px;
  border-radius: 4px;
}

/* ── 히어로 글자 스타일 ──────────────────── */
.typo-device-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 20px;
}
.typo-device-tab,
.typo-ministry-tab {
  font-size: .85rem;
  font-weight: 600;
  padding: 8px 18px;
  border-radius: 20px;
  border: 1px solid var(--color-border);
  background: #fff;
  color: var(--color-text-sub);
  cursor: pointer;
  transition: all .2s;
  font-family: var(--font-body);
}
.typo-device-tab:hover,
.typo-ministry-tab:hover { border-color: var(--color-accent); color: var(--color-primary); }
.typo-device-tab.active,
.typo-ministry-tab.active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}
.typo-subsection-title {
  font-size: .92rem;
  font-weight: 700;
  color: var(--color-primary);
  margin: 20px 0 12px;
  padding-top: 4px;
}
.typo-subsection-title:first-of-type { margin-top: 0; }
.typo-element-group {
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--color-border);
}
.typo-element-group:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.typo-element-label {
  font-size: .9rem;
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 12px;
}
.typo-fields-row {
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
}
@media (max-width: 768px) {
  .typo-fields-row { grid-template-columns: 1fr 1fr; }
}
.typo-preview-actions {
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--color-border);
}
.btn-preview {
  font-size: .85rem;
  font-weight: 600;
  color: var(--color-primary);
  background: #fff;
  border: 1px solid var(--color-border);
  padding: 10px 18px;
  border-radius: 10px;
  cursor: pointer;
  font-family: var(--font-body);
  transition: all .2s;
}
.btn-preview:hover {
  border-color: var(--color-accent);
  background: var(--color-surface);
}
