/* Pretendard Variable — 한글 weight 100~900 모두 완전 지원 (Noto Sans KR 300 한글 미커버 문제 해결) */
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable.min.css');
/* Noto Sans KR 도 fallback 으로 함께 로드 (CDN 차단 시) */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;700;900&display=swap');

:root {
  /* Naver palette */
  --naver-green: #03c75a;
  --naver-green-dark: #02a64a;
  --naver-green-light: #e6f8ee;
  --naver-blue: #0068c3;
  --bg-primary: #ffffff;
  --bg-secondary: #f5f6f7;
  --bg-tertiary: #fafbfc;
  --bg-hover: #f0f1f3;
  --text-primary: #222222;
  --text-secondary: #555555;
  --text-muted: #888888;
  --accent: var(--naver-green);
  --accent-hover: var(--naver-green-dark);
  --accent-glow: rgba(3, 199, 90, 0.18);
  --danger: #f04646;
  --warning: #f5a623;
  --border: #e5e7eb;
  --border-strong: #d1d5db;
  --radius-lg: 16px;
  --radius-md: 10px;
  --radius-sm: 6px;
  --radius: 12px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.06);
  --shadow-lg: 0 10px 30px rgba(0,0,0,0.08);
  --shadow: var(--shadow-md);
  --transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
  font-family:'Pretendard Variable','Pretendard','Noto Sans KR','Apple SD Gothic Neo','Malgun Gothic',sans-serif;
  background:var(--bg-primary);
  color:var(--text-primary);
  line-height:1.6;
  overflow-x:hidden;
  font-size:15px;
  font-weight:350;  /* Pretendard 가변 폰트 — 한글까지 weight 350 적용 가능 (Noto Sans KR 한계 극복) */
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
/* 본문 텍스트 — Pretendard Light (350) 한글 완전 지원 */
body p,
body td,
body li,
body dd,
body input,
body textarea,
body span:not([class]) {
  font-weight: 350;
}
::-webkit-scrollbar { width:10px; height:10px; }
::-webkit-scrollbar-track { background:var(--bg-secondary); }
::-webkit-scrollbar-thumb { background:#c0c4ca; border-radius:5px; }
::-webkit-scrollbar-thumb:hover { background:var(--naver-green); }

/* ===== HEADER (Naver style: white, slim) ===== */
header {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:#ffffff;
  border-bottom:1px solid var(--border);
  transition:box-shadow 0.2s;
}
header.scrolled { box-shadow:0 2px 8px rgba(0,0,0,0.04); }
.nav-inner {
  max-width:1280px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 20px; height:60px; gap:12px;
}
.logo {
  display:flex; align-items:center; gap:8px;
  font-weight:900; font-size:1.2rem;
  text-decoration:none; color:var(--text-primary);
  letter-spacing:-0.5px;
  white-space:nowrap; flex-shrink:0;
}
/* 버전 라벨 — 로고 옆에 작고 옅게 (Fire-Sugi 텍스트는 굵게 유지) */
.logo-ver {
  font-size: 0.68rem;
  font-weight: 400;
  color: var(--text-muted);
  letter-spacing: 0;
  margin-left: 2px;
  opacity: 0.75;
}
.logo-icon {
  width:32px; height:32px; flex-shrink:0;
  background:var(--naver-green);
  border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-size:1rem;
  box-shadow:0 2px 6px rgba(3,199,90,0.25);
}
.logo span { color:var(--naver-green); }

nav { display:flex; gap:0; flex:1; justify-content:center; }
nav a {
  color:var(--text-primary); text-decoration:none;
  padding:8px 11px; border-radius:8px;
  font-size:0.86rem; font-weight:500;
  transition:all 0.2s;
  position:relative;
  white-space:nowrap;
}
nav a:hover { background:var(--bg-secondary); color:var(--naver-green); }
nav a.active {
  color:var(--naver-green);
  font-weight:700;
}
nav a.active::after { display:none !important; content:none !important; }

.nav-toggle { display:none; background:none; border:none; color:var(--text-primary); font-size:1.4rem; cursor:pointer; flex-shrink:0; }
.auth-area { display:flex; align-items:center; gap:6px; flex-shrink:0; white-space:nowrap; }
.user-info { display:flex; align-items:center; gap:8px; }
.user-badge { color:var(--naver-green); font-size:0.82rem; font-weight:600; white-space:nowrap; }
.user-name-text { font-size:0.88rem; font-weight:700; color:var(--text-primary); white-space:nowrap; }

/* === 등급 뱃지 (관리자·정회원·일반) === */
.tier-pill {
  display:inline-flex; align-items:center; gap:4px;
  padding:4px 11px; border-radius:14px;
  font-size:0.78rem; font-weight:800;
  white-space:nowrap;
  border:1.5px solid transparent;
  letter-spacing:0.2px;
}
.tier-admin {
  background: var(--c-amber-light) !important;
  color: var(--c-amber-dark) !important;
  border-color: #f0c060 !important;
}
.tier-premium {
  background: var(--c-blue-light) !important;
  color: var(--c-blue-dark) !important;
  border-color: #93b5e8 !important;
}
.tier-user {
  background: var(--bg-secondary) !important;
  color: var(--text-secondary) !important;
  border-color: var(--border) !important;
}

/* 등급 변경 셀렉트 */
.tier-select {
  padding: 4px 6px;
  border: 1px solid var(--border-strong);
  border-radius: 5px;
  font-size: 0.74rem;
  font-family: inherit;
  background: #fff;
  cursor: pointer;
}
.tier-select:focus { outline: none; border-color: var(--naver-green); }

/* 접속 버튼 + 클릭 카운트 뱃지 */
.access-row {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
}
.click-count-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 6px 12px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 14px;
  font-size: 0.82rem; font-weight: 700;
  color: var(--text-secondary);
}

/* 잠긴 프로그램 링크 */
.locked-link {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 18px 20px;
  text-align: center;
}
.detail-link-btn[disabled] {
  background: var(--bg-secondary) !important;
  color: var(--text-muted) !important;
  border: 1px solid var(--border-strong) !important;
  cursor: not-allowed !important;
}
.locked-msg {
  margin-top: 12px;
  color: var(--text-secondary);
  font-size: 0.88rem;
  line-height: 1.6;
}
.locked-msg a {
  color: var(--c-blue-dark);
  font-weight: 700;
  text-decoration: underline;
}
.btn-sm { padding:6px 12px; font-size:0.78rem; border-radius:6px; white-space:nowrap; }

/* ===== TAB PAGES ===== */
.tab-page { display:none; min-height:calc(100vh - 60px); padding-top:60px; background:var(--bg-secondary); }
.tab-page.active { display:block; animation:fadeIn 0.25s ease; }
.tab-section { padding:48px 24px; }
@keyframes fadeIn { from{opacity:0;} to{opacity:1;} }

/* ===== HOME HERO (Naver-style search portal) ===== */
.hero {
  background:#ffffff;
  padding:80px 24px 60px;
  text-align:center;
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--border);
}
.hero::before { display:none; }
.hero-content { position:relative; z-index:1; max-width:720px; margin:0 auto; }

.naver-logo-big {
  font-size:clamp(2.4rem, 5vw, 3.4rem);
  font-weight:900;
  letter-spacing:-2px;
  margin-bottom:8px;
  display:inline-flex; align-items:center; gap:10px;
}
.naver-logo-big .green { color:var(--naver-green); }
.naver-logo-big .fire-emoji { font-size:0.85em; }
.hero-tagline {
  color:var(--text-muted);
  font-size:0.95rem;
  margin-bottom:32px;
}

/* Naver search box */
.naver-search {
  display:flex;
  width:100%;
  max-width:640px;
  margin:0 auto 28px;
  border:2px solid var(--naver-green);
  border-radius:12px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 4px 16px rgba(3,199,90,0.12);
  transition:box-shadow 0.2s;
}
.naver-search:focus-within { box-shadow:0 6px 24px rgba(3,199,90,0.22); }
.naver-search-select {
  border:none; background:#f8f9fa;
  padding:0 12px; font-size:0.9rem; font-weight:600;
  color:var(--text-primary); cursor:pointer;
  border-right:1px solid var(--border);
  outline:none;
}
.naver-search input {
  flex:1; border:none; outline:none;
  padding:14px 18px; font-size:1.05rem;
  background:transparent; color:var(--text-primary);
  font-family:inherit;
}
.naver-search input::placeholder { color:var(--text-muted); }
.naver-search-btn {
  border:none; background:var(--naver-green);
  color:#fff; padding:0 22px;
  font-size:1.2rem; cursor:pointer;
  transition:background 0.2s;
}
.naver-search-btn:hover { background:var(--naver-green-dark); }

/* Hero 캐치프레이즈 (퀵 숏컷 대체) */
.hero-catchphrase {
  margin: 28px auto 16px;
  text-align: center;
  max-width: 640px;
  animation: fadeInUp 0.7s ease 0.2s both;
}
.hc-main {
  font-size: clamp(1.6rem, 4vw, 2.2rem);
  font-weight: 900;
  letter-spacing: -1px;
  color: var(--text-primary);
  line-height: 1.3;
  margin-bottom: 14px;
}
.hc-em {
  color: var(--naver-green);
  position: relative;
  display: inline-block;
}
.hc-em::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 2px;
  height: 8px;
  background: var(--naver-green-light);
  z-index: -1;
  border-radius: 4px;
}
.hc-sub {
  font-size: 0.98rem;
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: 18px;
}
.hc-keywords {
  display: flex; justify-content: center; gap: 10px;
  flex-wrap: wrap;
  font-size: 0.85rem;
}
.hc-keywords span {
  color: var(--naver-green-dark);
  font-weight: 700;
  background: var(--naver-green-light);
  padding: 5px 12px;
  border-radius: 14px;
}
.hc-keywords span:nth-child(2) { color: var(--c-blue-dark); background: var(--c-blue-light); }
.hc-keywords span:nth-child(3) { color: var(--c-amber-dark); background: var(--c-amber-light); }
.hc-keywords span:nth-child(4) { color: #6020a8; background: #f0e6ff; }

/* === 홈 화면 — 최근 게시판 글 위젯 === */
.home-board {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  max-width: 880px;
  margin: 0 auto;
}
.hb-item {
  display: flex; flex-direction: column;
  gap: 6px;
  padding: 16px 22px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 0.15s;
}
.hb-item:last-child { border-bottom: none; }
.hb-item:hover { background: var(--naver-green-light); }
.hb-title {
  font-size: 1rem; font-weight: 700;
  color: var(--text-primary);
  line-height: 1.4;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.hb-lock { color: var(--c-amber-dark); margin-right: 2px; }
.hb-tag-bot {
  display: inline-block; margin-left: 6px;
  padding: 1px 6px; border-radius: 3px;
  background: var(--c-blue-light); color: var(--c-blue-dark);
  font-size: 0.7rem; font-weight: 800;
  vertical-align: middle;
}
.hb-meta {
  display: flex; gap: 12px; flex-wrap: wrap;
  font-size: 0.78rem; color: var(--text-muted);
}
.hb-author {
  color: var(--naver-green-dark); font-weight: 700;
}
.hb-date, .hb-views, .hb-comments { color: var(--text-muted); }
.home-board-empty {
  text-align: center; padding: 48px 20px;
  background: #fff;
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius);
  color: var(--text-muted);
  font-size: 0.95rem;
  max-width: 880px; margin: 0 auto;
}
.home-board-footer {
  text-align: center;
  margin-top: 18px;
}

/* Quick shortcuts (services grid) */
.quick-shortcuts {
  display:flex; flex-wrap:wrap; justify-content:center;
  gap:6px 4px;
  max-width:680px; margin:0 auto 28px;
}
.quick-shortcut {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 14px;
  background:var(--bg-secondary);
  border:1px solid transparent;
  border-radius:30px;
  font-size:0.88rem; font-weight:500;
  color:var(--text-primary); text-decoration:none; cursor:pointer;
  transition:all 0.2s;
}
.quick-shortcut:hover {
  background:var(--naver-green-light);
  border-color:var(--naver-green);
  color:var(--naver-green-dark);
  transform:translateY(-1px);
}
.quick-shortcut .qs-icon { font-size:1rem; }

/* Hero stats — slim Naver-style row */
.hero-stats {
  display:flex; gap:48px; justify-content:center;
  margin-top:8px; flex-wrap:wrap;
  padding-top:24px;
  border-top:1px solid var(--border);
  max-width:480px; margin-left:auto; margin-right:auto;
}
.hero-stats > div { text-align:center; }
.stat-number { font-size:1.6rem; font-weight:900; color:var(--naver-green); }
.stat-label { font-size:0.82rem; color:var(--text-muted); margin-top:2px; }
.hero-stats > div:nth-child(2) .stat-number,
.hero-stats > div:nth-child(3) .stat-number { color:var(--naver-green); }

/* Hide old hero h1/p/buttons/badge if present */
.hero-badge { display:none; }
.hero h1 { display:none; }
.hero > .hero-content > p:not(.hero-tagline) { display:none; }
.hero-buttons { display:none; }

/* ===== BUTTONS ===== */
.btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 22px; border-radius:8px;
  font-size:0.92rem; font-weight:600;
  text-decoration:none; cursor:pointer; border:none;
  transition:all 0.2s;
  font-family:inherit;
  white-space:nowrap;
}
.btn-primary {
  background:var(--naver-green); color:#fff;
}
.btn-primary:hover {
  background:var(--naver-green-dark);
  box-shadow:0 4px 12px rgba(3,199,90,0.3);
}
.btn-outline {
  background:#fff; color:var(--text-primary);
  border:1px solid var(--border-strong);
}
.btn-outline:hover {
  background:var(--bg-secondary);
  border-color:var(--naver-green);
  color:var(--naver-green-dark);
}

/* ===== SECTIONS ===== */
.section-inner { max-width:1200px; margin:0 auto; }
.section-header { text-align:left; margin-bottom:28px; padding-bottom:14px; border-bottom:2px solid var(--text-primary); }
.section-header .tag {
  display:inline-block; color:var(--naver-green);
  font-size:0.78rem; font-weight:700;
  letter-spacing:1.5px; text-transform:uppercase;
  margin-bottom:6px;
}
.section-header h2 {
  font-size:1.5rem; font-weight:600;
  margin-bottom:6px; color:var(--text-primary);
  letter-spacing:-0.5px;
}
.section-header p {
  color:var(--text-secondary); max-width:none;
  margin:0; font-size:0.9rem;
}

/* ===== PROGRAM CARDS ===== */
.programs-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:16px; }
.program-card {
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:24px 22px;
  transition:var(--transition);
  position:relative; overflow:hidden;
  cursor:pointer;
}
.program-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:3px; background:var(--naver-green);
  transform:scaleX(0); transform-origin:left;
  transition:transform 0.3s ease;
}
.program-card:hover {
  transform:translateY(-3px);
  border-color:var(--naver-green);
  box-shadow:var(--shadow-lg);
}
.program-card:hover::before { transform:scaleX(1); }
.card-icon { display:none; }

/* === FEATURED (CORE AI) 프로그램 카드 — 화려한 장식 === */
.program-card.is-featured {
  grid-column: 1 / -1;  /* 전체 너비 차지 */
  background:
    linear-gradient(135deg, rgba(245,166,35,0.08) 0%, rgba(255,255,255,1) 30%, rgba(3,199,90,0.06) 70%, rgba(28,92,214,0.06) 100%);
  border: 2px solid var(--c-amber);
  position: relative;
  overflow: visible;
  padding: 32px 28px 26px;
  box-shadow: 0 8px 28px rgba(245,166,35,0.18);
  margin-top: 14px;
  animation: featuredGlow 3s ease-in-out infinite;
}
@keyframes featuredGlow {
  0%, 100% { box-shadow: 0 8px 28px rgba(245,166,35,0.18); }
  50% { box-shadow: 0 12px 36px rgba(245,166,35,0.32); }
}
.program-card.is-featured::before {
  display: block !important;
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 5px;
  background: linear-gradient(90deg, var(--c-amber), var(--naver-green), var(--c-blue), var(--c-amber));
  background-size: 200% 100%;
  transform: scaleX(1) !important;
  animation: rainbowSlide 4s linear infinite;
  border-radius: var(--radius) var(--radius) 0 0;
}
@keyframes rainbowSlide {
  0% { background-position: 0% 0; }
  100% { background-position: 200% 0; }
}

.featured-ribbon {
  position: absolute;
  top: -16px; left: 50%;
  transform: translateX(-50%);
  padding: 8px 24px;
  background: linear-gradient(90deg, var(--c-amber-dark) 0%, #f5a623 50%, var(--c-amber-dark) 100%);
  color: #fff;
  font-weight: 900;
  font-size: 0.82rem;
  letter-spacing: 1.5px;
  border-radius: 18px;
  box-shadow: 0 4px 14px rgba(245,166,35,0.5);
  white-space: nowrap;
  z-index: 2;
}
.featured-ribbon::before,
.featured-ribbon::after {
  content: ''; position: absolute; top: 50%; transform: translateY(-50%);
  width: 8px; height: 8px;
  background: var(--c-amber-dark);
  border-radius: 50%;
}
.featured-ribbon::before { left: -3px; }
.featured-ribbon::after { right: -3px; }

.featured-stars {
  position: absolute;
  top: 12px; right: 16px;
  font-size: 1rem;
  letter-spacing: 2px;
  filter: drop-shadow(0 1px 2px rgba(245,166,35,0.4));
}

.is-featured .prog-header h3 {
  font-size: 1.4rem;
  font-weight: 900;
  letter-spacing: -0.5px;
  margin-bottom: 0;
}
.is-featured .featured-name {
  background: linear-gradient(90deg, var(--c-amber-dark), #d97706, var(--naver-green-dark));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.is-featured > p {
  font-size: 0.95rem;
  line-height: 1.7;
  margin: 12px 0 14px;
  color: var(--text-primary);
}

.featured-tags {
  display: flex; gap: 6px; flex-wrap: wrap;
  margin: 6px 0 12px;
}
.featured-tags span {
  padding: 4px 12px;
  border-radius: 14px;
  font-size: 0.78rem;
  font-weight: 600;
  border: 1.5px solid;
  letter-spacing: 0.3px;
}
.ft-ai    { background: var(--c-blue-light);     color: var(--c-blue-dark);     border-color: var(--c-blue); }
.ft-core  { background: var(--c-amber-light);    color: var(--c-amber-dark);    border-color: var(--c-amber); }
.ft-main  { background: var(--naver-green-light); color: var(--naver-green-dark); border-color: var(--naver-green); }
.ft-crown { background: #f0e6ff;                 color: #6020a8;                 border-color: #b89af0; }

/* Featured 카드 호버 효과 강화 */
.program-card.is-featured:hover {
  transform: translateY(-4px) scale(1.005);
  box-shadow: 0 16px 40px rgba(245,166,35,0.32);
}

@media (max-width: 700px) {
  .program-card.is-featured { padding: 28px 18px 18px; }
  .is-featured .prog-header h3 { font-size: 1.1rem; }
  .featured-ribbon { font-size: 0.72rem; padding: 6px 16px; }
}

/* === 프로그램 개발중 / 완료 표시 === */
.prog-header {
  display:flex; align-items:center; gap:8px;
  margin-bottom:8px;
}
.prog-header h3 {
  flex:1; margin-bottom:0 !important;
}
.prog-status {
  display:inline-block; padding:3px 10px;
  border-radius:4px; font-size:0.72rem; font-weight:600;
  letter-spacing:0.3px; white-space:nowrap;
  border:1px solid var(--border);
}
.prog-status.prog-done {
  background:#222; color:#fff;
}
.prog-status.prog-dev {
  background:var(--bg-secondary);
  color:var(--text-muted);
  border-color:var(--border-strong);
}

/* 개발중 카드 — 살짝 흐리게 + 호버 효과 약화 */
.program-card.is-dev {
  background:var(--bg-tertiary);
  opacity:0.85;
}
.program-card.is-dev:hover {
  transform:none;
  border-color:var(--border-strong);
  box-shadow:var(--shadow-sm);
}
.program-card.is-dev::before { display:none; }
.prog-dev-msg {
  color:var(--text-muted) !important;
  font-style:italic;
  font-size:0.85rem !important;
}

/* === 완료된 프로그램: 메타 / 스크린샷 / 매뉴얼 === */
.detail-meta-row {
  display:flex; flex-wrap:wrap; gap:8px;
  margin: -8px 0 24px;
  padding:12px 14px;
  background:var(--bg-secondary);
  border:1px solid var(--border);
  border-radius:8px;
  font-size:0.84rem;
  color:var(--text-secondary);
}
.detail-meta { display:inline-flex; align-items:center; gap:6px; }
.detail-meta b {
  background:#fff;
  border:1px solid var(--border);
  padding:2px 8px; border-radius:4px;
  font-size:0.74rem; font-weight:700;
  color:var(--text-primary);
}
.detail-meta + .detail-meta::before {
  content:''; display:inline-block; width:1px; height:14px;
  background:var(--border-strong); margin-right:8px;
}

.screenshots-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:18px;
}
.screenshot-item {
  background:var(--bg-secondary);
  border:1px solid var(--border);
  border-radius:10px;
  overflow:hidden;
  transition:var(--transition);
}
.screenshot-item:hover {
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-color:var(--text-muted);
}
.screenshot-item a {
  display:block; position:relative;
  background:#fff;
  min-height:180px;
}
.screenshot-item img {
  display:block; width:100%; height:auto;
  background:#fff;
}
.screenshot-fallback {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  min-height:200px; padding:20px;
  color:var(--text-muted); gap:6px; text-align:center;
}
.screenshot-fallback span:first-child { font-size:2.5rem; }
.screenshot-fallback small { font-size:0.78rem; max-width:200px; line-height:1.5; }
.screenshot-item figcaption {
  padding:10px 14px;
  background:#fff;
  border-top:1px solid var(--border);
  font-size:0.84rem; color:var(--text-secondary);
  line-height:1.5;
}
.screenshot-note {
  margin-top:10px;
  font-size:0.78rem !important;
  color:var(--text-muted) !important;
  font-style:italic;
}

/* 관리자 스크린샷 컨트롤 */
.ss-admin-controls {
  display:inline-flex; gap:4px; margin-left:12px;
  font-size:0.78rem;
}
.ss-admin-row {
  display:flex; gap:3px; flex-wrap:wrap;
  padding:8px 12px;
  background:var(--bg-secondary);
  border-top:1px solid var(--border);
}
.ss-admin-row .btn-mini { font-size:0.72rem; padding:3px 8px; }
.ss-admin-row .btn-mini[disabled] { opacity:0.4; cursor:not-allowed; }
.ss-tag-custom {
  display:inline-block; margin-left:6px;
  padding:1px 6px; border-radius:3px;
  background:var(--text-primary); color:#fff;
  font-size:0.65rem; font-weight:700;
}
.screenshot-empty {
  text-align:center; padding:48px 20px;
  background:var(--bg-secondary);
  border:2px dashed var(--border-strong);
  border-radius:10px;
  color:var(--text-muted);
  font-size:0.95rem;
}

/* 사용 매뉴얼 — 단계별 번호 강조 */
.howto-list {
  counter-reset: step;
  list-style: none !important;
  padding-left: 0 !important;
}
.howto-list li {
  counter-increment: step;
  position:relative;
  padding:10px 12px 10px 44px;
  margin-bottom:8px;
  background:var(--bg-secondary);
  border-left:3px solid var(--text-primary);
  border-radius:0 6px 6px 0;
  font-size:0.92rem; color:var(--text-primary) !important;
  line-height:1.7;
}
.howto-list li::before {
  content: counter(step);
  position:absolute; left:10px; top:10px;
  width:24px; height:24px;
  background:var(--text-primary); color:#fff;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:0.78rem; font-weight:800;
}

/* 관리자 영역 (상세 페이지) */
.detail-admin-zone {
  margin-top:24px; padding-top:20px;
  border-top:2px dashed var(--border-strong);
}
.detail-admin-zone h3 {
  color:var(--text-muted) !important;
  font-size:0.92rem !important;
}
.admin-actions-row {
  display:flex; align-items:center; gap:14px;
  flex-wrap:wrap;
  padding:14px 16px;
  background:var(--bg-secondary);
  border:1px solid var(--border);
  border-radius:8px;
}

/* 휴지통 — 삭제된 프로그램 영역 */
.program-trash {
  margin-top:40px; padding:20px 22px;
  background:var(--bg-secondary);
  border:1px dashed var(--border-strong);
  border-radius:10px;
}
.trash-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:12px; flex-wrap:wrap; gap:8px;
}
.trash-header h3 {
  font-size:0.95rem; color:var(--text-muted); font-weight:700;
}
.trash-list { display:flex; flex-direction:column; gap:6px; }
.trash-item {
  display:flex; align-items:center; gap:10px;
  padding:8px 12px;
  background:#fff; border:1px solid var(--border);
  border-radius:6px;
  font-size:0.88rem;
}
.trash-name { flex:1; font-weight:600; color:var(--text-primary); }
.trash-tag {
  background:var(--bg-secondary); color:var(--text-secondary);
  padding:2px 8px; border-radius:4px;
  font-size:0.74rem; font-weight:700;
}

/* 개발중 상세 페이지 안내 박스 */
.dev-placeholder {
  text-align:center;
  padding:60px 20px 40px;
}
.dev-icon {
  font-size:3.6rem;
  margin-bottom:16px;
  filter:grayscale(100%);
  opacity:0.6;
}
.dev-placeholder h3 {
  font-size:1.2rem; font-weight:800;
  color:var(--text-primary);
  margin-bottom:8px;
}
.dev-placeholder p {
  color:var(--text-secondary);
  font-size:0.95rem;
  margin-bottom:6px;
}
.dev-placeholder .dev-sub {
  font-size:0.85rem;
  color:var(--text-muted);
  margin-top:14px;
}
.dev-placeholder .dev-sub a {
  color:var(--text-primary);
  font-weight:700;
  text-decoration:underline;
}
.program-card h3 { font-size:1.05rem; margin-bottom:6px; font-weight:500; color:var(--text-primary); }
.program-card p { color:var(--text-secondary); font-size:0.88rem; margin-bottom:14px; line-height:1.6; }
.card-tag {
  display:inline-block;
  background:var(--naver-green-light);
  color:var(--naver-green-dark);
  padding:3px 10px; border-radius:4px;
  font-size:0.75rem; font-weight:700;
}

/* ===== PROGRAM DETAIL ===== */
.detail-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:36px; }
.detail-header { display:flex; align-items:center; gap:18px; margin-bottom:28px; padding-bottom:20px; border-bottom:1px solid var(--border); }
.detail-icon { width:64px; height:64px; background:var(--naver-green-light); border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:2rem; }
.detail-header h2 { font-size:1.4rem; font-weight:900; }
.detail-header .card-tag { margin-top:6px; }
.detail-section { margin-bottom:24px; }
.detail-section h3 { font-size:1rem; font-weight:700; margin-bottom:10px; color:var(--naver-green-dark); display:flex; align-items:center; gap:6px; }
.detail-section p,.detail-section li { color:var(--text-secondary); font-size:0.92rem; line-height:1.75; }
.detail-section ul { padding-left:18px; }
.detail-section li { margin-bottom:4px; }
.detail-section .feature-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:10px; }
.feature-item { background:var(--bg-secondary); border:1px solid var(--border); border-radius:8px; padding:14px; }
.feature-item h4 { font-size:0.92rem; margin-bottom:4px; color:var(--text-primary); }
.feature-item p { font-size:0.83rem; }
.detail-link { display:inline-flex; align-items:center; gap:6px; color:var(--naver-green-dark); text-decoration:none; font-weight:700; margin-top:6px; transition:gap 0.2s; }
.detail-link:hover { gap:10px; text-decoration:underline; }

/* ===== BLOG ===== */
.blog-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px; }
.blog-card {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden;
  transition:var(--transition);
  cursor:pointer;
}
.blog-card:hover {
  transform:translateY(-3px);
  box-shadow:var(--shadow-lg);
  border-color:var(--naver-green);
}
.blog-thumb {
  width:100%; height:160px;
  background:linear-gradient(135deg,#e8f5ec,#c8eed5);
  display:flex; align-items:center; justify-content:center;
  font-size:2.5rem; position:relative; color:var(--naver-green-dark);
}
.blog-thumb .date-badge {
  position:absolute; top:12px; right:12px;
  background:rgba(255,255,255,0.95); backdrop-filter:blur(4px);
  padding:4px 10px; border-radius:4px;
  font-size:0.72rem; color:var(--text-secondary); font-weight:600;
}
.blog-body { padding:18px 20px; }
.blog-body .category {
  color:var(--naver-green); font-size:0.74rem; font-weight:700;
  text-transform:uppercase; letter-spacing:1px; margin-bottom:6px;
}
.blog-body h3 { font-size:1.05rem; margin-bottom:6px; font-weight:700; color:var(--text-primary); line-height:1.4; }
.blog-body p { color:var(--text-secondary); font-size:0.86rem; line-height:1.6; }
.blog-body .meta { display:flex; gap:14px; margin-top:14px; font-size:0.78rem; color:var(--text-muted); }

/* ===== NEWS ===== */
.news-list { display:flex; flex-direction:column; gap:0; max-width:880px; margin:0 auto; background:#fff; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.news-item { display:flex; align-items:flex-start; gap:16px; padding:18px 22px; transition:background 0.15s; border-bottom:1px solid var(--border); }
.news-item:last-child { border-bottom:none; }
.news-item:hover { background:var(--bg-secondary); }
.news-dot {
  width:38px; height:38px; min-width:38px;
  background:var(--naver-green-light); color:var(--naver-green-dark);
  border-radius:10px; display:flex; align-items:center; justify-content:center;
  font-size:1.05rem;
}
.news-content { flex:1; }
.news-content h4 { font-size:1rem; margin-bottom:4px; font-weight:700; color:var(--text-primary); }
.news-content p { color:var(--text-secondary); font-size:0.86rem; line-height:1.6; }
.news-content .news-date { font-size:0.76rem; color:var(--naver-green); margin-top:6px; font-weight:600; }

/* ===== BOARD ===== */
.board-container { background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:24px; max-width:980px; margin:0 auto; }
.board-toolbar { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; gap:14px; flex-wrap:wrap; }
.board-count { color:var(--text-secondary); font-size:0.88rem; flex-shrink:0; font-weight:400; }
.board-count span { color:var(--naver-green); font-weight:600; }
.board-search { position:relative; flex:1; min-width:200px; max-width:380px; }
.board-search input {
  width:100%; padding:9px 38px 9px 14px;
  background:#fff; border:1px solid var(--border-strong);
  border-radius:8px; color:var(--text-primary);
  font-size:0.88rem; transition:border-color 0.2s;
  font-family:inherit;
}
.board-search input:focus { outline:none; border-color:var(--naver-green); box-shadow:0 0 0 3px var(--accent-glow); }
.btn-search { position:absolute; right:8px; top:50%; transform:translateY(-50%); background:none; border:none; color:var(--naver-green); cursor:pointer; font-size:1rem; padding:4px 8px; }
.board-pagination { text-align:center; margin-top:20px; padding-top:16px; border-top:1px solid var(--border); }
.write-form { background:var(--bg-secondary); border:1px solid var(--border); border-radius:10px; padding:20px; margin-bottom:18px; animation:fadeInUp 0.25s ease; }
.form-row { display:flex; gap:12px; margin-bottom:12px; }
.board-table-wrap { overflow-x:auto; }
.board-table { width:100%; border-collapse:collapse; font-size:0.9rem; }
.board-table thead { border-top:2px solid var(--text-primary); border-bottom:1px solid var(--border-strong); background:var(--bg-secondary); }
.board-table th { padding:12px 10px; color:var(--text-secondary); font-weight:500; font-size:0.78rem; letter-spacing:0.5px; text-align:left; }
.board-table td { padding:14px 10px; border-bottom:1px solid var(--border); color:var(--text-primary); font-weight:400; }
.board-table tbody tr { transition:background 0.15s; cursor:pointer; }
.board-table tbody tr:hover { background:var(--bg-secondary); }
.col-no { width:60px; text-align:center; }
.col-title { min-width:200px; }
.col-author { width:100px; }
.col-date { width:100px; }
.col-views { width:60px; text-align:center; }
.td-title { font-weight:400; }
.td-title:hover { color:var(--naver-green-dark); }
.secret-icon { color:var(--warning); margin-right:4px; }
.board-empty { text-align:center; padding:48px 20px; color:var(--text-muted); font-size:0.95rem; }

/* ===== MODAL ===== */
.modal-overlay { position:fixed; inset:0; z-index:200; background:rgba(0,0,0,0.45); backdrop-filter:blur(3px); display:flex; align-items:center; justify-content:center; padding:24px; animation:fadeIn 0.2s ease; }
.modal-content { background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:32px; max-width:700px; width:100%; max-height:85vh; overflow-y:auto; position:relative; animation:fadeInUp 0.25s ease; box-shadow:var(--shadow-lg); }
.modal-sm { max-width:400px; }
.modal-close { position:absolute; top:14px; right:14px; background:none; border:none; color:var(--text-muted); font-size:1.2rem; cursor:pointer; transition:color 0.2s; padding:6px 10px; border-radius:6px; }
.modal-close:hover { color:var(--text-primary); background:var(--bg-secondary); }
.modal-category { color:var(--naver-green); font-size:0.78rem; font-weight:700; letter-spacing:1px; margin-bottom:6px; }
.modal-content h2 { font-size:1.3rem; margin-bottom:10px; color:var(--text-primary); }
.modal-meta { display:flex; gap:14px; font-size:0.8rem; color:var(--text-muted); margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid var(--border); }
.modal-body { line-height:1.85; font-size:0.94rem; white-space:pre-wrap; color:var(--text-primary); }

/* ===== COMMENTS ===== */
.comments-section { margin-top:22px; padding-top:18px; border-top:1px solid var(--border); }
.comments-section h4 { margin-bottom:14px; font-size:0.95rem; color:var(--text-primary); }
.comment-item { background:var(--bg-secondary); border-radius:8px; padding:12px 14px; margin-bottom:8px; }
.comment-item .comment-header { display:flex; justify-content:space-between; margin-bottom:4px; font-size:0.78rem; }
.comment-item .comment-author { color:var(--naver-green-dark); font-weight:700; }
.comment-item .comment-date { color:var(--text-muted); }
.comment-item .comment-text { font-size:0.88rem; color:var(--text-primary); line-height:1.6; }
.comment-write { display:flex; gap:8px; margin-top:12px; }
.comment-write textarea { flex:1; padding:10px 14px; background:#fff; border:1px solid var(--border-strong); border-radius:8px; color:var(--text-primary); font-family:inherit; font-size:0.88rem; resize:none; }
.comment-write textarea:focus { outline:none; border-color:var(--naver-green); }

/* ===== FORMS ===== */
.form-group { margin-bottom:14px; }
.form-group label { display:block; font-size:0.84rem; font-weight:600; margin-bottom:6px; color:var(--text-primary); }
.form-group input,.form-group textarea {
  width:100%; padding:11px 14px;
  background:#fff; border:1px solid var(--border-strong);
  border-radius:8px; color:var(--text-primary);
  font-family:inherit; font-size:0.92rem;
  transition:border-color 0.2s;
}
.form-group input:focus,.form-group textarea:focus {
  outline:none; border-color:var(--naver-green);
  box-shadow:0 0 0 3px var(--accent-glow);
}
.form-group textarea { resize:vertical; min-height:100px; }
.form-error { color:var(--danger); font-size:0.83rem; margin-bottom:10px; min-height:18px; }
.checkbox-label { display:flex; align-items:center; gap:8px; font-size:0.88rem; color:var(--text-secondary); cursor:pointer; }
.checkbox-label input[type="checkbox"] { width:16px; height:16px; accent-color:var(--naver-green); }
.terms-box { background:var(--bg-secondary); border:1px solid var(--border); border-radius:8px; padding:14px; margin-bottom:14px; }
.terms-box h4 { font-size:0.88rem; margin-bottom:6px; }
.terms-scroll { max-height:120px; overflow-y:auto; font-size:0.78rem; color:var(--text-secondary); line-height:1.7; white-space:pre-wrap; }

/* ===== FOOTER ===== */
footer { padding:32px 24px; border-top:1px solid var(--border); background:#fff; text-align:center; }
.footer-inner { max-width:1200px; margin:0 auto; }
.footer-inner p { color:var(--text-muted); font-size:0.82rem; }
.footer-links { display:flex; gap:20px; justify-content:center; margin-bottom:14px; flex-wrap:wrap; }
.footer-links a { color:var(--text-secondary); text-decoration:none; font-size:0.86rem; transition:color 0.2s; }
.footer-links a:hover { color:var(--naver-green); }

/* ===== ANIMATIONS ===== */
@keyframes fadeInUp { from{opacity:0;transform:translateY(16px);} to{opacity:1;transform:translateY(0);} }
.particle { display:none; }

/* ===== RESPONSIVE ===== */
@media (max-width:1100px) {
  nav a { padding:8px 8px; font-size:0.82rem; }
  nav a.active::after { left:8px; right:8px; }
}
@media (max-width:960px) {
  /* legacy 룰 정리 — 충돌 방지용 핵심만 유지 */
  nav a.active::after { display:none !important; content:none !important; }
  .auth-area { gap:4px; }
  .blog-grid { grid-template-columns:1fr; }
  .tab-section { padding:32px 14px; }
  .detail-header { flex-direction:column; text-align:center; }
  .form-row { flex-direction:column; }
  .hero { padding:48px 16px 36px; }
  .naver-search { max-width:100%; }
  .naver-search-select { display:none; }
  .hero-stats { gap:32px; }
}

/* ===== STRENGTH/PROCESS/CTA (Naver-clean style) ===== */
.reveal { opacity: 0; transform: translateY(20px); transition: var(--transition); }
.reveal.active { opacity: 1; transform: translateY(0); }

.step-number { font-size: 2.2rem; font-weight: 900; color: var(--naver-green); opacity: 0.25; line-height: 1; margin-bottom: 4px; }
.strength-card {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius); padding:28px 24px;
  transition:var(--transition); position:relative;
}
.strength-card:hover {
  transform:translateY(-4px);
  border-color:var(--naver-green);
  box-shadow:var(--shadow-lg);
}
.strength-card h3 { font-size:1.1rem; font-weight:700; margin-bottom:8px; }
.strength-card p { font-size:0.9rem; color:var(--text-secondary); line-height:1.7; }

.process-timeline { position:relative; max-width:820px; margin:32px auto; padding-left:36px; }
.process-timeline::before { content:''; position:absolute; left:7px; top:6px; bottom:6px; width:2px; background:var(--border-strong); }
.process-item { position:relative; margin-bottom:28px; }
.process-dot {
  position:absolute; left:-36px; top:4px;
  width:14px; height:14px;
  background:var(--naver-green); border-radius:50%;
  border:3px solid #fff;
  box-shadow:0 0 0 1px var(--naver-green);
}
.process-content h3 { font-size:1.05rem; margin-bottom:4px; color:var(--text-primary); font-weight:700; }
.process-content p { color:var(--text-secondary); font-size:0.9rem; }

.cta-section {
  background:linear-gradient(135deg, var(--naver-green-light), #ffffff);
  border:1px solid var(--naver-green);
  border-radius:var(--radius);
  padding:56px 32px; text-align:center; margin-top:32px;
  position:relative;
}
.cta-section h2 { font-size:1.8rem; margin-bottom:16px; color:var(--text-primary); }
.cta-section p { font-size:1rem; color:var(--text-secondary); margin-bottom:28px; }

.back-to-top {
  position:fixed; bottom:24px; right:24px;
  width:44px; height:44px;
  background:var(--naver-green); color:#fff;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  text-decoration:none; opacity:0; transition:var(--transition);
  z-index:99; box-shadow:var(--shadow-lg);
  font-weight:700;
}
.back-to-top.visible { opacity:1; }
.back-to-top:hover { transform:translateY(-3px); background:var(--naver-green-dark); }

/* ===== FEATURED PROGRAM (Naver-clean) ===== */
.featured-program {
  display:grid; grid-template-columns:1.2fr 1fr;
  gap:48px; align-items:center;
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius); padding:48px;
}
.featured-content h2 { font-size:1.7rem; margin-bottom:14px; line-height:1.3; }
.featured-content .gradient-text { color:var(--naver-green); }
.featured-content p { color:var(--text-secondary); font-size:0.95rem; margin-bottom:18px; }
.featured-features { display:flex; flex-direction:column; gap:8px; margin-bottom:24px; color:var(--text-secondary); font-size:0.9rem; }
.featured-features span { display:flex; align-items:center; gap:6px; }

.mockup-ui {
  background:var(--bg-secondary); border-radius:12px;
  border:1px solid var(--border);
  box-shadow:var(--shadow-lg);
  width:100%; aspect-ratio:16/10;
  padding:18px; display:flex; flex-direction:column; gap:10px;
  transition:var(--transition);
}
.mockup-header { display:flex; gap:6px; margin-bottom:6px; }
.mockup-header div { width:9px; height:9px; border-radius:50%; background:#d1d5db; }
.mockup-header div:first-child { background:#fc6058; }
.mockup-header div:nth-child(2) { background:#fcbb40; }
.mockup-header div:nth-child(3) { background:var(--naver-green); }
.mockup-line { height:8px; border-radius:4px; background:#dde0e5; }
.mockup-box { flex:1; border-radius:8px; background:linear-gradient(135deg, var(--naver-green-light), transparent); border:1px dashed var(--naver-green); }

@media (max-width: 992px) {
  .featured-program { grid-template-columns:1fr; text-align:center; padding:32px 20px; gap:24px; }
  .featured-features { align-items:center; }
  .mockup-ui { max-width:380px; margin:0 auto; }
}

/* Gradient text fallback (for any leftover .gradient-text) */
.gradient-text { color:var(--naver-green); background:none; -webkit-background-clip:initial; background-clip:initial; -webkit-text-fill-color:initial; }

/* === 모든 이모티콘 일괄 숨김 === */
.news-emoji,
.qs-icon,
.fire-emoji,
.logo-icon,
.news-thumb-naver,
.card-icon,
.detail-icon,
.bot-tag,
.nb-tag,
.online-dot,
.news-auto-badge,
.mi-avatar,
.mnf-avatar { display:none !important; }

/* 뉴스 카드 썸네일 영역 숨겨도 레이아웃 정상화 */
.news-card-naver { display:flex; flex-direction:column; }
.news-card-body { padding-top:18px; }

/* ===== ADMIN: STAT BOXES ===== */
.admin-stats {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:14px; margin-bottom:24px;
}
.stat-box {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius); padding:20px 22px;
  position:relative; transition:var(--transition);
}
.stat-box:hover { box-shadow:var(--shadow-md); border-color:var(--naver-green); }
.stat-box.accent { background:linear-gradient(135deg, var(--naver-green-light), #fff); border-color:var(--naver-green); }
.sb-label { font-size:0.82rem; color:var(--text-secondary); font-weight:600; }
.sb-value { font-size:2rem; font-weight:900; color:var(--text-primary); line-height:1.1; margin-top:6px; letter-spacing:-1px; }
.sb-value.online, .sb-value.accent { color:var(--naver-green); }
.sb-value.danger { color:var(--danger); }
.sb-sub { font-size:0.76rem; color:var(--text-muted); margin-top:6px; }

.anon-note {
  margin: 8px 0 18px;
  padding: 10px 14px;
  background: var(--bg-secondary);
  border-left: 3px solid var(--c-blue);
  border-radius: 4px;
  font-size: 0.82rem;
  color: var(--text-secondary);
  line-height: 1.6;
}
.anon-note a { color: var(--c-blue-dark); font-weight: 700; text-decoration: underline; }

/* === 어제 활동 요약 === */
.yesterday-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  margin-bottom: 18px;
}
.yest-box {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px 10px;
  text-align: center;
}
.yest-num {
  font-size: 1.6rem; font-weight: 900;
  color: var(--c-blue-dark);
  line-height: 1.1;
}
.yest-lab {
  font-size: 0.78rem; color: var(--text-secondary);
  margin-top: 4px; font-weight: 600;
}
.yest-section { margin-top: 18px; padding-top: 14px; border-top: 1px dashed var(--border); }
.yest-section h4 {
  font-size: 0.92rem; font-weight: 700;
  color: var(--text-primary); margin-bottom: 10px;
}
.yest-list {
  display: flex; flex-direction: column; gap: 4px;
  max-height: 280px; overflow-y: auto;
}
.yest-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  background: #fff; border: 1px solid var(--border); border-radius: 6px;
  font-size: 0.86rem;
}
.yest-time {
  font-family: 'Consolas', 'Menlo', monospace;
  font-size: 0.78rem;
  color: var(--text-muted);
  min-width: 44px;
}
.yest-id {
  font-weight: 700;
  color: var(--naver-green-dark);
  min-width: 90px;
}
.yest-tier, .yest-action {
  flex: 1; color: var(--text-secondary);
}
.yest-date { color: var(--text-muted); font-size: 0.78rem; }
.yest-empty {
  text-align: center; padding: 20px;
  color: var(--text-muted); font-size: 0.86rem;
  background: var(--bg-tertiary); border-radius: 8px;
}
.yest-more {
  text-align: center; padding: 8px;
  color: var(--text-muted); font-size: 0.8rem; font-style: italic;
}
@media (max-width: 768px) {
  .yesterday-grid { grid-template-columns: repeat(2, 1fr); }
}

/* 관리자 전용 인라인 뱃지 (섹션 제목 옆) */
.admin-badge-inline {
  display: inline-block;
  margin-left: 8px;
  padding: 3px 10px;
  background: var(--c-amber-light);
  color: var(--c-amber-dark);
  border: 1px solid #f0c060;
  border-radius: 12px;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.5px;
  vertical-align: middle;
}

/* ===== ADMIN: BADGES ===== */
.badge {
  display:inline-block; padding:3px 10px;
  border-radius:14px; font-size:0.74rem;
  font-weight:700; white-space:nowrap;
}
.badge-admin { background:#fff4d4; color:#a07300; border:1px solid #f5d97a; }
.badge-user { background:var(--bg-secondary); color:var(--text-secondary); border:1px solid var(--border); }
.badge-online { background:var(--naver-green-light); color:var(--naver-green-dark); border:1px solid var(--naver-green); }
.badge-offline { background:var(--bg-secondary); color:var(--text-muted); border:1px solid var(--border); }
.badge-banned { background:#ffe0e0; color:var(--danger); border:1px solid #ffb4b4; }

/* ===== ADMIN: MINI BUTTONS ===== */
.action-row {
  display:flex;
  gap:4px;
  flex-wrap:nowrap;
  align-items:center;
  white-space:nowrap;
}
.action-row .btn-mini,
.action-row .tier-select {
  flex:0 0 auto;
  white-space:nowrap;
}
.btn-mini {
  padding:5px 10px; border-radius:5px;
  border:1px solid var(--border-strong); background:#fff;
  color:var(--text-primary); font-size:0.76rem; font-weight:500;
  cursor:pointer; transition:all 0.15s; font-family:inherit;
}
.btn-mini:hover { background:var(--naver-green-light); border-color:var(--naver-green); color:var(--naver-green-dark); }
.btn-mini-warn { background:#fff8e6; border-color:#f5d97a; color:#8a6300; }
.btn-mini-warn:hover { background:#ffe9a6; border-color:#dba500; color:#6b4d00; }
.btn-mini-danger { background:#fff0f0; border-color:#ffb4b4; color:var(--danger); }
.btn-mini-danger:hover { background:#ffd6d6; border-color:var(--danger); color:#a82020; }

/* ===== DASHBOARD ===== */
.dashboard-grid {
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:18px;
}
.dash-card {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius); padding:22px 24px;
}
.dash-full { grid-column:1 / -1; }
.dash-card-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:18px; gap:8px; flex-wrap:wrap;
}
.dash-card-header h3 {
  font-size:1rem; font-weight:700; color:var(--text-primary);
  display:flex; align-items:center; gap:6px;
}
.dash-select {
  padding:6px 10px; border:1px solid var(--border-strong);
  border-radius:6px; font-size:0.8rem; background:#fff;
  color:var(--text-primary); cursor:pointer;
  font-family:inherit; outline:none;
}
.dash-select:focus { border-color:var(--naver-green); }

/* 막대 차트 */
.bar-chart {
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:8px; height:180px; padding:0 4px;
}
.bar-col { flex:1; display:flex; flex-direction:column; align-items:center; height:100%; }
.bar-value { font-size:0.78rem; font-weight:700; color:var(--text-primary); margin-bottom:4px; }
.bar {
  width:100%; max-width:42px;
  flex:1; background:var(--bg-secondary);
  border-radius:6px 6px 0 0; overflow:hidden;
  display:flex; align-items:flex-end;
  border:1px solid var(--border);
  border-bottom:none;
}
.bar-fill {
  width:100%;
  background:linear-gradient(180deg, var(--naver-green), var(--naver-green-dark));
  border-radius:5px 5px 0 0;
  min-height:2px;
  transition:height 0.4s ease;
}
.bar-label { font-size:0.74rem; color:var(--text-muted); margin-top:6px; }

/* 온라인 리스트 */
.online-list { display:flex; flex-direction:column; gap:6px; max-height:260px; overflow-y:auto; }
.online-row {
  display:flex; align-items:center; gap:10px;
  padding:8px 12px;
  background:var(--bg-secondary); border-radius:8px;
  font-size:0.88rem;
}
.online-dot {
  width:8px; height:8px; background:var(--naver-green);
  border-radius:50%;
  box-shadow:0 0 0 3px rgba(3,199,90,0.2);
  animation:pulse 2s infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow:0 0 0 3px rgba(3,199,90,0.2); }
  50% { box-shadow:0 0 0 5px rgba(3,199,90,0.05); }
}
.online-id { flex:1; font-weight:600; color:var(--text-primary); }
.online-time { color:var(--text-muted); font-size:0.78rem; }

/* 로그 액션 색상 */
.log-action {
  display:inline-block; padding:2px 8px;
  border-radius:4px; font-size:0.78rem; font-weight:600;
}
.log-login { background:var(--naver-green-light); color:var(--naver-green-dark); }
.log-logout { background:var(--bg-secondary); color:var(--text-secondary); }
.log-signup { background:#e6f0ff; color:#0050b3; }
.log-post { background:#fff4d4; color:#8a6300; }
.log-warn { background:#ffe0e0; color:var(--danger); }
.log-admin { background:#f0e6ff; color:#6020a8; }
.log-default { background:var(--bg-secondary); color:var(--text-secondary); }

@media (max-width:992px) {
  .dashboard-grid { grid-template-columns:1fr; }
  .dash-full { grid-column:auto; }
}
@media (max-width:768px) {
  .bar-chart { height:140px; }
  .admin-stats { grid-template-columns:repeat(2, 1fr); }
}

/* ========================================================
   KFMA STYLE — 법령정보·기술자료·서식자료·회원정보
   ======================================================== */

/* 좌측 사이드 + 우측 콘텐츠 레이아웃 */
.kfma-layout {
  display:grid;
  grid-template-columns:220px 1fr;
  gap:24px;
  align-items:start;
}
.kfma-side {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px 18px;
  position:sticky; top:80px;
}
.kfma-side h4 {
  font-size:0.95rem; font-weight:800;
  margin-bottom:14px; padding-bottom:10px;
  border-bottom:2px solid var(--naver-green);
  color:var(--text-primary);
}
.side-menu { list-style:none; padding:0; margin:0 0 14px; }
.side-menu li { margin-bottom:2px; }
.side-menu a {
  display:block; padding:9px 12px;
  color:var(--text-primary); text-decoration:none;
  font-size:0.88rem; border-radius:6px;
  transition:all 0.15s; font-weight:500;
}
.side-menu a:hover { background:var(--naver-green-light); color:var(--naver-green-dark); }
.side-menu a.active {
  background:var(--naver-green); color:#fff; font-weight:700;
}
.side-tip {
  background:var(--naver-green-light);
  border:1px solid var(--naver-green);
  border-radius:8px;
  padding:10px 12px;
  font-size:0.78rem; color:var(--naver-green-dark);
  line-height:1.6;
}

.kfma-content { display:flex; flex-direction:column; gap:24px; }
.kfma-block {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius); padding:24px;
}
.kfma-block-header {
  display:flex; align-items:baseline; justify-content:space-between;
  margin-bottom:16px; padding-bottom:12px;
  border-bottom:2px solid var(--text-primary);
  flex-wrap:wrap; gap:8px;
}
.kfma-block-header h3 { font-size:1.1rem; font-weight:600; color:var(--text-primary); }
.kfma-sub { font-size:0.82rem; color:var(--text-muted); }

/* 법령 카드 그리드 (4개 메인 법) */
.law-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));
  gap:14px;
}
.law-card {
  background:#fff;
  border:1px solid var(--border);
  border-left:4px solid var(--law-color, var(--naver-green));
  border-radius:8px;
  padding:18px 18px 14px;
  transition:var(--transition);
}
.law-card:hover {
  box-shadow:var(--shadow-md);
  transform:translateY(-2px);
}
.law-card-header { margin-bottom:14px; }
.law-card-header h4 {
  font-size:1.05rem; font-weight:500; color:var(--text-primary);
  margin-bottom:4px;
}
.law-card-header span {
  font-size:0.8rem; color:var(--text-muted);
  display:block; line-height:1.5;
}
.law-links { display:grid; grid-template-columns:repeat(3, 1fr); gap:6px; }
.law-link {
  display:flex; align-items:center; justify-content:space-between;
  padding:8px 10px;
  background:var(--bg-secondary);
  border:1px solid var(--border);
  border-radius:6px;
  text-decoration:none;
  color:var(--text-primary);
  font-size:0.78rem; font-weight:500;
  transition:all 0.15s;
}
.law-link:hover {
  background:var(--law-color, var(--naver-green));
  border-color:var(--law-color, var(--naver-green));
  color:#fff;
}
.ll-type { font-weight:500; }
.ll-arrow { opacity:0.5; }
.law-link:hover .ll-arrow { opacity:1; }

/* 구법 (폐지) 리스트 */
.old-law-list {
  display: flex; flex-direction: column; gap: 10px;
}
.old-law-item {
  padding: 14px 16px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-left: 4px solid var(--text-muted);
  border-radius: 6px;
  transition: var(--transition);
}
.old-law-item:hover {
  border-left-color: var(--c-amber-dark);
  background: #fff;
}
.old-law-name {
  display: inline-flex; align-items: center; gap: 6px;
  font-weight: 500;
  color: var(--text-primary);
  text-decoration: none;
  font-size: 0.95rem;
  margin-bottom: 4px;
}
.old-law-name:hover { color: var(--c-blue-dark); text-decoration: underline; }
.old-law-note {
  font-size: 0.82rem;
  color: var(--text-secondary);
  line-height: 1.6;
  margin-top: 6px;
}

/* 행정규칙 그룹 */
.rule-list { display:flex; flex-direction:column; gap:14px; }
.rule-group {
  border:1px solid var(--border); border-radius:8px;
  padding:14px 18px; background:var(--bg-tertiary);
}
.rule-group h5 {
  font-size:0.9rem; font-weight:700; margin-bottom:8px;
  color:var(--naver-green-dark);
}
.rule-group ul { list-style:none; padding:0; margin:0; }
.rule-group li { padding:5px 0; border-bottom:1px dashed var(--border); }
.rule-group li:last-child { border-bottom:none; }
.rule-group a {
  display:flex; align-items:center; justify-content:space-between;
  color:var(--text-primary); text-decoration:none;
  font-size:0.86rem; padding:3px 0;
  transition:color 0.15s;
}
.rule-group a:hover { color:var(--naver-green-dark); }
.rule-ext { color:var(--text-muted); font-size:0.78rem; }

/* KFMA 게시판 공통 (기술자료/서식자료) */
.kfma-board {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius); padding:22px 24px;
}
.kfma-tabs {
  display:flex; gap:6px; margin-bottom:18px;
  flex-wrap:wrap; padding-bottom:14px;
  border-bottom:1px solid var(--border);
}
.kfma-tab {
  padding:8px 16px; border:1px solid var(--border-strong);
  background:#fff; border-radius:20px;
  font-size:0.85rem; font-weight:600;
  cursor:pointer; transition:all 0.15s;
  color:var(--text-secondary);
  font-family:inherit;
}
.kfma-tab:hover { border-color:var(--naver-green); color:var(--naver-green-dark); }
.kfma-tab.active {
  background:var(--naver-green); border-color:var(--naver-green);
  color:#fff;
}

.kfma-table tbody tr { cursor:default; }
.kfma-table .td-title { font-weight:400; }

/* 카테고리 칩 (단색 통일) */
.cat-chip {
  display:inline-block; padding:3px 10px;
  border-radius:4px; font-size:0.74rem; font-weight:500;
  text-align:center; min-width:50px;
  background:var(--bg-secondary);
  color:var(--text-secondary);
  border:1px solid var(--border);
}
.cat-check, .cat-design, .cat-build, .cat-super, .cat-guide,
.cat-report, .cat-contract, .cat-ledger, .cat-etc {
  background:var(--bg-secondary);
  color:var(--text-secondary);
  border:1px solid var(--border);
}

/* 파일 형식 뱃지 (단색 통일) */
.file-badge {
  display:inline-block; padding:2px 8px;
  border-radius:3px; font-size:0.7rem; font-weight:600;
  letter-spacing:0.5px;
  font-family:'Consolas','Menlo',monospace;
  background:var(--bg-secondary);
  color:var(--text-secondary);
  border:1px solid var(--border);
}
.file-pdf, .file-hwp, .file-xlsx, .file-docx, .file-zip {
  background:var(--bg-secondary);
  color:var(--text-secondary);
  border:1px solid var(--border);
}

/* NEW 뱃지 */
.badge-new {
  display:inline-block; margin-left:6px; padding:1px 6px;
  background:var(--danger); color:#fff;
  border-radius:3px; font-size:0.65rem; font-weight:800;
  letter-spacing:0.5px; vertical-align:middle;
}

.btn-dl {
  background:var(--naver-green-light);
  border-color:var(--naver-green);
  color:var(--naver-green-dark);
  font-size:0.75rem;
}
.btn-dl:hover { background:var(--naver-green); color:#fff; }

/* 회원정보 페이지 */
.member-info-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.mi-card {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius); padding:24px 26px;
}
.mi-card h3 {
  font-size:1.05rem; font-weight:800; color:var(--text-primary);
  margin-bottom:16px; padding-bottom:10px;
  border-bottom:2px solid var(--text-primary);
}
.mi-empty {
  text-align:center; padding:32px 20px;
  color:var(--text-muted); font-size:0.9rem;
}
.mi-profile {
  display:flex; align-items:center; gap:16px;
  padding:14px; background:var(--naver-green-light);
  border-radius:10px; margin-bottom:18px;
}
.mi-avatar {
  width:56px; height:56px; border-radius:50%;
  background:var(--naver-green); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.6rem; font-weight:900;
}
.mi-name {
  font-size:1.05rem; font-weight:800;
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
}
.mi-meta { font-size:0.82rem; color:var(--text-secondary); margin-top:4px; }
.mi-stats {
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:8px; margin-bottom:16px;
  text-align:center;
}
.mi-stats > div {
  background:var(--bg-secondary); border:1px solid var(--border);
  border-radius:8px; padding:10px 6px;
}
.mi-num {
  font-size:1.3rem; font-weight:900;
  color:var(--naver-green); line-height:1.1;
}
.mi-lab { font-size:0.74rem; color:var(--text-muted); margin-top:3px; }
.mi-actions { display:flex; gap:6px; flex-wrap:wrap; }

/* 회원 등급 */
.grade-list { display:flex; flex-direction:column; gap:14px; }
.grade-row {
  display:grid; grid-template-columns:120px 1fr;
  gap:14px; align-items:start;
  padding:12px;
  background:var(--bg-tertiary); border-radius:8px;
}
.grade-row ul {
  margin:0; padding-left:18px; font-size:0.86rem;
  color:var(--text-secondary); line-height:1.7;
}
.grade-badge {
  display:inline-block; padding:4px 10px;
  border-radius:14px; font-size:0.78rem; font-weight:700;
  text-align:center; height:fit-content;
}
.grade-badge.gold   { background:#fff4d4; color:#a07300; border:1px solid #f5d97a; }
.grade-badge.silver { background:#e8eef5; color:#3a5a8a; border:1px solid #b9c7da; }
.grade-badge.bronze { background:#fde8d8; color:#8a4a20; border:1px solid #f0c79a; }

/* 가입 절차 */
.signup-steps {
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:14px;
}
.ss-step {
  display:flex; align-items:flex-start; gap:12px;
  padding:14px; background:var(--bg-tertiary);
  border:1px solid var(--border); border-radius:8px;
}
.ss-num {
  width:32px; height:32px; min-width:32px;
  background:var(--naver-green); color:#fff;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-weight:900; font-size:0.95rem;
}
.ss-step b { display:block; font-size:0.92rem; margin-bottom:3px; }
.ss-step p { font-size:0.8rem; color:var(--text-secondary); line-height:1.5; }

/* 반응형 */
@media (max-width:992px) {
  .kfma-layout { grid-template-columns:1fr; }
  .kfma-side { position:static; }
  .side-menu { display:flex; flex-wrap:wrap; gap:4px; }
  .side-menu li { flex:1; min-width:120px; }
  .member-info-grid { grid-template-columns:1fr; }
  .signup-steps { grid-template-columns:repeat(2, 1fr); }
}
@media (max-width:600px) {
  .law-links { grid-template-columns:1fr; }
  .mi-stats { grid-template-columns:repeat(2, 1fr); }
  .grade-row { grid-template-columns:1fr; }
  .signup-steps { grid-template-columns:1fr; }
  .kfma-tabs { gap:4px; }
  .kfma-tab { padding:6px 12px; font-size:0.78rem; }
}

/* ========================================================
   📱 모바일 최적화 (종합)
   ======================================================== */

/* iOS 자동 폰트 확대 방지 */
html { -webkit-text-size-adjust: 100%; }

/* 터치 디바이스: 호버 효과 비활성화 (모바일에서 stuck 방지) */
@media (hover: none) {
  .program-card:hover,
  .blog-card:hover,
  .news-card-naver:hover,
  .law-card:hover { transform: none; }
}

/* === 휴대폰·태블릿 (960px 이하) === */
@media (max-width: 960px) {
  /* 기본 폰트·간격 축소 */
  body { font-size: 14px; }

  /* 헤더 — 2행 고정 (로고+사용자 / 메뉴 가로 스크롤) */
  .nav-inner {
    padding: 8px 12px;
    height: auto;
    gap: 8px;
    flex-wrap: wrap !important;
    align-items: center;
  }
  .logo { font-size: 1.05rem; flex: 0 0 auto !important; order: 1; }
  .logo-icon { width: 28px; height: 28px; font-size: 0.9rem; }
  .auth-area {
    flex: 1 1 auto !important;
    justify-content: flex-end !important;
    order: 2;
    min-width: 0;
    margin-left: 0 !important;
  }
  .user-name-text { font-size: 0.78rem; max-width: 80px; overflow: hidden; text-overflow: ellipsis; }
  .tier-pill { padding: 3px 8px; font-size: 0.7rem; }
  .btn-sm { padding: 5px 10px; font-size: 0.74rem; }

  /* 햄버거 토글 — 펼치기/접기 버튼 */
  .nav-toggle {
    display: inline-flex !important;
    align-items: center; justify-content: center;
    background: var(--bg-secondary);
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    padding: 6px 12px;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--text-primary);
    cursor: pointer;
    order: 3;
    flex: 0 0 auto;
  }
  .nav-toggle:hover, .nav-toggle:active {
    background: var(--naver-green-light);
    border-color: var(--naver-green);
    color: var(--naver-green-dark);
  }
  /* 메뉴 열림 표시 — nav.open일 때 토글 아이콘 변경 (Edge/Safari 호환) */
  .nav-toggle.is-open { background: var(--naver-green); color: #fff; border-color: var(--naver-green); }

  /* 네비 — 평소 숨김, .open 시 2~3행 자동 줄바꿈 펼침 */
  nav {
    display: none !important;
    position: static !important;
    flex: 0 0 100% !important;
    width: 100% !important;
    order: 4;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    overflow: visible !important;
    padding: 8px 0 0 !important;
    margin: 4px 0 0 0;
    border: none !important;
    border-top: 1px dashed var(--border) !important;
    box-shadow: none !important;
    gap: 6px;
    row-gap: 6px;
    background: transparent;
    justify-content: flex-start;
    animation: navSlideDown 0.25s ease;
  }
  nav.open { display: flex !important; }
  @keyframes navSlideDown {
    from { opacity: 0; transform: translateY(-6px); }
    to { opacity: 1; transform: translateY(0); }
  }
  .auth-area { order: 3; margin-left: 0 !important; }
  nav a {
    flex: 0 0 auto;
    padding: 6px 12px !important;
    font-size: 0.82rem !important;
    border: 1px solid var(--border) !important;
    border-bottom: 1px solid var(--border) !important;
    border-radius: 16px !important;
    background: var(--bg-secondary);
    white-space: nowrap;
    font-weight: 600;
  }
  nav a.active {
    background: var(--naver-green-light) !important;
    color: var(--naver-green-dark) !important;
    border-color: var(--naver-green) !important;
    font-weight: 600;
  }

  /* 헤더가 2~3행이라 콘텐츠 padding-top 동적 확보 */
  .tab-page { padding-top: 140px; }

  /* Hero 영역 컴팩트 */
  .hero { padding: 36px 16px 28px !important; }
  .naver-logo-big { font-size: 2rem !important; gap: 6px; }
  .hero-tagline { font-size: 0.86rem; margin-bottom: 20px; }
  .hero-catchphrase { margin: 18px auto 12px; }
  .hc-main { font-size: 1.5rem !important; }
  .hc-sub { font-size: 0.9rem; }
  .hc-keywords { gap: 6px; }
  .hc-keywords span { padding: 4px 10px; font-size: 0.78rem; }
  .hero-stats { gap: 20px !important; margin-top: 16px; padding-top: 16px; flex-wrap: nowrap; }
  .stat-number { font-size: 1.3rem; }
  .stat-label { font-size: 0.74rem; }

  /* 섹션 패딩 축소 */
  .tab-section { padding: 28px 14px !important; }
  .section-header h2 { font-size: 1.3rem !important; }
  .section-header p { font-size: 0.85rem; }

  /* 프로그램 카드 그리드 1열로 */
  .programs-grid { grid-template-columns: 1fr !important; gap: 12px; }
  .program-card { padding: 20px 18px; }
  .program-card h3 { font-size: 1.05rem; }
  .program-card p { font-size: 0.86rem; }

  /* Featured 카드 모바일 최적화 */
  .program-card.is-featured {
    padding: 30px 18px 18px;
    margin-top: 18px;
    animation: none;  /* 모바일에서 펄스 끔 (배터리 절약) */
  }
  .is-featured .prog-header h3 { font-size: 1.15rem !important; }
  .featured-ribbon {
    font-size: 0.7rem; padding: 6px 14px;
    letter-spacing: 0.5px; top: -14px;
  }
  .featured-stars { font-size: 0.86rem; right: 12px; top: 10px; }
  .featured-tags { gap: 4px; }
  .featured-tags span { padding: 3px 9px; font-size: 0.72rem; }

  /* 상세 페이지 */
  .detail-card { padding: 22px 18px !important; }
  .detail-header { gap: 12px; padding-bottom: 14px; margin-bottom: 20px; }
  .detail-header h2 { font-size: 1.15rem !important; }
  .detail-meta-row { padding: 10px 12px; gap: 6px; font-size: 0.78rem; }
  .detail-meta { display: flex; flex-wrap: wrap; gap: 4px; width: 100%; }
  .detail-meta + .detail-meta::before { display: none; }
  .detail-section h3 { font-size: 0.95rem; }
  .detail-section p, .detail-section li { font-size: 0.88rem; }
  .feature-grid { grid-template-columns: 1fr !important; }

  /* 모달 풀스크린 */
  .modal-overlay { padding: 0 !important; }
  .modal-content {
    max-width: 100% !important; width: 100% !important;
    height: 100vh !important; max-height: 100vh !important;
    border-radius: 0 !important;
    padding: 56px 16px 24px !important;
  }
  .modal-close { top: 10px; right: 10px; width: 36px; height: 36px; }

  /* 게시판·뉴스·회원 테이블 가로 스크롤 */
  .board-table-wrap { -webkit-overflow-scrolling: touch; overflow-x: auto; }
  .board-table { min-width: 540px; font-size: 0.84rem; }
  .board-table th, .board-table td { padding: 10px 8px; }
  /* 모바일에서 제목은 1줄로 — 넘치면 말줄임표 */
  .board-table .td-title,
  .board-table .col-title {
    max-width: 240px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  /* td-title 안의 NEW 뱃지·이모지 등도 같은 줄 유지 */
  .board-table .td-title > *,
  .board-table .col-title > * {
    display: inline-block;
    vertical-align: middle;
  }

  /* 폼 입력 — iOS 자동 줌 방지 (16px 최소) */
  .form-group input, .form-group textarea,
  .board-search input, #boardSearchInput,
  #memberSearchInput, #newsSearchInput,
  .naver-search input {
    font-size: 16px !important;
  }

  /* 버튼 터치 영역 확보 (44x44 최소) */
  .btn { min-height: 40px; padding: 10px 20px; }
  .btn-mini { min-height: 32px; padding: 6px 10px; }
  .quick-shortcut { padding: 10px 14px; }

  /* 회원 등급·뱃지 */
  .grade-badge { padding: 3px 8px; font-size: 0.74rem; }

  /* 뉴스 모달 — 본문 가독성 */
  .news-modal-content { padding: 50px 16px 20px !important; }
  #newsModalTitle { font-size: 1.1rem !important; line-height: 1.4; }
  .news-modal-body { font-size: 0.92rem; }
  .news-modal-body p.lead { padding: 12px 14px; font-size: 0.96rem; }
  .news-modal-body ol.news-list li { padding: 10px 12px 10px 42px; }
  .news-modal-body ol.news-list li::before { width: 24px; height: 24px; font-size: 0.78rem; }

  /* CTA 섹션 */
  .cta-section { padding: 36px 20px !important; }
  .cta-section h2 { font-size: 1.4rem !important; }
  .cta-section p { font-size: 0.92rem; }

  /* 푸터 */
  footer { padding: 24px 16px; }
  .footer-links { gap: 12px; }
  .footer-links a { font-size: 0.82rem; }

  /* 홈 게시판 위젯 */
  .hb-item { padding: 14px 16px; }
  .hb-title { white-space: normal; line-height: 1.5; font-size: 0.94rem; }
  .hb-meta { font-size: 0.74rem; gap: 10px; }

  /* 마이페이지 */
  .mi-card { padding: 18px 16px; }
  .mi-profile { padding: 12px; gap: 12px; }
  .mi-avatar { width: 48px; height: 48px; font-size: 1.3rem; }
  .mi-name { font-size: 0.96rem; }
  .mi-stats { grid-template-columns: repeat(2, 1fr) !important; gap: 6px; }
  .mi-num { font-size: 1.15rem; }
  .mi-actions { flex-direction: column; }
  .mi-actions .btn { width: 100%; justify-content: center; }

  /* 사이드 메뉴(법령탭) */
  .kfma-side { position: static !important; padding: 14px; }
  .kfma-side h4 { font-size: 0.88rem; }
  .side-menu li { flex: 1 1 calc(50% - 4px); min-width: auto; }

  /* 블로그 참고 카드 */
  .blog-refs-grid { grid-template-columns: 1fr !important; }

  /* 뒤로가기 버튼 큼지막히 */
  .back-to-top { width: 48px; height: 48px; bottom: 18px; right: 18px; font-size: 1.1rem; }
}

/* === 작은 휴대폰 (400px 이하) — iPhone SE 등 === */
@media (max-width: 400px) {
  .nav-inner { padding: 0 10px; gap: 4px; }
  .logo { font-size: 0.95rem; }
  .logo-icon { width: 24px; height: 24px; }
  .user-name-text { max-width: 60px; }
  .hc-main { font-size: 1.3rem !important; }
  .naver-logo-big { font-size: 1.7rem !important; }
  .hero-stats { gap: 14px !important; }
  .stat-number { font-size: 1.15rem; }
  .featured-ribbon { font-size: 0.64rem; padding: 5px 11px; }
}

/* ========================================================
   NEIGHBOR (이웃) SYSTEM
   ======================================================== */
.btn-neighbor {
  display:inline-flex; align-items:center; gap:4px;
  padding:5px 12px; border-radius:14px;
  background:#fff; border:1px solid var(--naver-green);
  color:var(--naver-green-dark); font-size:0.78rem; font-weight:700;
  cursor:pointer; transition:all 0.15s; white-space:nowrap;
  font-family:inherit;
}
.btn-neighbor:hover {
  background:var(--naver-green-light);
}
.btn-neighbor.is-neighbor {
  background:var(--naver-green);
  color:#fff; border-color:var(--naver-green);
}
.btn-neighbor.is-neighbor:hover {
  background:var(--danger);
  border-color:var(--danger);
}
.btn-neighbor.is-neighbor:hover::after {
  content:' 끊기';
}

.bot-tag, .nb-tag {
  display:inline-block; margin-left:3px;
  font-size:0.85em; vertical-align:middle;
}
.nb-tag { color:var(--naver-green); }

/* 마이페이지 — 이웃 새글 위젯 */
.mi-neighbor-feed {
  margin-top:20px; padding-top:18px;
  border-top:2px dashed var(--border-strong);
}
.mnf-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:12px;
}
.mnf-header h4 {
  font-size:0.95rem; font-weight:800; color:var(--text-primary);
}
.mnf-count {
  background:var(--naver-green); color:#fff;
  padding:2px 10px; border-radius:10px;
  font-size:0.74rem; font-weight:700;
}
.mnf-empty {
  text-align:center; padding:24px 12px;
  color:var(--text-muted); font-size:0.86rem; line-height:1.7;
  background:var(--bg-secondary); border-radius:8px;
}
.mnf-item {
  display:flex; align-items:center; gap:10px;
  padding:10px 12px; border-bottom:1px solid var(--border);
  cursor:pointer; transition:background 0.15s;
}
.mnf-item:last-child { border-bottom:none; }
.mnf-item:hover { background:var(--naver-green-light); }
.mnf-avatar {
  width:32px; height:32px; min-width:32px;
  border-radius:50%; background:var(--naver-green);
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:0.9rem;
}
.mnf-body { flex:1; min-width:0; }
.mnf-title {
  font-size:0.9rem; font-weight:600; color:var(--text-primary);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.mnf-meta {
  display:flex; gap:8px; font-size:0.74rem;
  color:var(--text-muted); margin-top:2px;
}
.mnf-author { color:var(--naver-green-dark); font-weight:700; }

/* ========================================================
   NEWS SYSTEM (자동수집 카드 그리드)
   ======================================================== */
.news-control {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px; margin-bottom:14px;
  background:#fff; border:1px solid var(--border); border-radius:var(--radius);
  flex-wrap:wrap; gap:10px;
}
.news-status { display:flex; gap:18px; flex-wrap:wrap; font-size:0.86rem; color:var(--text-secondary); }
.ns-item b { color:var(--naver-green-dark); font-weight:800; margin:0 2px; }
.news-actions { display:flex; gap:6px; }

.news-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(300px, 1fr));
  gap:18px;
}
.news-card-naver {
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden;
  display:flex; flex-direction:column;
  transition:var(--transition);
}
.news-card-naver:hover {
  transform:translateY(-3px);
  box-shadow:var(--shadow-lg);
  border-color:var(--naver-green);
}
.news-thumb-naver {
  height:120px; position:relative;
  display:flex; align-items:center; justify-content:center;
}
.news-emoji { font-size:3rem; line-height:1; }
.news-auto-badge {
  position:absolute; top:8px; right:8px;
  padding:2px 8px; background:rgba(0,0,0,0.65); color:#fff;
  border-radius:12px; font-size:0.7rem; font-weight:700;
  backdrop-filter:blur(4px);
}
.news-card-body {
  padding:16px 18px 14px;
  display:flex; flex-direction:column; flex:1;
  gap:8px;
}
.news-card-meta { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.news-source-chip {
  display:inline-block; padding:3px 10px;
  color:#fff; border-radius:4px;
  font-size:0.74rem; font-weight:500;
  letter-spacing:0.3px;
}
.topic-chip {
  display:inline-block; padding:3px 10px;
  color:#fff; border-radius:14px;
  font-size:0.74rem; font-weight:500;
  letter-spacing:0.3px;
}
.news-card-title {
  font-size:1.02rem; font-weight:500; line-height:1.35;
  color:var(--text-primary);
  display:-webkit-box; -webkit-line-clamp:2; line-clamp:2;
  -webkit-box-orient:vertical; overflow:hidden;
}
.news-card-summary {
  font-size:0.82rem !important;
  color:#7c7c7c !important;
  line-height:1.55 !important;
  flex:1; font-weight:400 !important;
  display:-webkit-box; -webkit-line-clamp:3; line-clamp:3;
  -webkit-box-orient:vertical; overflow:hidden;
  letter-spacing:0;
}
/* 본문 안의 모든 인라인 태그(b/strong/span/em/mark)도 굵기·색·배경 강제 일반화 */
.news-card-summary b,
.news-card-summary strong,
.news-card-summary span,
.news-card-summary em,
.news-card-summary mark {
  font-weight:400 !important;
  color:inherit !important;
  background:transparent !important;
  font-style:normal !important;
}
.news-card-footer {
  display:flex; align-items:center; justify-content:space-between;
  margin-top:6px; padding-top:10px;
  border-top:1px dashed var(--border);
  gap:8px; flex-wrap:wrap;
}
.news-card-date {
  font-size:0.78rem; color:var(--text-muted);
}
.news-card-link {
  color:var(--naver-green-dark);
  font-size:0.82rem; font-weight:700;
  text-decoration:none;
  transition:color 0.15s;
}
.news-card-link:hover { color:var(--naver-green); text-decoration:underline; }

@media (max-width:600px) {
  .news-grid { grid-template-columns:1fr; }
  .news-control { flex-direction:column; align-items:stretch; }
  .news-actions { justify-content:flex-end; }
}

/* === 뉴스 상세 모달 — 가독성 향상 prose 스타일 === */
.news-modal-content {
  max-width:780px !important;
  padding:36px 40px !important;
}
.news-modal-meta {
  display:flex; gap:6px; align-items:center; flex-wrap:wrap;
  margin-bottom:14px;
}
.news-modal-tag {
  display:inline-block; padding:3px 10px;
  background:var(--bg-secondary); color:var(--text-secondary);
  border:1px solid var(--border);
  border-radius:14px; font-size:0.74rem; font-weight:700;
}
#newsModalTitle {
  font-size:1.5rem !important;
  line-height:1.4;
  margin-bottom:18px !important;
  color:var(--text-primary);
  letter-spacing:-0.5px;
}
.news-modal-info {
  display:flex; gap:14px; flex-wrap:wrap;
  padding:12px 16px;
  margin-bottom:24px;
  background:var(--bg-secondary);
  border:1px solid var(--border);
  border-radius:8px;
  font-size:0.84rem;
  color:var(--text-secondary);
}
.news-modal-info span b {
  background:#fff; border:1px solid var(--border);
  padding:2px 8px; border-radius:4px; margin-right:6px;
  font-size:0.74rem; font-weight:700;
  color:var(--text-primary);
}

/* 본문 prose */
.news-modal-body {
  font-size:1.02rem;
  line-height:1.85;
  color:var(--text-primary);
}
.news-modal-body p {
  margin-bottom:16px;
  text-align:justify;
}
.news-modal-body p.lead {
  font-size:1.08rem; font-weight:600;
  color:var(--text-primary);
  padding:14px 18px;
  background:var(--bg-secondary);
  border-left:4px solid var(--text-primary);
  border-radius:0 8px 8px 0;
  margin-bottom:22px;
}
.news-modal-body p.empty {
  color:var(--text-muted); font-style:italic; text-align:center;
  padding:30px;
}

/* 번호 리스트 — 큰 원형 번호 */
.news-modal-body ol.news-list {
  list-style:none;
  counter-reset:newslist;
  padding-left:0;
  margin-bottom:18px;
}
.news-modal-body ol.news-list li {
  counter-increment:newslist;
  position:relative;
  padding:12px 14px 12px 50px;
  margin-bottom:8px;
  background:var(--bg-secondary);
  border:1px solid var(--border);
  border-radius:8px;
  line-height:1.7;
}
.news-modal-body ol.news-list li::before {
  content:counter(newslist);
  position:absolute; left:12px; top:12px;
  width:28px; height:28px;
  background:var(--text-primary); color:#fff;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:0.84rem; font-weight:800;
}

/* 불릿 리스트 */
.news-modal-body ul.news-list {
  list-style:none;
  padding-left:0;
  margin-bottom:18px;
}
.news-modal-body ul.news-list li {
  position:relative;
  padding:10px 14px 10px 28px;
  margin-bottom:6px;
  background:#fff;
  border-left:3px solid var(--text-primary);
  border-bottom:1px solid var(--border);
  line-height:1.7;
}
.news-modal-body ul.news-list li::before {
  content:'▸';
  position:absolute; left:10px; top:10px;
  color:var(--text-primary); font-weight:900;
}

/* 정의 리스트 (원인:/결과: 패턴) */
.news-modal-body dl.news-dl {
  display:grid;
  grid-template-columns:auto 1fr;
  gap:6px 16px;
  background:var(--bg-secondary);
  border:1px solid var(--border);
  border-radius:8px;
  padding:16px 18px;
  margin-bottom:18px;
}
.news-modal-body dl.news-dl dt {
  font-weight:800;
  color:#fff;
  background:var(--text-primary);
  padding:3px 12px;
  border-radius:4px;
  white-space:nowrap;
  height:fit-content;
  font-size:0.85rem;
}
.news-modal-body dl.news-dl dd {
  margin:0;
  line-height:1.7;
}
.news-modal-body dl.news-dl dd.dd-only {
  grid-column:1 / -1;
}

/* 핵심 키워드 강조 */
.kw-num   { background:#fff3cd; color:#856404; padding:1px 6px; border-radius:3px; font-weight:800; }
.kw-year  { background:#e8f1ff; color:#1c5cd6; padding:1px 6px; border-radius:3px; font-weight:800; }
.kw-money { background:#e8f8ee; color:#1d7a3a; padding:1px 6px; border-radius:3px; font-weight:800; }
.kw-law   { background:#f0e6ff; color:#6020a8; padding:1px 6px; border-radius:3px; font-weight:800; font-family:'Consolas','Menlo',monospace; }

.news-modal-actions {
  display:flex; gap:8px; justify-content:flex-end;
  margin-top:24px; padding-top:18px;
  border-top:1px solid var(--border);
  flex-wrap:wrap;
}

@media (max-width:600px) {
  .news-modal-content { padding:24px 18px !important; }
  #newsModalTitle { font-size:1.2rem !important; }
  .news-modal-body { font-size:0.95rem; }
  .news-modal-body dl.news-dl { grid-template-columns:1fr; }
  .news-modal-body dl.news-dl dt { width:fit-content; }
}

/* === 상세 페이지 상태 뱃지 옆 삭제 버튼 === */
.status-del-btn {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  margin-left: 8px;
  padding: 3px 10px;
  background: #fff;
  border: 1px solid #f0a0a0;
  border-radius: 12px;
  color: #c93030;
  font-size: 0.74rem;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  vertical-align: middle;
  transition: all 0.15s;
}
.status-del-btn:hover {
  background: #ffe0e0;
  transform: scale(1.05);
}

/* === 상세 페이지 상단 액션 버튼 === */
.detail-top-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--border);
}
.top-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  background: #f7f9fc;
  border: 1px solid var(--border);
  border-radius: 14px;
  color: #444;
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: all 0.15s;
  white-space: nowrap;
}
.top-action-btn:hover {
  background: #eef4ff;
  border-color: var(--naver-blue);
  color: var(--naver-blue);
  transform: translateY(-1px);
}
.top-action-btn.top-action-done {
  background: #e8f8ee;
  border-color: #03c75a;
  color: #018a3e;
}
.top-action-btn.top-action-done:hover {
  background: #03c75a;
  color: #fff;
}
.top-action-btn.top-action-warn {
  background: #fff7e6;
  border-color: #f5a623;
  color: #b8740c;
}
.top-action-btn.top-action-warn:hover {
  background: #f5a623;
  color: #fff;
}
.top-action-btn.top-action-danger {
  background: #fff;
  border-color: #f0a0a0;
  color: #c93030;
}
.top-action-btn.top-action-danger:hover {
  background: #ffe0e0;
}

/* === 프로그램 카드 ✕ 삭제 버튼 === */
.card-del-btn {
  position: absolute;
  top: 8px; right: 8px;
  width: 26px; height: 26px;
  background: rgba(255,255,255,0.8);
  border: 1px solid var(--border);
  border-radius: 50%;
  color: var(--text-muted);
  font-size: 0.85rem;
  font-weight: 700;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.15s;
  opacity: 0;
  z-index: 5;
}
.program-card { position: relative; }
/* 클릭 랭킹 번호 뱃지 — 통계 모달의 prog-rank-no 와 동일한 룰로 1·2·3위 색상 */
.card-rank-no {
  position: absolute;
  top: 8px; left: 8px;
  background: var(--naver-blue); color: #fff;
  width: 26px; height: 26px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 0.88rem;
  z-index: 6;
  box-shadow: 0 2px 4px rgba(0,0,0,0.12);
  pointer-events: none;
}
/* 메달 색은 클릭 랭킹 번호 기준 — 카드 위치(DOM)와 무관 */
.card-rank-no.rank-gold { background: #ffd60a; color: #000; }
.card-rank-no.rank-silver { background: #c0c8d2; color: #000; }
.card-rank-no.rank-bronze { background: #cd7f32; }

/* ===== 관리자 메뉴 아이콘 그리드 모달 ===== */
.admin-menu-modal h2 { display: flex; align-items: center; gap: 6px; }
.admin-menu-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.admin-menu-btn {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 8px;
  padding: 18px 12px;
  background: var(--bg-secondary);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.18s;
  font-family: inherit;
  min-height: 110px;
}
.admin-menu-btn:hover {
  background: #e8f5ff;
  border-color: var(--naver-blue);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(28,92,214,0.18);
}
.admin-menu-btn .amb-icon {
  font-size: 2.1rem; line-height: 1;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.08));
}
.admin-menu-btn .amb-label {
  font-size: 0.82rem; font-weight: 700; color: var(--text-primary);
  text-align: center; line-height: 1.35;
}
.admin-menu-btn-danger { grid-column: 1 / -1; }
.admin-menu-btn-danger:hover {
  background: #ffe8e8;
  border-color: #dc2626;
  box-shadow: 0 6px 16px rgba(220,38,38,0.2);
}
.admin-menu-btn-danger:hover .amb-label { color: #dc2626; }

/* ===== 프로그램별 댓글 (공개/비공개) ===== */
.program-comments-section { margin-top: 18px; padding-top: 16px; border-top: 2px solid var(--border); }
.program-comments-section h3 { display: flex; align-items: center; gap: 8px; font-size: 1.05rem; margin-bottom: 12px; color: var(--text-primary); }
.prog-comment-count { background: var(--naver-blue); color: #fff; font-size: 0.75rem; padding: 2px 8px; border-radius: 10px; font-weight: 700; }
.prog-comments-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; }
.prog-comment-empty { color: var(--text-secondary); font-size: 0.88rem; text-align: center; padding: 16px; background: var(--bg-secondary); border-radius: 8px; }
.prog-comment-item { background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 8px; padding: 10px 12px; }
.prog-comment-header { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 6px; }
.prog-comment-author { font-weight: 700; color: var(--text-primary); font-size: 0.88rem; }
.prog-comment-private-badge { background: #fff4d4; color: #8a6500; border: 1px solid #e6c878; border-radius: 4px; padding: 1px 6px; font-size: 0.7rem; font-weight: 600; }
.prog-comment-public-badge { background: #e6f8ee; color: #167c44; border: 1px solid #a8dcb8; border-radius: 4px; padding: 1px 6px; font-size: 0.7rem; font-weight: 600; }
.prog-comment-date { color: var(--text-muted); font-size: 0.75rem; margin-left: auto; }
.prog-comment-del { background: none; border: none; cursor: pointer; color: var(--text-muted); font-size: 0.9rem; padding: 2px 4px; border-radius: 3px; transition: all 0.15s; }
.prog-comment-del:hover { background: #ffe0e0; color: #c93030; }
.prog-comment-text { font-size: 0.92rem; color: var(--text-primary); line-height: 1.5; white-space: pre-wrap; word-break: break-word; font-weight: 400; }
.prog-comment-own-badge { background: #fff4d4; color: #8a6500; border: 1px solid #e6c878; border-radius: 4px; padding: 1px 6px; font-size: 0.7rem; font-weight: 600; }
.prog-comment-edit { background: none; border: none; cursor: pointer; color: var(--naver-blue); font-size: 0.88rem; padding: 2px 4px; border-radius: 3px; transition: all 0.15s; margin-left: 2px; }
.prog-comment-edit:hover { background: #e8f5ff; }
.prog-comment-actions { display: flex; align-items: center; gap: 10px; margin-top: 6px; }
.prog-reply-btn { background: none; border: 1px solid var(--border); cursor: pointer; color: var(--text-secondary); font-size: 0.78rem; padding: 3px 10px; border-radius: 12px; transition: all 0.15s; font-weight: 500; }
.prog-reply-btn:hover { background: var(--bg-secondary); color: var(--naver-blue); border-color: var(--naver-blue); }
.prog-reply-count { font-size: 0.75rem; color: var(--text-muted); }
.prog-reply-form { display: flex; gap: 6px; margin-top: 8px; padding: 8px; background: #fff; border: 1px dashed var(--border); border-radius: 6px; align-items: stretch; }
.prog-reply-form > input,
.prog-reply-form > .prog-cmt-toggle,
.prog-reply-form > button { box-sizing: border-box; }
.prog-reply-form .prog-cmt-author { flex: 0 0 100px; }
.prog-reply-form .prog-cmt-input { flex: 1 1 auto; min-width: 0; }
.prog-reply-form .prog-cmt-toggle { padding: 6px 8px; border: 1px solid var(--border); border-radius: 6px; background: #fff; display: inline-flex; align-items: center; gap: 4px; cursor: pointer; }
.prog-reply-form .prog-cmt-pwd { flex: 0 0 80px; padding: 6px 8px; border: 1px solid var(--border); border-radius: 6px; }
.prog-replies { margin-top: 8px; padding-left: 18px; border-left: 2px solid #e8f0fc; display: flex; flex-direction: column; gap: 6px; }
.prog-comment-reply { background: #f7fafd; }
.prog-comment-reply .prog-comment-author { color: var(--naver-blue); }
.prog-comment-locked { cursor: pointer; color: var(--text-muted); font-style: italic; padding: 6px 10px; background: #f5f0d8; border: 1px dashed #d4c47a; border-radius: 6px; text-align: center; transition: all 0.15s; }
.prog-comment-locked:hover { background: #e8df97; color: #6a4f00; }
.prog-comment-write { background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 8px; padding: 8px 10px; }
/* 한 줄 컴팩트 행 — 닉네임 · 본문(flex) · 🔒 · 비번 · 등록 */
.prog-cmt-row { display: flex; align-items: stretch; gap: 6px; }
.prog-cmt-row > input,
.prog-cmt-row > .prog-cmt-toggle { box-sizing: border-box; padding: 7px 9px; border: 1px solid var(--border); border-radius: 6px; font-size: 0.85rem; font-family: inherit; background: #fff; }
.prog-cmt-row .prog-cmt-author { flex: 0 0 110px; min-width: 0; }
.prog-cmt-row .prog-cmt-input { flex: 1 1 auto; min-width: 0; }
.prog-cmt-row .prog-cmt-toggle { display: inline-flex; align-items: center; gap: 4px; font-size: 0.9rem; color: var(--text-secondary); cursor: pointer; user-select: none; padding: 7px 8px; }
.prog-cmt-row .prog-cmt-toggle input[type="checkbox"] { margin: 0; }
.prog-cmt-row .prog-cmt-pwd { flex: 0 0 90px; min-width: 0; }
.prog-cmt-row .prog-cmt-submit { flex: 0 0 auto; white-space: nowrap; }
.prog-cmt-note { font-size: 0.72rem; color: var(--text-muted); margin: 6px 2px 0; }
@media (max-width: 600px) {
  .prog-cmt-row { flex-wrap: wrap; gap: 4px; }
  .prog-cmt-row .prog-cmt-author { flex: 1 1 100%; }
  .prog-cmt-row .prog-cmt-input { flex: 1 1 100%; }
  .prog-cmt-row .prog-cmt-toggle,
  .prog-cmt-row .prog-cmt-pwd,
  .prog-cmt-row .prog-cmt-submit { flex: 0 1 auto; }
  .prog-comment-header { gap: 6px; }
  .prog-comment-date { margin-left: 0; width: 100%; }
}

.program-card:hover .card-del-btn { opacity: 1; }
.card-del-btn:hover {
  background: #ffe0e0;
  border-color: #f0a0a0;
  color: #c93030;
  transform: scale(1.1);
}
/* 모바일에서는 항상 보이게 (호버 없음) */
@media (hover: none) {
  .card-del-btn { opacity: 1; }
}
/* Featured 카드 — 별 영역과 겹치지 않게 위치 조정 */
.program-card.is-featured .card-del-btn {
  top: 8px; right: 8px;
  z-index: 10;
}
.program-card.is-featured .featured-stars { right: 44px; }  /* 별을 왼쪽으로 */

/* === 빠른 프로그램 등록 바 === */
.prog-add-bar {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.quick-add-input {
  flex: 1 1 auto;
  min-width: 200px;
  max-width: 380px;
  padding: 8px 14px;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  font-size: 0.92rem;
  font-family: inherit;
  background: #fff;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.quick-add-input:focus {
  outline: none;
  border-color: var(--naver-green);
  box-shadow: 0 0 0 3px rgba(3,199,90,0.15);
}
.quick-add-btn { white-space: nowrap; }
.quick-add-url {
  flex: 1 1 240px;
  min-width: 180px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 13px;
}
.quick-add-file-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  background: #f7f9fc;
  border: 1px dashed var(--border);
  border-radius: 10px;
  cursor: pointer;
  font-size: 13px;
  color: #555;
  white-space: nowrap;
  transition: background 0.15s, border-color 0.15s;
}
.quick-add-file-label:hover {
  background: #eef4ff;
  border-color: var(--naver-blue);
  color: var(--naver-blue);
}
@media (max-width: 600px) {
  .prog-add-bar { justify-content: stretch; }
  .quick-add-input { max-width: 100%; min-width: 0; flex: 1 1 100%; }
  .quick-add-file-label { flex: 1 1 100%; justify-content: center; }
}

/* ========================================================
   🔓 회원 시스템 완전 제거 — 조회 전용 공개 모드
   ======================================================== */
#authUserInfo,
nav a[data-tab="members-info"],
nav a[data-tab="dashboard"],
.admin-only,
.locked-link,
.tier-pill {
  display: none !important;
}
/* 관리자 모드(body.is-admin) — admin-only 요소 재노출 */
body.is-admin .admin-only { display: revert !important; }
body.is-admin .news-actions.admin-only { display: flex !important; }
body.is-admin .write-form.admin-only:not([hidden]) { display: block !important; }
body.is-admin button.admin-only,
body.is-admin a.admin-only,
body.is-admin span.admin-only { display: inline-flex !important; }
/* auth-area는 보이게 유지 — 관리자 버튼 노출 위해 (회원정보·등급뱃지는 위에서 개별 숨김) */
.auth-area { display: flex !important; align-items: center; gap: 8px; }
#authLoginBtn { display: inline-flex !important; }
/* 상세 페이지 관리 영역은 표시 (비번 보호 적용) */
.detail-admin-zone { display: block !important; }
#loginModal, #signupModal, #programAddModal { display: none !important; }
/* 단, 관리자가 [+ 새 프로그램 추가] 클릭 시는 표시되도록 inline display:flex가 우선 */
#programAddModal[style*="display:flex"], #programAddModal[style*="display: flex"] { display: flex !important; }
/* 개발중 탭 자체 제거 — AI 프로그램에 통합 */
#tab-records { display: none !important; }
nav a[data-tab="records"] { display: none !important; }
/* 게시판 글쓰기 버튼은 일반인도 사용 가능하게 노출 */
.board-toolbar > .btn-primary { display: inline-flex !important; }

/* ===== 접속 통계 모달 차트 — 컴팩트 모드 ===== */
.stats-summary {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
  gap: 6px; margin-bottom: 8px;
}
.stats-summary .ss-card {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 6px; padding: 5px 8px; text-align: center;
}
.stats-summary .ss-num {
  width: auto !important; height: auto !important; min-width: 0 !important;
  background: transparent !important; color: var(--naver-green) !important;
  border-radius: 0 !important; display: block !important;
  font-size: 1.1rem !important; font-weight: 800 !important;
  line-height: 1.1 !important;
}
.stats-summary .ss-lab { font-size: 0.66rem; color: var(--text-secondary); margin-top: 1px; }
/* 일별·월별 차트 2열 배치 — 한 줄 컴팩트 */
.stats-charts-row {
  display: grid; grid-template-columns: 1.7fr 1fr; gap: 8px;
  align-items: start;
}
.stats-h3 { font-size: 0.74rem; margin: 4px 0 3px; font-weight: 700; color: var(--text-secondary); }
.stats-chart {
  display: flex; align-items: flex-end; gap: 2px;
  height: 50px; padding: 4px 4px 2px;
  background: linear-gradient(to top, #f7f9fc 0%, #fff 100%);
  border: 1px solid var(--border); border-radius: 6px;
  overflow: visible;  /* 라벨이 차트 바깥(아래)으로 살짝 빠져나가도록 */
}
.stats-chart .bar {
  flex: 1 1 0; min-width: 3px;
  background: linear-gradient(to top, #1c5cd6, #4a8cff);
  border-radius: 2px 2px 0 0;
  position: relative;
  transition: opacity 0.15s;
  cursor: pointer;
}
.stats-chart .bar:hover { opacity: 0.75; }
.stats-chart .bar.zero { background: #e8eaf0; }
/* X축 라벨 — 차트 아래에 작게 노출 (월별·일별 5n 둘 다) */
.stats-chart .bar .bar-lab {
  position: absolute; bottom: -11px; left: 50%; transform: translateX(-50%);
  font-size: 0.48rem; color: var(--text-secondary);
  white-space: nowrap;
  pointer-events: none;
}
/* 일별 30칸은 겹치므로 5칸+마지막만 노출 (예: 5/2, 5/7, ..., 5/27) */
#dailyChart .bar .bar-lab { display: none; }
#dailyChart .bar:nth-child(5n) .bar-lab,
#dailyChart .bar:last-child .bar-lab {
  display: block; font-weight: 600;
}
/* 월별 12칸은 다 노출 (예: 25.06 ... 26.05) */
.stats-chart .bar .bar-val {
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  font-size: 0.6rem; color: var(--naver-blue); font-weight: 700;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
}
.stats-chart .bar:hover .bar-val { opacity: 1; }
/* 라벨 공간 확보 — 차트 아래 14px 여유 */
.stats-section { margin-top: 4px; padding-bottom: 16px; }
@media (max-width: 720px) {
  .stats-charts-row { grid-template-columns: 1fr; }
}

/* 프로그램 다운로드 랭킹 — 2열 컴팩트 (한눈에 보기) */
.prog-rank-list {
  display: grid; grid-template-columns: 1fr 1fr; gap: 4px 8px;
}
.prog-rank-row {
  display: grid; grid-template-columns: 18px 1fr 60px 42px;
  align-items: center; gap: 6px;
  padding: 3px 6px;
  background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 4px;
  min-width: 0;
}
.prog-rank-no {
  background: var(--naver-blue); color: #fff;
  border-radius: 50%; width: 18px; height: 18px;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 0.66rem;
}
.prog-rank-row:nth-child(1) .prog-rank-no { background: #ffd60a; color: #000; }
.prog-rank-row:nth-child(2) .prog-rank-no { background: #c0c8d2; color: #000; }
.prog-rank-row:nth-child(3) .prog-rank-no { background: #cd7f32; }
.prog-rank-name { font-weight: 600; color: var(--text-primary); font-size: 0.72rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
.prog-rank-barbg { background: #eef2f8; border-radius: 3px; height: 5px; overflow: hidden; }
.prog-rank-bar { background: linear-gradient(90deg, #1c5cd6, #4a8cff); height: 100%; transition: width 0.3s; }
.prog-rank-count { text-align: right; font-weight: 700; color: var(--naver-blue); font-size: 0.7rem; }
@media (max-width: 720px) {
  .prog-rank-list { grid-template-columns: 1fr; }
  .prog-rank-row { grid-template-columns: 18px 1fr 50px 36px; }
}
/* 자동글·일괄 자동글 등 관리자 전용 outline 버튼은 .admin-only 클래스로 별도 제어 */
/* 비활성 잠긴 버튼 → 활성처럼 보이게 (스타일만) */
.detail-link-btn[disabled] {
  background: var(--naver-green) !important;
  color: #fff !important;
  border-color: var(--naver-green) !important;
  cursor: pointer !important;
  opacity: 1 !important;
}

/* === 페이지 전체 색깔 아이콘 / 강조색 일괄 무채색화 === */

/* 1) 그린·블루·앰버 3색 팔레트 복구 (빨강 제외) */
:root {
  --naver-green: #03c75a;
  --naver-green-dark: #02a64a;
  --naver-green-light: #e6f8ee;
  --accent: #03c75a;
  --accent-hover: #02a64a;
  --accent-glow: rgba(3,199,90,0.18);
  --c-blue: #1c5cd6;
  --c-blue-dark: #1448a8;
  --c-blue-light: #e8f1ff;
  --c-amber: #f5a623;
  --c-amber-dark: #b87a00;
  --c-amber-light: #fff4d4;
}

/* 2) 모든 컬러 뱃지/칩/액션 버튼을 회색으로 강제 */
.badge,
.badge-admin,
.badge-user,
.badge-online,
.badge-offline,
.badge-banned,
.grade-badge,
.grade-badge.gold,
.grade-badge.silver,
.grade-badge.bronze,
.log-action,
.log-login, .log-logout, .log-signup, .log-post, .log-warn, .log-admin, .log-default,
.btn-mini,
.btn-mini-warn,
.btn-mini-danger,
.btn-neighbor,
.btn-neighbor.is-neighbor,
.cat-chip, .cat-check, .cat-design, .cat-build, .cat-super, .cat-guide,
.cat-report, .cat-contract, .cat-ledger, .cat-etc,
.file-badge, .file-pdf, .file-hwp, .file-xlsx, .file-docx, .file-zip,
.brc-tag {
  background: var(--bg-secondary) !important;
  color: var(--text-secondary) !important;
  border: 1px solid var(--border) !important;
}

/* 3) 그린 → 무채색 (호버 효과 제거) */
.btn-primary {
  background: #333333 !important;
  color: #fff !important;
}
.btn-primary:hover {
  background: #555555 !important;
  box-shadow: none !important;
}

/* 4) 차트 막대 색 회색으로 */
.bar-fill {
  background: linear-gradient(180deg, #888, #555) !important;
}

/* 5) 라이브 펄스 애니메이션 색 회색 */
.online-dot {
  background: #888 !important;
  box-shadow: 0 0 0 3px rgba(0,0,0,0.05) !important;
  animation: none !important;
}

/* 6) 법령 카드 좌측 컬러 보더 → 회색 */
.law-card { border-left-color: #888 !important; }
.law-link:hover {
  background: #333 !important;
  border-color: #333 !important;
}

/* 7) 뉴스 카드 썸네일 보더(아직 인라인 적용된 경우) 색 제거 */
.news-thumb-naver { border-bottom-color: var(--border) !important; }
.news-card-naver { border-color: var(--border) !important; }

/* 8) 그라데이션 텍스트·배경 무력화 */
.gradient-text { color: var(--text-primary) !important; background: none !important; }
.cta-section { background: var(--bg-secondary) !important; border-color: var(--border) !important; }
.featured-content .gradient-text { color: var(--text-primary) !important; }

/* 9) 잔존 이모지 아이콘에 grayscale 필터 (텍스트 라벨에 박힌 이모지 포함) */
button, .btn, a.btn, .quick-shortcut, .kfma-tab,
.cat-chip, .file-badge, .badge, .grade-badge, .topic-chip,
.log-action, .news-source-chip, .news-card-link,
.brc-tag, .brc-link, .ns-item, .mnf-item {
  filter: grayscale(100%);
}

/* 10) hero 큰 로고의 그린 강조 — 복구 (네이버 시그니처 컬러 유지) */
.naver-logo-big .green { color: #03c75a !important; }

/* ========================================================
   🎨 3색 강조 복구 — 그린(성공)·블루(정보)·앰버(강조)
   (앞 무채색 규칙을 부분적으로 오버라이드)
   ======================================================== */

/* 완료 뱃지 → 그린 */
.prog-status.prog-done {
  background: var(--naver-green) !important;
  color: #fff !important;
  border-color: var(--naver-green) !important;
}

/* 섹션 태그 → 블루 (PROGRAMS / RECORDS / NEWS 등) */
.section-header .tag,
.detail-section h3 {
  color: var(--c-blue) !important;
}

/* 헤더 네비 active 인디케이터 → 그린 (밑줄 없음) */
nav a.active { color: var(--naver-green) !important; }
nav a:hover { color: var(--naver-green-dark) !important; }

/* 로고 아이콘 (헤더) → 그린 */
.logo-icon { background: var(--naver-green) !important; box-shadow: 0 2px 6px rgba(3,199,90,0.25) !important; }
.logo span { color: var(--naver-green) !important; }

/* btn-primary → 그린 */
.btn-primary {
  background: var(--naver-green) !important;
  color: #fff !important;
}
.btn-primary:hover {
  background: var(--naver-green-dark) !important;
  box-shadow: 0 4px 12px rgba(3,199,90,0.3) !important;
}

/* btn-outline 호버 → 그린 보더 */
.btn-outline:hover {
  border-color: var(--naver-green) !important;
  color: var(--naver-green-dark) !important;
}

/* 카드 hover → 그린 보더 */
.program-card:hover,
.blog-card:hover,
.law-card:hover,
.strength-card:hover,
.news-card-naver:hover,
.blog-ref-card:hover {
  border-color: var(--naver-green) !important;
}

/* 카드 상단 그라데이션 라인 (그린) */
.program-card::before {
  background: var(--naver-green) !important;
}

/* 카드 분류 태그 → 블루 라이트 */
.card-tag {
  background: var(--c-blue-light) !important;
  color: var(--c-blue-dark) !important;
  border: 1px solid #d6e4fb !important;
}

/* 히어로 통계 — 3가지 색 분리 */
.hero-stats > div:nth-child(1) .stat-number { color: var(--naver-green) !important; }
.hero-stats > div:nth-child(2) .stat-number { color: var(--c-blue) !important; }
.hero-stats > div:nth-child(3) .stat-number { color: var(--c-amber-dark) !important; }

/* 큰 섹션 제목 — 첫 글자 그린 강조 (장식적) */
.section-header h2 { color: var(--text-primary) !important; }
.section-header h2::first-letter { color: var(--naver-green) !important; }

/* 퀵 숏컷 hover → 그린 */
.quick-shortcut:hover {
  background: var(--naver-green-light) !important;
  border-color: var(--naver-green) !important;
  color: var(--naver-green-dark) !important;
}

/* KFMA 사이드 메뉴 active → 그린 */
.side-menu a.active {
  background: var(--naver-green) !important;
  color: #fff !important;
}
.side-menu a:hover {
  background: var(--naver-green-light) !important;
  color: var(--naver-green-dark) !important;
}
.side-tip {
  background: var(--naver-green-light) !important;
  border-color: var(--naver-green) !important;
  color: var(--naver-green-dark) !important;
}

/* 폼 포커스 → 그린 */
.form-group input:focus,
.form-group textarea:focus,
.board-search input:focus,
.naver-search:focus-within {
  border-color: var(--naver-green) !important;
  box-shadow: 0 0 0 3px rgba(3,199,90,0.18) !important;
}

/* 차트 막대 → 그린 그라데이션 */
.bar-fill {
  background: linear-gradient(180deg, var(--naver-green), var(--naver-green-dark)) !important;
}

/* 온라인 펄스 점 → 그린 + 애니메이션 복구 */
.online-dot {
  background: var(--naver-green) !important;
  box-shadow: 0 0 0 3px rgba(3,199,90,0.2) !important;
  animation: pulse 2s infinite !important;
}

/* 회원 등급 뱃지 → 3색 (관리자=그린, 정회원=블루, 일반=앰버) */
.grade-badge.gold,
.badge-admin {
  background: var(--c-amber-light) !important;
  color: var(--c-amber-dark) !important;
  border-color: #f0d97a !important;
}
.grade-badge.silver {
  background: var(--c-blue-light) !important;
  color: var(--c-blue-dark) !important;
  border-color: #c5d8f5 !important;
}
.grade-badge.bronze {
  background: var(--naver-green-light) !important;
  color: var(--naver-green-dark) !important;
  border-color: #b8e5c8 !important;
}
.badge-online {
  background: var(--naver-green-light) !important;
  color: var(--naver-green-dark) !important;
  border-color: var(--naver-green) !important;
}
.badge-banned {
  background: var(--c-amber-light) !important;
  color: var(--c-amber-dark) !important;
  border-color: #f0d97a !important;
}

/* 이웃 버튼 → 그린 */
.btn-neighbor {
  background: #fff !important;
  color: var(--naver-green-dark) !important;
  border-color: var(--naver-green) !important;
}
.btn-neighbor:hover { background: var(--naver-green-light) !important; }
.btn-neighbor.is-neighbor {
  background: var(--naver-green) !important;
  color: #fff !important;
}

/* 로그 액션 → 3색 분배 */
.log-login { background: var(--naver-green-light) !important; color: var(--naver-green-dark) !important; border-color: #b8e5c8 !important; }
.log-signup { background: var(--c-blue-light) !important; color: var(--c-blue-dark) !important; border-color: #c5d8f5 !important; }
.log-post { background: var(--c-amber-light) !important; color: var(--c-amber-dark) !important; border-color: #f0d97a !important; }
.log-admin { background: #f0e6ff !important; color: #6020a8 !important; border-color: #d0b8f0 !important; }

/* btn-mini 호버 → 그린 */
.btn-mini:hover {
  background: var(--naver-green-light) !important;
  border-color: var(--naver-green) !important;
  color: var(--naver-green-dark) !important;
}

/* 뉴스 출처/토픽 칩 — 토픽별 색상 (빨강 대신 앰버) */
.topic-chip {
  background: var(--text-secondary) !important;
  color: #fff !important;
  border: none !important;
}
.news-source-chip {
  background: var(--c-blue) !important;
  color: #fff !important;
  border: none !important;
}
/* 뉴스 자세히 보기 / 원문 링크 → 블루 */
.news-card-link {
  color: var(--c-blue-dark) !important;
}
.news-card-link:hover { color: var(--c-blue) !important; text-decoration: underline !important; }

/* NEW 뱃지 → 앰버 (빨강 대체) */
.badge-new,
.news-card-naver .badge-new {
  background: var(--c-amber) !important;
  color: #fff !important;
  border: none !important;
}

/* CTA 섹션 → 그린 라이트 배경 복구 */
.cta-section {
  background: linear-gradient(135deg, var(--naver-green-light), #fff) !important;
  border: 1px solid var(--naver-green) !important;
}

/* 법령 카드 좌측 보더 → inline style 그대로 사용 (no override) */
.law-card { border-left-width: 4px !important; }
.law-link:hover {
  background: var(--c-blue) !important;
  border-color: var(--c-blue) !important;
  color: #fff !important;
}

/* "최근 자동수집 날짜" 강조 → 그린 */
.ns-item b { color: var(--naver-green-dark) !important; }

/* 마이페이지 통계 숫자 → 그린 */
.mi-num { color: var(--naver-green) !important; }
.mi-avatar, .mnf-avatar { background: var(--naver-green) !important; }
.mi-profile { background: var(--naver-green-light) !important; }

/* 댓글 작성자 → 블루 */
.comment-item .comment-author { color: var(--c-blue-dark) !important; }

/* 회원 표 — 나(자신) 표시 → 그린 */
.td-title span[style*="naver-green"] { color: var(--naver-green) !important; }

/* 잔존 이모지 grayscale 필터 해제 (색 살리기) */
button, .btn, a.btn, .quick-shortcut, .kfma-tab,
.cat-chip, .file-badge, .badge, .grade-badge, .topic-chip,
.log-action, .news-source-chip, .news-card-link,
.brc-tag, .brc-link, .ns-item, .mnf-item {
  filter: none !important;
}

/* 키워드 강조 색상 (뉴스 모달) — 빨강 없음, 3색 + 보라 */
.kw-num   { background: var(--c-amber-light) !important; color: var(--c-amber-dark) !important; }
.kw-year  { background: var(--c-blue-light) !important; color: var(--c-blue-dark) !important; }
.kw-money { background: var(--naver-green-light) !important; color: var(--naver-green-dark) !important; }
.kw-law   { background: #f0e6ff !important; color: #6020a8 !important; }

/* 게시판 작성자(이웃·봇) 태그 → 색상 */
.nb-tag { color: var(--naver-green) !important; }
.bot-tag { color: var(--c-blue) !important; }

/* === 최신 뉴스 검색 — 토픽별 연한 파스텔 색 === */
/* 토픽 칩 — 토픽별 연한 색 */
.topic-chip {
  background: #f0f4ff !important;
  color: #4a5cad !important;
  border: 1px solid #d6e0ff !important;
}
/* 출처 칩 — 연한 그린 */
.news-source-chip {
  background: #e6f8ee !important;
  color: #02a64a !important;
  border: 1px solid #b8e5c8 !important;
}
/* NEW 뱃지 — 연한 앰버 */
.news-card-naver .badge-new {
  background: #fff4d4 !important;
  color: #a07300 !important;
  border: 1px solid #f0d97a !important;
}
/* 자세히 보기·원문 보기 링크 — 연한 블루 */
.news-card-link {
  color: #4a5cad !important;
}
.news-card-link:hover {
  color: #2a3c8d !important;
  text-decoration: underline !important;
}
/* 삭제 버튼 — 연한 핑크 (admin 전용이라 잘 안 보이지만) */
.news-card-naver .btn-mini-danger {
  background: #fde8e8 !important;
  color: #a85050 !important;
  border: 1px solid #f0c5c5 !important;
}
/* 뉴스 카드 호버 — 연한 그린 보더 */
.news-card-naver:hover {
  border-color: #b8e5c8 !important;
  box-shadow: 0 6px 20px rgba(2,166,74,0.12) !important;
}
/* 뉴스 썸네일 영역 — 연한 그라데이션 (display:none 해제 + 연한 색) */
.news-thumb-naver {
  display: flex !important;
  background: linear-gradient(135deg, #f0faf3 0%, #f0f4ff 50%, #fff4d4 100%) !important;
  border-bottom: 2px solid #e6f8ee !important;
  min-height: 60px;
}
.news-emoji {
  display: inline-block !important;
  font-size: 2rem !important;
  opacity: 0.85;
}
/* 자동수집 뱃지 — 연한 회색 */
.news-auto-badge {
  display: inline-block !important;
  background: rgba(255,255,255,0.85) !important;
  color: #888 !important;
  border: 1px solid #ddd !important;
  font-size: 0.7rem;
  padding: 2px 8px;
  border-radius: 10px;
  position: absolute;
  top: 8px; right: 8px;
}
/* 마지막 자동수집 날짜 — 연한 그린 */
.ns-item b { color: #02a64a !important; }
/* 검색 입력창 포커스 — 연한 그린 */
#newsSearchInput:focus { border-color: #02a64a !important; box-shadow: 0 0 0 3px rgba(2,166,74,0.12) !important; }
/* 토픽 필터 탭 active — 진한 블루 + 흰 글자 (모바일 가독성 ↑) */
#newsFilterTabs .kfma-tab.active {
  background: #1c5cd6 !important;
  color: #ffffff !important;
  border-color: #1c5cd6 !important;
  font-weight: 700 !important;
}

/* ========================================================
   참고 블로그 / 사이트 위젯
   ======================================================== */
.blog-refs {
  margin-top:36px; padding-top:28px;
  border-top:2px solid var(--text-primary);
}
.blog-refs-header {
  display:flex; align-items:baseline; justify-content:space-between;
  margin-bottom:18px; flex-wrap:wrap; gap:8px;
}
.blog-refs-header h3 {
  font-size:1.15rem; font-weight:800; color:var(--text-primary);
}
.blog-refs-sub { font-size:0.82rem; color:var(--text-muted); }

.blog-refs-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
  gap:14px;
}
.blog-ref-card {
  display:flex; flex-direction:column; gap:8px;
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius); padding:18px 20px;
  text-decoration:none; color:var(--text-primary);
  transition:var(--transition);
}
.blog-ref-card:hover {
  transform:translateY(-3px);
  border-color:var(--naver-green);
  box-shadow:var(--shadow-md);
}
.brc-top {
  display:flex; align-items:center; justify-content:space-between;
  font-size:0.74rem;
}
.brc-tag {
  background:var(--naver-green-light);
  color:var(--naver-green-dark);
  padding:2px 9px; border-radius:10px; font-weight:700;
}
.brc-host {
  color:var(--text-muted);
  font-family:'Consolas','Menlo',monospace;
  font-size:0.74rem;
}
.brc-name {
  font-size:1rem; font-weight:800;
  color:var(--text-primary);
}
.brc-desc {
  font-size:0.84rem; color:var(--text-secondary);
  line-height:1.6; flex:1;
}
.brc-link {
  font-size:0.82rem; font-weight:700;
  color:var(--naver-green-dark);
  margin-top:4px;
  transition:gap 0.15s;
}
.blog-ref-card:hover .brc-link { color:var(--naver-green); }

/* ===== Event Alert (Auto-generated section) ===== */
.nav-events {
  background: linear-gradient(120deg, #b045d4, #00b4d8) !important;
  color: #fff !important;
  padding: 6px 14px !important;
  border-radius: 999px !important;
  font-weight: 600 !important;
  transition: transform 0.1s, box-shadow 0.15s;
}
.nav-events:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(176, 69, 212, 0.3);
  text-decoration: none !important;
}

.event-cta-card {
  display: flex;
  align-items: center;
  gap: 22px;
  padding: 28px 32px;
  background: linear-gradient(120deg, #0b62ff, #b045d4);
  color: #fff;
  border-radius: 18px;
  text-decoration: none;
  box-shadow: 0 6px 24px rgba(11, 98, 255, 0.25);
  transition: transform 0.15s, box-shadow 0.2s;
}
.event-cta-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 32px rgba(11, 98, 255, 0.35);
  text-decoration: none;
}
.event-cta-icon {
  font-size: 54px;
  line-height: 1;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.15));
}
.event-cta-text { flex: 1; }
.event-cta-title {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 4px;
  letter-spacing: -0.3px;
}
.event-cta-sub {
  font-size: 14px;
  opacity: 0.9;
  line-height: 1.45;
}
.event-cta-arrow {
  font-size: 28px;
  opacity: 0.85;
  transition: transform 0.2s;
}
.event-cta-card:hover .event-cta-arrow {
  transform: translateX(6px);
  opacity: 1;
}

@media (max-width: 600px) {
  .event-cta-card { flex-direction: column; text-align: center; padding: 22px; }
  .event-cta-icon { font-size: 44px; }
  .event-cta-title { font-size: 19px; }
  .event-cta-arrow { display: none; }
}
