:root {
  --primary: #336699;
  --primary-dark: #23496e;
  --accent: #c88b2b;
  --bg: #f7f8fb;
  --surface: #ffffff;
  --surface-soft: #f3f6fa;
  --line: #d9e0ea;
  --text: #1f2937;
  --muted: #667085;
  --success: #2f855a;
  --warn: #d97706;
  --danger: #c53030;
  --shadow: 0 12px 40px rgba(19, 40, 70, 0.08);
  --radius: 18px;
  --radius-sm: 12px;
  --max: 1240px;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--text); font-family: "Noto Sans KR", sans-serif; }
img { max-width: 100%; display: block; }
button, input, textarea, select { font: inherit; }
.hidden { display: none !important; }
.page-section { display: none; padding: 36px 0 64px; }
.page-section.active { display: block; }
.container { width: min(calc(100% - 32px), var(--max)); margin: 0 auto; }
.container.narrow { width: min(calc(100% - 32px), 860px); }
.container.wide { width: min(calc(100% - 32px), 1360px); }
.site-header { position: sticky; top: 0; z-index: 30; background: rgba(247,248,251,.92); backdrop-filter: blur(12px); border-bottom: 1px solid rgba(51,102,153,.08); }
.header-inner { display: flex; align-items: center; justify-content: space-between; min-height: 76px; }
.brand { display: flex; align-items: center; gap: 14px; }
.brand-logo-link, .brand-text-link { display: inline-flex; text-decoration: none; color: inherit; }
.brand-text-link { flex-direction: column; justify-content: center; }
.brand-logo-link { flex-shrink: 0; border-radius: 16px; }
.brand-logo, .brand-logo-result { width: 60px; height: 60px; object-fit: contain; }
.brand-eyebrow, .eyebrow { color: var(--accent); font-weight: 700; letter-spacing: .04em; margin: 0 0 6px; }
.brand-title { font-family: "Noto Serif KR", serif; font-size: 1.15rem; margin: 0; }

/* hero-grid를 1.2fr .8fr 에서 1fr(전체 너비)로 수정하여 꽉 차게 변경 */
.hero-grid { display: grid; grid-template-columns: 1fr; gap: 28px; align-items: center; }

.hero-title { font-family: "Noto Serif KR", serif; font-size: clamp(1.6rem, 2.7vw, 2.35rem); line-height: 1.28; margin: 0 0 16px; }
.hero-desc { color: var(--muted); line-height: 1.8; margin: 0 0 24px; font-size: 1.05rem; }
.hero-card, .card { background: var(--surface); border-radius: var(--radius); box-shadow: var(--shadow); padding: 24px; border: 1px solid rgba(51,102,153,.08); }
.hero-card ul { list-style: none; margin: 16px 0 0; padding: 0; }
.hero-card li { display: flex; align-items: center; gap: 10px; padding: 10px 0; border-bottom: 1px dashed var(--line); }
.hero-card li:last-child { border-bottom: none; }
.counter-row { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 16px; margin: 30px 0; }
.counter-card { padding: 24px 16px; background: #ffffff; border: 1px solid rgba(51,102,153,.1); border-radius: 16px; text-align: center; box-shadow: 0 4px 12px rgba(0,0,0,0.03); }
.counter-card strong { display: block; color: var(--primary-dark); font-size: 2.2rem; font-weight: 800; margin-bottom: 8px; }
.counter-card span { color: var(--muted); font-weight: 500; font-size: 1.05rem; }
.feature-chips, .chip-select, .inline-actions, .hero-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.hero-guide-note { margin: 14px 0 0; color: var(--primary-dark); line-height: 1.7; }
.hero-guide-note a, .note-guide-link a { color: var(--primary-dark); font-weight: 700; text-decoration: underline; }
.note-guide-link { margin-top: 10px; }
.chip, .chip-btn { border: 1px solid rgba(51,102,153,.12); background: #fff; border-radius: 999px; padding: 10px 18px; font-size: 0.95rem; color: var(--muted); font-weight: 500; }
.chip-accent { background: rgba(200,139,43,.08); border-color: rgba(200,139,43,.3); color: #8a5a13; font-weight: 700; }
.chip-btn { cursor: pointer; }
.chip-btn.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; border: 0; cursor: pointer; border-radius: 12px; padding: 14px 22px; font-weight: 700; font-size: 1rem; transition: transform .15s ease, opacity .15s ease, background .15s ease; text-decoration: none; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--primary-dark); color: #fff; }
.btn-secondary { background: rgba(51,102,153,.08); color: var(--primary-dark); }
.btn-danger { background: rgba(197,48,48,.12); color: var(--danger); }
.btn-back { background: transparent; padding-left: 0; color: var(--muted); }
.section-head { margin-bottom: 20px; }
.section-head.compact { margin-bottom: 14px; }
.note { color: var(--muted); line-height: 1.7; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.form-grid.single { grid-template-columns: 1fr; }
.form-group { display: flex; flex-direction: column; gap: 8px; }
.form-group label { font-weight: 700; color: var(--primary-dark); }
input, textarea, select { width: 100%; border: 1px solid var(--line); border-radius: 12px; padding: 13px 14px; background: #fff; color: var(--text); }
textarea { resize: vertical; }
.code-editor { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: .9rem; line-height: 1.6; min-height: 280px; }
.checkbox-group { justify-content: center; }
.checkbox-group label { display: flex; gap: 8px; align-items: center; }
.radio-card-group { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 12px; }
.radio-card { display: flex; align-items: center; justify-content: center; background: var(--surface-soft); border: 1px solid var(--line); border-radius: 12px; padding: 14px; cursor: pointer; }
.radio-card input { width: auto; margin-right: 8px; }
.status-box, .security-banner, .access-verified-banner { margin-top: 14px; padding: 14px 16px; border-radius: 12px; background: rgba(51,102,153,.08); color: var(--primary-dark); }
.security-banner.warn { background: rgba(217,119,6,.14); color: #8a5a13; }
.progress-bar { width: 100%; height: 10px; border-radius: 999px; background: #e9eef6; overflow: hidden; }
.progress-bar.large { height: 14px; }
.progress-fill { width: 0%; height: 100%; background: linear-gradient(90deg,var(--primary),var(--accent)); transition: width .3s ease; }
.survey-header { display: flex; justify-content: space-between; gap: 20px; align-items: flex-start; margin-bottom: 24px; }
.survey-progress-wrap { width: 240px; display: flex; flex-direction: column; gap: 8px; }
.survey-body { display: grid; gap: 18px; }
.question-card { border: 1px solid var(--line); border-radius: 16px; padding: 18px; background: #fff; }
.question-card h4 { margin: 0 0 14px; }
.option-list { display: grid; gap: 10px; }
.option-btn { text-align: left; border: 1px solid var(--line); border-radius: 12px; background: #fff; padding: 12px 14px; cursor: pointer; }
.option-btn.active { border-color: var(--primary); background: rgba(51,102,153,.08); }
.survey-nav { margin-top: 22px; display: flex; justify-content: space-between; gap: 10px; }
.center { text-align: center; }
.analyzing-steps { display: grid; gap: 12px; margin: 22px 0; }
.step { padding: 12px 16px; border-radius: 12px; background: var(--surface-soft); color: var(--muted); border: 1px solid var(--line); }
.step.active { background: rgba(51,102,153,.08); color: var(--primary-dark); border-color: rgba(51,102,153,.2); }
.result-print-area { display: grid; gap: 20px; }
.result-header, .access-verified-banner { display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.result-brand { display: flex; align-items: center; gap: 14px; }
.result-meta { color: var(--muted); text-align: right; }
.result-summary-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 16px; }
.result-score-card { background: #fff; border-radius: 16px; padding: 22px; box-shadow: var(--shadow); border: 1px solid rgba(51,102,153,.08); }
.result-score-card span { display: block; color: var(--muted); margin-bottom: 8px; }
.result-score-card strong { display: block; font-size: 2rem; font-weight: 800; color: var(--primary-dark); }
.result-score-card em { display: block; margin-top: 8px; font-style: normal; color: var(--accent); font-weight: 700; }
.result-score-card.accent { background: linear-gradient(180deg,#fffaf2,#fff); }
.result-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 18px; }
.domain-score-bars { display: grid; gap: 14px; }
.domain-score-row { display: grid; grid-template-columns: 120px 1fr 60px; gap: 12px; align-items: center; }
.domain-score-track { height: 12px; background: #edf2f8; border-radius: 999px; overflow: hidden; }
.domain-score-value { height: 100%; background: linear-gradient(90deg,var(--primary),var(--accent)); border-radius: 999px; }
.prose-block { line-height: 1.9; color: #334155; }
.prose-block ul { margin: 8px 0 0 1.2rem; }
.result-actions { display: flex; justify-content: flex-end; gap: 12px; margin-top: 20px; }
.result-disclaimer { padding: 16px; border-radius: 12px; background: rgba(217,119,6,.08); color: #8a5a13; }
.admin-shell { display: grid; gap: 20px; }
.admin-topbar { display: flex; justify-content: space-between; align-items: center; gap: 16px; margin-bottom: 18px; }
.admin-user-info { color: var(--muted); }
.admin-stats-grid, .admin-chart-grid, .admin-grid { display: grid; gap: 18px; margin-bottom: 18px; }
.admin-stats-grid { grid-template-columns: repeat(4,minmax(0,1fr)); }
.admin-chart-grid, .admin-grid.two-col { grid-template-columns: repeat(2,minmax(0,1fr)); }
.admin-grid { grid-template-columns: 1fr; }
.stat-card strong { display: block; font-size: 2rem; margin-top: 8px; color: var(--primary-dark); }
.admin-code-form-grid, .admin-filter-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 14px; margin-bottom: 14px; }
.table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: 14px; }
.admin-table { width: 100%; border-collapse: collapse; min-width: 880px; background: #fff; }
.admin-code-table { min-width: 980px; }
.admin-table th, .admin-table td { border-bottom: 1px solid var(--line); padding: 12px 14px; text-align: left; vertical-align: top; font-size: .95rem; }
.admin-table th { background: #f7f9fc; color: var(--primary-dark); font-weight: 800; }
.admin-table td code { background: rgba(51,102,153,.08); padding: 4px 8px; border-radius: 8px; }
.admin-status-pill { display: inline-flex; align-items: center; border-radius: 999px; padding: 4px 10px; font-size: .8rem; font-weight: 700; }
.admin-status-pill.unused { color: #1d4f84; background: rgba(51,102,153,.12); }
.admin-status-pill.used { color: #1f6f43; background: rgba(47,133,90,.12); }
.admin-status-pill.disabled { color: #8a5a13; background: rgba(217,119,6,.14); }
.admin-code-text { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: .84rem; color: var(--primary-dark); font-weight: 700; }
.table-count { margin-top: 10px; color: var(--muted); font-size: .92rem; }
.admin-results-footer { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin-top: 14px; }
.pagination { display: flex; align-items: center; justify-content: flex-end; gap: 6px; flex-wrap: wrap; }
.pagination-btn { min-width: 38px; height: 38px; padding: 0 12px; border: 1px solid var(--line); border-radius: 12px; background: #fff; color: var(--primary-dark); font-weight: 800; cursor: pointer; box-shadow: 0 6px 18px rgba(24, 41, 64, .04); transition: .18s ease; }
.pagination-btn:hover:not(:disabled) { border-color: rgba(51,102,153,.45); background: rgba(51,102,153,.06); transform: translateY(-1px); }
.pagination-btn.active { background: var(--primary); border-color: var(--primary); color: #fff; box-shadow: 0 8px 22px rgba(51,102,153,.22); }
.pagination-btn:disabled { opacity: .45; cursor: not-allowed; box-shadow: none; }
.pagination-ellipsis { color: var(--muted); font-weight: 800; padding: 0 4px; }

.admin-preview-panel { margin: 16px 0; padding: 16px; background: var(--surface-soft); border: 1px solid var(--line); border-radius: 14px; }
.preview-box { border: 1px dashed rgba(51,102,153,.25); border-radius: 12px; padding: 14px; background: #fff; margin-top: 10px; }
.preview-item { padding: 10px 0; border-bottom: 1px dashed var(--line); }
.preview-item:last-child { border-bottom: none; }
.badge { display: inline-flex; align-items: center; border-radius: 999px; padding: 4px 10px; font-size: .8rem; font-weight: 800; }
.badge.draft { color: #8a5a13; background: rgba(217,119,6,.14); }
.badge.published { color: #1f6f43; background: rgba(47,133,90,.12); }
.badge.archived { color: #6b7280; background: rgba(107,114,128,.12); }

@media (max-width: 1100px) { .hero-grid, .result-grid, .admin-chart-grid, .admin-grid.two-col { grid-template-columns: 1fr; } .admin-code-form-grid, .admin-filter-grid { grid-template-columns: 1fr; } .admin-stats-grid { grid-template-columns: repeat(2,minmax(0,1fr)); } }
@media (max-width: 768px) { .admin-results-footer { align-items: flex-start; flex-direction: column; } .pagination { justify-content: flex-start; } .counter-row, .result-summary-grid, .form-grid, .radio-card-group { grid-template-columns: 1fr; } .survey-header, .result-header, .access-verified-banner, .admin-topbar, .header-inner { flex-direction: column; align-items: flex-start; } .survey-progress-wrap { width: 100%; } .brand-logo-result { width: 56px; height: 56px; } .result-actions { justify-content: stretch; flex-direction: column; } .domain-score-row { grid-template-columns: 1fr; } }
@media print { .site-header, .result-actions, #admin, #landing, #access-gate, #basic-info, #survey, #analyzing { display: none !important; } #result { display: block !important; padding: 0 !important; } .result-print-area, .card, .result-score-card { box-shadow: none !important; border: 1px solid #ddd !important; } }

.note-tight { margin-top: 10px; font-size: .92rem; }
.material-package-list, .liquor-analysis-list { display: grid; gap: 14px; }
.material-card, .liquor-analysis-card { border: 1px solid var(--line); border-radius: 14px; padding: 16px; background: #fff; }
.material-card h4, .liquor-analysis-card h4 { margin: 0 0 8px; color: var(--primary-dark); }
.material-meta, .liquor-meta { display: flex; flex-wrap: wrap; gap: 8px; margin: 8px 0 10px; }
.material-pill, .liquor-pill { display: inline-flex; align-items: center; border-radius: 999px; padding: 4px 10px; background: rgba(51,102,153,.08); color: var(--primary-dark); font-size: .82rem; font-weight: 700; }
.material-card ul, .liquor-analysis-card ul { margin: 10px 0 0 18px; }
/* === 2026-05 UX/UI 개선 패치 === */
:focus-visible { outline: 3px solid rgba(51,102,153,.35); outline-offset: 3px; }
.hero-copy { max-width: 1080px; margin: 0 auto; }
.ux-flow-card { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin: 24px 0 18px; }
.ux-flow-item { background: linear-gradient(180deg,#fff,#f8fbff); border: 1px solid rgba(51,102,153,.12); border-radius: 16px; padding: 18px; box-shadow: 0 8px 24px rgba(19,40,70,.05); }
.ux-flow-item strong { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 12px; background: rgba(51,102,153,.1); color: var(--primary-dark); margin-bottom: 12px; }
.ux-flow-item span { display: block; font-weight: 800; color: var(--text); margin-bottom: 6px; }
.ux-flow-item em { display: block; font-style: normal; color: var(--muted); font-size: .92rem; line-height: 1.55; }
.privacy-notice, .input-guide-box, .admin-guide-banner { border: 1px solid rgba(51,102,153,.14); background: rgba(51,102,153,.06); color: var(--primary-dark); border-radius: 14px; padding: 15px 16px; margin: 16px 0; line-height: 1.65; }
.privacy-notice p, .admin-guide-banner p { margin: 5px 0 0; color: #40546b; }
.input-guide-box { margin-top: 12px; }
.survey-answer-count { color: var(--muted); font-size: .92rem; }
.survey-step-dots { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 4px; }
.survey-dot { min-width: 34px; height: 34px; border-radius: 999px; border: 1px solid var(--line); background: #fff; color: var(--muted); font-weight: 800; cursor: pointer; padding: 0 10px; }
.survey-dot.active { background: var(--primary-dark); color: #fff; border-color: var(--primary-dark); }
.survey-dot.completed { background: rgba(47,133,90,.12); color: var(--success); border-color: rgba(47,133,90,.22); }
.survey-dot.locked { opacity: .55; cursor: not-allowed; }
.option-btn { min-height: 48px; }
.option-btn:hover { border-color: rgba(51,102,153,.38); background: #f8fbff; }
.option-btn.active::before { content: '✓ '; font-weight: 900; color: var(--primary-dark); }
.result-actions .btn { min-width: 130px; }
.admin-guide-banner { margin: 0 0 18px; background: #fffaf2; border-color: rgba(200,139,43,.25); }
.admin-guide-banner strong { color: #8a5a13; }
@media (max-width: 960px) { .ux-flow-card { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 640px) {
  .container { width: min(calc(100% - 24px), var(--max)); }
  .page-section { padding: 24px 0 44px; }
  .hero-title { font-size: 1.8rem; }
  .ux-flow-card { grid-template-columns: 1fr; }
  .btn { width: 100%; padding: 14px 16px; }
  .inline-actions, .hero-actions { width: 100%; }
  .inline-actions .btn, .hero-actions .btn { flex: 1 1 100%; }
  .counter-card { padding: 18px 12px; }
  .question-card { padding: 16px; }
}
.question-num { display:inline-flex; align-items:center; justify-content:center; min-width: 38px; height: 28px; padding: 0 9px; margin-right: 8px; border-radius: 999px; background: rgba(51,102,153,.08); color: var(--primary-dark); font-size: .82rem; font-weight: 900; }


/* === 2026-05 쉬운 설명형 SaaS UI v2 패치 === */
:root {
  --primary: #2f6f95;
  --primary-dark: #173f5f;
  --accent: #c89135;
  --bg: #f3f7fb;
  --surface-soft: #f7fbff;
  --line: #d8e4ef;
  --shadow: 0 20px 60px rgba(16, 43, 72, 0.09);
}
body { background:
  radial-gradient(circle at top left, rgba(47,111,149,.14), transparent 34rem),
  radial-gradient(circle at top right, rgba(200,145,53,.12), transparent 28rem),
  var(--bg); }
.site-header { background: rgba(255,255,255,.82); border-bottom: 1px solid rgba(47,111,149,.12); }
.card, .result-score-card, .counter-card, .question-card { border-color: rgba(47,111,149,.12); box-shadow: 0 16px 48px rgba(16,43,72,.07); }
.hero-copy { max-width: 1120px; }
.hero-title { letter-spacing: -0.035em; }
.hero-desc { max-width: 900px; font-size: 1.08rem; color: #475569; }
.btn { border-radius: 14px; box-shadow: 0 8px 20px rgba(16,43,72,.06); }
.btn-primary { background: linear-gradient(135deg, var(--primary-dark), var(--primary)); }
.btn-secondary { background: #fff; border: 1px solid rgba(47,111,149,.18); }
.easy-summary-panel { display:grid; grid-template-columns: 1.05fr .95fr; gap: 18px; margin: 22px 0; padding: 24px; border-radius: 24px; background: linear-gradient(135deg, #ffffff, #f7fbff); border: 1px solid rgba(47,111,149,.14); box-shadow: 0 16px 46px rgba(16,43,72,.06); }
.easy-summary-main h3 { margin: 8px 0 10px; font-size: 1.4rem; color: var(--primary-dark); }
.easy-summary-main p { margin: 0; color: #475569; line-height: 1.8; }
.soft-label { display:inline-flex; align-items:center; width:max-content; border-radius:999px; padding: 6px 11px; background: rgba(200,145,53,.13); color:#8a5a13; font-size:.82rem; font-weight:900; letter-spacing:.02em; }
.easy-term-grid { display:grid; grid-template-columns: 1fr; gap: 10px; }
.easy-term-grid article { display:grid; grid-template-columns: 88px 1fr; align-items:center; gap: 12px; padding: 13px 14px; border-radius: 16px; border:1px solid rgba(47,111,149,.12); background:#fff; }
.easy-term-grid strong { color: var(--primary-dark); font-size: 1.02rem; }
.easy-term-grid span { color: #526579; line-height: 1.55; }
.glossary-details, .survey-glossary-details { border:1px solid rgba(47,111,149,.14); background:#fff; border-radius:20px; padding: 0; margin: 18px 0 24px; overflow:hidden; }
.glossary-details summary, .survey-glossary-details summary { cursor:pointer; list-style:none; padding: 17px 20px; font-weight:900; color: var(--primary-dark); background: linear-gradient(180deg,#fff,#f8fbff); }
.glossary-details summary::-webkit-details-marker, .survey-glossary-details summary::-webkit-details-marker { display:none; }
.glossary-grid { display:grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 12px; padding: 18px; border-top:1px solid var(--line); }
.glossary-grid article { padding:16px; border-radius:16px; background: #f8fbff; border:1px solid rgba(47,111,149,.10); }
.glossary-grid b { color:var(--primary-dark); }
.glossary-grid p { margin: 8px 0 0; color:#526579; line-height:1.7; }
.plain-help-box { padding: 14px 16px; border-radius: 16px; background: #fffaf0; border: 1px solid rgba(200,145,53,.25); color:#6f4a12; line-height:1.7; margin-top: 12px; }
.survey-helper-panel { display:grid; grid-template-columns: .9fr 1.1fr; gap: 16px; margin: 0 0 22px; }
.domain-easy-panel, .survey-glossary-details { margin:0; }
.domain-easy-panel { padding: 20px; border-radius: 22px; background: linear-gradient(135deg, #173f5f, #2f6f95); color:#fff; box-shadow: 0 16px 38px rgba(23,63,95,.18); }
.domain-easy-panel .soft-label { background: rgba(255,255,255,.18); color:#fff; }
.domain-easy-panel h3 { margin: 10px 0 8px; font-size:1.45rem; }
.domain-easy-panel p { margin:0; line-height:1.8; color: rgba(255,255,255,.88); }
.mini-glossary-grid { display:grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 10px; padding: 14px; }
.mini-term { padding: 14px; border-radius: 15px; background:#f8fbff; border: 1px solid rgba(47,111,149,.10); }
.mini-term b { display:block; color:var(--primary-dark); margin-bottom: 6px; }
.mini-term span { display:block; color:#526579; line-height:1.62; font-size:.94rem; }
.question-card { position:relative; overflow:hidden; padding: 22px; border-radius:22px; }
.question-card::before { content:''; position:absolute; left:0; top:0; bottom:0; width:5px; background: linear-gradient(180deg,var(--primary),var(--accent)); opacity:.8; }
.question-headline h4 { font-size: 1.08rem; line-height:1.55; margin-bottom: 12px; }
.question-help { background: #f7fbff; border: 1px solid rgba(47,111,149,.12); border-radius: 16px; padding: 13px 15px; margin: 0 0 12px; }
.question-help strong { display:block; color:var(--primary-dark); margin-bottom:4px; }
.question-help p { margin:0; color:#526579; line-height:1.68; }
.option-guide { color:#7a8798; font-size:.9rem; margin: 0 0 10px; }
.option-list { grid-template-columns: repeat(5,minmax(0,1fr)); gap: 9px; }
.option-btn { display:flex; flex-direction:column; align-items:flex-start; gap:8px; min-height: 98px; padding: 14px; border-radius: 16px; }
.option-score { display:inline-flex; align-items:center; justify-content:center; width:30px; height:30px; border-radius: 999px; background:#eef5fb; color:var(--primary-dark); font-weight:900; }
.option-btn.active { background: linear-gradient(180deg, #eef8ff, #fff); box-shadow: inset 0 0 0 1px rgba(47,111,149,.18); }
.option-btn.active .option-score { background: var(--primary-dark); color:#fff; }
.option-btn.active::before { content:''; }
.survey-header { background:#fff; border:1px solid rgba(47,111,149,.10); border-radius: 22px; padding: 20px; box-shadow: 0 12px 32px rgba(16,43,72,.05); }
.survey-progress-wrap { width: min(360px, 100%); }
.result-term-card { background: linear-gradient(180deg,#fff,#f8fbff); }
.result-glossary { padding:0; }
.result-glossary .mini-term, .result-glossary div { padding: 12px; border-radius:14px; background:#fff; border:1px solid rgba(47,111,149,.10); }
.result-glossary div b { display:block; color:var(--primary-dark); margin-bottom: 5px; }
.result-glossary div span { color:#526579; line-height: 1.6; }
.detail-supplement-grid { display:grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap:10px; margin: 12px 0 18px; }
.detail-supplement-item { border:1px solid rgba(47,111,149,.14); border-radius:14px; background:#f8fbff; padding:12px; }
.detail-supplement-item span { display:block; color:#526579; font-size:.92rem; line-height:1.55; margin-bottom:6px; }
.detail-supplement-item strong { display:block; color:var(--primary-dark); line-height:1.45; }
@media (max-width: 1100px) {
  .glossary-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .survey-helper-panel { grid-template-columns: 1fr; }
  .option-list { grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 760px) {
  .easy-summary-panel { grid-template-columns: 1fr; padding: 18px; }
  .easy-term-grid article { grid-template-columns: 1fr; gap: 4px; }
  .glossary-grid, .mini-glossary-grid, .option-list, .detail-supplement-grid { grid-template-columns: 1fr; }
  .option-btn { min-height: auto; flex-direction: row; align-items:center; }
  .survey-header { padding: 16px; }
  .brand-title { font-size: 1rem; }
}


/* === 2026-05 헤더 링크/메인 타이틀 크기 조정 패치 === */
.brand-logo-link, .brand-text-link { text-decoration: none; color: inherit; }
.brand-logo-link:hover, .brand-text-link:hover { opacity: .88; }
.hero-title { font-size: clamp(1.6rem, 2.7vw, 2.35rem) !important; line-height: 1.28; }
@media (max-width: 640px) {
  .hero-title { font-size: 1.45rem !important; }
}


/* ===== SoolLink v3 full UX upgrade ===== */
:root {
  --blue-900:#13294b;
  --blue-800:#1b3d68;
  --blue-700:#2f5f97;
  --gold-600:#bd8f3e;
  --gold-100:#fff7e6;
  --ivory:#fffdf8;
  --success:#25744f;
  --danger:#b42318;
}
body { background: linear-gradient(180deg, #f6f8fb 0%, #fbfcfe 42%, #fffdf8 100%); }
.site-header { backdrop-filter: blur(10px); background: rgba(255,255,255,0.94); border-bottom: 1px solid rgba(51,102,153,0.12); }
.brand-logo-link, .brand-text-link { text-decoration:none; color:inherit; }
.hero-copy { position:relative; }
.hero-title { letter-spacing:-0.04em; }
.hero-outcome-strip {
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:12px;
  margin:22px 0 22px;
}
.hero-outcome-strip article {
  background: linear-gradient(135deg, #ffffff 0%, #f7fbff 100%);
  border: 1px solid rgba(51,102,153,0.16);
  border-radius:18px;
  padding:16px 18px;
  box-shadow: 0 12px 26px rgba(19,41,75,0.06);
}
.hero-outcome-strip b { display:block; font-size:1rem; color:var(--blue-900); margin-bottom:4px; }
.hero-outcome-strip span { color:var(--muted); font-size:.9rem; line-height:1.45; }
.draft-resume-card {
  margin:18px 0 24px;
  padding:18px;
  border-radius:20px;
  background: linear-gradient(135deg, #fff7e6, #ffffff);
  border:1px solid rgba(189,143,62,0.28);
  box-shadow:0 12px 30px rgba(189,143,62,0.12);
}
.draft-resume-card.hidden { display:none; }
.draft-resume-card h3 { margin:0 0 6px; color:#7a5417; font-size:1.05rem; }
.draft-resume-card p { margin:0 0 12px; color:#5b6472; line-height:1.6; }
.draft-resume-card .inline-actions { margin-top:8px; }
.card { border:1px solid rgba(51,102,153,0.12); box-shadow:0 18px 50px rgba(19,41,75,0.08); }
.survey-header { align-items:flex-start; }
.survey-progress-wrap { min-width:260px; background:#fff; border:1px solid rgba(51,102,153,0.12); border-radius:18px; padding:14px; box-shadow:0 10px 24px rgba(19,41,75,.05); }
.survey-answer-count { display:block; margin-top:8px; color:var(--blue-700); font-weight:700; }
.missing-alert {
  margin:18px 0;
  padding:16px 18px;
  border-radius:18px;
  background:#fff7ed;
  border:1px solid rgba(217,119,6,.28);
  color:#7c3d00;
}
.missing-alert.hidden { display:none; }
.missing-alert strong { display:block; margin-bottom:6px; }
.missing-alert button { margin:6px 6px 0 0; border:0; border-radius:999px; padding:7px 11px; background:#fff; color:#7c3d00; cursor:pointer; border:1px solid rgba(217,119,6,.24); }
.question-card { position:relative; transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease; }
.question-card:hover { transform: translateY(-1px); box-shadow:0 16px 40px rgba(19,41,75,.08); }
.question-card.missing-focus { outline:3px solid rgba(217,119,6,.35); border-color:#d97706; }
.option-list { grid-template-columns: repeat(5, minmax(0, 1fr)); gap:10px; }
.option-btn { min-height:70px; justify-content:flex-start; text-align:left; border-radius:16px; }
.option-btn.active { background:linear-gradient(135deg, var(--blue-800), var(--blue-700)); color:#fff; box-shadow:0 12px 28px rgba(47,95,151,.22); }
.option-btn.active .option-score { background:rgba(255,255,255,.2); color:#fff; }
.result-print-area { background:linear-gradient(180deg, #ffffff 0%, #fbfcff 100%); border-radius:28px; padding:24px; }
.result-executive-card { margin:22px 0; background:linear-gradient(135deg, #13294b 0%, #2f5f97 72%, #bd8f3e 130%); color:#fff; overflow:hidden; }
.result-executive-card h3 { color:#fff; margin-top:4px; }
.result-section-kicker { display:inline-flex; padding:6px 10px; border-radius:999px; background:rgba(255,255,255,.14); font-size:.82rem; letter-spacing:.08em; text-transform:uppercase; }
.result-executive-summary { display:grid; grid-template-columns: 1.2fr 1fr; gap:18px; align-items:start; }
.result-executive-summary p { color:rgba(255,255,255,.92); line-height:1.75; }
.result-executive-badges { display:grid; gap:10px; }
.result-executive-badges span { display:flex; justify-content:space-between; gap:10px; padding:12px 14px; border-radius:14px; background:rgba(255,255,255,.13); color:#fff; }
.top-list-grid { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:18px; margin:18px 0; }
.priority-card { background:#fff; border-radius:22px; padding:22px; border:1px solid rgba(51,102,153,.12); box-shadow:0 14px 34px rgba(19,41,75,.07); }
.priority-card h3 { margin:0 0 12px; color:var(--blue-900); }
.priority-card ol { margin:0; padding-left:20px; display:grid; gap:12px; }
.priority-card li { line-height:1.6; color:#2b3440; }
.priority-score { display:inline-flex; margin-left:6px; padding:2px 8px; border-radius:999px; background:#eef6ff; color:var(--blue-700); font-size:.82rem; }
.action-plan-grid { display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:16px; margin:18px 0; }
.action-step-card { background:#fff; border-radius:22px; padding:20px; border:1px solid rgba(189,143,62,.18); box-shadow:0 14px 34px rgba(19,41,75,.06); }
.action-step-card b { display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:14px; background:var(--gold-100); color:#8a5f19; margin-bottom:12px; }
.action-step-card h4 { margin:0 0 8px; color:var(--blue-900); }
.action-step-card ul { margin:0; padding-left:18px; color:#4f5b6b; line-height:1.65; }
.consulting-cta-panel { margin:18px 0 24px; padding:24px; border-radius:24px; background:linear-gradient(135deg, #fff7e6, #ffffff 70%); border:1px solid rgba(189,143,62,.24); display:flex; justify-content:space-between; align-items:center; gap:20px; box-shadow:0 14px 34px rgba(189,143,62,.12); }
.consulting-cta-panel h3 { margin:0 0 6px; color:#7a5417; }
.consulting-cta-panel p { margin:0; color:#5f6673; line-height:1.65; }
.consulting-cta-panel a { flex:0 0 auto; }
.domain-score-row.low-score strong { color:#b42318; }
.domain-score-row.high-score strong { color:#25744f; }
.domain-score-row.low-score .domain-score-value { background:#f97316; }
.domain-score-row.high-score .domain-score-value { background:#22a06b; }
.prose-block .result-pill { display:inline-flex; align-items:center; padding:5px 9px; border-radius:999px; background:#eef6ff; color:var(--blue-700); font-weight:700; font-size:.85rem; margin:2px 4px 2px 0; }
@media (max-width: 900px) {
  .hero-outcome-strip, .top-list-grid, .action-plan-grid, .result-executive-summary { grid-template-columns:1fr; }
  .consulting-cta-panel { flex-direction:column; align-items:flex-start; }
  .option-list { grid-template-columns:1fr; }
  .survey-progress-wrap { width:100%; min-width:0; }
}
@media (max-width: 560px) {
  .result-print-area { padding:14px; border-radius:18px; }
  .hero-outcome-strip article, .priority-card, .action-step-card { border-radius:16px; padding:16px; }
}

/* v4 운영 고도화 UI */
.admin-operational-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin: 18px 0 24px;
}
.operation-card h3 { margin-bottom: 12px; }
.operation-card h4 { margin: 12px 0 6px; color: var(--muted); font-size: .92rem; }
.metric-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.metric-list li { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 9px 10px; border: 1px solid var(--line); border-radius: 12px; background: rgba(255,255,255,.72); }
.metric-list li strong { color: var(--ink); font-size: .94rem; }
.metric-list li span { color: var(--muted); font-size: .86rem; text-align: right; }
.metric-list button { border: 0; background: transparent; color: var(--primary); font-weight: 800; cursor: pointer; text-align: left; }
.alert-list li { background: #fff7ed; border-color: #fed7aa; }
.admin-detail-grid { display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(320px, .8fr); gap: 18px; }
.admin-detail-main, .admin-followup-panel, .admin-log-panel { border: 1px solid var(--line); border-radius: 18px; padding: 18px; background: #fff; }
.admin-followup-panel textarea, .admin-log-panel textarea { width: 100%; }
.admin-log-panel { margin-top: 18px; }
.consult-log-item { border: 1px solid var(--line); border-radius: 14px; padding: 12px 14px; margin-bottom: 10px; background: #f8fafc; }
.consult-log-item p { margin: 6px 0; color: var(--ink); line-height: 1.55; }
.consult-log-item small { color: var(--muted); }
.admin-status-pill.contact_pending { background: #e0f2fe; color: #075985; }
.admin-status-pill.contacted { background: #dcfce7; color: #166534; }
.admin-status-pill.consulting { background: #ede9fe; color: #5b21b6; }
.admin-status-pill.hold { background: #fef3c7; color: #92400e; }
.admin-status-pill.closed { background: #e5e7eb; color: #374151; }
.result-pdf-guide { margin-top: 14px; padding: 14px 16px; border-radius: 16px; background: #f8fafc; border: 1px solid var(--line); color: var(--muted); line-height: 1.65; }
@media (max-width: 1100px) {
  .admin-operational-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin-detail-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .admin-operational-stats { grid-template-columns: 1fr; }
  .metric-list li { align-items: flex-start; flex-direction: column; }
}

/* === 관리자 화면 전체 폰트/간격 축소 패치 2026-05 ===
   - 일반 사용자 화면에는 영향 없음
   - admin.php의 <body data-page="admin"> 에만 적용
*/
body[data-page="admin"] {
  font-size: 0.92rem;
}
body[data-page="admin"] .page-section {
  padding: 28px 0 52px;
}
body[data-page="admin"] .header-inner {
  min-height: 68px;
}
body[data-page="admin"] .brand-logo {
  width: 52px;
  height: 52px;
}
body[data-page="admin"] .brand-eyebrow {
  font-size: .82rem;
  margin-bottom: 4px;
}
body[data-page="admin"] .brand-title {
  font-size: 1rem;
}
body[data-page="admin"] .card,
body[data-page="admin"] .admin-detail-main,
body[data-page="admin"] .admin-followup-panel,
body[data-page="admin"] .admin-log-panel {
  padding: 18px;
  border-radius: 16px;
}
body[data-page="admin"] .admin-shell,
body[data-page="admin"] .admin-stats-grid,
body[data-page="admin"] .admin-chart-grid,
body[data-page="admin"] .admin-grid {
  gap: 14px;
}
body[data-page="admin"] .admin-stats-grid,
body[data-page="admin"] .admin-chart-grid,
body[data-page="admin"] .admin-grid {
  margin-bottom: 14px;
}
body[data-page="admin"] .admin-topbar {
  margin-bottom: 14px;
}
body[data-page="admin"] h2 {
  font-size: 1.32rem;
  line-height: 1.35;
  margin-top: 0;
}
body[data-page="admin"] h3 {
  font-size: 1.05rem;
  line-height: 1.4;
  margin-top: 0;
}
body[data-page="admin"] h4 {
  font-size: .94rem;
}
body[data-page="admin"] .note,
body[data-page="admin"] .admin-user-info,
body[data-page="admin"] .admin-guide-banner,
body[data-page="admin"] .security-banner,
body[data-page="admin"] .status-box {
  font-size: .86rem;
  line-height: 1.6;
}
body[data-page="admin"] .btn {
  font-size: .86rem;
  padding: 10px 15px;
  border-radius: 10px;
}
body[data-page="admin"] input,
body[data-page="admin"] textarea,
body[data-page="admin"] select {
  font-size: .88rem;
  padding: 10px 12px;
  border-radius: 10px;
}
body[data-page="admin"] .form-group {
  gap: 6px;
}
body[data-page="admin"] .form-group label {
  font-size: .86rem;
}
body[data-page="admin"] .form-grid,
body[data-page="admin"] .admin-code-form-grid,
body[data-page="admin"] .admin-filter-grid {
  gap: 12px;
}
body[data-page="admin"] .stat-card strong {
  font-size: 1.55rem;
}
body[data-page="admin"] .stat-card span {
  font-size: .86rem;
}
body[data-page="admin"] .admin-operational-stats {
  gap: 12px;
  margin: 14px 0 18px;
}
body[data-page="admin"] .operation-card h3 {
  margin-bottom: 9px;
}
body[data-page="admin"] .metric-list {
  gap: 6px;
}
body[data-page="admin"] .metric-list li {
  padding: 7px 9px;
  border-radius: 10px;
  font-size: .84rem;
}
body[data-page="admin"] .metric-list li strong {
  font-size: .86rem;
}
body[data-page="admin"] .metric-list li span {
  font-size: .78rem;
}
body[data-page="admin"] .table-wrap {
  border-radius: 12px;
}
body[data-page="admin"] .admin-table {
  min-width: 820px;
}
body[data-page="admin"] .admin-code-table {
  min-width: 920px;
}
body[data-page="admin"] .admin-table th,
body[data-page="admin"] .admin-table td {
  font-size: .80rem;
  padding: 8px 9px;
  line-height: 1.45;
}
body[data-page="admin"] .admin-table td code,
body[data-page="admin"] .admin-code-text {
  font-size: .76rem;
}
body[data-page="admin"] .admin-status-pill,
body[data-page="admin"] .badge {
  font-size: .72rem;
  padding: 3px 8px;
}
body[data-page="admin"] .code-editor {
  font-size: .80rem;
  line-height: 1.55;
  min-height: 230px;
}
body[data-page="admin"] .admin-preview-panel {
  padding: 13px;
  border-radius: 12px;
}
body[data-page="admin"] .prose-block,
body[data-page="admin"] .consult-log-item,
body[data-page="admin"] .consult-log-item p {
  font-size: .86rem;
  line-height: 1.65;
}
body[data-page="admin"] .consult-log-item {
  padding: 10px 12px;
  border-radius: 12px;
}
body[data-page="admin"] canvas {
  max-height: 145px;
}
@media (max-width: 768px) {
  body[data-page="admin"] {
    font-size: .90rem;
  }
  body[data-page="admin"] .card,
  body[data-page="admin"] .admin-detail-main,
  body[data-page="admin"] .admin-followup-panel,
  body[data-page="admin"] .admin-log-panel {
    padding: 15px;
  }
  body[data-page="admin"] .admin-table th,
  body[data-page="admin"] .admin-table td {
    font-size: .78rem;
    padding: 7px 8px;
  }
}


/* 2026-05 logo/PDF refinement */
.main-top-logo-wrap {
  display:flex;
  justify-content:center;
  align-items:center;
  margin: 2px auto 22px;
  padding: 8px 0 4px;
}
.main-top-logo {
  width: min(230px, 39vw);
  max-height: 90px;
  object-fit: contain;
}
.brand-logo-result-wide {
  width: min(110px, 20vw);
  height: auto;
  max-height: 60px;
  object-fit: contain;
}
.result-brand {
  align-items:center;
}
@media (max-width: 768px) {
  .main-top-logo-wrap { margin-bottom: 16px; }
  .main-top-logo { width: min(190px, 50vw); max-height: 75px; }
  .brand-logo-result-wide { width: min(95px, 34vw); max-height: 50px; }
}
@media print {
  .brand-logo-result-wide { width: 90px !important; height: auto !important; }
}

/* V1.2 진단 참여 UX 보강: 진행 흐름 색상 구분 + 영역명 step 표시 */
.ux-flow-item { position: relative; overflow: hidden; }
.ux-flow-item::before { content:""; position:absolute; inset:0 auto 0 0; width:5px; background:var(--primary); opacity:.85; }
.ux-flow-item:nth-child(1) strong { background:#e8f2ff; color:#1f5f99; }
.ux-flow-item:nth-child(2) strong { background:#eef8f0; color:#2f855a; }
.ux-flow-item:nth-child(3) strong { background:#fff7e6; color:#a66b00; }
.ux-flow-item:nth-child(4) strong { background:#f1ecff; color:#6b46c1; }
.ux-flow-item:nth-child(1)::before { background:#2f80ed; }
.ux-flow-item:nth-child(2)::before { background:#2f855a; }
.ux-flow-item:nth-child(3)::before { background:#bd8f3e; }
.ux-flow-item:nth-child(4)::before { background:#6b46c1; }

.survey-step-dots { gap: 8px; align-items: stretch; }
.survey-dot {
  min-width: 104px;
  height: auto;
  min-height: 42px;
  border-radius: 14px;
  padding: 7px 10px;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 7px;
  text-align: left;
  background: #fff;
}
.survey-dot .dot-num {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  background: #eef3f8;
  color: var(--muted);
  font-size: .86rem;
}
.survey-dot .dot-label { font-size: .88rem; line-height: 1.2; white-space: nowrap; }
.survey-dot.active { box-shadow: 0 10px 24px rgba(19,41,75,.16); transform: translateY(-1px); }
.survey-dot.active .dot-num { background: rgba(255,255,255,.18); color: #fff; }
.survey-dot.completed .dot-num { background: rgba(47,133,90,.18); color: var(--success); }
.survey-dot.locked .dot-num { background:#f1f3f5; color:#a0a8b3; }

@media (max-width: 640px) {
  .survey-step-dots { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .survey-dot { min-width: 0; width: 100%; }
  .survey-dot .dot-label { white-space: normal; }
}
.admin-status-pill.in_progress { color:#6b46c1; background:rgba(107,70,193,.13); }

/* v1.3 result report enhancement */
.basic-diagnosis-panel {
  margin: 18px 0;
  padding: 24px;
  border-radius: 24px;
  background: linear-gradient(135deg, #f8fbff 0%, #ffffff 62%, #fff8ec 100%);
  border: 1px solid rgba(51, 102, 153, .16);
  box-shadow: 0 14px 34px rgba(19, 41, 75, .07);
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: 20px;
  align-items: start;
}
.basic-diagnosis-copy h3 { margin: 4px 0 10px; color: var(--blue-900); }
.basic-diagnosis-copy p { margin: 0 0 10px; color: #4f5b6b; line-height: 1.75; }
.basic-diagnosis-reason { font-size: .94rem; color: #7a5417 !important; }
.basic-diagnosis-metrics { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.basic-diagnosis-metrics span {
  display: grid;
  gap: 6px;
  padding: 14px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid rgba(51, 102, 153, .12);
}
.basic-diagnosis-metrics b { color: var(--muted); font-size: .86rem; }
.basic-diagnosis-metrics strong { color: var(--blue-900); font-size: 1rem; }
.result-insight-grid { margin-top: 18px; }
.immediate-task-list ol { margin: 0; padding-left: 20px; display: grid; gap: 12px; }
.immediate-task-list li { line-height: 1.65; }
.immediate-task-list span { color: #4f5b6b; }
.deep-diagnosis-panel {
  margin: 18px 0;
  padding: 24px;
  border-radius: 24px;
  background: linear-gradient(135deg, #13294b 0%, #244d7a 70%, #bd8f3e 140%);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  box-shadow: 0 18px 42px rgba(19, 41, 75, .18);
}
.deep-diagnosis-panel h3 { margin: 4px 0 8px; color: #fff; }
.deep-diagnosis-panel p { margin: 0 0 12px; color: rgba(255,255,255,.88); line-height: 1.7; }
.deep-diagnosis-panel small { display: block; color: rgba(255,255,255,.72); margin-top: 10px; }
.deep-diagnosis-panel .btn { background: #fff; color: #13294b; border-color: #fff; flex: 0 0 auto; }
.deep-module-list { display: flex; flex-wrap: wrap; gap: 8px; }
.deep-module-list span {
  display: inline-flex;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.13);
  border: 1px solid rgba(255,255,255,.22);
  color: #fff;
  font-size: .9rem;
}
@media (max-width: 860px) {
  .basic-diagnosis-panel { grid-template-columns: 1fr; padding: 18px; }
  .basic-diagnosis-metrics { grid-template-columns: 1fr; }
  .deep-diagnosis-panel { flex-direction: column; align-items: flex-start; padding: 18px; }
}

/* v1.4 실제 운영 통계 카드 */
.live-stats-row {
  gap: 18px;
  margin: 34px 0 10px;
}
.live-stat-card {
  position: relative;
  overflow: hidden;
  min-height: 168px;
  padding: 24px 22px 22px;
  text-align: left;
  border: 1px solid rgba(47, 111, 149, .16);
  border-radius: 22px;
  background:
    radial-gradient(circle at 90% 12%, rgba(47,111,149,.10), transparent 34%),
    linear-gradient(180deg, #fff, #fbfdff);
  box-shadow: 0 18px 44px rgba(15, 42, 72, .075);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.live-stat-card:hover {
  transform: translateY(-2px);
  border-color: rgba(47, 111, 149, .26);
  box-shadow: 0 22px 54px rgba(15, 42, 72, .10);
}
.live-stat-card::after {
  content: '';
  position: absolute;
  left: 22px;
  right: 22px;
  bottom: 0;
  height: 4px;
  border-radius: 999px 999px 0 0;
  background: linear-gradient(90deg, var(--primary), rgba(217, 119, 6, .72));
  opacity: .75;
}
.live-stat-card .stat-icon {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  border-radius: 14px;
  color: var(--primary-dark);
  background: rgba(47,111,149,.10);
}
.live-stat-card strong {
  margin-bottom: 6px;
  color: var(--primary-dark);
  font-size: clamp(2.15rem, 4vw, 3.05rem);
  line-height: 1;
  letter-spacing: -.03em;
}
.live-stat-card span {
  display: block;
  color: #475569;
  font-size: 1.04rem;
  font-weight: 800;
}
.live-stat-card em {
  display: block;
  margin-top: 8px;
  color: #8190a5;
  font-size: .82rem;
  font-style: normal;
  font-weight: 700;
}
.live-stat-card.is-loading strong {
  opacity: .55;
}
.live-stat-card.is-loading .stat-icon {
  animation: statPulse 1.2s ease-in-out infinite;
}
.live-stat-card.has-error {
  border-color: rgba(185, 28, 28, .22);
}
.live-stats-caption {
  margin: 0 0 28px;
  color: #64748b;
  font-size: .88rem;
  font-weight: 700;
  text-align: right;
}
.live-stats-caption.is-error {
  color: #b91c1c;
}
@keyframes statPulse {
  0%, 100% { opacity: .55; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.04); }
}
@media (max-width: 768px) {
  .live-stat-card { min-height: auto; padding: 20px; }
  .live-stats-caption { text-align: left; }
}

/* v1.5: Hero CTA section refinement */
.hero-cta-panel {
  margin: 26px 0 0;
  padding: 24px;
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(35,73,110,.08), rgba(255,255,255,.96) 42%, rgba(200,139,43,.10)),
    #fff;
  border: 1px solid rgba(35,73,110,.14);
  box-shadow: 0 24px 70px rgba(16,43,72,.09);
  position: relative;
  overflow: hidden;
}
.hero-cta-panel::before {
  content: "";
  position: absolute;
  width: 220px;
  height: 220px;
  right: -90px;
  top: -120px;
  border-radius: 50%;
  background: rgba(200,139,43,.16);
}
.hero-cta-panel::after {
  content: "";
  position: absolute;
  width: 160px;
  height: 160px;
  left: -70px;
  bottom: -95px;
  border-radius: 50%;
  background: rgba(51,102,153,.10);
}
.hero-cta-copy,
.hero-actions-polished,
.hero-guide-strip {
  position: relative;
  z-index: 1;
}
.hero-cta-kicker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(35,73,110,.08);
  color: var(--primary-dark);
  font-weight: 800;
  font-size: .88rem;
  letter-spacing: -.01em;
}
.hero-cta-copy h3 {
  margin: 14px 0 8px;
  color: var(--primary-dark);
  font-family: "Noto Serif KR", serif;
  font-size: clamp(1.35rem, 2.2vw, 1.85rem);
  letter-spacing: -.035em;
}
.hero-cta-copy p {
  margin: 0;
  max-width: 860px;
  color: #526579;
  line-height: 1.75;
  font-size: 1.02rem;
}
.hero-actions-polished {
  margin-top: 20px;
  gap: 12px;
  align-items: center;
}
.hero-actions-polished .btn {
  min-height: 58px;
  padding: 0 28px;
  border-radius: 18px;
  font-size: 1.07rem;
  letter-spacing: -.02em;
}
.hero-start-btn {
  background: linear-gradient(135deg, #173f5f, #336699) !important;
  box-shadow: 0 16px 34px rgba(35,73,110,.25);
}
.hero-guide-btn {
  background: rgba(255,255,255,.92) !important;
  border: 1px solid rgba(35,73,110,.18) !important;
  color: var(--primary-dark) !important;
  box-shadow: 0 12px 30px rgba(16,43,72,.07);
}
.hero-guide-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
}
.hero-guide-strip span {
  display: flex;
  align-items: center;
  gap: 9px;
  min-height: 46px;
  padding: 11px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(35,73,110,.10);
  color: #475569;
  font-weight: 700;
  letter-spacing: -.02em;
}
.hero-guide-strip b {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 12px;
  background: rgba(35,73,110,.10);
  color: var(--primary-dark);
  font-size: .82rem;
  flex-shrink: 0;
}

@media (max-width: 760px) {
  .hero-cta-panel { padding: 20px; border-radius: 22px; }
  .hero-actions-polished { display: grid; grid-template-columns: 1fr; }
  .hero-actions-polished .btn { width: 100%; min-height: 56px; }
  .hero-guide-strip { grid-template-columns: 1fr; }
}

/* === V1.7 관리자 차트 상호작용 / 등급 표시 개선 === */
body[data-page="admin"] .enhanced-chart-grid .admin-chart-card {
  position: relative;
  overflow: hidden;
}
body[data-page="admin"] .chart-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}
body[data-page="admin"] .chart-card-head h3 { margin-bottom: 4px; }
body[data-page="admin"] .chart-card-head p {
  margin: 0;
  color: var(--muted);
  font-size: .86rem;
  line-height: 1.55;
}
body[data-page="admin"] .chart-hint-pill {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(51,102,153,.08);
  color: var(--primary-dark);
  border: 1px solid rgba(51,102,153,.16);
  font-size: .78rem;
  font-weight: 900;
}
body[data-page="admin"] .grade-summary-grid,
body[data-page="admin"] .domain-summary-grid {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
body[data-page="admin"] .grade-summary-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
body[data-page="admin"] .domain-summary-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
body[data-page="admin"] .grade-summary-item,
body[data-page="admin"] .domain-summary-item {
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 14px;
  padding: 10px 8px;
  text-align: center;
  cursor: pointer;
  transition: .18s ease;
  color: var(--text);
  box-shadow: 0 8px 20px rgba(24,41,64,.04);
}
body[data-page="admin"] .grade-summary-item:hover,
body[data-page="admin"] .domain-summary-item:hover {
  transform: translateY(-2px);
  border-color: rgba(51,102,153,.38);
  box-shadow: 0 14px 26px rgba(24,41,64,.08);
}
body[data-page="admin"] .grade-summary-item strong,
body[data-page="admin"] .domain-summary-item strong {
  display: block;
  margin-top: 6px;
  color: var(--primary-dark);
  font-size: .98rem;
}
body[data-page="admin"] .grade-summary-item small,
body[data-page="admin"] .domain-summary-item small {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-weight: 800;
  font-size: .74rem;
}
body[data-page="admin"] .grade-chip,
body[data-page="admin"] .grade-table-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-weight: 900;
}
body[data-page="admin"] .grade-chip {
  width: 30px;
  height: 30px;
  color: #fff;
  font-size: .85rem;
}
body[data-page="admin"] .grade-s { background: #2f6f43 !important; color: #fff; }
body[data-page="admin"] .grade-a { background: #3f6098 !important; color: #fff; }
body[data-page="admin"] .grade-b { background: #7584b6 !important; color: #fff; }
body[data-page="admin"] .grade-c { background: #d0832c !important; color: #fff; }
body[data-page="admin"] .grade-d { background: #b6403b !important; color: #fff; }
body[data-page="admin"] .domain-summary-item.high { border-color: rgba(47,111,67,.28); background: rgba(47,111,67,.06); }
body[data-page="admin"] .domain-summary-item.good { border-color: rgba(63,96,152,.28); background: rgba(63,96,152,.06); }
body[data-page="admin"] .domain-summary-item.mid { border-color: rgba(208,131,44,.30); background: rgba(208,131,44,.07); }
body[data-page="admin"] .domain-summary-item.low { border-color: rgba(182,64,59,.30); background: rgba(182,64,59,.07); }
body[data-page="admin"] .domain-summary-item span {
  display: block;
  color: var(--primary-dark);
  font-weight: 900;
  font-size: .78rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
body[data-page="admin"] .chart-feedback {
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(51,102,153,.08), rgba(217,119,6,.07));
  border: 1px solid rgba(51,102,153,.14);
  color: var(--muted);
  line-height: 1.6;
}
body[data-page="admin"] .chart-feedback strong {
  display: block;
  color: var(--primary-dark);
  margin-bottom: 2px;
  font-weight: 900;
}
body[data-page="admin"] .chart-feedback span { display: block; }
body[data-page="admin"] .chart-feedback.active {
  color: var(--text);
  border-color: rgba(51,102,153,.28);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.55);
}
body[data-page="admin"] .grade-table-chip {
  gap: 6px;
  border: 0;
  padding: 6px 10px;
  min-width: 58px;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(24,41,64,.07);
}
body[data-page="admin"] .grade-table-chip span {
  font-size: .72rem;
  font-weight: 800;
  opacity: .9;
}
body[data-page="admin"] .grade-table-chip:hover {
  filter: brightness(.97);
  transform: translateY(-1px);
}
@media (max-width: 1100px) {
  body[data-page="admin"] .grade-summary-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
  body[data-page="admin"] .domain-summary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  body[data-page="admin"] .chart-card-head { flex-direction: column; }
  body[data-page="admin"] .grade-summary-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  body[data-page="admin"] .domain-summary-grid { grid-template-columns: 1fr; }
}


/* v1.8: 관리자 등급 차트 선택 리스트 */
.grade-detail-panel {
  margin: 18px 0 22px;
  border: 1px solid rgba(47, 77, 119, 0.16);
  background: linear-gradient(135deg, #ffffff 0%, #fbfcff 55%, #fffaf2 100%);
  box-shadow: 0 22px 50px rgba(21, 42, 75, 0.08);
}

.grade-detail-panel.hidden {
  display: none;
}

.grade-detail-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(47, 77, 119, 0.10);
}

.grade-detail-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
  color: #6f7890;
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.grade-detail-head h3 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 8px;
  color: #142948;
  font-size: 1.25rem;
  letter-spacing: -0.04em;
}

.grade-detail-head p {
  margin: 0;
  color: #6b7280;
  line-height: 1.55;
}

.grade-detail-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

.grade-detail-body {
  margin-top: 16px;
}

.grade-detail-table-wrap {
  overflow-x: auto;
  border: 1px solid rgba(47, 77, 119, 0.10);
  border-radius: 18px;
  background: #fff;
}

.grade-detail-table {
  min-width: 920px;
}

.grade-detail-table td:first-child,
.grade-detail-table th:first-child {
  text-align: center;
  width: 70px;
}

.grade-detail-table td:nth-child(6),
.grade-detail-table th:nth-child(6) {
  text-align: right;
}

.grade-detail-footer {
  margin-top: 14px;
}

.grade-detail-panel.is-collapsed .grade-detail-head {
  border-bottom: 0;
  padding-bottom: 0;
}

.grade-detail-panel.is-collapsed .grade-detail-footer {
  margin-top: 10px;
}

@media (max-width: 720px) {
  .grade-detail-head {
    flex-direction: column;
  }
  .grade-detail-actions {
    width: 100%;
  }
  .grade-detail-actions .btn {
    flex: 1;
  }
}


/* v1.9: 등급 상세 리스트는 클릭 후 접은 상태로 먼저 노출 */
.grade-detail-collapsed-note {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-top: 14px;
  padding: 16px 18px;
  border: 1px solid rgba(47, 77, 119, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
}

.grade-detail-collapsed-note strong {
  display: block;
  color: #142948;
  font-size: 1rem;
  margin-bottom: 4px;
}

.grade-detail-collapsed-note span {
  display: block;
  color: #6b7280;
  line-height: 1.45;
}

.grade-detail-panel.is-collapsed .grade-detail-body {
  margin-top: 0;
}

@media (max-width: 720px) {
  .grade-detail-collapsed-note {
    align-items: stretch;
    flex-direction: column;
  }
}

/* v1.20 checklist refinements: logo, admin user form, icon visibility */
.brand-logo-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  background: transparent;
}
.brand-logo {
  width: 52px;
  height: 52px;
  object-fit: contain;
  border-radius: 16px;
}
.btn i,
.btn .fa-solid,
.btn .fa-regular,
.btn .fa-brands {
  color: currentColor;
  opacity: .95;
}
.btn:empty,
button:empty {
  display: none !important;
}
.admin-filter-actions {
  align-items: center;
}
.admin-user-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.form-mode-pill {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(51,102,153,.09);
  color: var(--primary-dark);
  border: 1px solid rgba(51,102,153,.16);
  font-weight: 800;
  font-size: .84rem;
}
.role-badge,
.status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  border-radius: 999px;
  padding: 5px 10px;
  font-weight: 800;
  font-size: .78rem;
  border: 1px solid rgba(51,102,153,.14);
}
.role-super-admin { background: rgba(47,111,67,.10); color: #2f6f43; border-color: rgba(47,111,67,.20); }
.role-operator { background: rgba(63,96,152,.10); color: #3f6098; border-color: rgba(63,96,152,.20); }
.role-viewer { background: rgba(102,112,133,.10); color: #667085; border-color: rgba(102,112,133,.20); }
.status-active { background: rgba(47,111,67,.10); color: #2f6f43; border-color: rgba(47,111,67,.20); }
.status-disabled { background: rgba(197,48,48,.10); color: #a11d1d; border-color: rgba(197,48,48,.18); }
.status-warn { background: rgba(208,131,44,.12); color: #a56514; border-color: rgba(208,131,44,.22); }
.status-muted { background: rgba(102,112,133,.08); color: #667085; border-color: rgba(102,112,133,.14); }
@media (max-width: 768px) {
  .admin-user-head { flex-direction: column; }
  .form-mode-pill { align-self: flex-start; }
}

/* v1.21 admin dashboard API loading diagnostics */
.admin-load-message {
  margin: 0 0 18px;
  padding: 13px 16px;
  border-radius: 16px;
  border: 1px solid rgba(51,102,153,.18);
  background: rgba(51,102,153,.07);
  color: var(--primary-dark);
  font-weight: 700;
  line-height: 1.55;
}
.admin-load-message.warning {
  border-color: rgba(208,131,44,.28);
  background: rgba(208,131,44,.10);
  color: #8a5314;
}
.admin-load-message.error {
  border-color: rgba(180,64,59,.24);
  background: rgba(180,64,59,.09);
  color: #922724;
}
.admin-load-message.info {
  border-color: rgba(51,102,153,.18);
  background: rgba(51,102,153,.07);
  color: var(--primary-dark);
}


/* v1.24 remaining checklist polish: full logo application, compact admin guide, no blank white action buttons */
.main-top-logo-wrap {
  width: 96px;
  height: 96px;
  padding: 12px;
  border-radius: 28px;
  background: #fff;
  border: 1px solid rgba(51,102,153,.16);
  box-shadow: 0 18px 42px rgba(16,43,72,.08);
}
.main-top-logo {
  width: 72px;
  height: 72px;
  max-width: 72px;
  max-height: 72px;
  object-fit: contain;
}
.brand-logo-result-wide {
  width: 72px !important;
  height: 72px !important;
  max-width: 72px;
  max-height: 72px;
  object-fit: contain;
  border-radius: 18px;
}
.admin-guide-banner-compact {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 14px;
  padding: 12px 14px;
  background: linear-gradient(135deg, rgba(51,102,153,.06), rgba(200,139,43,.07));
  border-color: rgba(51,102,153,.14);
}
.admin-guide-banner-compact strong {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 10px;
  border-radius: 999px;
  background: #fff;
  color: var(--primary-dark);
  border: 1px solid rgba(51,102,153,.16);
}
.admin-guide-banner-compact p {
  margin: 0;
  color: var(--muted);
}
.btn,
button.btn,
a.btn {
  min-width: 0;
  white-space: nowrap;
}
.btn:not(:has(*)):empty,
button:not(:has(*)):empty,
a.btn:not(:has(*)):empty {
  display: none !important;
}
.btn i:only-child,
.btn .fa-solid:only-child,
.btn .fa-regular:only-child,
.btn .fa-brands:only-child {
  min-width: 1em;
}
.admin-table .btn,
.admin-code-table .btn {
  min-height: 36px;
  color: var(--primary-dark);
  background: #fff;
  border: 1px solid rgba(51,102,153,.16);
}
.admin-table .btn-danger,
.admin-code-table .btn-danger {
  color: var(--danger);
  background: rgba(197,48,48,.10);
  border-color: rgba(197,48,48,.12);
}
@media (max-width: 720px) {
  .admin-guide-banner-compact {
    align-items: flex-start;
    flex-direction: column;
  }
  .main-top-logo-wrap { width: 84px; height: 84px; border-radius: 24px; }
  .main-top-logo { width: 60px; height: 60px; }
}

/* v1.25 participation code management redesign */
body[data-page="admin"] .admin-access-card {
  overflow: hidden;
  border: 1px solid rgba(51,102,153,.14);
  background:
    radial-gradient(circle at top left, rgba(51,102,153,.08), transparent 34%),
    linear-gradient(180deg, #ffffff 0%, #fbfcff 100%);
}
.admin-access-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(51,102,153,.10);
  margin-bottom: 16px;
}
.section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 10px;
  margin-bottom: 8px;
  border-radius: 999px;
  background: rgba(51,102,153,.08);
  color: var(--primary-dark);
  font-weight: 900;
  font-size: .78rem;
}
.section-desc {
  margin: 5px 0 0;
  color: var(--muted);
  line-height: 1.55;
  font-size: .88rem;
}
.btn-code-main,
.btn-code-create {
  box-shadow: 0 14px 30px rgba(51,82,128,.18);
}
.admin-code-summary {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.code-summary-item {
  min-height: 96px;
  padding: 14px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid rgba(51,102,153,.13);
  box-shadow: 0 12px 26px rgba(16,43,72,.045);
}
.code-summary-item span,
.code-summary-item em {
  display: block;
  color: var(--muted);
  font-style: normal;
  line-height: 1.35;
}
.code-summary-item span {
  font-weight: 800;
  color: var(--primary-dark);
  font-size: .82rem;
}
.code-summary-item strong {
  display: block;
  margin: 8px 0 4px;
  font-size: 1.55rem;
  line-height: 1;
  color: var(--primary-dark);
  letter-spacing: -.03em;
}
.code-summary-item em { font-size: .76rem; }
.admin-code-issue-panel {
  padding: 16px;
  margin-bottom: 16px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(51,102,153,.075), rgba(200,139,43,.075));
  border: 1px solid rgba(51,102,153,.14);
}
.issue-panel-title {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}
.issue-panel-title strong {
  display: block;
  color: var(--primary-dark);
  font-size: .98rem;
  margin-bottom: 3px;
}
.issue-panel-title span {
  color: var(--muted);
  font-size: .84rem;
  line-height: 1.55;
}
.admin-code-form-grid.polished {
  grid-template-columns: 1.25fr .85fr 1.35fr .75fr;
  margin-bottom: 12px;
}
.admin-code-form-grid.polished .form-group {
  padding: 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.76);
  border: 1px solid rgba(51,102,153,.09);
}
.admin-code-form-grid.polished .form-group label b {
  color: var(--danger);
}
.admin-code-actions {
  margin-top: 4px;
}
.admin-code-list-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin: 18px 0 10px;
}
.admin-code-list-head h4 {
  margin: 0 0 3px;
  color: var(--primary-dark);
  font-size: 1rem;
}
.admin-code-list-head p {
  margin: 0;
  color: var(--muted);
  font-size: .84rem;
}
.code-count-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 56px;
  padding: 7px 11px;
  border-radius: 999px;
  background: #fff;
  color: var(--primary-dark);
  border: 1px solid rgba(51,102,153,.15);
  font-weight: 900;
  font-size: .82rem;
}
.admin-code-table-wrap {
  border: 1px solid rgba(51,102,153,.13);
  background: #fff;
}
body[data-page="admin"] .admin-code-table th {
  background: linear-gradient(180deg, #f8fbff 0%, #f2f6fb 100%);
  font-size: .78rem;
  letter-spacing: -.01em;
}
.table-main-text {
  color: var(--primary-dark);
  font-weight: 850;
}
.memo-text {
  display: inline-block;
  max-width: 180px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--muted);
}
.table-action-group {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.admin-code-table .btn-copy-code {
  background: rgba(51,102,153,.08);
  border-color: rgba(51,102,153,.16);
  color: var(--primary-dark);
  font-weight: 850;
}
.admin-code-table .admin-code-text {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 10px;
  background: rgba(51,102,153,.09);
  color: var(--primary-dark);
  font-weight: 900;
  letter-spacing: .03em;
}
.admin-status-pill.unused { background: rgba(51,102,153,.09); color: var(--primary-dark); border-color: rgba(51,102,153,.16); }
.admin-status-pill.in_progress { background: rgba(208,131,44,.13); color: #9a5c12; border-color: rgba(208,131,44,.22); }
.admin-status-pill.used { background: rgba(47,111,67,.12); color: #2f6f43; border-color: rgba(47,111,67,.20); }
.admin-status-pill.expired,
.admin-status-pill.disabled { background: rgba(180,64,59,.10); color: #9e2e2a; border-color: rgba(180,64,59,.18); }
.empty-row td {
  padding: 0 !important;
}
.admin-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 190px;
  padding: 34px 20px;
  text-align: center;
  background: linear-gradient(180deg, #ffffff, #f8fbff);
}
.admin-empty-state .empty-icon {
  width: 54px;
  height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  margin-bottom: 12px;
  background: rgba(51,102,153,.10);
  color: var(--primary-dark);
  font-size: 1.25rem;
}
.admin-empty-state strong {
  color: var(--primary-dark);
  font-size: 1rem;
  margin-bottom: 6px;
}
.admin-empty-state p {
  max-width: 480px;
  margin: 0 0 14px;
  color: var(--muted);
  line-height: 1.6;
}
@media (max-width: 1200px) {
  .admin-code-summary { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .admin-code-form-grid.polished { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .admin-access-head,
  .admin-code-list-head { flex-direction: column; align-items: flex-start; }
  .admin-code-summary { grid-template-columns: 1fr; }
  .admin-code-form-grid.polished { grid-template-columns: 1fr; }
  .table-action-group { flex-direction: column; align-items: stretch; }
  .table-action-group .btn { width: 100%; justify-content: center; }
}

/* v1.26 admin remaining polish: result management + config management */
body[data-page="admin"] .admin-results-card,
body[data-page="admin"] .admin-config-card {
  overflow: hidden;
  border: 1px solid rgba(51,102,153,.14);
  background:
    radial-gradient(circle at top right, rgba(51,102,153,.07), transparent 32%),
    linear-gradient(180deg, #ffffff 0%, #fbfcff 100%);
}
.admin-results-head,
.admin-config-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(51,102,153,.10);
  margin-bottom: 16px;
}
.admin-results-head-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}
.admin-result-summary {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.result-summary-item {
  min-height: 90px;
  padding: 14px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid rgba(51,102,153,.13);
  box-shadow: 0 12px 26px rgba(16,43,72,.045);
}
.result-summary-item span,
.result-summary-item em {
  display: block;
  font-style: normal;
  line-height: 1.35;
}
.result-summary-item span {
  color: var(--primary-dark);
  font-weight: 900;
  font-size: .82rem;
}
.result-summary-item strong {
  display: block;
  margin: 8px 0 4px;
  color: var(--primary-dark);
  font-size: 1.4rem;
  line-height: 1;
  letter-spacing: -.03em;
}
.result-summary-item em {
  color: var(--muted);
  font-size: .76rem;
}
.admin-filter-panel {
  padding: 16px;
  margin-bottom: 16px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(51,102,153,.06), rgba(200,139,43,.055));
  border: 1px solid rgba(51,102,153,.13);
}
.filter-panel-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 13px;
}
.filter-panel-title strong {
  color: var(--primary-dark);
  font-size: .98rem;
}
.filter-panel-title span {
  color: var(--muted);
  font-size: .82rem;
}
.admin-active-filter-chips {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid rgba(51,102,153,.14);
  color: var(--primary-dark);
  font-size: .78rem;
  font-weight: 750;
}
.filter-chip b {
  color: var(--muted);
  font-weight: 900;
}
.filter-chip.muted {
  color: var(--muted);
}
.admin-results-list-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin: 18px 0 10px;
}
.admin-results-list-head h4 {
  margin: 0 0 3px;
  color: var(--primary-dark);
  font-size: 1rem;
}
.admin-results-list-head p {
  margin: 0;
  color: var(--muted);
  font-size: .84rem;
}
.admin-results-table-wrap {
  border: 1px solid rgba(51,102,153,.13);
  background: #fff;
}
body[data-page="admin"] .admin-results-table th {
  background: linear-gradient(180deg, #f8fbff 0%, #f2f6fb 100%);
}
.admin-config-card .code-editor {
  background: #0f172a;
  color: #e5edf8;
  border-color: rgba(15,23,42,.30);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
}
.admin-config-card .admin-preview-panel {
  background: linear-gradient(135deg, rgba(51,102,153,.06), rgba(255,255,255,.95));
}
.admin-config-card .table-wrap {
  border: 1px solid rgba(51,102,153,.13);
}
@media (max-width: 1200px) {
  .admin-result-summary { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .admin-results-head,
  .admin-config-head,
  .admin-results-list-head,
  .filter-panel-title { flex-direction: column; align-items: flex-start; }
  .admin-results-head-actions { justify-content: flex-start; }
  .admin-result-summary { grid-template-columns: 1fr; }
}

/* v1.27 undeveloped admin completion: access-code paging/filter + detail polish */
body[data-page="admin"] .admin-code-filter-panel {
  display: grid;
  grid-template-columns: minmax(260px, 1.6fr) minmax(160px, .6fr) auto;
  align-items: end;
  gap: 12px;
  padding: 14px;
  margin: 8px 0 10px;
  border-radius: 18px;
  border: 1px solid rgba(51,102,153,.13);
  background: linear-gradient(135deg, rgba(51,102,153,.055), rgba(255,255,255,.9));
}
body[data-page="admin"] .admin-code-filter-panel .form-group { margin: 0; }
body[data-page="admin"] .code-filter-actions { justify-content: flex-end; margin: 0; }
body[data-page="admin"] .admin-code-footer { margin-top: 12px; }
body[data-page="admin"] .admin-detail-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 20px;
  margin-bottom: 16px;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(51,102,153,.10), rgba(200,139,43,.08));
  border: 1px solid rgba(51,102,153,.14);
}
body[data-page="admin"] .admin-detail-hero h3 { margin: 4px 0 6px; color: var(--primary-dark); font-size: 1.35rem; }
body[data-page="admin"] .admin-detail-hero p { margin: 0; color: var(--muted); }
body[data-page="admin"] .detail-eyebrow { display:inline-flex; padding: 6px 10px; border-radius:999px; background:#fff; color:var(--primary-dark); font-size:.78rem; font-weight:900; border:1px solid rgba(51,102,153,.12); }
body[data-page="admin"] .detail-grade-badge { min-width: 84px; min-height: 84px; border-radius: 24px; display:flex; flex-direction:column; align-items:center; justify-content:center; background:#fff; border:1px solid rgba(51,102,153,.13); box-shadow:0 14px 30px rgba(16,43,72,.08); }
body[data-page="admin"] .detail-grade-badge strong { font-size: 2rem; line-height: 1; color: var(--primary-dark); }
body[data-page="admin"] .detail-grade-badge span { margin-top: 5px; color: var(--muted); font-weight:800; font-size:.82rem; }
body[data-page="admin"] .detail-grade-badge.grade-s strong { color:#2f6f43; }
body[data-page="admin"] .detail-grade-badge.grade-a strong { color:#3f6098; }
body[data-page="admin"] .detail-grade-badge.grade-b strong { color:#7584b6; }
body[data-page="admin"] .detail-grade-badge.grade-c strong { color:#d0832c; }
body[data-page="admin"] .detail-grade-badge.grade-d strong { color:#b6403b; }
body[data-page="admin"] .admin-detail-kpi-grid { display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:10px; margin-bottom:16px; }
body[data-page="admin"] .admin-detail-kpi-grid > div { padding:14px; border-radius:16px; background:#fff; border:1px solid rgba(51,102,153,.13); box-shadow:0 10px 22px rgba(16,43,72,.045); }
body[data-page="admin"] .admin-detail-kpi-grid span { display:block; color:var(--muted); font-size:.78rem; font-weight:800; }
body[data-page="admin"] .admin-detail-kpi-grid strong { display:block; margin-top:6px; color:var(--primary-dark); font-size:1.25rem; }
body[data-page="admin"] .detail-section-title { margin: 6px 0 12px; color: var(--primary-dark); font-size: .98rem; }
body[data-page="admin"] .detail-info-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 10px; margin-bottom: 18px; }
body[data-page="admin"] .detail-info-grid > div,
body[data-page="admin"] .detail-info-list p { padding: 12px; border-radius: 14px; background: #f8fafc; border: 1px solid rgba(51,102,153,.10); }
body[data-page="admin"] .detail-info-grid span { display:block; color:var(--muted); font-size:.76rem; font-weight:800; margin-bottom:5px; }
body[data-page="admin"] .detail-info-grid strong { color:var(--ink); }
body[data-page="admin"] .detail-domain-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:10px; margin-bottom:14px; }
body[data-page="admin"] .detail-domain-card { padding:14px; border-radius:16px; background:#fff; border:1px solid rgba(51,102,153,.12); }
body[data-page="admin"] .detail-domain-card span,
body[data-page="admin"] .detail-domain-card em { display:block; }
body[data-page="admin"] .detail-domain-card span { color:var(--primary-dark); font-weight:900; font-size:.82rem; }
body[data-page="admin"] .detail-domain-card strong { display:block; margin:7px 0 3px; font-size:1.25rem; color:var(--primary-dark); }
body[data-page="admin"] .detail-domain-card em { color:var(--muted); font-style:normal; font-size:.78rem; font-weight:800; }
body[data-page="admin"] .detail-domain-card.low { border-color:rgba(180,64,59,.22); background:#fff7f7; }
body[data-page="admin"] .detail-domain-card.mid { border-color:rgba(208,131,44,.24); background:#fffaf2; }
body[data-page="admin"] .detail-domain-card.good { border-color:rgba(63,96,152,.20); background:#f7faff; }
body[data-page="admin"] .detail-domain-card.high { border-color:rgba(47,111,67,.20); background:#f5fff8; }
body[data-page="admin"] .detail-priority-box { padding:14px 16px; margin: 4px 0 18px; border-radius:16px; background:linear-gradient(135deg,#fff7ed,#fff); border:1px solid #fed7aa; }
body[data-page="admin"] .detail-priority-box strong { color:#92400e; }
body[data-page="admin"] .detail-priority-box p { margin:6px 0 0; color:#5f6673; }
body[data-page="admin"] .detail-info-list { display:grid; gap:9px; }
body[data-page="admin"] .detail-info-list p { margin:0; display:flex; justify-content:space-between; gap:12px; }
body[data-page="admin"] .detail-info-list b { color:var(--primary-dark); }
body[data-page="admin"] .detail-info-list span { color:var(--muted); text-align:right; }
body[data-page="admin"] .detail-history-box { margin-top:12px; padding:12px; border-radius:14px; background:#f8fafc; border:1px solid rgba(51,102,153,.10); color:var(--muted); }
body[data-page="admin"] .detail-actions { margin-top: 16px; }
body[data-page="admin"] .admin-followup-panel { background: linear-gradient(180deg,#ffffff,#fbfcff); }
@media (max-width: 1100px) {
  body[data-page="admin"] .admin-code-filter-panel { grid-template-columns: 1fr; }
  body[data-page="admin"] .code-filter-actions { justify-content:flex-start; }
  body[data-page="admin"] .admin-detail-kpi-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  body[data-page="admin"] .detail-info-grid,
  body[data-page="admin"] .detail-domain-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
  body[data-page="admin"] .admin-detail-hero { flex-direction: column; align-items: flex-start; }
  body[data-page="admin"] .admin-detail-kpi-grid,
  body[data-page="admin"] .detail-info-grid,
  body[data-page="admin"] .detail-domain-grid { grid-template-columns: 1fr; }
  body[data-page="admin"] .detail-info-list p { flex-direction: column; }
  body[data-page="admin"] .detail-info-list span { text-align:left; }
}


/* v1.28 logo placement update: uploaded logo.png for top-left, main_logo.png for central hero mark */
.site-header .brand {
  gap: 16px;
}
.site-header .brand-logo-link {
  width: auto !important;
  height: auto !important;
  min-width: 0;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
.site-header .brand-logo {
  width: min(174px, 24vw) !important;
  height: auto !important;
  max-height: 62px;
  max-width: 174px;
  object-fit: contain;
  border-radius: 0 !important;
}
body[data-page="admin"] .site-header .brand-logo {
  width: min(158px, 22vw) !important;
  height: auto !important;
  max-height: 54px;
}
.main-top-logo-wrap {
  width: min(168px, 34vw) !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 auto 18px !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}
.main-top-logo {
  width: min(150px, 32vw) !important;
  height: auto !important;
  max-width: 150px !important;
  max-height: 190px !important;
  object-fit: contain !important;
  margin: 0 auto;
}
.result-brand .brand-logo-result-wide {
  width: min(150px, 26vw) !important;
  height: auto !important;
  max-height: 58px !important;
  object-fit: contain !important;
  border-radius: 0 !important;
}
@media (max-width: 768px) {
  .site-header .brand-logo {
    width: min(142px, 42vw) !important;
    max-height: 50px;
  }
  body[data-page="admin"] .site-header .brand-logo {
    width: min(132px, 38vw) !important;
    max-height: 48px;
  }
  .brand-text-link .brand-eyebrow {
    font-size: .78rem;
  }
  .brand-text-link .brand-title {
    font-size: .95rem;
  }
  .main-top-logo-wrap {
    width: min(130px, 42vw) !important;
    margin-bottom: 14px !important;
  }
  .main-top-logo {
    width: min(124px, 40vw) !important;
    max-height: 160px !important;
  }
}
@media (max-width: 480px) {
  .site-header .brand {
    gap: 10px;
  }
  .site-header .brand-logo {
    width: min(118px, 38vw) !important;
  }
  .brand-text-link .brand-eyebrow {
    display: none;
  }
  .brand-text-link .brand-title {
    font-size: .9rem;
  }
}

/* v1.29: 상담 상태 영문+한글 병기 표시 보강 */
body[data-page="admin"] .operation-card .metric-list li strong,
body[data-page="admin"] .admin-status-pill {
  word-break: keep-all;
  line-height: 1.35;
}
body[data-page="admin"] .operation-card .metric-list li {
  min-height: 38px;
}

/* v1.20: 진단 결과 상세 이동 및 등급 라벨 가독성 보강 */
body[data-page="admin"] .admin-results-table tr.is-selected-result td {
  background: rgba(51, 102, 153, 0.055);
  box-shadow: inset 3px 0 0 var(--primary);
}
body[data-page="admin"] .detail-scroll-focus {
  animation: adminDetailFocusPulse 1.25s ease-out 1;
}
@keyframes adminDetailFocusPulse {
  0% { box-shadow: 0 0 0 0 rgba(51,102,153,.36), var(--shadow); }
  100% { box-shadow: 0 0 0 18px rgba(51,102,153,0), var(--shadow); }
}
body[data-page="admin"] .grade-chip,
body[data-page="admin"] .grade-table-chip,
body[data-page="admin"] .grade-table-chip span,
body[data-page="admin"] .detail-grade-badge,
body[data-page="admin"] .detail-grade-badge strong,
body[data-page="admin"] .detail-grade-badge span {
  color: #ffffff !important;
}
body[data-page="admin"] .detail-grade-badge.grade-s,
body[data-page="admin"] .detail-grade-badge.grade-a,
body[data-page="admin"] .detail-grade-badge.grade-b,
body[data-page="admin"] .detail-grade-badge.grade-c,
body[data-page="admin"] .detail-grade-badge.grade-d {
  border: 0;
  box-shadow: 0 16px 34px rgba(24,41,64,.16);
}
body[data-page="admin"] .detail-grade-badge span { opacity: .92; }

/* v1.21 관리자 메뉴별 페이지 분할 */
.admin-section-nav {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  padding: 12px;
  margin: 18px 0 18px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 18px 40px rgba(28, 48, 78, 0.08);
}
.admin-nav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  color: var(--muted);
  border: 1px solid transparent;
  background: transparent;
  font-weight: 800;
  text-decoration: none;
  transition: transform 0.18s ease, background 0.18s ease, color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}
.admin-nav-link:hover {
  transform: translateY(-1px);
  color: var(--primary);
  background: rgba(61, 86, 121, 0.08);
  border-color: rgba(61, 86, 121, 0.16);
}
body[data-admin-module="dashboard"] .admin-nav-link[data-admin-target="dashboard"],
body[data-admin-module="codes"] .admin-nav-link[data-admin-target="codes"],
body[data-admin-module="results"] .admin-nav-link[data-admin-target="results"],
body[data-admin-module="consulting"] .admin-nav-link[data-admin-target="consulting"],
body[data-admin-module="surveys"] .admin-nav-link[data-admin-target="surveys"],
body[data-admin-module="online"] .admin-nav-link[data-admin-target="online"],
body[data-admin-module="users"] .admin-nav-link[data-admin-target="users"],
body[data-admin-module="logs"] .admin-nav-link[data-admin-target="logs"] {
  color: #fff;
  background: var(--primary);
  border-color: var(--primary);
  box-shadow: 0 14px 28px rgba(61, 86, 121, 0.28);
}
.admin-module {
  display: none;
}
body[data-admin-module="dashboard"] [data-admin-module-panel="dashboard"],
body[data-admin-module="codes"] [data-admin-module-panel="codes"],
body[data-admin-module="results"] [data-admin-module-panel="results"],
body[data-admin-module="consulting"] [data-admin-module-panel="consulting"],
body[data-admin-module="surveys"] [data-admin-module-panel="surveys"],
body[data-admin-module="online"] [data-admin-module-panel="online"],
body[data-admin-module="users"] [data-admin-module-panel="users"],
body[data-admin-module="logs"] [data-admin-module-panel="logs"] {
  display: block;
}
.admin-page-intro {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-end;
  margin: 10px 0 18px;
  padding: 22px 24px;
  border: 1px solid rgba(218, 229, 242, 0.95);
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(255,255,255,0.98), rgba(248, 251, 255, 0.94));
  box-shadow: 0 20px 48px rgba(28, 48, 78, 0.07);
}
.admin-page-intro h2 {
  margin: 8px 0 6px;
  font-size: clamp(24px, 2.4vw, 34px);
  color: var(--text);
}
.admin-page-intro p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.7;
}
.admin-module[data-admin-module-panel="codes"] .admin-access-card,
.admin-module[data-admin-module-panel="results"] .admin-results-card,
.admin-module[data-admin-module-panel="surveys"] .admin-config-card,
.admin-module[data-admin-module-panel="online"] .admin-config-card,
.admin-module[data-admin-module-panel="users"] #admin-user-management-card,
.admin-module[data-admin-module-panel="users"] > .card,
.consulting-note-card {
  margin-bottom: 22px;
}
body[data-admin-module="surveys"] .admin-config-card,
body[data-admin-module="online"] .admin-config-card,
body[data-admin-module="users"] #admin-user-management-card,
body[data-admin-module="users"] .admin-module[data-admin-module-panel="users"] > .card {
  width: 100%;
}
@media (max-width: 960px) {
  .admin-section-nav {
    gap: 8px;
    padding: 10px;
    border-radius: 18px;
  }
  .admin-nav-link {
    flex: 1 1 calc(50% - 8px);
    min-width: 140px;
  }
  .admin-page-intro {
    padding: 18px;
    border-radius: 20px;
  }
}
@media (max-width: 560px) {
  .admin-nav-link {
    flex-basis: 100%;
  }
}

/* === v1.22 관리자 폴더/별도 로그인 페이지 === */
.admin-login-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at 12% 16%, rgba(166, 111, 54, 0.12), transparent 28%),
    linear-gradient(135deg, #f7f9fc 0%, #eef3f8 100%);
}
.admin-login-header {
  background: rgba(255, 255, 255, 0.86);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(31, 55, 86, 0.10);
}
.admin-login-main {
  min-height: calc(100vh - 96px);
  display: flex;
  align-items: center;
}
.login-hero-section {
  width: 100%;
  padding: 56px 0 72px;
}
.login-container {
  display: flex;
  justify-content: center;
}
.admin-login-standalone {
  width: min(560px, 100%);
  padding: 36px;
  border-radius: 28px;
  box-shadow: 0 24px 70px rgba(28, 47, 75, 0.16);
}
.admin-login-standalone h2 {
  margin: 12px 0 8px;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  color: var(--ink);
}
.login-actions {
  margin-top: 18px;
}
.login-actions .btn {
  min-height: 52px;
  border-radius: 16px;
}
.login-help-text {
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 0.95rem;
}
.admin-section-nav {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(247, 249, 252, 0.92);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(31, 55, 86, 0.10);
}
@media (max-width: 720px) {
  .admin-login-main {
    align-items: flex-start;
  }
  .login-hero-section {
    padding: 24px 0 48px;
  }
  .admin-login-standalone {
    padding: 24px;
    border-radius: 22px;
  }
}

/* === v1.23 관리자 상단 고정 메뉴 === */
body[data-page="admin"] .site-header {
  position: sticky;
  top: 0;
  z-index: 1100;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(218, 229, 242, 0.92);
  box-shadow: 0 10px 30px rgba(28, 48, 78, 0.06);
}
body[data-page="admin"] .page-section {
  padding-top: 18px;
}
.admin-sticky-menu {
  position: sticky;
  top: 69px;
  z-index: 1000;
  padding: 12px 0 14px;
  margin: 0 0 18px;
  background: linear-gradient(180deg, rgba(246, 249, 253, 0.98), rgba(246, 249, 253, 0.92));
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(218, 229, 242, 0.72);
}
.admin-sticky-menu::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 100vw;
  height: 100%;
  transform: translateX(-50%);
  background: inherit;
  border-bottom: inherit;
  z-index: -1;
}
.admin-sticky-topbar {
  align-items: center;
  margin: 0 0 10px !important;
  padding: 0 2px;
}
.admin-sticky-topbar h2 {
  margin: 0 0 4px;
}
.admin-sticky-topbar .admin-user-info {
  margin: 0;
}
.admin-sticky-actions {
  flex-wrap: wrap;
  justify-content: flex-end;
}
.admin-sticky-menu .admin-section-nav {
  margin: 0;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
  -webkit-overflow-scrolling: touch;
  border-radius: 24px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.92);
}
.admin-sticky-menu .admin-section-nav::-webkit-scrollbar {
  height: 7px;
}
.admin-sticky-menu .admin-section-nav::-webkit-scrollbar-thumb {
  background: rgba(61, 86, 121, 0.28);
  border-radius: 999px;
}
.admin-sticky-menu .admin-nav-link {
  flex: 0 0 auto;
  min-width: max-content;
  min-height: 42px;
  padding: 0 15px;
  white-space: nowrap;
}
body[data-page="admin"] .admin-page-intro {
  margin-top: 0;
}
@media (max-width: 960px) {
  .admin-sticky-menu {
    top: 68px;
    padding: 10px 0 12px;
  }
  .admin-sticky-topbar {
    align-items: flex-start;
    gap: 10px;
  }
  .admin-sticky-actions {
    width: 100%;
    justify-content: flex-start;
  }
  .admin-sticky-menu .admin-section-nav {
    border-radius: 18px;
  }
  .admin-sticky-menu .admin-nav-link {
    flex: 0 0 auto;
    min-width: max-content;
  }
}
@media (max-width: 560px) {
  body[data-page="admin"] .site-header {
    position: relative;
  }
  .admin-sticky-menu {
    top: 0;
  }
  .admin-sticky-topbar h2 {
    font-size: 1.12rem;
  }
  .admin-sticky-actions .btn {
    flex: 1 1 auto;
  }
}

/* v1.24 운영 안정화: 비밀번호 변경/권한 안내 */
.admin-password-panel .force-visible {
  display: block;
  margin: 16px 0;
}
.admin-access-denied-card {
  margin-top: 22px;
  padding: 34px;
  border: 1px solid rgba(176, 65, 58, 0.24);
  background: linear-gradient(135deg, rgba(176,65,58,0.08), rgba(255,255,255,0.96));
}
.admin-access-denied-card h2 {
  margin: 10px 0 8px;
  color: var(--ink, #25324a);
}
.admin-nav-link[data-admin-target="password"] {
  margin-left: auto;
}
@media (max-width: 920px) {
  .admin-nav-link[data-admin-target="password"] {
    margin-left: 0;
  }
}


/* v1.25 운영 로그 */
.admin-log-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 14px 0 18px;
}
.admin-log-summary .log-summary-item {
  padding: 16px 18px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(135deg, #fff, #f8fbff);
  box-shadow: 0 12px 28px rgba(28, 48, 78, 0.06);
}
.admin-log-summary .log-summary-item span {
  display: block;
  color: var(--muted);
  font-weight: 800;
  margin-bottom: 6px;
}
.admin-log-summary .log-summary-item strong {
  display: block;
  font-size: 26px;
  color: var(--primary);
}
.admin-log-filter {
  display: grid;
  grid-template-columns: 180px minmax(220px, 1fr) 170px auto;
  gap: 12px;
  align-items: end;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(248, 251, 255, 0.82);
  margin-bottom: 18px;
}
.admin-log-filter-actions {
  margin-bottom: 0;
}
.admin-log-columns {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: 18px;
}
.admin-log-columns h4 {
  margin: 0 0 10px;
  color: var(--primary);
  font-size: 18px;
}
.admin-log-table td {
  vertical-align: top;
}
.log-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 10px;
  font-weight: 900;
  font-size: 13px;
  color: #fff;
  background: var(--primary);
}
.log-badge.fail { background: #b6403b; }
.log-badge.success { background: #2f6f43; }
.log-meta {
  max-width: 360px;
  white-space: normal;
  word-break: break-word;
  color: var(--muted);
  font-size: 13px;
}
@media (max-width: 980px) {
  .admin-log-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin-log-filter { grid-template-columns: 1fr; }
  .admin-log-columns { grid-template-columns: 1fr; }
}

/* v1.27 requirements gap finish: slimmer diagnosis visual + safer admin labels */
.hero-dx-banner {
  width: 100%;
  height: clamp(220px, 28vw, 420px);
  object-fit: cover;
  object-position: center;
  display: block;
  margin: 0 0 30px;
  border-radius: 18px;
  box-shadow: 0 14px 40px rgba(15, 39, 71, 0.10);
  border: 1px solid rgba(219, 229, 241, 0.95);
}
.admin-login-panel .login-help-text {
  line-height: 1.65;
}
.admin-table .grade-badge,
.grade-badge,
.grade-pill,
.result-grade-badge,
.admin-grade-chip,
[class*="grade-"][class*="badge"] {
  color: #ffffff !important;
}
button:empty,
a.btn:empty {
  display: none !important;
}
@media (max-width: 768px) {
  .hero-dx-banner {
    height: clamp(180px, 52vw, 300px);
    border-radius: 14px;
  }
}


/* v1.28 main hero image refinement: compact central logo + lower modern diagnosis banner */
body[data-page="user"] #landing {
  padding-top: 22px;
}
body[data-page="user"] .hero-copy {
  max-width: 1180px;
  margin: 0 auto;
  text-align: center;
}
body[data-page="user"] .main-top-logo-wrap {
  width: min(104px, 26vw) !important;
  margin: 0 auto 18px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
body[data-page="user"] .main-top-logo {
  width: min(104px, 26vw) !important;
  max-width: 104px !important;
  max-height: 142px !important;
  height: auto !important;
  object-fit: contain !important;
  filter: drop-shadow(0 14px 28px rgba(31, 41, 55, .08));
}
body[data-page="user"] .eyebrow {
  margin-bottom: 10px;
  font-size: clamp(.88rem, 1.2vw, 1.02rem);
  letter-spacing: .11em;
}
body[data-page="user"] .hero-title {
  max-width: 1100px;
  margin: 0 auto 18px;
  font-size: clamp(2.05rem, 4.7vw, 4.15rem) !important;
  line-height: 1.15 !important;
  letter-spacing: -0.055em;
  color: #1e2636;
}
body[data-page="user"] .hero-dx-banner {
  width: 100%;
  height: clamp(170px, 22vw, 300px) !important;
  object-fit: cover;
  object-position: center;
  margin: 8px auto 24px !important;
  border-radius: 22px;
  border: 1px solid rgba(219,229,241,.95);
  box-shadow: 0 18px 45px rgba(15,39,71,.10);
  background: #fff;
}
body[data-page="user"] .hero-desc {
  max-width: 860px;
  margin: 0 auto 22px;
  font-size: clamp(.96rem, 1.3vw, 1.08rem);
  line-height: 1.75;
}
body[data-page="user"] .hero-outcome-strip,
body[data-page="user"] .ux-flow-card,
body[data-page="user"] .easy-summary-panel,
body[data-page="user"] .glossary-details,
body[data-page="user"] .counter-row,
body[data-page="user"] .feature-chips,
body[data-page="user"] .hero-cta-panel {
  text-align: left;
}
@media (max-width: 768px) {
  body[data-page="user"] #landing { padding-top: 16px; }
  body[data-page="user"] .main-top-logo-wrap {
    width: min(86px, 28vw) !important;
    margin-bottom: 14px !important;
  }
  body[data-page="user"] .main-top-logo {
    width: min(86px, 28vw) !important;
    max-height: 118px !important;
  }
  body[data-page="user"] .hero-title {
    font-size: clamp(1.85rem, 8vw, 2.7rem) !important;
    line-height: 1.18 !important;
    margin-bottom: 14px;
  }
  body[data-page="user"] .hero-dx-banner {
    height: clamp(140px, 42vw, 230px) !important;
    border-radius: 16px;
    margin-bottom: 20px !important;
  }
}


/* v1.29 hero visual fix: prevent diagnosis banner crop and reduce headline overlap */
body[data-page="user"] #landing {
  padding-top: 18px;
}
body[data-page="user"] .main-top-logo-wrap {
  width: min(92px, 24vw) !important;
  margin: 0 auto 12px !important;
}
body[data-page="user"] .main-top-logo {
  width: min(92px, 24vw) !important;
  max-width: 92px !important;
  max-height: 126px !important;
}
body[data-page="user"] .eyebrow {
  margin-bottom: 8px !important;
}
body[data-page="user"] .hero-title {
  max-width: 1080px;
  font-size: clamp(1.85rem, 3.45vw, 3.05rem) !important;
  line-height: 1.18 !important;
  letter-spacing: -0.052em;
  margin: 0 auto 16px !important;
  word-break: keep-all;
  overflow-wrap: normal;
}
body[data-page="user"] .hero-dx-banner {
  width: 100% !important;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  object-position: center center !important;
  display: block;
  margin: 4px auto 22px !important;
  border-radius: 20px;
  background: #ffffff;
}
@media (max-width: 768px) {
  body[data-page="user"] .main-top-logo-wrap {
    width: min(78px, 25vw) !important;
    margin-bottom: 10px !important;
  }
  body[data-page="user"] .main-top-logo {
    width: min(78px, 25vw) !important;
    max-height: 106px !important;
  }
  body[data-page="user"] .hero-title {
    font-size: clamp(1.55rem, 6.8vw, 2.35rem) !important;
    line-height: 1.22 !important;
    margin-bottom: 12px !important;
  }
  body[data-page="user"] .hero-dx-banner {
    border-radius: 14px;
    margin-bottom: 18px !important;
  }
}

/* v1.30 운영 점검 + 인쇄/모바일 보강 */
body[data-admin-module="system"] .admin-nav-link[data-admin-target="system"] {
  color: #fff;
  background: var(--primary);
  border-color: var(--primary);
  box-shadow: 0 14px 28px rgba(61, 86, 121, 0.28);
}
body[data-admin-module="system"] [data-admin-module-panel="system"] {
  display: block;
}
.system-check-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}
.system-check-card {
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 12px 28px rgba(28,48,78,.06);
}
.system-check-card span { display:block; color: var(--muted); font-weight: 800; margin-bottom: 8px; }
.system-check-card strong { font-size: 1.6rem; color: var(--primary-dark); }
.system-check-card.ok { border-color: rgba(47,111,67,.22); background: rgba(47,111,67,.04); }
.system-check-card.warn { border-color: rgba(208,131,44,.28); background: rgba(208,131,44,.06); }
.system-check-list {
  list-style: none;
  padding: 0;
  margin: 18px 0 0;
  display: grid;
  gap: 10px;
}
.system-check-list li {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.72);
}
.system-check-list li.ok { border-color: rgba(47,111,67,.22); }
.system-check-list li.warn { border-color: rgba(208,131,44,.34); background: rgba(208,131,44,.06); }
.system-check-list li strong { color: var(--primary-dark); }
.system-check-list li span { color: var(--muted); }
.danger-note { color: #9b2f2b !important; }

@media (max-width: 860px) {
  .system-check-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
  .system-check-summary { grid-template-columns: 1fr; }
  body[data-page="admin"] .admin-table.responsive-ready thead { display: none; }
  body[data-page="admin"] .admin-table.responsive-ready,
  body[data-page="admin"] .admin-table.responsive-ready tbody,
  body[data-page="admin"] .admin-table.responsive-ready tr,
  body[data-page="admin"] .admin-table.responsive-ready td { display: block; width: 100%; }
  body[data-page="admin"] .admin-table.responsive-ready tr {
    margin: 0 0 12px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 10px 24px rgba(28,48,78,.05);
  }
  body[data-page="admin"] .admin-table.responsive-ready td {
    border: 0 !important;
    padding: 9px 4px !important;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    text-align: right;
  }
  body[data-page="admin"] .admin-table.responsive-ready td::before {
    content: attr(data-label);
    color: var(--muted);
    font-weight: 800;
    text-align: left;
  }
}
@media print {
  body.print-admin-detail-mode * { visibility: hidden !important; }
  body.print-admin-detail-mode #admin-result-detail,
  body.print-admin-detail-mode #admin-result-detail * { visibility: visible !important; }
  body.print-admin-detail-mode #admin-result-detail {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    padding: 20px;
    background: #fff;
  }
  body.print-admin-detail-mode .admin-followup-panel,
  body.print-admin-detail-mode .admin-log-panel,
  body.print-admin-detail-mode .detail-actions { display: none !important; }
}

/* v1.32 운영 로그 10개 단위 페이지 처리 */
.log-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.log-section-head h4 {
  margin-bottom: 0;
}
.log-section-head .table-count {
  color: var(--muted);
  font-weight: 800;
  white-space: nowrap;
}
.admin-log-footer {
  display: flex;
  justify-content: flex-end;
  margin-top: 12px;
}
@media (max-width: 640px) {
  .log-section-head {
    align-items: flex-start;
    flex-direction: column;
  }
  .admin-log-footer {
    justify-content: flex-start;
  }
}


/* v1.32 운영 로그 정리 */
.admin-log-maintenance {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto;
  gap: 16px;
  align-items: end;
  padding: 18px;
  margin: 0 0 18px;
  border: 1px solid rgba(182, 64, 59, 0.18);
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(255,255,255,0.95), rgba(255,248,246,0.9));
  box-shadow: 0 14px 32px rgba(28,48,78,0.06);
}
.admin-log-maintenance h4 {
  margin: 4px 0 6px;
  color: var(--primary);
  font-size: 18px;
}
.admin-log-maintenance-controls {
  display: grid;
  grid-template-columns: 180px 150px auto;
  gap: 10px;
  align-items: end;
}
.log-export-actions {
  justify-content: flex-end;
  margin: -2px 0 10px;
}
.btn.btn-sm {
  min-height: 36px;
  padding: 8px 12px;
  font-size: 13px;
  border-radius: 12px;
}
@media (max-width: 980px) {
  .admin-log-maintenance,
  .admin-log-maintenance-controls {
    grid-template-columns: 1fr;
  }
  .log-export-actions {
    justify-content: flex-start;
  }
}


#access-code-status.error {
  color: #9f2a23;
  background: #fff1f0;
  border: 1px solid #f0b8b3;
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 800;
}

.admin-confirm-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(17, 24, 39, 0.56);
}

.admin-confirm-dialog {
  width: min(480px, 100%);
  padding: 22px;
  border: 1px solid rgba(182, 64, 59, 0.18);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 24px 70px rgba(17, 24, 39, 0.25);
}

.admin-confirm-dialog h3 {
  margin: 0 0 10px;
  color: #9f2a23;
  font-size: 20px;
}

.admin-confirm-dialog p {
  margin: 0 0 16px;
  color: #374151;
  line-height: 1.6;
}

.admin-confirm-check {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 12px;
  border: 1px solid #f0b8b3;
  border-radius: 8px;
  background: #fff7f6;
  color: #4b5563;
  font-weight: 800;
}

.admin-confirm-check input {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: #b6403b;
}

.admin-confirm-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
}

.admin-confirm-actions .btn:disabled {
  cursor: not-allowed;
  opacity: 0.45;
}

@media (max-width: 520px) {
  .admin-confirm-actions {
    flex-direction: column-reverse;
  }
}

/* v1.35 compact participant UX: keep the first screen focused on start flow */
body[data-page="user"] .easy-summary-panel,
body[data-page="user"] .glossary-details,
body[data-page="user"] .live-stats-row,
body[data-page="user"] .live-stats-caption,
body[data-page="user"] .feature-chips,
body[data-page="user"] .plain-help-box {
  display: none !important;
}

body[data-page="user"] .hero-desc {
  max-width: 760px;
}

body[data-page="user"] .privacy-notice,
body[data-page="user"] .input-guide-box {
  padding: 12px 14px;
  margin: 12px 0;
  font-size: .95rem;
}

body[data-page="user"] .survey-helper-panel {
  gap: 12px;
}

body[data-page="user"] .survey-glossary-details:not([open]) {
  margin-top: 0;
}

body[data-page="user"] input.field-invalid {
  border-color: #c53030;
  background: #fff7f7;
}

body[data-page="user"] .field-error {
  color: #c53030;
  font-weight: 800;
  font-size: .9rem;
}

/* v1.37 survey UX refinement */
body[data-page="user"] .domain-easy-panel {
  padding: 14px 16px;
  border-radius: 16px;
  background: #ffffff;
  color: var(--primary-dark);
  border: 1px solid rgba(47,111,149,.16);
  box-shadow: 0 10px 24px rgba(16,43,72,.05);
}

body[data-page="user"] .domain-easy-panel .soft-label {
  background: rgba(47,111,149,.09);
  color: var(--primary-dark);
}

body[data-page="user"] .domain-easy-panel h3 {
  margin: 8px 0 5px;
  font-size: 1.14rem;
}

body[data-page="user"] .domain-easy-panel p {
  color: #526579;
  line-height: 1.55;
  font-size: .96rem;
}

body[data-page="user"] .question-card {
  padding: 17px 18px;
  border-radius: 14px;
  border-color: rgba(219,229,241,.9);
  box-shadow: 0 8px 24px rgba(15,39,71,.045);
}

body[data-page="user"] .question-card::before {
  display: none;
}

body[data-page="user"] .question-headline h4 {
  margin: 0 0 28px;
  font-size: 1rem;
  line-height: 1.45;
}

body[data-page="user"] .question-help {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 11px 13px;
  margin: 30px 0 0;
  border-radius: 10px;
  background: #f6f9fd;
  border-color: rgba(219,229,241,.95);
}

body[data-page="user"] .question-help strong {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 9px;
  margin: 0;
  border-radius: 999px;
  background: #e9f1f8;
  font-size: .84rem;
}

body[data-page="user"] .question-help p {
  line-height: 1.5;
  font-size: .94rem;
}

body[data-page="user"] .option-guide {
  display: none !important;
}

body[data-page="user"] .option-list {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

body[data-page="user"] .option-btn {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  padding: 8px 10px;
  border-radius: 8px;
  border-color: rgba(219,229,241,.95);
  box-shadow: none;
}

body[data-page="user"] .option-btn:hover {
  border-color: rgba(47,111,149,.55);
  background: #f4f9ff;
}

body[data-page="user"] .option-score {
  flex: 0 0 26px;
  width: 26px;
  height: 26px;
  font-size: .86rem;
}

body[data-page="user"] .option-label {
  line-height: 1.35;
  font-size: .92rem;
}

body[data-page="user"] .option-btn.active {
  background: #eaf4ff;
  color: #173f5f;
  border-color: #2f5f97;
  box-shadow: inset 0 0 0 1px rgba(47,95,151,.25);
}

body[data-page="user"] .option-btn.active .option-score {
  background: #173f5f;
  color: #fff;
}

body[data-page="user"] .missing-alert {
  background: #f4f9ff;
  border-color: rgba(47,111,149,.18);
  color: #173f5f;
}

body[data-page="user"] .missing-alert button {
  color: #173f5f;
  border-color: rgba(47,111,149,.22);
}

body[data-page="user"] .question-card.missing-focus {
  outline: 3px solid rgba(47,111,149,.22);
  border-color: #2f5f97;
}

@media (max-width: 1100px) {
  body[data-page="user"] .option-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  body[data-page="user"] .question-help {
    display: block;
  }
  body[data-page="user"] .question-help strong {
    margin-bottom: 6px;
  }
  body[data-page="user"] .option-list {
    grid-template-columns: 1fr;
  }
}

/* v1.38 survey readability spacing/color */
body[data-page="user"] .survey-body {
  gap: 28px;
}

body[data-page="user"] .question-card {
  margin-bottom: 2px;
}

body[data-page="user"] .option-btn {
  background: #f8fbff;
  border-color: #cddbec;
  color: #1e293b;
}

body[data-page="user"] .option-btn:nth-child(even) {
  background: #f4f8fd;
}

body[data-page="user"] .option-score {
  background: #dfeaf6;
  color: #173f5f;
  border: 1px solid #c4d6e9;
}

body[data-page="user"] .option-label {
  color: #172033;
  font-weight: 800;
}

body[data-page="user"] .option-btn:hover {
  background: #eef6ff;
  border-color: #78a8d4;
}

body[data-page="user"] .option-btn.active {
  background: #dceeff;
  border-color: #2f6f95;
  color: #102033;
}

body[data-page="user"] .option-btn.active .option-score {
  background: #173f5f;
  border-color: #173f5f;
  color: #fff;
}

/* v1.39 main diagnosis stats banner: colorful DB summary below the second hero banner */
body[data-page="user"] .colorful-main-stats {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin: 22px 0 10px;
}

body[data-page="user"] .colorful-main-stats .live-stat-card {
  min-height: 150px;
  padding: 22px 24px;
  border: 0;
  border-radius: 20px;
  color: #fff;
  box-shadow: 0 18px 42px rgba(15, 42, 72, .16);
}

body[data-page="user"] .colorful-main-stats .live-stat-card:nth-child(1) {
  background: linear-gradient(135deg, #1d4ed8, #06b6d4);
}

body[data-page="user"] .colorful-main-stats .live-stat-card:nth-child(2) {
  background: linear-gradient(135deg, #047857, #84cc16);
}

body[data-page="user"] .colorful-main-stats .live-stat-card:nth-child(3) {
  background: linear-gradient(135deg, #7c3aed, #f97316);
}

body[data-page="user"] .colorful-main-stats .live-stat-card::after {
  left: 24px;
  right: 24px;
  bottom: 16px;
  height: 5px;
  background: rgba(255,255,255,.42);
}

body[data-page="user"] .colorful-main-stats .stat-icon {
  width: 46px;
  height: 46px;
  border-radius: 15px;
  color: #fff;
  background: rgba(255,255,255,.18);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);
}

body[data-page="user"] .colorful-main-stats .live-stat-card strong {
  color: #fff;
  font-size: clamp(2.1rem, 4vw, 3rem);
}

body[data-page="user"] .colorful-main-stats .live-stat-card span,
body[data-page="user"] .colorful-main-stats .live-stat-card em {
  color: rgba(255,255,255,.92);
}

body[data-page="user"] .colorful-main-stats .live-stat-card span {
  font-size: 1.08rem;
}

body[data-page="user"] .colorful-main-stats .live-stat-card em {
  padding-bottom: 10px;
}

body[data-page="user"] .colorful-main-stats-caption {
  display: block !important;
  margin: 0 4px 22px;
  text-align: right;
  color: #5b6b80;
}

@media (max-width: 900px) {
  body[data-page="user"] .colorful-main-stats {
    grid-template-columns: 1fr;
  }

  body[data-page="user"] .colorful-main-stats-caption {
    text-align: left;
  }
}
