/* ============================================================
   서둔교회 교회학교 — 통합 디자인 시스템 (church-school.css)
   el- 접두사 사용, 부서별 테마는 body 클래스로 전환
   기본(클래스 없음) = 아동부 indigo-violet
   ============================================================ */

/* ===== CSS Variables ===== */
:root {
  --el-primary: #4338ca;
  --el-primary-dark: #3730a3;
  --el-primary-darker: #312e81;
  --el-primary-light: #6366f1;
  --el-primary-lighter: #818cf8;
  --el-primary-pale: #a78bfa;
  --el-accent: #f59e0b;
  --el-accent-dark: #d97706;
  --el-accent-light: #fef3c7;
  --el-accent-bg: #fffbeb;
  --el-bg: #eef2ff;
  --el-bg-warm: #f5f3ff;
  --el-bg-accent: #fef3c7;
  --el-text: #1e1b4b;
  --el-text-secondary: #4338ca;
  --el-text-muted: #6b7280;
  --el-card-bg: #fff;
  --el-card-shadow: 0 2px 8px rgba(0,0,0,.05);
  --el-card-shadow-hover: 0 4px 16px rgba(0,0,0,.1);
  --el-border: #e5e7eb;
  --el-success: #10b981;
  --el-danger: #ef4444;
  --el-warning: #f59e0b;
  --el-info: #3b82f6;
  --el-radius: 16px;
  --el-radius-sm: 10px;
  --el-radius-lg: 20px;
  /* Gradient variables for theming */
  --el-gradient-body: linear-gradient(135deg, #eef2ff 0%, #f5f3ff 50%, #fef3c7 100%);
  --el-gradient-hero: linear-gradient(135deg, #312e81 0%, #4338ca 25%, #6366f1 50%, #818cf8 75%, #a78bfa 100%);
  --el-gradient-hero-sub: linear-gradient(135deg, #312e81 0%, #4338ca 50%, #6366f1 100%);
  --el-hero-orb-color: #fde68a;
  --el-hero-accent: #fde68a;
  --el-hero-accent-rgb: 253,224,71;
}

/* ===== 테마: 아기부 (Pink) ===== */
.el-theme-baby {
  --el-primary: #ec4899;
  --el-primary-dark: #db2777;
  --el-primary-darker: #be185d;
  --el-primary-light: #f472b6;
  --el-primary-lighter: #f9a8d4;
  --el-primary-pale: #fbcfe8;
  --el-bg: #fdf2f8;
  --el-bg-warm: #fce7f3;
  --el-bg-accent: #fff1f2;
  --el-text: #831843;
  --el-text-secondary: #ec4899;
  --el-gradient-body: linear-gradient(135deg, #fdf2f8 0%, #fce7f3 50%, #fff1f2 100%);
  --el-gradient-hero: linear-gradient(135deg, #be185d 0%, #db2777 25%, #ec4899 50%, #f472b6 75%, #f9a8d4 100%);
  --el-gradient-hero-sub: linear-gradient(135deg, #be185d 0%, #db2777 50%, #ec4899 100%);
  --el-hero-orb-color: #fda4af;
  --el-hero-accent: #fda4af;
  --el-hero-accent-rgb: 253,164,175;
}

/* ===== 테마: 중등부 (Purple-Blue) ===== */
.el-theme-middle {
  --el-primary: #667eea;
  --el-primary-dark: #5a67d8;
  --el-primary-darker: #4c51bf;
  --el-primary-light: #7f9cf5;
  --el-primary-lighter: #a3bffa;
  --el-primary-pale: #c3dafe;
  --el-bg: #f5f3ff;
  --el-bg-warm: #ede9fe;
  --el-bg-accent: #e0e7ff;
  --el-text: #1e1b4b;
  --el-text-secondary: #667eea;
  --el-gradient-body: linear-gradient(135deg, #f5f3ff 0%, #ede9fe 50%, #e0e7ff 100%);
  --el-gradient-hero: linear-gradient(135deg, #4c51bf 0%, #5a67d8 25%, #667eea 50%, #7f9cf5 75%, #a3bffa 100%);
  --el-gradient-hero-sub: linear-gradient(135deg, #4c51bf 0%, #5a67d8 50%, #667eea 100%);
  --el-hero-orb-color: #c4b5fd;
  --el-hero-accent: #c4b5fd;
  --el-hero-accent-rgb: 196,181,253;
}

/* ===== 테마: 고등부 (Navy-Blue) ===== */
.el-theme-high {
  --el-primary: #1e3a8a;
  --el-primary-dark: #1e40af;
  --el-primary-darker: #172554;
  --el-primary-light: #3b82f6;
  --el-primary-lighter: #60a5fa;
  --el-primary-pale: #93c5fd;
  --el-bg: #eff6ff;
  --el-bg-warm: #dbeafe;
  --el-bg-accent: #e0f2fe;
  --el-text: #172554;
  --el-text-secondary: #1e3a8a;
  --el-gradient-body: linear-gradient(135deg, #eff6ff 0%, #dbeafe 50%, #e0f2fe 100%);
  --el-gradient-hero: linear-gradient(135deg, #172554 0%, #1e3a8a 25%, #1e40af 50%, #3b82f6 75%, #60a5fa 100%);
  --el-gradient-hero-sub: linear-gradient(135deg, #172554 0%, #1e3a8a 50%, #1e40af 100%);
  --el-hero-orb-color: #93c5fd;
  --el-hero-accent: #93c5fd;
  --el-hero-accent-rgb: 147,197,253;
}

/* ===== Reset ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:18px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:'Pretendard',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--el-gradient-body);
  color:var(--el-text);line-height:1.7;min-height:100dvh;
  padding-bottom:72px;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:var(--el-primary);text-decoration:none;transition:color .2s}
a:hover{color:var(--el-primary-dark)}
img{max-width:100%;display:block}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ===== 히어로 (메인) ===== */
.el-hero {
  position:relative;
  background:var(--el-gradient-hero);
  overflow:hidden;
}
.el-hero::before {
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 50%,rgba(var(--el-hero-accent-rgb),.12) 0%,transparent 50%),
    radial-gradient(circle at 80% 20%,rgba(var(--el-hero-accent-rgb),.2) 0%,transparent 40%),
    radial-gradient(circle at 60% 80%,rgba(var(--el-hero-accent-rgb),.15) 0%,transparent 40%);
}
.el-hero::after {
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(30deg,rgba(255,255,255,.03) 25%,transparent 25%),
    linear-gradient(150deg,rgba(255,255,255,.03) 25%,transparent 25%);
  background-size:60px 100px;
}

/* Floating orbs */
.el-hero-orb {
  position:absolute;border-radius:50%;opacity:.08;background:var(--el-hero-orb-color);
  animation:elFloat 8s ease-in-out infinite;
}
.el-hero-orb:nth-child(1){width:200px;height:200px;top:-40px;right:-30px}
.el-hero-orb:nth-child(2){width:120px;height:120px;bottom:20px;left:-20px;animation-delay:-3s}
.el-hero-orb:nth-child(3){width:80px;height:80px;top:30%;left:60%;animation-delay:-5s;opacity:.05}
@keyframes elFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}

.el-hero-inner {
  position:relative;z-index:1;padding:32px 20px 28px;color:#fff;max-width:900px;margin:0 auto;
}

/* Hero navigation */
.el-hero-nav {
  display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;
}
.el-hero-nav-home {
  display:flex;align-items:center;gap:6px;font-size:.82rem;
  color:rgba(255,255,255,.6);text-decoration:none;transition:color .2s;
}
.el-hero-nav-home:hover{color:#fff}
.el-hero-nav-home svg{width:18px;height:18px}

/* Hero content */
.el-hero-content{display:flex;align-items:flex-end;justify-content:space-between;gap:40px}
.el-hero-text{flex:1}
.el-hero-label {
  display:inline-flex;align-items:center;gap:8px;padding:6px 14px;
  background:rgba(var(--el-hero-accent-rgb),.15);border:1px solid rgba(var(--el-hero-accent-rgb),.25);
  border-radius:20px;font-size:.75rem;font-weight:600;color:var(--el-hero-accent);margin-bottom:14px;
}
.el-hero-label .dot{width:8px;height:8px;background:var(--el-hero-accent);border-radius:50%;animation:elPulse 2s ease-in-out infinite}
@keyframes elPulse{0%,100%{opacity:1}50%{opacity:.4}}

.el-hero-title{font-size:2rem;font-weight:900;letter-spacing:-.02em;line-height:1.2;margin-bottom:10px}
.el-hero-title span{
  background:linear-gradient(135deg,var(--el-hero-accent) 0%,var(--el-accent) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.el-hero-sub{font-size:.95rem;color:rgba(255,255,255,.8);line-height:1.6;margin-bottom:12px}
.el-hero-motto{
  font-size:.9rem;color:var(--el-hero-accent);font-weight:600;
  padding:8px 16px;background:rgba(var(--el-hero-accent-rgb),.1);border-radius:10px;display:inline-block;
}

/* Hero card area (PC) */
.el-hero-card-area{display:none;flex:0 0 260px}
.el-hero-info-card {
  background:rgba(255,255,255,.1);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:22px;color:#fff;
}
.el-hero-info-card h3{font-size:.9rem;font-weight:700;margin-bottom:14px}
.el-hero-info-item {
  display:flex;align-items:center;gap:10px;padding:10px 0;
  border-top:1px solid rgba(255,255,255,.1);font-size:.85rem;
}
.el-hero-info-item svg{width:18px;height:18px;stroke:var(--el-hero-accent);fill:none;stroke-width:1.8;flex-shrink:0}
.el-hero-info-label{color:rgba(255,255,255,.6)}
.el-hero-info-value{color:#fff;font-weight:600;margin-left:auto}

@media(min-width:768px){
  .el-hero-inner{padding:40px 32px 36px}
  .el-hero-title{font-size:2.5rem}
  .el-hero-card-area{display:block}
}
@media(min-width:1024px){
  .el-hero-inner{padding:48px 40px 40px}
  .el-hero-title{font-size:2.8rem}
}

/* ===== 히어로 (서브페이지) ===== */
.el-hero-sub-page {
  position:relative;
  background:var(--el-gradient-hero-sub);
  overflow:hidden;padding:24px 20px 20px;
}
.el-hero-sub-page::before {
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 80% 20%,rgba(var(--el-hero-accent-rgb),.1) 0%,transparent 50%);
}
.el-hero-sub-page .el-hero-orb:nth-child(1){width:120px;height:120px;top:-30px;right:-20px;opacity:.06}
.el-hero-sub-page .el-hero-orb:nth-child(2){width:80px;height:80px;bottom:-10px;left:-15px;opacity:.04;animation-delay:-3s}
.el-hero-sub-inner{position:relative;z-index:1;max-width:900px;margin:0 auto}
.el-hero-sub-nav{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.el-hero-sub-back{
  display:flex;align-items:center;gap:4px;font-size:.82rem;
  color:rgba(255,255,255,.6);text-decoration:none;transition:color .2s;
}
.el-hero-sub-back:hover{color:#fff}
.el-hero-sub-back svg{width:18px;height:18px}
.el-hero-sub-title{font-size:1.4rem;font-weight:800;color:#fff;margin-bottom:4px}
.el-hero-sub-desc{font-size:.85rem;color:rgba(255,255,255,.7)}

/* ===== 유저 프로필 (히어로 내) ===== */
.el-user-card {
  background:rgba(255,255,255,.1);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:14px 18px;
  margin-top:16px;
}
.el-user-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.el-user-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.el-user-name{font-size:.92rem;font-weight:700;color:#fff}
.el-user-badge{
  background:rgba(var(--el-hero-accent-rgb),.2);color:var(--el-hero-accent);padding:2px 10px;
  border-radius:8px;font-size:.72rem;font-weight:700;
}
.el-user-level{
  background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);
  padding:2px 8px;border-radius:8px;font-size:.72rem;font-weight:600;
}
.el-user-points{display:flex;align-items:center;gap:6px;flex-shrink:0}
.el-user-sticker{
  background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;
  padding:5px 12px;border-radius:10px;font-size:.78rem;font-weight:700;
  display:flex;align-items:center;gap:4px;
  box-shadow:0 2px 8px rgba(245,158,11,.3);
}
.el-user-progress{margin-top:10px}
.el-user-progress-bar{
  background:rgba(255,255,255,.15);border-radius:10px;height:6px;overflow:hidden;
}
.el-user-progress-fill{
  background:linear-gradient(90deg,#fbbf24,#f59e0b);height:100%;
  border-radius:10px;transition:width .5s ease-out;
  box-shadow:0 0 8px rgba(251,191,36,.5);
}
.el-user-progress-text{
  display:flex;justify-content:space-between;margin-top:4px;
  font-size:.68rem;color:rgba(255,255,255,.5);
}

/* Login/Logout button in hero */
.el-login-btn{
  display:inline-flex;align-items:center;gap:6px;padding:10px 20px;
  background:#fff;color:var(--el-primary);border-radius:12px;
  font-weight:600;font-size:.85rem;text-decoration:none;
  box-shadow:0 4px 12px rgba(0,0,0,.15);transition:all .2s;
}
.el-login-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.2);color:var(--el-primary)}
.el-logout-btn{
  background:rgba(255,255,255,.15);color:rgba(255,255,255,.8);
  border:1px solid rgba(255,255,255,.2);padding:4px 12px;
  border-radius:8px;font-size:.75rem;cursor:pointer;transition:all .2s;
}
.el-logout-btn:hover{background:rgba(255,255,255,.25);color:#fff}

/* ===== 메인 래퍼 ===== */
.el-main{max-width:900px;margin:0 auto;padding:0 16px}
@media(min-width:768px){.el-main{padding:0 32px}}

/* ===== 교육주제 카드 (D-day 위치) ===== */
.el-theme-card {
  margin-top:-20px;position:relative;z-index:10;
  background:#fff;border-radius:16px;padding:20px;
  box-shadow:0 4px 20px rgba(0,0,0,.08);
}
.el-theme-inner{
  background:linear-gradient(135deg,var(--el-primary) 0%,var(--el-primary-light) 100%);
  border-radius:12px;padding:18px;color:#fff;text-align:center;
}
.el-theme-year{font-size:.78rem;opacity:.85;margin-bottom:6px}
.el-theme-title{font-size:1.1rem;font-weight:800;margin-bottom:10px}
.el-theme-verse{
  background:rgba(255,255,255,.15);border-radius:10px;padding:12px;
  font-size:.85rem;line-height:1.6;
}
.el-theme-ref{font-size:.75rem;opacity:.8;margin-top:6px;font-weight:600}

/* ===== 퀵 액션 ===== */
.el-quick{padding:24px 0 0}
.el-quick-title{font-size:1.1rem;font-weight:800;color:var(--el-text);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.el-quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.el-quick-item {
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:18px 8px;background:#fff;border-radius:var(--el-radius);
  box-shadow:var(--el-card-shadow);text-decoration:none;color:var(--el-text);
  transition:all .2s;min-height:48px;
}
.el-quick-item:hover{transform:translateY(-3px);box-shadow:var(--el-card-shadow-hover);color:var(--el-text)}
.el-quick-icon {
  width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;
}
.el-quick-icon.indigo{background:linear-gradient(135deg,#e0e7ff,#c7d2fe)}
.el-quick-icon.violet{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}
.el-quick-icon.amber{background:linear-gradient(135deg,#fef3c7,#fde68a)}
.el-quick-icon.rose{background:linear-gradient(135deg,#ffe4e6,#fecdd3)}
.el-quick-icon.emerald{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}
.el-quick-icon.sky{background:linear-gradient(135deg,#e0f2fe,#bae6fd)}
.el-quick-icon.pink{background:linear-gradient(135deg,#fce7f3,#fbcfe8)}
.el-quick-icon.orange{background:linear-gradient(135deg,#ffedd5,#fed7aa)}
.el-quick-label{font-size:.78rem;font-weight:700;text-align:center}

@media(max-width:400px){
  .el-quick-grid{grid-template-columns:repeat(3,1fr)}
}

/* ===== 섹션 공통 ===== */
.el-section{padding:28px 0 0}
.el-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.el-section-title{font-size:1.15rem;font-weight:800;color:var(--el-text);display:flex;align-items:center;gap:8px}
.el-section-more{font-size:.82rem;color:var(--el-primary);font-weight:600;text-decoration:none}
.el-section-more:hover{color:var(--el-primary-dark)}

/* ===== 카드 ===== */
.el-card {
  background:#fff;border-radius:var(--el-radius);padding:20px;
  box-shadow:var(--el-card-shadow);transition:transform .2s,box-shadow .2s;
}
.el-card:hover{transform:translateY(-2px);box-shadow:var(--el-card-shadow-hover)}
.el-card-flat{box-shadow:none;border:1px solid var(--el-border)}

/* ===== 이번주 말씀 ===== */
.el-verse-card{
  background:linear-gradient(135deg,var(--el-primary) 0%,#7c3aed 100%);
  border-radius:var(--el-radius);padding:20px;color:#fff;
}
.el-verse-date{font-size:.82rem;opacity:.85;margin-bottom:6px}
.el-verse-theme{font-size:.95rem;font-weight:700;margin-bottom:10px}
.el-verse-text{font-size:.92rem;line-height:1.7;margin-bottom:10px}
.el-verse-ref{font-size:.82rem;opacity:.85;text-align:right;font-weight:600}

/* ===== 공지사항 ===== */
.el-notice-card {
  background:#fff;border-radius:14px;padding:16px 18px;margin-bottom:10px;
  box-shadow:var(--el-card-shadow);cursor:pointer;transition:all .2s;
  border-left:4px solid var(--el-primary-light);
}
.el-notice-card:hover{box-shadow:var(--el-card-shadow-hover);transform:translateX(4px)}
.el-notice-card.pinned{border-left-color:var(--el-accent);background:var(--el-accent-bg)}
.el-notice-badge {
  display:inline-block;font-size:.7rem;font-weight:700;padding:3px 10px;
  border-radius:6px;margin-bottom:6px;
}
.el-notice-badge.important{background:#fef2f2;color:#dc2626}
.el-notice-badge.class{background:#eef2ff;color:var(--el-primary)}
.el-notice-badge.event{background:#f0fdf4;color:#16a34a}
.el-notice-badge.general{background:#f5f5f4;color:#78716c}
.el-notice-title{font-size:.92rem;font-weight:700;color:var(--el-text);margin-bottom:4px}
.el-notice-preview{font-size:.82rem;color:var(--el-text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.el-notice-date{font-size:.72rem;color:#a8a29e;margin-top:8px}

/* ===== 갤러리 (수평 스크롤) ===== */
.el-gallery-scroll{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch}
.el-gallery-scroll::-webkit-scrollbar{display:none}
.el-gallery-card {
  flex:0 0 180px;background:#fff;border-radius:var(--el-radius);overflow:hidden;
  box-shadow:var(--el-card-shadow);transition:transform .2s;cursor:pointer;
}
.el-gallery-card:hover{transform:translateY(-3px)}
.el-gallery-thumb{width:100%;height:130px;background:#e5e7eb;object-fit:cover}
.el-gallery-info{padding:12px}
.el-gallery-title{font-size:.82rem;font-weight:700;color:var(--el-text);margin-bottom:2px}
.el-gallery-date{font-size:.7rem;color:#a8a29e}

/* 사진 그리드 */
.el-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.el-photo-item{aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer}
.el-photo-item img{width:100%;height:100%;object-fit:cover;transition:transform .2s}
.el-photo-item:hover img{transform:scale(1.05)}

/* ===== 리스트 아이템 ===== */
.el-list-item {
  display:flex;align-items:center;gap:14px;background:#fff;
  border-radius:14px;padding:16px 18px;box-shadow:var(--el-card-shadow);
  transition:transform .15s;margin-bottom:10px;
}
.el-list-item:hover{transform:translateX(4px)}
.el-list-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.el-list-dot.indigo{background:var(--el-primary)}
.el-list-dot.violet{background:#7c3aed}
.el-list-dot.amber{background:var(--el-accent)}
.el-list-dot.emerald{background:var(--el-success)}
.el-list-dot.rose{background:#f43f5e}
.el-list-info{flex:1;min-width:0}
.el-list-name{font-size:.92rem;font-weight:700;color:var(--el-text)}
.el-list-sub{font-size:.78rem;color:var(--el-text-muted);margin-top:2px}
.el-list-badge{
  font-size:.75rem;font-weight:700;color:var(--el-primary);
  background:#eef2ff;padding:4px 12px;border-radius:8px;flex-shrink:0;
}

/* ===== 버튼 ===== */
.el-btn {
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:12px 24px;border-radius:12px;font-size:.88rem;font-weight:700;
  text-decoration:none;transition:all .2s;min-height:48px;cursor:pointer;border:none;
}
.el-btn-primary{
  background:linear-gradient(135deg,var(--el-primary),var(--el-primary-dark));
  color:#fff;box-shadow:0 4px 12px rgba(67,56,202,.3);
}
.el-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(67,56,202,.4);color:#fff}
.el-btn-secondary{background:#fff;color:var(--el-primary);border:2px solid var(--el-border)}
.el-btn-secondary:hover{border-color:var(--el-primary);transform:translateY(-2px);color:var(--el-primary)}
.el-btn-accent{
  background:linear-gradient(135deg,var(--el-accent),var(--el-accent-dark));
  color:#fff;box-shadow:0 4px 12px rgba(245,158,11,.3);
}
.el-btn-accent:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(245,158,11,.4);color:#fff}
.el-btn-sm{padding:8px 16px;font-size:.82rem;min-height:36px;border-radius:10px}
.el-btn-block{width:100%}
.el-btn-ghost{background:transparent;color:var(--el-primary);padding:8px 16px}
.el-btn-ghost:hover{background:var(--el-bg)}

/* ===== 배지 ===== */
.el-badge{
  display:inline-flex;align-items:center;gap:4px;padding:3px 10px;
  border-radius:8px;font-size:.72rem;font-weight:700;
}
.el-badge-indigo{background:#eef2ff;color:var(--el-primary)}
.el-badge-amber{background:var(--el-accent-light);color:var(--el-accent-dark)}
.el-badge-emerald{background:#d1fae5;color:#059669}
.el-badge-rose{background:#ffe4e6;color:#e11d48}
.el-badge-violet{background:#ede9fe;color:#7c3aed}
.el-badge-gray{background:#f3f4f6;color:#6b7280}

/* ===== CTA 배너 ===== */
.el-cta {
  margin:28px 0 0;
  background:linear-gradient(135deg,var(--el-bg) 0%,var(--el-bg-warm) 50%,var(--el-bg-accent) 100%);
  border-radius:var(--el-radius);padding:28px 20px;text-align:center;
}
.el-cta-icon{font-size:2.2rem;margin-bottom:10px}
.el-cta-title{font-size:1.1rem;font-weight:800;color:var(--el-text);margin-bottom:6px}
.el-cta-desc{font-size:.88rem;color:var(--el-text-muted);line-height:1.6;margin-bottom:18px}

/* ===== FAB (출석체크) ===== */
.el-fab {
  position:fixed;bottom:90px;right:20px;width:60px;height:60px;
  background:linear-gradient(135deg,var(--el-accent),var(--el-accent-dark));
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;box-shadow:0 6px 20px rgba(245,158,11,.4);
  cursor:pointer;transition:all .3s;z-index:99;border:none;
}
.el-fab:hover{transform:scale(1.1);box-shadow:0 8px 28px rgba(245,158,11,.5)}
.el-fab:active{transform:scale(.95)}
.el-fab.completed{background:linear-gradient(135deg,var(--el-success),#059669);box-shadow:0 6px 20px rgba(16,185,129,.4)}

/* ===== 모달 ===== */
.el-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;
}
.el-modal-overlay.active{display:flex}
.el-modal {
  background:#fff;border-radius:var(--el-radius-lg);padding:28px 24px;max-width:500px;width:100%;
  max-height:80vh;overflow-y:auto;position:relative;
}
.el-modal-close {
  position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;
  background:#f3f4f6;display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;color:var(--el-text-muted);cursor:pointer;transition:background .2s;
}
.el-modal-close:hover{background:#e5e7eb}
.el-modal-title{font-size:1.1rem;font-weight:800;color:var(--el-text);margin-bottom:8px;padding-right:40px}
.el-modal-date{font-size:.78rem;color:#a8a29e;margin-bottom:16px}
.el-modal-content{font-size:.92rem;color:#374151;line-height:1.8;white-space:pre-wrap}

/* ===== 라이트박스 ===== */
.el-lightbox {
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:300;
  align-items:center;justify-content:center;padding:20px;
}
.el-lightbox.active{display:flex}
.el-lightbox img{max-width:100%;max-height:85vh;border-radius:12px;object-fit:contain}
.el-lightbox-close {
  position:fixed;top:20px;right:20px;width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.2);color:#fff;display:flex;align-items:center;
  justify-content:center;font-size:1.5rem;cursor:pointer;z-index:301;
}

/* ===== 빈 상태 ===== */
.el-empty{text-align:center;padding:28px 16px;color:var(--el-text-muted)}
.el-empty-icon{font-size:2rem;margin-bottom:8px;opacity:.4}
.el-empty-text{font-size:.88rem}

/* ===== 스켈레톤 ===== */
.el-skeleton{
  background:linear-gradient(90deg,#e5e7eb 25%,#d1d5db 50%,#e5e7eb 75%);
  background-size:200% 100%;animation:elShimmer 1.5s infinite;border-radius:12px;
}
@keyframes elShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.el-skeleton-text{height:16px;margin-bottom:8px}
.el-skeleton-text.short{width:60%}
.el-skeleton-card{height:120px;margin-bottom:12px}

/* ===== 탭 ===== */
.el-tabs{display:flex;gap:4px;padding:4px;background:#f3f4f6;border-radius:12px;margin-bottom:20px}
.el-tab{
  flex:1;padding:10px 16px;border-radius:10px;font-size:.85rem;font-weight:600;
  text-align:center;color:var(--el-text-muted);cursor:pointer;transition:all .2s;
  background:transparent;border:none;
}
.el-tab.active{background:#fff;color:var(--el-primary);box-shadow:0 2px 8px rgba(0,0,0,.08)}
.el-tab:hover:not(.active){color:var(--el-text)}

/* ===== 폼 ===== */
.el-input{
  width:100%;padding:12px 16px;border:2px solid var(--el-border);border-radius:12px;
  font-size:.92rem;font-family:inherit;transition:border-color .2s;
  background:#fff;color:var(--el-text);
}
.el-input:focus{outline:none;border-color:var(--el-primary-light);box-shadow:0 0 0 3px rgba(99,102,241,.1)}
.el-input::placeholder{color:#9ca3af}
.el-label{display:block;font-size:.85rem;font-weight:600;color:var(--el-text);margin-bottom:6px}

/* ===== 토스트/알림 ===== */
.el-toast{
  position:fixed;top:20px;left:50%;transform:translateX(-50%);z-index:400;
  background:var(--el-text);color:#fff;padding:14px 24px;border-radius:12px;
  font-size:.88rem;font-weight:600;box-shadow:0 4px 20px rgba(0,0,0,.2);
  animation:elSlideDown .3s ease;
}
@keyframes elSlideDown{from{transform:translateX(-50%) translateY(-20px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}

/* ===== 하단 네비 ===== */
.el-nav-bottom {
  position:fixed;bottom:0;left:0;right:0;z-index:100;background:#fff;
  border-top:1px solid #e5e7eb;height:68px;display:flex;align-items:center;
  justify-content:space-around;padding-bottom:env(safe-area-inset-bottom,0);
  box-shadow:0 -2px 10px rgba(0,0,0,.04);
}
.el-nav-item {
  display:flex;flex-direction:column;align-items:center;gap:3px;
  font-size:.68rem;font-weight:600;color:#9ca3af;padding:8px 14px;
  transition:color .2s;text-decoration:none;min-width:48px;min-height:48px;
  justify-content:center;
}
.el-nav-item svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.8}
.el-nav-item.active,.el-nav-item:hover{color:var(--el-primary)}

/* ===== PC 헤더 (데스크탑 네비게이션) ===== */
.el-pc-header {
  display:none;
}

@media(min-width:768px){
  .el-pc-header {
    display:block;
    position:fixed;
    top:0;left:0;right:0;z-index:1000;
    background:var(--el-gradient-hero);
    box-shadow:0 4px 20px rgba(0,0,0,.15);
  }
  .el-pc-header-inner {
    max-width:1400px;margin:0 auto;padding:0 24px;
  }
  .el-pc-header-top {
    display:flex;align-items:center;justify-content:space-between;
    height:64px;border-bottom:1px solid rgba(255,255,255,.1);
  }
  .el-pc-header-logo {
    display:flex;align-items:center;gap:12px;color:#fff;text-decoration:none;
  }
  .el-pc-header-logo img{height:40px}
  .el-pc-header-logo span{font-size:1rem;font-weight:700}
  .el-pc-header-nav {
    display:flex;align-items:center;height:52px;gap:8px;
  }
  .el-pc-nav-item {
    color:rgba(255,255,255,.9);padding:8px 16px;font-size:.78rem;font-weight:600;
    text-decoration:none;border-radius:8px;transition:all .2s;
  }
  .el-pc-nav-item:hover{background:rgba(255,255,255,.15);color:#fff}
  .el-pc-nav-item.active{background:rgba(255,255,255,.2);color:#fff}
  .el-pc-header-actions {
    display:flex;align-items:center;gap:12px;
  }
  .el-pc-btn {
    padding:8px 16px;border-radius:20px;font-size:.72rem;font-weight:600;
    text-decoration:none;transition:all .2s;
  }
  .el-pc-btn-home {
    background:rgba(255,255,255,.15);color:#fff;
  }
  .el-pc-btn-home:hover{background:rgba(255,255,255,.25)}
}

/* PC 헤더가 있을 때 body 여백 */
@media(min-width:768px){
  body.has-pc-header{padding-top:120px}
}

/* ===== 메뉴 그리드 (중등부/고등부 메인용) ===== */
.el-menu-section{padding:20px 16px}
.el-menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.el-menu-item {
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:20px 12px;background:#fff;border-radius:var(--el-radius);
  text-decoration:none;color:var(--el-text);transition:all .2s;
  border:1px solid var(--el-border);
}
.el-menu-item:hover{transform:translateY(-2px);box-shadow:var(--el-card-shadow-hover);border-color:var(--el-primary);color:var(--el-text)}
.el-menu-item:active{transform:scale(.98)}
.el-menu-icon {
  width:40px;height:40px;display:flex;align-items:center;justify-content:center;
  background:var(--el-bg);border-radius:12px;margin-bottom:8px;
}
.el-menu-icon svg{width:22px;height:22px;stroke:var(--el-primary);fill:none;stroke-width:1.8}
.el-menu-label{font-size:.72rem;font-weight:600;text-align:center;color:var(--el-text)}

@media(min-width:768px){
  .el-menu-section{padding:32px 24px}
  .el-menu-grid{grid-template-columns:repeat(4,1fr);gap:16px}
  .el-menu-item{padding:28px 16px}
  .el-menu-icon{width:48px;height:48px;margin-bottom:12px}
  .el-menu-icon svg{width:26px;height:26px}
  .el-menu-label{font-size:.78rem}
}

/* ===== 로딩 스피너 ===== */
.el-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--el-text-muted)}
.el-loading-spinner{
  width:32px;height:32px;border:3px solid var(--el-border);
  border-top-color:var(--el-primary);border-radius:50%;
  animation:elSpin 1s linear infinite;margin-bottom:12px;
}
@keyframes elSpin{to{transform:rotate(360deg)}}
.el-loading-text{font-size:.85rem;color:var(--el-text-muted)}

/* ===== 푸터 공간 ===== */
.el-footer-space{height:32px}

/* ===== 반응형 ===== */
@media(min-width:1024px){
  .el-nav-bottom{display:none}
  .el-footer-space{height:48px}
  body{padding-bottom:0}
}
@media(max-width:767px){
  .el-hero-content{flex-direction:column;gap:0}
  .el-quick-grid{gap:8px}
}
@media(max-width:400px){
  .el-quick-icon{width:44px;height:44px;font-size:1.3rem}
}

/* PC/모바일 전환 */
@media(min-width:768px){
  .el-mobile-only{display:none !important}
  .el-pc-only{display:block !important}
}
@media(max-width:767px){
  .el-mobile-only{display:block !important}
  .el-pc-only{display:none !important}
}

/* ===== 유틸리티 ===== */
.el-text-center{text-align:center}
.el-mt-0{margin-top:0}.el-mt-1{margin-top:8px}.el-mt-2{margin-top:16px}.el-mt-3{margin-top:24px}
.el-mb-0{margin-bottom:0}.el-mb-1{margin-bottom:8px}.el-mb-2{margin-bottom:16px}.el-mb-3{margin-bottom:24px}
.el-p-1{padding:8px}.el-p-2{padding:16px}.el-p-3{padding:24px}
.el-gap-1{gap:8px}.el-gap-2{gap:12px}.el-gap-3{gap:16px}
.el-flex{display:flex}.el-flex-col{flex-direction:column}
.el-items-center{align-items:center}.el-justify-between{justify-content:space-between}
.el-w-full{width:100%}
.el-hidden{display:none}
.el-block{display:block}

/* ===== 글래스모피즘 카드 (로그인 등) ===== */
.el-glass {
  background:rgba(255,255,255,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.4);border-radius:var(--el-radius-lg);
  box-shadow:0 8px 32px rgba(0,0,0,.1);
}

/* ===== 비디오/미디어 카드 ===== */
.el-media-card{
  background:#fff;border-radius:var(--el-radius);overflow:hidden;
  box-shadow:var(--el-card-shadow);transition:transform .2s;
}
.el-media-card:hover{transform:translateY(-3px);box-shadow:var(--el-card-shadow-hover)}
.el-media-thumb{width:100%;aspect-ratio:16/9;background:#e5e7eb;object-fit:cover}
.el-media-info{padding:14px}
.el-media-title{font-size:.88rem;font-weight:700;color:var(--el-text);margin-bottom:4px}
.el-media-sub{font-size:.75rem;color:var(--el-text-muted)}

/* ===== 성경이야기 카드 ===== */
.el-story-card{
  display:flex;gap:14px;background:#fff;border-radius:var(--el-radius);
  padding:16px;box-shadow:var(--el-card-shadow);transition:all .2s;
  text-decoration:none;color:var(--el-text);margin-bottom:12px;
}
.el-story-card:hover{transform:translateY(-2px);box-shadow:var(--el-card-shadow-hover);color:var(--el-text)}
.el-story-icon{
  width:56px;height:56px;border-radius:14px;display:flex;align-items:center;
  justify-content:center;font-size:1.6rem;flex-shrink:0;
  background:linear-gradient(135deg,var(--el-bg),var(--el-bg-warm));
}
.el-story-info{flex:1;min-width:0}
.el-story-title{font-size:.92rem;font-weight:700;margin-bottom:2px}
.el-story-desc{font-size:.78rem;color:var(--el-text-muted);line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.el-story-progress{
  font-size:.7rem;font-weight:600;color:var(--el-primary);
  background:var(--el-bg);padding:2px 8px;border-radius:6px;margin-top:4px;
  display:inline-block;
}

/* ===== 포인트/상점 카드 ===== */
.el-reward-card{
  background:#fff;border-radius:var(--el-radius);padding:16px;text-align:center;
  box-shadow:var(--el-card-shadow);transition:all .2s;cursor:pointer;
}
.el-reward-card:hover{transform:translateY(-3px);box-shadow:var(--el-card-shadow-hover)}
.el-reward-icon{font-size:2rem;margin-bottom:8px}
.el-reward-name{font-size:.88rem;font-weight:700;color:var(--el-text);margin-bottom:4px}
.el-reward-price{font-size:.82rem;font-weight:600;color:var(--el-accent-dark)}

/* ===== 달력 ===== */
.el-calendar{background:#fff;border-radius:var(--el-radius);padding:20px;box-shadow:var(--el-card-shadow)}
.el-calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.el-calendar-title{font-size:1rem;font-weight:800;color:var(--el-text)}
.el-calendar-nav{display:flex;gap:8px}
.el-calendar-nav button{
  width:36px;height:36px;border-radius:10px;background:#f3f4f6;
  display:flex;align-items:center;justify-content:center;
  color:var(--el-text-muted);font-size:1rem;cursor:pointer;transition:all .2s;border:none;
}
.el-calendar-nav button:hover{background:var(--el-primary);color:#fff}
.el-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;text-align:center}
.el-calendar-dow{font-size:.72rem;font-weight:700;color:var(--el-text-muted);padding:8px 0}
.el-calendar-day{
  padding:8px 4px;border-radius:10px;font-size:.82rem;cursor:pointer;transition:all .15s;
}
.el-calendar-day:hover{background:var(--el-bg)}
.el-calendar-day.today{background:var(--el-primary);color:#fff;font-weight:700}
.el-calendar-day.has-event{position:relative}
.el-calendar-day.has-event::after{
  content:'';width:6px;height:6px;background:var(--el-accent);border-radius:50%;
  position:absolute;bottom:2px;left:50%;transform:translateX(-50%);
}
.el-calendar-day.sunday{color:#ef4444}

/* ===== 스크롤 앵커 ===== */
[id$="-section"]{scroll-margin-top:20px}
