/* ─── COMVILLAIN darkmode.css ─── */
/* html.dark-mode 클래스 기반으로 다크 모드 활성화  */

/* ── CSS Variable Overrides ── */
html.dark-mode {
  --cv-bg:        #09090b;
  --cv-bg-2:      #18181b;
  --cv-bg-3:      #27272a;
  --cv-surface:   #141416;

  --cv-card-bg:     rgba(255, 255, 255, 0.025);
  --cv-card-bg-2:   rgba(255, 255, 255, 0.055);
  --cv-card-border: rgba(255, 255, 255, 0.07);
  --cv-divider-c:   rgba(255, 255, 255, 0.06);
  --cv-overlay:     rgba(9, 9, 11, 0.95);
  --cv-overlay-2:   rgba(9, 9, 11, 0.98);

  --cv-border:    rgba(255, 255, 255, 0.07);
  --cv-border-2:  rgba(255, 255, 255, 0.12);

  --cv-accent-glow:  rgba(6, 182, 212, 0.18);
  --cv-accent-light: #67e8f9;

  --cv-text:   #f4f4f5;
  --cv-text-2: #a1a1aa;
  --cv-text-3: #71717a;

  --shadow-sm:   0 1px 3px rgba(0, 0, 0, 0.5);
  --shadow-md:   0 4px 12px rgba(0, 0, 0, 0.5);
  --shadow-lg:   0 8px 28px rgba(0, 0, 0, 0.55);
  --shadow-xl:   0 16px 48px rgba(0, 0, 0, 0.6);
  --shadow-card: 0 1px 0 rgba(255, 255, 255, 0.05) inset, 0 4px 24px rgba(0, 0, 0, 0.4);
}

/* ── Body ── */
html.dark-mode body {
  background-color: #09090b;
  color: #f4f4f5;
}

/* ── Glass card ── */
html.dark-mode .cv-glass {
  background: rgba(255, 255, 255, 0.03);
}

/* ── Header ── */
html.dark-mode .alpha-header {
  background: rgba(9, 9, 11, 0.8) !important;
  border-bottom-color: rgba(255, 255, 255, 0.06) !important;
}
html.dark-mode .alpha-header.scrolled {
  background: rgba(9, 9, 11, 0.95) !important;
  border-bottom-color: rgba(255, 255, 255, 0.09) !important;
  box-shadow: none !important;
}
/* 히어로 페이지: 다크모드도 맨 위=투명, 스크롤=어두운 반투명 */
html.dark-mode .alpha-header.on-hero,
html.dark-mode body.cv-hero-page .alpha-header {
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-bottom-color: transparent !important;
  box-shadow: none !important;
}
html.dark-mode .alpha-header.on-hero.scrolled,
html.dark-mode body.cv-hero-page .alpha-header.scrolled {
  background: rgba(9, 9, 11, 0.92) !important;
  backdrop-filter: blur(20px) saturate(160%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(160%) !important;
  border-bottom-color: rgba(255, 255, 255, 0.09) !important;
  box-shadow: 0 2px 24px rgba(0, 0, 0, 0.4) !important;
}
html.dark-mode .sub-menu {
  background: rgba(24, 24, 27, 0.97) !important;
  border-color: rgba(255, 255, 255, 0.09) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.55) !important;
}

/* ── Mobile Menu ── */
html.dark-mode .mobile-menu {
  background: rgba(9, 9, 11, 0.98) !important;
}

/* ── Footer ── */
html.dark-mode .alpha-footer {
  background: #0a0a0d !important;
  border-top-color: rgba(255, 255, 255, 0.06) !important;
}
html.dark-mode .footer-top,
html.dark-mode .footer-sitemap {
  border-bottom-color: rgba(255, 255, 255, 0.05) !important;
}
html.dark-mode .footer-logo { filter: brightness(0.7) !important; }
html.dark-mode .footer-logo:hover { filter: brightness(1) !important; }
html.dark-mode .sns-icons img { filter: brightness(0.5) !important; }
html.dark-mode .sns-icons a:hover img { filter: brightness(0.75) !important; }

/* ── Biz badge green colour: lighter on dark ── */
html.dark-mode .cv-biz-badge { color: #6ee7b7 !important; }

/* ── Dark mode toggle icon (button itself) ── */
.dark-mode-toggle {
  background: transparent !important;
  border-color: transparent !important;
}

/* ── Smooth theme transition ── */
body,
.alpha-header,
.alpha-footer,
.bento-card,
.cv-plan,
.cv-biz-card,
.cv-tool-category,
.cv-zz-visual-inner,
.cv-hero-card {
  transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}

/* ==========================================================
   비게시판 스킨 다크 모드 오버라이드
   ========================================================== */

/* ── Outlogin 스킨 ── */
html.dark-mode #alpha-outlogin {
  background: transparent !important;
  color: #f4f4f5 !important;
}
html.dark-mode #alpha-outlogin .outlogin-member { border-color: rgba(255,255,255,0.07) !important; }
html.dark-mode #alpha-outlogin .member-info { border-bottom-color: rgba(255,255,255,0.07) !important; }
html.dark-mode #alpha-outlogin .member-name { color: #f4f4f5 !important; }
html.dark-mode #alpha-outlogin .stat-label { color: #a1a1aa !important; }
html.dark-mode #alpha-outlogin .stat-value { color: #06b6d4 !important; }
html.dark-mode #alpha-outlogin .stat-item {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
}
html.dark-mode #alpha-outlogin .link-item {
  color: #a1a1aa !important;
}
html.dark-mode #alpha-outlogin .link-item:hover {
  background: rgba(255,255,255,0.05) !important;
  color: #f4f4f5 !important;
}
html.dark-mode #alpha-outlogin .outlogin-links { border-top-color: rgba(255,255,255,0.07) !important; }
html.dark-mode #alpha-outlogin .outlogin-links a { color: #71717a !important; }
html.dark-mode #alpha-outlogin .outlogin-links .divider { color: rgba(255,255,255,0.12) !important; }
html.dark-mode #alpha-outlogin .form-input {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.1) !important;
  color: #f4f4f5 !important;
}
html.dark-mode #alpha-outlogin .form-input:focus { border-color: rgba(6,182,212,0.5) !important; }
html.dark-mode #alpha-outlogin .form-input::placeholder { color: #52525b !important; }

/* ── Member 스킨 ── */
html.dark-mode .alpha-member-page {
  background: transparent !important;
  color: #f4f4f5 !important;
}
html.dark-mode .alpha-member-page .member-card {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
}
html.dark-mode .alpha-member-page .member-header h1 { color: #f4f4f5 !important; }
html.dark-mode .alpha-member-page .form-label { color: #a1a1aa !important; }
html.dark-mode .alpha-member-page .section-title { color: #f4f4f5 !important; }
html.dark-mode .alpha-member-page .form-section { border-bottom-color: rgba(255,255,255,0.07) !important; }
html.dark-mode .alpha-member-page .form-input,
html.dark-mode .alpha-member-page select,
html.dark-mode .alpha-member-page textarea {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.1) !important;
  color: #f4f4f5 !important;
}
html.dark-mode .alpha-member-page .form-input:focus,
html.dark-mode .alpha-member-page select:focus,
html.dark-mode .alpha-member-page textarea:focus {
  border-color: rgba(6,182,212,0.5) !important;
}
html.dark-mode .alpha-member-page .form-input::placeholder { color: #52525b !important; }
html.dark-mode .alpha-member-page .form-input:read-only { background: rgba(255,255,255,0.02) !important; }
html.dark-mode .alpha-member-page .btn-check {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.1) !important;
  color: #a1a1aa !important;
}
html.dark-mode .alpha-member-page .btn-cancel {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.1) !important;
  color: #71717a !important;
}
html.dark-mode .alpha-member-page .member-links { border-top-color: rgba(255,255,255,0.07) !important; }
html.dark-mode .alpha-member-page .member-links a { color: #71717a !important; }
html.dark-mode .alpha-member-page .member-links .divider { color: rgba(255,255,255,0.12) !important; }
html.dark-mode .alpha-member-page .agreement-box { border-color: rgba(255,255,255,0.07) !important; }
html.dark-mode .alpha-member-page .agreement-header {
  background: rgba(255,255,255,0.025) !important;
  border-bottom-color: rgba(255,255,255,0.07) !important;
}
html.dark-mode .alpha-member-page .agreement-header h3 { color: #f4f4f5 !important; }
html.dark-mode .alpha-member-page .agreement-content {
  background: rgba(255,255,255,0.015) !important;
  color: #71717a !important;
}
html.dark-mode .alpha-member-page .agreement-content::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.12) !important; }
html.dark-mode .alpha-member-page .checkbox-label span,
html.dark-mode .alpha-member-page .radio-label span { color: #a1a1aa !important; }

/* ── Content 스킨 ── */
html.dark-mode .alpha-content-page {
  background: transparent !important;
  color: #f4f4f5 !important;
}
html.dark-mode .alpha-content-page .content-body { color: #a1a1aa !important; }
html.dark-mode .alpha-content-page .content-body a { color: #06b6d4 !important; }
html.dark-mode .alpha-content-page .content-body blockquote {
  border-left-color: #06b6d4 !important;
  background: rgba(6,182,212,0.04) !important;
  color: #a1a1aa !important;
}
html.dark-mode .alpha-content-page .content-body code,
html.dark-mode .alpha-content-page .content-body pre {
  background: #0f0f12 !important;
  color: #67e8f9 !important;
}

/* ── QA 스킨 ── */
html.dark-mode .alpha-qa-page,
html.dark-mode .alpha-qa-view,
html.dark-mode .alpha-qa-write {
  background: transparent !important;
  color: #f4f4f5 !important;
}
html.dark-mode .alpha-qa-page .qa-item,
html.dark-mode .alpha-qa-view .qa-content-card,
html.dark-mode .alpha-qa-write .qa-write-card {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
}
html.dark-mode .alpha-qa-page .qa-title,
html.dark-mode .alpha-qa-view .qa-view-title { color: #f4f4f5 !important; }
html.dark-mode .alpha-qa-page .qa-meta,
html.dark-mode .alpha-qa-page .qa-preview,
html.dark-mode .alpha-qa-view .qa-body { color: #a1a1aa !important; }

/* ── FAQ 스킨 ── */
html.dark-mode .alpha-faq-page {
  background: transparent !important;
  color: #f4f4f5 !important;
}
html.dark-mode .alpha-faq-page .faq-item {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
}
html.dark-mode .alpha-faq-page .faq-question { color: #f4f4f5 !important; }
html.dark-mode .alpha-faq-page .faq-answer { color: #a1a1aa !important; }

/* ── Search 스킨 ── */
html.dark-mode .alpha-search-page {
  background: transparent !important;
  color: #f4f4f5 !important;
}
html.dark-mode .alpha-search-page input[type="search"],
html.dark-mode .alpha-search-page input[type="text"] {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.1) !important;
  color: #f4f4f5 !important;
}
html.dark-mode .alpha-search-page .result-item {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
}

/* ── New / Popular / Visit / Poll 위젯 ── */
html.dark-mode .alpha-new-page,
html.dark-mode #alpha-popular,
html.dark-mode #alpha-visit,
html.dark-mode #alpha-poll {
  background: transparent !important;
  color: #f4f4f5 !important;
}
html.dark-mode .alpha-new-page .new-item,
html.dark-mode #alpha-popular .popular-item {
  border-bottom-color: rgba(255,255,255,0.05) !important;
}
html.dark-mode .alpha-new-page .new-title,
html.dark-mode #alpha-popular .popular-title { color: #f4f4f5 !important; }
html.dark-mode .alpha-new-page .new-board,
html.dark-mode #alpha-popular .popular-meta { color: #a1a1aa !important; }
html.dark-mode #alpha-visit .stat-grid { border-color: rgba(255,255,255,0.07) !important; }
html.dark-mode #alpha-visit .stat-item {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
}
html.dark-mode #alpha-visit .stat-label { color: #a1a1aa !important; }
html.dark-mode #alpha-poll .poll-header { border-bottom-color: rgba(6,182,212,0.2) !important; }
html.dark-mode #alpha-poll .poll-title { color: #f4f4f5 !important; }
html.dark-mode #alpha-poll .poll-option {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
}
html.dark-mode #alpha-poll .option-text { color: #a1a1aa !important; }
html.dark-mode #alpha-poll .option-check { border-color: rgba(255,255,255,0.18) !important; }
html.dark-mode #alpha-poll .result-text { color: #e4e4e7 !important; }
html.dark-mode #alpha-poll .result-bar { background: rgba(255,255,255,0.08) !important; }
html.dark-mode #alpha-poll .btn-result {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.1) !important;
  color: #a1a1aa !important;
}
html.dark-mode #alpha-poll .poll-info { border-top-color: rgba(255,255,255,0.07) !important; }
html.dark-mode #alpha-poll .poll-admin { border-top-color: rgba(255,255,255,0.07) !important; }

/* ── Latest Basic 스킨 ── */
html.dark-mode .alpha-latest-basic {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
}
html.dark-mode .alpha-latest-basic .latest-header { border-bottom-color: rgba(255,255,255,0.07) !important; }
html.dark-mode .alpha-latest-basic .latest-title a { color: #f4f4f5 !important; }
html.dark-mode .alpha-latest-basic .latest-subject { color: #a1a1aa !important; }
html.dark-mode .alpha-latest-basic .latest-link:hover { background: rgba(255,255,255,0.04) !important; }
html.dark-mode .alpha-latest-basic .latest-link:hover .latest-subject { color: #e4e4e7 !important; }

/* ── Latest Tabs 스킨 ── */
html.dark-mode .alpha-latest-tabs {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
  color: #f4f4f5 !important;
}
html.dark-mode .alpha-latest-tabs .tab-nav {
  background: rgba(255,255,255,0.02) !important;
  border-bottom-color: rgba(255,255,255,0.07) !important;
}
html.dark-mode .alpha-latest-tabs .tab-btn { color: #71717a !important; }
html.dark-mode .alpha-latest-tabs .tab-btn.active { color: #06b6d4 !important; }
html.dark-mode .alpha-latest-tabs .latest-item {
  border-bottom-color: rgba(255,255,255,0.05) !important;
}
html.dark-mode .alpha-latest-tabs .latest-title { color: #f4f4f5 !important; }
html.dark-mode .alpha-latest-tabs .latest-meta { color: #71717a !important; }

/* ── Connect 스킨 ── */
html.dark-mode #current-connect-page .connect-header h1 { color: #f4f4f5 !important; }
html.dark-mode #current-connect-page .connect-item {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
  box-shadow: none !important;
}
html.dark-mode #current-connect-page .info-main .name { color: #e4e4e7 !important; }
html.dark-mode #current-connect-page .member-badge { color: #67e8f9 !important; }
html.dark-mode #current-connect-page .action-btn { border-color: rgba(255,255,255,0.08) !important; background: rgba(255,255,255,0.04) !important; }
html.dark-mode .connect-total-count { color: #67e8f9 !important; }

/* ── FAQ 스킨 ── */
html.dark-mode .alpha-faq-page .faq-header h1 { color: #f4f4f5 !important; }
html.dark-mode .alpha-faq-page .faq-item {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
  box-shadow: none !important;
}
html.dark-mode .alpha-faq-page .faq-item.active { border-color: rgba(6,182,212,0.3) !important; }
html.dark-mode .alpha-faq-page .faq-q-text { color: #f4f4f5 !important; }
html.dark-mode .alpha-faq-page .faq-answer {
  background: rgba(255,255,255,0.02) !important;
  border-top-color: rgba(255,255,255,0.07) !important;
}
html.dark-mode .alpha-faq-page .faq-a-content { color: #a1a1aa !important; }
html.dark-mode .alpha-faq-page .faq-categories { border-bottom-color: rgba(255,255,255,0.07) !important; }
html.dark-mode .alpha-faq-page .search-input-wrap {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.1) !important;
}
html.dark-mode .alpha-faq-page .search-input { color: #e4e4e7 !important; background: transparent !important; }

/* ── Search 스킨 ── */
html.dark-mode .alpha-search-page .search-header h1 { color: #f4f4f5 !important; }
html.dark-mode .alpha-search-page .search-input {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.1) !important;
  color: #e4e4e7 !important;
}
html.dark-mode .alpha-search-page .result-item {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
  box-shadow: none !important;
}
html.dark-mode .alpha-search-page .result-board { color: #67e8f9 !important; }
html.dark-mode .alpha-search-page .result-subject { color: #e4e4e7 !important; }
html.dark-mode .alpha-search-page .search-result-info { color: #a1a1aa !important; }
html.dark-mode .alpha-search-page .search-empty p { color: #52525b !important; }

/* ── Content 스킨 ── */
html.dark-mode .alpha-content-page .content-header h1 { color: #f4f4f5 !important; }
html.dark-mode .alpha-content-page .content-body {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
  color: #a1a1aa !important;
  box-shadow: none !important;
}
html.dark-mode .alpha-content-page .content-body h1,
html.dark-mode .alpha-content-page .content-body h2,
html.dark-mode .alpha-content-page .content-body h3,
html.dark-mode .alpha-content-page .content-body h4 { color: #f4f4f5 !important; }
html.dark-mode .alpha-content-page .content-body strong { color: #f4f4f5 !important; }
html.dark-mode .alpha-content-page .content-body pre {
  background: #18181b !important;
  border-color: rgba(255,255,255,0.07) !important;
  color: #e4e4e7 !important;
}
html.dark-mode .alpha-content-page .content-body th { background: rgba(255,255,255,0.05) !important; color: #f4f4f5 !important; }
html.dark-mode .alpha-content-page .content-body td,
html.dark-mode .alpha-content-page .content-body th { border-color: rgba(255,255,255,0.07) !important; }

/* ── QA 스킨 ── */
html.dark-mode .alpha-qa-page .qa-header h1 { color: #f4f4f5 !important; }
html.dark-mode .alpha-qa-page .qa-item {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
  box-shadow: none !important;
}
html.dark-mode .alpha-qa-page .qa-subject { color: #e4e4e7 !important; }
html.dark-mode .alpha-qa-page .qa-item.answered .status-badge { color: #34d399 !important; }
html.dark-mode .alpha-qa-page .qa-item.pending .status-badge { color: #fbbf24 !important; }
html.dark-mode .alpha-qa-view .qa-view-header { border-bottom-color: rgba(255,255,255,0.07) !important; }
html.dark-mode .alpha-qa-view .qa-view-header h1 { color: #f4f4f5 !important; }
html.dark-mode .alpha-qa-view .qa-contact-info {
  background: rgba(255,255,255,0.03) !important;
  border-color: rgba(255,255,255,0.07) !important;
}
html.dark-mode .alpha-qa-view .qa-content {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
  color: #a1a1aa !important;
  box-shadow: none !important;
}
html.dark-mode .alpha-qa-view .qa-actions { border-top-color: rgba(255,255,255,0.07) !important; }
html.dark-mode .alpha-qa-view .btn-list {
  background: rgba(255,255,255,0.05) !important;
  color: #a1a1aa !important;
  border-color: rgba(255,255,255,0.09) !important;
}
html.dark-mode .alpha-qa-view .qa-answer { background: rgba(16,185,129,0.07) !important; }
html.dark-mode .alpha-qa-view .answer-header h3 { color: #34d399 !important; }
html.dark-mode .alpha-qa-view .answer-content { color: #a1a1aa !important; }
html.dark-mode .alpha-qa-write .qa-write-header h1 { color: #f4f4f5 !important; }
html.dark-mode .alpha-qa-write .form-section {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(255,255,255,0.07) !important;
  box-shadow: none !important;
}
html.dark-mode .alpha-qa-write .form-input,
html.dark-mode .alpha-qa-write .form-select,
html.dark-mode .alpha-qa-write .form-textarea {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.1) !important;
  color: #e4e4e7 !important;
}
html.dark-mode .alpha-qa-write .form-select { background-color: #18181b !important; }
html.dark-mode .alpha-qa-write .btn-cancel {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.1) !important;
}

/* ── IP Modal (Connect) dark ── */
html.dark-mode #ip-detail-modal .modal-content {
  background: #1c1c1f !important;
  border-color: rgba(255,255,255,0.09) !important;
}
html.dark-mode #ip-detail-modal .modal-header { border-bottom-color: rgba(255,255,255,0.07) !important; }
html.dark-mode #ip-detail-modal .modal-header h3 { color: #f4f4f5 !important; }
html.dark-mode #ip-detail-modal .modal-close { background: rgba(255,255,255,0.06) !important; }
html.dark-mode #ip-detail-modal .ip-info-item {
  background: rgba(255,255,255,0.03) !important;
  border-color: rgba(255,255,255,0.07) !important;
}
html.dark-mode #ip-detail-modal .ip-info-item .value { color: #e4e4e7 !important; }
html.dark-mode #ip-detail-modal .modal-footer { border-top-color: rgba(255,255,255,0.07) !important; }
