:root{
  --ink:#172033;
  --ink2:#334155;
  --muted:#7a8494;
  --line:#e6eaf1;
  --soft:#f7f8fb;
  --paper:#ffffff;
  --ivory:#fffdf7;
  --gold:#b99a52;
  --gold2:#ead9a8;
  --navy:#111a2e;
  --navy2:#1c2942;
  --blue:#5b7cfa;
  --green:#4d9f72;
  --red:#da6c6c;
  --shadow:0 14px 34px rgba(17,26,46,.075);
  --shadow-soft:0 8px 22px rgba(17,26,46,.055);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:linear-gradient(180deg,#ffffff 0%,#f6f7fa 48%,#eef2f7 100%);
  color:var(--ink);
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI","Apple SD Gothic Neo","Noto Sans KR",sans-serif;
  font-size:15px;
  line-height:1.58;
  letter-spacing:-.015em;
}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.app{max-width:1280px;margin:0 auto;padding:26px 20px 72px}
.top{
  display:flex;
  justify-content:space-between;
  gap:22px;
  align-items:flex-start;
  margin-bottom:16px;
  border-radius:30px;
  padding:28px;
  background:
    radial-gradient(circle at 82% 10%,rgba(185,154,82,.36),transparent 30%),
    linear-gradient(135deg,#10192b 0%,#172033 58%,#25344f 100%);
  color:#fff;
  box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.08);
}
.brand h1{font-size:31px;line-height:1.15;margin:10px 0 10px;font-weight:900;letter-spacing:-.045em}
.brand p{margin:0;color:#dce2ec;font-size:15px;max-width:820px}
.badge{
  display:inline-flex;gap:8px;align-items:center;
  background:rgba(255,255,255,.10);
  color:#fff;
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;
  padding:8px 13px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.02em;
  box-shadow:none;
  white-space:nowrap;
}
.actions{display:flex;gap:9px;flex-wrap:wrap;justify-content:flex-end;min-width:250px}
.btn{
  border:0;border-radius:14px;padding:10px 14px;
  background:var(--navy);color:#fff;font-weight:850;font-size:14px;
  box-shadow:0 10px 20px rgba(17,26,46,.12);
  transition:.16s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn.secondary{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:none}
.btn.gold{background:linear-gradient(135deg,#9b7a32,#c8ad6f);color:white}
.btn.ghost{background:transparent;color:var(--ink);border:1px dashed #cfd6e2;box-shadow:none}
.top .btn.secondary{background:rgba(255,255,255,.95)}
.layout{display:block}
.panel{
  background:rgba(255,255,255,.96);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
}
.side{
  position:relative;
  top:auto;
  align-self:auto;
  overflow:hidden;
  margin-bottom:18px;
  padding:18px;
  background:linear-gradient(180deg,#fff,#fbfcff);
}
.side-head{
  padding:0 2px 14px;
  border-bottom:0;
  background:transparent;
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:12px;
}
.side-head h2{margin:0;font-size:17px;letter-spacing:-.035em;font-weight:950}
.side-head small{display:block;color:var(--muted);font-size:12px;margin-top:2px}
.steps{
  padding:0;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.step-nav{
  display:flex;
  gap:10px;
  padding:12px;
  border-radius:18px;
  border:1px solid var(--line);
  background:#fff;
  text-align:left;
  width:100%;
  align-items:center;
  min-height:72px;
  box-shadow:0 6px 16px rgba(17,26,46,.035);
  position:relative;
  overflow:hidden;
}
.step-nav:hover{background:#fbfcff;transform:translateY(-1px)}
.step-nav.active{background:linear-gradient(135deg,#111a2e,#1d2a42);color:white;border-color:#111a2e;box-shadow:0 12px 26px rgba(17,26,46,.16)}
.step-nav.active:before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(90deg,#b99a52,#ead9a8)}
.step-no{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;font-weight:950;background:#f0f3f8;color:var(--ink);flex:0 0 auto;font-size:13px}
.step-nav.active .step-no{background:var(--gold);color:white}
.step-title{display:block;font-weight:950;font-size:13px;line-height:1.15}
.step-desc{display:block;font-size:12px;color:var(--muted);margin-top:2px;line-height:1.25}
.step-nav.active .step-desc{color:#d9dfeb}
.side-box-wrap{display:grid;grid-template-columns:1.4fr .8fr;gap:10px;margin-top:10px}
.side-box{margin:10px 0 0;padding:13px 14px;border-radius:18px;background:#f7f8fb;border:1px solid var(--line)}
.side-box b{display:block;margin-bottom:4px;font-size:13px}
.side-box .mini{font-size:12px;color:var(--muted);line-height:1.55}
.main{min-width:0}
.section{padding:24px;margin-bottom:18px}
.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px}
.section h2{font-size:25px;line-height:1.18;margin:0;letter-spacing:-.045em;font-weight:950}
.section p.sub{margin:7px 0 0;color:var(--muted);font-size:14px}
.section h3{font-size:17px;margin:14px 0 12px;letter-spacing:-.03em}
.grid{display:grid;gap:12px}
.region-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.card-btn{
  border:1px solid var(--line);background:#fff;border-radius:20px;padding:15px;text-align:left;min-height:98px;
  transition:.16s;box-shadow:0 7px 16px rgba(23,32,51,.035)
}
.card-btn:hover{transform:translateY(-2px);box-shadow:0 14px 26px rgba(23,32,51,.07)}
.card-btn.selected{border:2px solid var(--gold);box-shadow:0 12px 28px rgba(185,154,82,.14);background:linear-gradient(180deg,#fff,#fffaf0)}
.card-btn h3{margin:0 0 5px;font-size:18px}
.card-btn .stat{color:var(--muted);font-size:12px}
.chip-row{display:flex;gap:8px;flex-wrap:wrap}
.chip{border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 12px;font-size:13px;font-weight:850;color:var(--ink2)}
.chip.selected,.chip:hover{background:#111a2e;color:#fff;border-color:#111a2e}
.chip.gold{background:#fff8df;border-color:#edd894;color:#74591c}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.search,.select{border:1px solid var(--line);border-radius:14px;padding:10px 12px;background:#fff;font-size:14px}
.search{min-width:200px}
.material-wrap{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.material-box{border:1px solid var(--line);border-radius:22px;background:#fff;padding:16px}
.material-box h3{margin:0 0 11px;font-size:16px}
.material-list{display:flex;flex-wrap:wrap;gap:8px}
.material-chip{border:1px solid var(--line);border-radius:999px;background:#f8fafc;padding:8px 11px;font-size:13px;font-weight:850}
.material-chip.selected{background:#111a2e;color:#fff;border-color:#111a2e}
.material-chip .count{font-size:10px;color:var(--muted);margin-left:4px}
.material-chip.selected .count{color:#dfe5f0}
.material-selected-bar{margin-top:12px;border:1px solid rgba(168,137,66,.28);background:#fffaf0;border-radius:18px;padding:13px 14px;display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}
.material-selected-bar b{font-size:13px;color:#172033}
.material-selected-bar span{display:block;margin-top:3px;font-size:12px;color:#667085}
.selected-material-list{display:flex;gap:7px;flex-wrap:wrap;align-items:center;justify-content:flex-end}
.selected-material-pill{border:1px solid rgba(168,137,66,.35);border-radius:999px;background:#fff;color:#806021;padding:6px 10px;font-size:12px;font-weight:900}
.material-clear-btn{border:1px solid var(--line);border-radius:999px;background:#fff;color:#475569;padding:6px 10px;font-size:12px;font-weight:850;cursor:pointer}
.direction-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.option-card{border:1px solid var(--line);border-radius:22px;background:#fff;padding:17px;min-height:122px;transition:.16s}
.option-card:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(17,26,46,.06)}
.option-card.selected{border:2px solid var(--gold);background:#fffaf0}
.option-card b{font-size:16px}
.option-card p{color:var(--muted);margin:7px 0 0;font-size:13px}
.sticky-next{display:flex;justify-content:flex-end;gap:9px;margin-top:20px}
.result-hero{display:grid;grid-template-columns:minmax(280px,340px) 1fr;gap:20px;align-items:stretch}
.taste-card{border:1px solid var(--line);border-radius:24px;background:#fff;padding:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:310px}
.radar-title{font-size:12px;font-weight:950;margin-bottom:6px;color:var(--ink)}
.concept-main{border:1px solid var(--line);border-radius:24px;background:#fff;padding:20px;min-width:0}
.concept-main h3{font-size:26px;letter-spacing:-.045em;margin:0 0 10px;font-weight:950}
.concept-meta{display:flex;gap:7px;flex-wrap:wrap;margin:7px 0 15px}
.pill{border-radius:999px;padding:7px 11px;background:#eef2f7;color:var(--ink2);font-weight:850;font-size:12px;display:inline-flex;margin:2px 3px 2px 0}
.pill.gold{background:#fff0c8;color:#76591b}
.data-table{width:100%;border-collapse:collapse;overflow:hidden;border-radius:16px;font-size:14px}
.data-table th{width:128px;text-align:left;background:#f6f8fb;color:var(--ink);font-weight:950}
.data-table th,.data-table td{padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:top}
.insight{margin-top:15px;border:1px solid #ead9a8;border-radius:20px;background:#fffdf6;padding:15px;font-size:15px;color:#4d5566;line-height:1.68}
.mini-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin-top:16px}
.mini-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:16px}
.mini-card h4{margin:8px 0 9px;font-size:18px}
.mini-card .mini-layout{display:grid;grid-template-columns:120px 1fr;gap:12px;align-items:center}
.benchmark-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(430px,1fr));gap:16px}
.benchmark-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:19px}
.benchmark-card h3{margin:0;font-size:22px;letter-spacing:-.04em;border-bottom:2px solid #ecdcae;padding-bottom:10px}
.bench-body{display:grid;grid-template-columns:210px 1fr;gap:15px;margin-top:15px}
.bench-radar{border:1px solid var(--line);background:#fafbfe;border-radius:22px;padding:12px;display:flex;align-items:center;justify-content:center;min-height:230px}
.ai-label{display:inline-flex;align-items:center;background:#111a2e;color:white;border-radius:999px;font-weight:950;padding:7px 12px;margin-top:14px;font-size:13px}
.report{white-space:pre-wrap;background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;color:#2f3c52;font-size:14px;line-height:1.72}
.admin-login,.admin-area{display:none}.admin-login.show,.admin-area.show{display:block}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:11px}
.field label{display:block;font-weight:900;margin-bottom:5px;font-size:13px}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:13px;padding:10px;background:#fff;font-size:14px}
.field textarea{min-height:82px}
.admin-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.admin-tab{border:1px solid var(--line);background:#fff;padding:9px 13px;border-radius:999px;font-weight:900;font-size:13px}
.admin-tab.active{background:#111a2e;color:#fff}
.admin-pane{display:none}.admin-pane.active{display:block}
.notice{border:1px solid #dce3ee;background:#f8fafc;border-radius:18px;padding:14px;color:#526176;font-size:14px;line-height:1.62}
.empty{padding:22px;border:1px dashed #cfd6e2;border-radius:20px;text-align:center;color:var(--muted);background:#fafbfe}
.small{font-size:12px;color:var(--muted)}
.compare-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:9px;margin-top:14px}
.metric{border:1px solid var(--line);border-radius:16px;padding:12px;background:#fff}
.metric b{display:block;font-size:21px}
.footer-actions{display:flex;gap:9px;flex-wrap:wrap;margin-top:14px}
.section.step-page{display:none;animation:fadeIn .18s ease-out}.section.step-page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.step-guide{display:grid;grid-template-columns:48px 1fr;gap:13px;align-items:center;background:linear-gradient(135deg,#fffaf0,#ffffff);border:1px solid #ead9a8;border-radius:22px;padding:14px;margin-bottom:16px}
.step-guide strong{display:grid;place-items:center;width:48px;height:48px;border-radius:16px;background:#111a2e;color:#fff;font-size:19px}
.step-guide b{display:block;font-size:16px}
.step-guide span{display:block;color:#718096;font-size:13px}
@media(max-width:900px){
  .app{padding:18px 14px 60px}.top{flex-direction:column;padding:24px}.actions{justify-content:flex-start;min-width:0}.brand h1{font-size:28px}
  .steps{grid-template-columns:repeat(2,minmax(0,1fr))}.result-hero{grid-template-columns:1fr}.bench-body{grid-template-columns:1fr}.benchmark-grid{grid-template-columns:1fr}.section-head{flex-direction:column}.search{min-width:0;width:100%}.toolbar{width:100%}
}
@media(max-width:620px){
  body{font-size:14px}.app{padding:14px 10px 52px}.top{border-radius:24px;padding:20px}.section{padding:18px}.steps{grid-template-columns:1fr}.step-nav{min-height:64px}.mini-card .mini-layout{grid-template-columns:1fr}.benchmark-card{padding:15px}.section h2{font-size:22px}.concept-main h3{font-size:23px}.side{padding:14px}.side-head{display:block}.region-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* v6 UX / PDF / data protection refinements */
.btn.pdf{background:linear-gradient(135deg,#111a2e 0%,#243652 58%,#b99a52 100%);color:#fff;border:0;box-shadow:0 12px 26px rgba(17,26,46,.16)}
.btn.subtle{background:#f8fafc;color:#334155;border:1px solid var(--line);box-shadow:none}
.result-actionbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 14px;border:1px solid var(--line);border-radius:20px;background:linear-gradient(135deg,#ffffff,#f8fafc);box-shadow:0 8px 20px rgba(17,26,46,.045)}
.result-actionbar .result-status{display:flex;align-items:center;gap:9px;color:#64748b;font-size:13px;font-weight:750}
.result-status:before{content:"";width:9px;height:9px;border-radius:999px;background:#4d9f72;box-shadow:0 0 0 4px rgba(77,159,114,.12)}
.result-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.result-section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:34px}
.result-section-title h2{margin:0!important}
.security-note{margin-top:14px;border:1px solid rgba(185,154,82,.34);background:linear-gradient(135deg,#fffdf7,#ffffff);border-radius:20px;padding:14px 16px;display:grid;grid-template-columns:34px 1fr;gap:10px;align-items:flex-start;color:#475569;font-size:13px;line-height:1.62}
.security-note b{display:block;color:#172033;margin-bottom:2px;font-size:13px}.security-note .lock{width:34px;height:34px;border-radius:12px;background:#111a2e;color:white;display:grid;place-items:center;font-weight:950}
.taste-card,.concept-main,.benchmark-card,.mini-card{transition:.18s ease}.taste-card:hover,.concept-main:hover,.benchmark-card:hover,.mini-card:hover{transform:translateY(-1px);box-shadow:0 12px 30px rgba(17,26,46,.07)}
.concept-main{background:linear-gradient(180deg,#ffffff,#fbfcff)}
.ai-label{letter-spacing:-.02em}.insight{font-size:14px}.report{font-size:13.5px}
/* v8 PDF export fix: the report must be rendered in the document, not far off-screen. html2canvas can output a blank PDF when the source node is positioned at left:-99999px. */
.pdf-report-shell{position:absolute;left:0;top:0;width:794px;min-height:1123px;background:#fff;color:#172033;padding:28px;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI","Apple SD Gothic Neo","Noto Sans KR",sans-serif;letter-spacing:-.01em;z-index:999999;pointer-events:none;box-sizing:border-box;-webkit-print-color-adjust:exact;print-color-adjust:exact}
.pdf-report-shell *{box-sizing:border-box;-webkit-print-color-adjust:exact;print-color-adjust:exact}
.pdf-export-loading{position:fixed;inset:0;display:grid;place-items:center;background:rgba(15,23,42,.44);backdrop-filter:blur(4px);z-index:999998}
.pdf-export-loading .box{background:#fff;border:1px solid #e6eaf1;border-radius:20px;padding:18px 22px;box-shadow:0 24px 70px rgba(17,26,46,.18);font-weight:900;color:#111a2e;letter-spacing:-.03em}
.pdf-export-loading .box span{display:block;margin-top:6px;color:#64748b;font-weight:650;font-size:13px}
.pdf-report-shell .pdf-cover{border:1px solid #e6eaf1;border-radius:22px;padding:22px;margin-bottom:18px;background:linear-gradient(135deg,#111a2e,#243652);color:white}
.pdf-report-shell .pdf-cover .eyebrow{display:inline-flex;border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:6px 10px;font-size:11px;font-weight:900;color:#fff;margin-bottom:10px}.pdf-report-shell .pdf-cover h1{font-size:25px;line-height:1.2;margin:0 0 8px;font-weight:950;letter-spacing:-.04em}.pdf-report-shell .pdf-cover p{margin:0;color:#dfe6f0;font-size:12px}
.pdf-report-shell .section,.pdf-report-shell .panel{box-shadow:none!important}.pdf-report-shell .result-hero{grid-template-columns:260px 1fr;gap:14px}.pdf-report-shell .taste-card{min-height:260px}.pdf-report-shell .benchmark-grid,.pdf-report-shell .mini-cards{grid-template-columns:1fr}.pdf-report-shell .footer-actions,.pdf-report-shell .result-actionbar,.pdf-report-shell .toolbar{display:none!important}.pdf-report-shell .benchmark-card,.pdf-report-shell .mini-card,.pdf-report-shell .concept-main,.pdf-report-shell .taste-card{break-inside:avoid;page-break-inside:avoid}.pdf-report-shell h2{break-after:avoid}.pdf-report-shell svg{max-width:100%;height:auto}.pdf-report-shell .section{padding:0;margin:0}.pdf-report-shell .report{white-space:pre-wrap}
@media print{
  body{background:#fff!important}.top,.side,.step-guide,.section-head .toolbar,.sticky-next,.footer-actions,.result-actionbar,#adminSection{display:none!important}.app{max-width:none;padding:0}.panel,.section,.taste-card,.concept-main,.benchmark-card,.mini-card{box-shadow:none!important}.section{padding:0;border:0}.step-page{display:none!important}#step4{display:block!important}#resultArea{display:block!important}.benchmark-card,.mini-card,.concept-main,.taste-card{break-inside:avoid;page-break-inside:avoid}.benchmark-grid,.mini-cards{grid-template-columns:1fr}.result-hero{grid-template-columns:1fr 1fr}.insight{font-size:12px}.report{font-size:12px}
}


/* v7 premium UI/UX refresh */
:root{
  --ink:#111827;
  --ink2:#334155;
  --muted:#7b8495;
  --line:#e4e8f0;
  --soft:#f6f8fb;
  --paper:#ffffff;
  --ivory:#fffdf7;
  --gold:#b79a58;
  --gold-dark:#8f7131;
  --gold2:#ead9a8;
  --navy:#10192b;
  --navy2:#1b2840;
  --shadow:0 24px 70px rgba(17,26,46,.085);
  --shadow-soft:0 16px 42px rgba(17,26,46,.06);
  --radius:30px;
}
body{
  background:
    radial-gradient(circle at 8% -8%,rgba(185,154,82,.14),transparent 30%),
    radial-gradient(circle at 88% 2%,rgba(17,26,46,.10),transparent 26%),
    linear-gradient(180deg,#fbfcff 0%,#f6f8fb 46%,#eef2f7 100%);
  color:var(--ink);
  font-size:14.5px;
}
.app{max-width:1500px;padding:30px 28px 86px}
.top{
  position:relative;
  overflow:hidden;
  align-items:center;
  padding:36px 38px;
  border-radius:36px;
  margin-bottom:22px;
  background:
    radial-gradient(circle at 82% 18%,rgba(215,187,111,.30),transparent 28%),
    radial-gradient(circle at 8% 12%,rgba(255,255,255,.10),transparent 24%),
    linear-gradient(135deg,#0d1628 0%,#14213a 48%,#263653 100%);
  box-shadow:0 28px 80px rgba(16,25,43,.22);
}
.top:before{
  content:"";
  position:absolute;
  inset:0;
  background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:34px 34px;
  mask-image:linear-gradient(90deg,rgba(0,0,0,.8),transparent 86%);
  pointer-events:none;
}
.top:after{
  content:"";
  position:absolute;
  right:-80px;bottom:-120px;width:310px;height:310px;border-radius:999px;
  border:1px solid rgba(234,217,168,.28);
  box-shadow:inset 0 0 0 36px rgba(255,255,255,.025);
  pointer-events:none;
}
.brand,.actions{position:relative;z-index:1}
.brand h1{font-size:35px;line-height:1.13;margin:12px 0 12px;font-weight:950;letter-spacing:-.055em;max-width:920px}
.brand p{font-size:15px;color:#d7deea;max-width:850px;line-height:1.72}
.badge{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.24);backdrop-filter:blur(10px);padding:8px 14px;font-size:11.5px;letter-spacing:.08em}
.actions{gap:10px}.btn{border-radius:16px;padding:10px 15px;font-size:13.5px;font-weight:900}.btn.secondary{background:#fff;color:#111827;border-color:#e2e8f0}.btn:hover{transform:translateY(-2px);filter:saturate(1.04)}
.side{
  display:grid;
  grid-template-columns:220px minmax(520px,1fr) minmax(210px,.5fr) minmax(190px,.45fr);
  gap:12px;
  align-items:stretch;
  position:sticky;
  top:12px;
  z-index:20;
  padding:14px;
  margin-bottom:22px;
  border:1px solid rgba(226,232,240,.86);
  border-radius:30px;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(16px);
  box-shadow:0 18px 58px rgba(17,26,46,.08);
}
.side-head{
  padding:14px 16px;
  border-radius:22px;
  background:linear-gradient(135deg,#111a2e,#1b2840);
  color:#fff;
  align-items:center;
}
.side-head h2{font-size:15px;color:#fff}.side-head small{color:#c9d2df;font-size:11.5px;line-height:1.45}
.steps{gap:8px;align-content:stretch}.step-nav{min-height:68px;border-radius:20px;padding:11px 12px;background:#f8fafc;border:1px solid rgba(226,232,240,.9);box-shadow:none}.step-nav:hover{background:#fff;box-shadow:0 12px 28px rgba(17,26,46,.055)}.step-nav.active{background:linear-gradient(135deg,#111a2e,#223451);box-shadow:0 14px 30px rgba(17,26,46,.18);border-color:rgba(17,26,46,.2)}.step-nav.active:before{height:3px;background:linear-gradient(90deg,#b79a58,#efe0ad)}.step-no{width:32px;height:32px;border-radius:13px;background:#edf1f6}.step-nav.active .step-no{background:#b79a58;color:white}.step-title{font-size:12.5px;letter-spacing:-.02em}.step-desc{font-size:11.5px}
.side-box{margin:0;padding:14px 15px;border-radius:22px;background:#f8fafc;border:1px solid rgba(226,232,240,.92)}.side-box b{font-size:12.5px}.side-box .mini{font-size:11.5px;color:#667085;line-height:1.55}
.section{
  padding:30px;
  margin-bottom:22px;
  border-radius:34px;
  border:1px solid rgba(226,232,240,.9);
  background:rgba(255,255,255,.92);
  box-shadow:0 22px 70px rgba(17,26,46,.065);
}
.step-guide{
  grid-template-columns:42px 1fr;
  gap:12px;
  padding:12px 14px;
  margin-bottom:22px;
  border-radius:24px;
  background:linear-gradient(135deg,#fff9ec 0%,#ffffff 72%);
  border:1px solid rgba(185,154,82,.28);
  box-shadow:0 10px 24px rgba(185,154,82,.06);
}
.step-guide strong{width:42px;height:42px;border-radius:16px;font-size:17px;background:linear-gradient(135deg,#111a2e,#243653)}.step-guide b{font-size:15px}.step-guide span{font-size:12.5px;color:#798396}
.section-head{align-items:center;margin-bottom:24px}.section h2{font-size:30px;letter-spacing:-.06em;line-height:1.1}.section p.sub{font-size:13.5px;color:#7b8495;margin-top:9px}.toolbar{gap:10px}.search,.select{border-radius:18px;border-color:#e2e8f0;background:#fff;height:48px;padding:0 16px;box-shadow:inset 0 1px 0 rgba(17,26,46,.025),0 8px 18px rgba(17,26,46,.035)}.search{min-width:250px}
.region-grid{grid-template-columns:repeat(auto-fill,minmax(205px,1fr));gap:16px}.region-card{position:relative;display:flex;flex-direction:column;gap:8px;min-height:148px;padding:20px;border-radius:28px;background:linear-gradient(180deg,#ffffff 0%,#fbfcff 100%);border:1px solid rgba(226,232,240,.95);box-shadow:0 13px 32px rgba(17,26,46,.045);overflow:hidden}.region-card:before{content:"";position:absolute;left:18px;right:18px;top:0;height:4px;border-radius:999px;background:linear-gradient(90deg,#b79a58,#ead9a8);opacity:0;transition:.16s}.region-card:after{content:"";position:absolute;right:-28px;bottom:-36px;width:100px;height:100px;border-radius:999px;background:rgba(183,154,88,.07);transition:.16s}.region-card:hover{transform:translateY(-4px);border-color:#d6dce7;box-shadow:0 22px 44px rgba(17,26,46,.09)}.region-card:hover:after{transform:scale(1.12)}.region-card.selected{border:1px solid rgba(183,154,88,.9);background:linear-gradient(145deg,#fffaf0 0%,#ffffff 54%,#f8fafc 100%);box-shadow:0 24px 50px rgba(183,154,88,.18),0 0 0 4px rgba(183,154,88,.09)}.region-card.selected:before{opacity:1}.region-kicker{font-size:10px;letter-spacing:.12em;color:#a78b47;font-weight:950;text-transform:uppercase}.region-title{display:block;font-size:25px;font-weight:950;letter-spacing:-.055em;color:#080f1f;line-height:1.05}.region-count{font-size:13px;color:#7b8495;font-weight:700}.region-materials{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto;position:relative;z-index:1}.region-materials span{display:inline-flex;align-items:center;border-radius:999px;background:#f1f4f8;color:#596579;padding:5px 8px;font-size:11.5px;font-weight:850}.region-card.selected .region-materials span{background:#fff;border:1px solid rgba(183,154,88,.28);color:#735a22}
.notice{border:1px solid rgba(226,232,240,.95);background:linear-gradient(135deg,#f8fafc,#ffffff);border-radius:22px;padding:15px 17px;color:#5b6678;font-size:13.5px}.sticky-next{margin-top:22px}.material-box,.option-card,.taste-card,.concept-main,.benchmark-card,.mini-card,.report{border-radius:28px;border-color:rgba(226,232,240,.95);box-shadow:0 13px 32px rgba(17,26,46,.045)}.material-box{background:linear-gradient(180deg,#fff,#fbfcff);padding:19px}.material-box h3{font-size:16.5px}.material-chip{border-radius:999px;background:#f7f9fc;border-color:#e3e8f1;padding:9px 12px}.material-chip:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(17,26,46,.06)}.material-chip.selected{background:linear-gradient(135deg,#111a2e,#233650);border-color:#111a2e}.material-selected-bar{border-radius:24px;background:linear-gradient(135deg,#fffaf0,#fff);border-color:rgba(183,154,88,.28);padding:14px 16px}.option-card{background:linear-gradient(180deg,#fff,#fbfcff);padding:19px;min-height:126px}.option-card.selected{border:1px solid rgba(183,154,88,.9);background:linear-gradient(145deg,#fffaf0,#fff);box-shadow:0 18px 38px rgba(183,154,88,.14),0 0 0 4px rgba(183,154,88,.08)}.option-card b{font-size:16.5px}.option-card p{font-size:12.8px;line-height:1.6}.result-actionbar{border-radius:24px;padding:14px 16px;background:linear-gradient(135deg,#ffffff,#f7f9fc);box-shadow:0 13px 30px rgba(17,26,46,.045)}.security-note{border-radius:24px}.taste-card,.concept-main{background:linear-gradient(180deg,#ffffff,#fbfcff)}.concept-main h3{font-size:29px}.insight{border-radius:24px;font-size:13.5px;background:linear-gradient(135deg,#fffdf7,#ffffff)}.data-table th{background:#f7f9fc}.ai-label{padding:8px 13px}.footer-actions{gap:10px}
@media(max-width:1180px){.side{position:relative;top:auto;grid-template-columns:1fr}.steps{grid-template-columns:repeat(4,minmax(0,1fr))}.side-head{display:flex}.side-box{display:none}.app{padding:22px 18px 70px}.region-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}
@media(max-width:900px){.top{padding:26px;border-radius:30px}.brand h1{font-size:29px}.steps{grid-template-columns:repeat(2,minmax(0,1fr))}.section{padding:23px;border-radius:28px}.section h2{font-size:26px}.search{min-width:0;width:100%}.region-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.region-card{min-height:132px;padding:17px}.region-title{font-size:22px}}
@media(max-width:620px){body{font-size:14px}.app{padding:14px 10px 54px}.top{padding:22px}.brand h1{font-size:25px}.brand p{font-size:13.5px}.side{padding:11px;border-radius:24px}.steps{grid-template-columns:1fr}.step-nav{min-height:62px}.section{padding:18px;border-radius:24px}.section h2{font-size:23px}.section-head{align-items:flex-start}.region-grid{grid-template-columns:1fr}.region-card{min-height:118px}.step-guide{grid-template-columns:38px 1fr}.step-guide strong{width:38px;height:38px}.toolbar{width:100%}.btn{width:auto}}



/* v10 unified hero workflow override */
.unified-hero{
  display:block;
  padding:34px 36px 30px;
  border-radius:36px;
  margin-bottom:20px;
  overflow:hidden;
  position:relative;
  background:
    radial-gradient(circle at 92% 14%,rgba(255,255,255,.24),transparent 18%),
    radial-gradient(circle at 83% 68%,rgba(185,154,82,.28),transparent 26%),
    linear-gradient(135deg,#10192b 0%,#172033 52%,#263653 100%);
  box-shadow:0 28px 60px rgba(17,26,46,.16);
}
.unified-hero:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:44px 44px;
  mask-image:linear-gradient(90deg,rgba(0,0,0,.8),rgba(0,0,0,.35));
}
.unified-hero:after{
  content:"";
  position:absolute;
  right:-74px;
  top:-96px;
  width:360px;
  height:360px;
  border-radius:50%;
  border:1px solid rgba(234,217,168,.35);
  box-shadow:inset 0 0 80px rgba(255,255,255,.05);
  pointer-events:none;
}
.hero-main,.hero-workflow{position:relative;z-index:1}
.hero-main{display:flex;align-items:flex-start;justify-content:space-between;gap:26px}
.unified-hero .brand h1{font-size:35px;margin:13px 0 11px;letter-spacing:-.06em}
.unified-hero .brand p{font-size:15.5px;color:#e4e9f2;max-width:860px}
.unified-hero .badge{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.26);backdrop-filter:blur(8px)}
.unified-hero .actions{padding-top:38px;min-width:0;flex-wrap:nowrap}
.unified-hero .actions .btn{border-radius:18px;padding:13px 17px;white-space:nowrap;box-shadow:0 14px 26px rgba(0,0,0,.12)}
.unified-hero .actions .btn.secondary{background:#fff;color:#111a2e;border:1px solid rgba(255,255,255,.6)}
.unified-hero .actions .btn.gold{background:linear-gradient(135deg,#b79a58,#d7c180);color:#fff}
.hero-workflow{
  margin-top:28px;
  display:grid;
  grid-template-columns:minmax(160px,.8fr) minmax(430px,2.45fr) minmax(210px,1fr) minmax(190px,.92fr);
  gap:12px;
  align-items:stretch;
}
.workflow-title,.hero-info-card{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.08);
  color:#fff;
  border-radius:24px;
  padding:18px 18px;
  backdrop-filter:blur(10px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.workflow-title{background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.06))}
.workflow-title span{display:inline-flex;margin-bottom:18px;font-size:10px;font-weight:950;letter-spacing:.14em;color:#e5d3a2}
.workflow-title b{display:block;font-size:19px;font-weight:950;letter-spacing:-.04em;line-height:1.2}
.workflow-title small{display:block;margin-top:7px;color:#d9dfeb;font-size:12.5px;line-height:1.5}
.hero-workflow .steps{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.hero-workflow .step-nav{
  min-height:118px;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  gap:12px;
  padding:18px;
  border-radius:24px;
  color:#d9dfeb;
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.12);
  box-shadow:none;
}
.hero-workflow .step-nav:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.hero-workflow .step-nav.active{
  background:linear-gradient(160deg,#ffffff 0%,#fffaf0 100%);
  color:#111a2e;
  border-color:rgba(234,217,168,.82);
  box-shadow:0 22px 44px rgba(0,0,0,.18),0 0 0 1px rgba(234,217,168,.30) inset;
}
.hero-workflow .step-nav.active:before{height:5px;background:linear-gradient(90deg,#b79a58,#ead9a8)}
.hero-workflow .step-no{width:34px;height:34px;border-radius:999px;background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.12)}
.hero-workflow .step-nav.active .step-no{background:#b99a52;color:white;border-color:#b99a52}
.hero-workflow .step-title{font-size:13px;color:inherit}
.hero-workflow .step-desc{font-size:12.5px;color:#bfc7d6}
.hero-workflow .step-nav.active .step-desc{color:#647086}
.hero-info-card b{display:block;font-size:15px;font-weight:950;color:#fff;margin-bottom:8px}
.hero-info-card .mini{font-size:12.8px;color:#d9dfeb;line-height:1.72}
.hero-info-card .mini b{display:inline;color:#fff;font-size:13px;margin:0;font-weight:950}
.layout{display:block}
.main{width:100%}
@media(max-width:1180px){
  .hero-main{flex-direction:column}.unified-hero .actions{padding-top:0}.hero-workflow{grid-template-columns:1fr}.hero-workflow .steps{grid-template-columns:repeat(4,minmax(0,1fr))}.workflow-title,.hero-info-card{padding:16px}
}
@media(max-width:760px){
  .unified-hero{padding:24px 20px;border-radius:28px}.unified-hero .brand h1{font-size:27px}.unified-hero .brand p{font-size:13.5px}.unified-hero .actions{width:100%;display:grid;grid-template-columns:1fr 1fr}.hero-workflow .steps{grid-template-columns:1fr 1fr}.hero-workflow .step-nav{min-height:94px}.workflow-title{display:none}
}
@media(max-width:480px){.unified-hero .actions{grid-template-columns:1fr}.hero-workflow .steps{grid-template-columns:1fr}}


/* v11 map-based region selector */
.map-section-head{align-items:flex-start}
.search.compact{min-width:220px;height:44px;border-radius:18px;font-size:13px}
.region-map-shell{position:relative;display:grid;grid-template-columns:minmax(430px,650px) minmax(280px,1fr);gap:24px;align-items:stretch;margin-top:18px}
.map-panel{position:relative;min-height:650px;border-radius:34px;border:1px solid rgba(226,232,240,.92);background:radial-gradient(circle at 75% 18%,rgba(183,154,88,.14),transparent 32%),linear-gradient(145deg,#ffffff 0%,#f8fafc 100%);box-shadow:0 24px 70px rgba(15,23,42,.08);overflow:hidden;padding:24px}
.map-panel:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(15,23,42,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.04) 1px,transparent 1px);background-size:36px 36px;mask-image:linear-gradient(180deg,rgba(0,0,0,.6),rgba(0,0,0,.05));pointer-events:none}
.map-panel-head{position:relative;z-index:2;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:6px}
.map-panel-head span{display:block;color:#a78b47;font-size:10px;font-weight:950;letter-spacing:.16em}
.map-panel-head b{display:block;margin-top:4px;color:#0e1729;font-size:22px;letter-spacing:-.045em}
.map-panel-head small{display:block;margin-top:7px;color:#758197;font-weight:700;line-height:1.5}
.nationwide-select{position:absolute;right:24px;top:24px;z-index:5;display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(183,154,88,.34);background:#fff;border-radius:999px;padding:11px 16px;color:#172033;font-weight:950;letter-spacing:-.02em;box-shadow:0 14px 32px rgba(15,23,42,.10);cursor:pointer;transition:.18s}
.nationwide-select:before{content:"";width:22px;height:22px;border-radius:999px;background:linear-gradient(135deg,#b79a58,#e7d39a);box-shadow:inset 0 0 0 5px rgba(255,255,255,.45)}
.nationwide-select:hover{transform:translateY(-2px);box-shadow:0 20px 42px rgba(15,23,42,.14)}
.nationwide-select.active{background:linear-gradient(135deg,#b79a58,#d7bd77);color:#fff;border-color:rgba(255,255,255,.24)}
.korea-map{position:relative;z-index:2;width:min(100%,600px);height:auto;display:block;margin:24px auto 0;filter:drop-shadow(0 22px 22px rgba(15,23,42,.10))}
.map-region{cursor:pointer;outline:none;transition:.18s}
.map-region path,.map-region ellipse,.map-region circle{fill:var(--region-fill,#e9edf4);stroke:#ffffff;stroke-width:5;transition:.18s}
.map-region text{font-family:inherit;font-weight:950;fill:#111827;font-size:22px;letter-spacing:-.055em;text-anchor:middle;paint-order:stroke;stroke:#fff;stroke-width:6px;stroke-linejoin:round;pointer-events:none}
.map-region .map-count{font-size:11px;fill:#5d6678;font-weight:850;letter-spacing:-.025em;stroke-width:4px}
.map-region:hover path,.map-region:hover ellipse,.map-region:hover circle{filter:brightness(1.03);transform:translateY(-2px);stroke:#fbf5df;stroke-width:6}
.map-region.active path,.map-region.active ellipse,.map-region.active circle{stroke:#b79a58;stroke-width:7;filter:drop-shadow(0 8px 12px rgba(183,154,88,.28)) brightness(1.02)}
.map-region.filtered{opacity:.18;pointer-events:none}
.map-region.filtered text{opacity:.5}
.map-region .pin{fill:#0f172a;stroke:#fff;stroke-width:3;opacity:.82}
.map-legend{position:relative;z-index:2;display:flex;flex-wrap:wrap;gap:8px;margin:20px auto 0;max-width:620px;color:#657184;font-size:12px;font-weight:800}
.map-legend span{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:999px;background:rgba(255,255,255,.72);border:1px solid rgba(226,232,240,.9)}
.map-legend i{display:block;width:10px;height:10px;border-radius:999px;background:#b79a58}
.region-map-side{display:grid;gap:16px;align-content:start}
.map-side-card{border:1px solid rgba(226,232,240,.92);border-radius:30px;background:linear-gradient(180deg,#fff 0%,#fbfcff 100%);box-shadow:0 20px 52px rgba(15,23,42,.07);padding:24px;min-height:190px}
.map-side-card.primary{background:linear-gradient(145deg,#111827 0%,#202b46 100%);color:#fff;overflow:hidden;position:relative}
.map-side-card.primary:after{content:"";position:absolute;right:-60px;bottom:-70px;width:180px;height:180px;border-radius:999px;background:rgba(183,154,88,.18)}
.map-side-card .eyebrow{display:block;color:#b79a58;font-size:10px;font-weight:950;letter-spacing:.16em;margin-bottom:8px}
.map-side-card.primary .eyebrow{color:#ead9a8}
.map-side-title{font-size:28px;font-weight:950;letter-spacing:-.055em;line-height:1.1;margin:0 0 10px}
.map-side-desc{margin:0;color:#6f7a8f;font-weight:750;line-height:1.65}
.map-side-card.primary .map-side-desc{color:#d7deec}
.map-side-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:18px;position:relative;z-index:1}
.map-side-stat{padding:14px;border-radius:20px;background:rgba(248,250,252,.92);border:1px solid rgba(226,232,240,.95)}
.map-side-card.primary .map-side-stat{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12)}
.map-side-stat small{display:block;color:#8590a3;font-size:11px;font-weight:900;margin-bottom:5px}
.map-side-card.primary .map-side-stat small{color:#bfc8da}
.map-side-stat b{font-size:20px;letter-spacing:-.04em;color:#0e1729}
.map-side-card.primary .map-side-stat b{color:#fff}
.region-chip-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:15px}
.region-chip-list span{display:inline-flex;align-items:center;border-radius:999px;background:#f2f5f9;color:#566175;padding:8px 11px;font-size:12px;font-weight:900}
.map-side-card.primary .region-chip-list span{background:rgba(255,255,255,.10);color:#fff;border:1px solid rgba(255,255,255,.12)}
.map-side-action{margin-top:18px;display:flex;align-items:center;gap:10px;color:#0f172a;font-weight:900;font-size:13px}
.map-side-action:before{content:"";width:28px;height:28px;border-radius:999px;background:linear-gradient(135deg,#b79a58,#ead9a8)}
@media(max-width:1180px){.region-map-shell{grid-template-columns:1fr}.map-panel{min-height:auto}.region-map-side{grid-template-columns:1fr 1fr}.korea-map{max-height:640px}}
@media(max-width:820px){.region-map-side{grid-template-columns:1fr}.map-panel{padding:18px;border-radius:28px}.nationwide-select{position:relative;right:auto;top:auto;margin:12px 0 0}.map-panel-head{display:block}.korea-map{margin-top:16px}.map-region text{font-size:19px}.map-region .map-count{font-size:10px}}
@media(max-width:560px){.region-map-shell{gap:16px}.map-panel{padding:14px}.map-panel-head b{font-size:19px}.korea-map{width:100%;min-width:0}.map-region text{font-size:16px}.map-region .map-count{display:none}.map-side-stats{grid-template-columns:1fr}.search.compact{width:100%;min-width:0}}


/* v12.4 PHP admin page compatibility */


/* v12.4 PHP operation refinements */
.hero-info-card .mini b{display:inline!important;margin:0!important;font-size:13px!important;color:#fff!important;}
.option-card{cursor:pointer;text-align:left;width:100%;}
.benchmark-card .bench-body{grid-template-columns:1fr;}
.benchmark-card .small{display:block;margin-top:4px;}
#step4 .toolbar .btn{white-space:nowrap;}
@media(max-width:760px){.unified-hero .actions{grid-template-columns:1fr!important}.unified-hero .actions .btn{width:100%;}.result-actionbar{align-items:flex-start}.result-actions{width:100%}.result-actions .btn{flex:1}}

/* v12.5 result screen redesign: benchmark recommendation + taster-style report cards */
.benchmark-reco-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(360px,1fr));
  gap:18px;
}
.benchmark-reco-card{
  background:linear-gradient(180deg,#ffffff,#fbfcff);
  border:1px solid rgba(226,232,240,.95);
  border-radius:30px;
  padding:22px;
  box-shadow:0 18px 48px rgba(17,26,46,.06);
  min-height:320px;
}
.benchmark-reco-card h3{
  margin:0;
  font-size:24px;
  letter-spacing:-.055em;
  font-weight:950;
  color:#0f172a;
}
.reco-line{
  height:2px;
  margin:13px 0 18px;
  background:linear-gradient(90deg,#b99a52,#ead9a8,rgba(234,217,168,0));
}
.reco-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.reco-table{font-size:14px;background:#fff;border-radius:18px;overflow:hidden}
.reco-table th{width:124px;background:#f7f9fc;font-size:14px}
.reco-table th,.reco-table td{padding:13px 14px;line-height:1.65}
.concept-visual-grid{
  grid-template-columns:repeat(3,minmax(320px,1fr));
  gap:18px;
}
.concept-visual-card{
  padding:22px;
  border-radius:30px;
  background:linear-gradient(180deg,#ffffff,#fbfcff);
  box-shadow:0 18px 48px rgba(17,26,46,.06);
}
.concept-card-head{display:flex;align-items:flex-start;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.concept-card-head b{display:block;font-size:21px;line-height:1.25;letter-spacing:-.055em;font-weight:950;color:#0f172a;width:100%}
.concept-card-body{display:grid;grid-template-columns:150px 1fr;gap:14px;align-items:center;margin:4px 0 16px}
.concept-radar{
  border:1px solid rgba(226,232,240,.95);
  border-radius:22px;
  background:#fafbfe;
  display:grid;
  place-items:center;
  min-height:160px;
  overflow:hidden;
}
.concept-radar svg{height:160px!important}
.taste-bars{display:grid;gap:8px;min-width:0}
.taste-bar-row span{display:block;font-size:12px;color:#6b7486;font-weight:850;margin-bottom:3px}
.taste-bar-track{height:8px;border-radius:999px;background:#eef2f7;overflow:hidden}
.taste-bar-track i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#9f8445,#c8ad6f)}
.compact-table{font-size:13.5px;border-radius:18px;overflow:hidden;background:#fff}
.compact-table th{width:92px;background:#f7f9fc}
.compact-table th,.compact-table td{padding:10px 11px;line-height:1.55}
.gold-text{color:#806021;font-weight:950}
.compact-insight{font-size:13.5px;margin-top:10px;padding:13px 14px;border-radius:20px;background:#fffdf7;color:#4f5b6c}
.benchmark-report-grid{
  grid-template-columns:repeat(2,minmax(520px,1fr));
  gap:18px;
}
.report-benchmark-card{
  padding:22px;
  border-radius:30px;
  background:linear-gradient(180deg,#ffffff,#fbfcff);
  box-shadow:0 18px 48px rgba(17,26,46,.06);
}
.report-benchmark-card h3{
  font-size:24px;
  letter-spacing:-.055em;
  padding-bottom:14px;
  border-bottom:2px solid #e8d8a7;
}
.report-bench-body{
  display:grid!important;
  grid-template-columns:250px 1fr!important;
  gap:18px!important;
  align-items:stretch;
  margin-top:18px!important;
}
.report-bench-body .bench-radar{
  min-height:260px;
  padding:12px;
  border-radius:24px;
  background:#fafbfe;
}
.report-bench-body .bench-radar svg{height:240px!important}
.benchmark-profile-table{font-size:14px;background:#fff;border-radius:18px;overflow:hidden;align-self:start}
.benchmark-profile-table th{width:120px;background:#f7f9fc;font-size:14px}
.benchmark-profile-table th,.benchmark-profile-table td{padding:13px 14px;line-height:1.65}
#step4 h2{font-size:30px;letter-spacing:-.06em}
#step4 .sub{font-size:14px;color:#7b8495}
#planningReport{margin-top:14px}
@media(max-width:1180px){
  .concept-visual-grid{grid-template-columns:1fr}
  .benchmark-report-grid{grid-template-columns:1fr}
  .benchmark-reco-grid{grid-template-columns:1fr}
}
@media(max-width:720px){
  .concept-card-body{grid-template-columns:1fr}
  .concept-radar svg{height:210px!important}
  .report-bench-body{grid-template-columns:1fr!important}
  .benchmark-reco-card,.concept-visual-card,.report-benchmark-card{padding:17px;border-radius:24px}
  .benchmark-reco-card h3,.report-benchmark-card h3{font-size:21px}
  #step4 h2{font-size:24px}
}

/* v12.6 admin screen CSS recovery / /soolai/admin/login.php */
.admin-body{
  min-height:100vh;
  margin:0;
  background:
    radial-gradient(circle at 12% -8%, rgba(183,154,88,.18), transparent 30%),
    radial-gradient(circle at 92% 0%, rgba(17,26,46,.13), transparent 34%),
    linear-gradient(180deg,#fbfcff 0%,#f4f6fb 48%,#edf2f7 100%);
  color:#111827;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI","Apple SD Gothic Neo","Noto Sans KR",sans-serif;
  font-size:15px;
  line-height:1.6;
  letter-spacing:-.02em;
}
.admin-body *{box-sizing:border-box}
.admin-body a{color:#172033;text-decoration:none;font-weight:850}
.admin-body a:hover{color:#9b7a32;text-decoration:underline}
.admin-body .eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border-radius:999px;
  padding:8px 13px;
  background:rgba(183,154,88,.12);
  border:1px solid rgba(183,154,88,.25);
  color:#8f7131;
  font-size:11px;
  font-weight:950;
  letter-spacing:.12em;
}
.login-card{
  width:min(94vw,460px);
  margin:clamp(42px,10vh,110px) auto;
  padding:34px;
  border-radius:32px;
  border:1px solid rgba(226,232,240,.95);
  background:rgba(255,255,255,.94);
  box-shadow:0 30px 80px rgba(17,26,46,.13);
  backdrop-filter:blur(14px);
}
.login-card h1{
  margin:18px 0 8px;
  font-size:30px;
  line-height:1.15;
  font-weight:950;
  letter-spacing:-.055em;
  color:#10192b;
}
.login-card p{margin:0 0 22px;color:#697386;font-weight:650}
.login-card form{display:grid;gap:14px;margin-top:18px}
.login-card label,.admin-form label{
  display:grid;
  gap:7px;
  color:#172033;
  font-weight:900;
  font-size:13px;
}
.login-card input,
.admin-form input,
.admin-form select,
.admin-form textarea,
.admin-search input{
  width:100%;
  min-height:46px;
  border:1px solid #dfe5ef;
  border-radius:16px;
  background:#fff;
  padding:10px 13px;
  color:#111827;
  font:inherit;
  outline:none;
  box-shadow:inset 0 1px 0 rgba(17,26,46,.025);
}
.login-card input:focus,
.admin-form input:focus,
.admin-form select:focus,
.admin-form textarea:focus,
.admin-search input:focus{
  border-color:#b79a58;
  box-shadow:0 0 0 4px rgba(183,154,88,.14);
}
.admin-form textarea{min-height:96px;resize:vertical}
.muted{color:#7b8495!important;font-size:12.5px;margin-top:16px!important}
.alert{
  margin:16px 0;
  padding:13px 15px;
  border-radius:18px;
  border:1px solid rgba(218,108,108,.22);
  background:#fff5f5;
  color:#9f2f2f;
  font-weight:850;
}
.admin-shell{
  width:min(1500px,calc(100% - 36px));
  margin:22px auto 70px;
  display:grid;
  grid-template-columns:260px minmax(0,1fr);
  gap:20px;
  align-items:start;
}
.admin-side{
  position:sticky;
  top:20px;
  min-height:calc(100vh - 44px);
  padding:22px;
  border-radius:32px;
  color:#fff;
  background:
    radial-gradient(circle at 86% 8%,rgba(234,217,168,.18),transparent 32%),
    linear-gradient(160deg,#10192b 0%,#172033 56%,#25344f 100%);
  box-shadow:0 30px 80px rgba(17,26,46,.18);
  overflow:hidden;
}
.admin-side:before{
  content:"";
  position:absolute;
  inset:0;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:34px 34px;
  pointer-events:none;
}
.admin-side>*{position:relative;z-index:1}
.admin-side .eyebrow{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.18);color:#ead9a8}
.admin-side h2{margin:16px 0 22px;font-size:26px;font-weight:950;letter-spacing:-.055em;color:#fff}
.admin-side nav{display:grid;gap:8px}
.admin-side nav a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:44px;
  padding:11px 13px;
  border-radius:16px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.08);
  color:#e8edf6;
  font-size:13px;
  font-weight:900;
  text-decoration:none;
  transition:.16s ease;
}
.admin-side nav a:after{content:"›";opacity:.55;font-size:18px;line-height:1}
.admin-side nav a:hover{background:rgba(255,255,255,.13);transform:translateX(2px);color:#fff;text-decoration:none}
.admin-main{min-width:0}
.admin-title{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:16px;
  margin:2px 0 18px;
}
.admin-title h1{margin:0;font-size:30px;line-height:1.15;font-weight:950;letter-spacing:-.055em;color:#10192b}
.admin-title p{margin:8px 0 0;color:#718096;font-weight:650}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.stat-box{
  border:1px solid rgba(226,232,240,.92);
  border-radius:26px;
  background:linear-gradient(180deg,#fff,#fbfcff);
  box-shadow:0 18px 50px rgba(17,26,46,.06);
  padding:20px;
}
.stat-box span{display:block;color:#7b8495;font-size:12px;font-weight:900;margin-bottom:8px}
.stat-box strong{display:block;color:#10192b;font-size:32px;line-height:1;font-weight:950;letter-spacing:-.05em}
.admin-card{
  margin-bottom:18px;
  padding:24px;
  border:1px solid rgba(226,232,240,.92);
  border-radius:30px;
  background:rgba(255,255,255,.94);
  box-shadow:0 20px 60px rgba(17,26,46,.065);
  overflow-x:auto;
}
.admin-card h2{margin:0 0 18px;font-size:21px;font-weight:950;letter-spacing:-.045em;color:#10192b}
.admin-card p{color:#596579;font-weight:650}
.admin-form{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  align-items:start;
}
.admin-form.narrow{max-width:560px;grid-template-columns:1fr}
.admin-form label:has(textarea),
.admin-form label.check{grid-column:1/-1}
.admin-form label.check{display:flex;align-items:center;gap:9px;min-height:42px;padding:10px 12px;border:1px solid #e2e8f0;border-radius:16px;background:#f8fafc}
.admin-form label.check input{width:auto;min-height:0}
.admin-search{display:flex;gap:10px;align-items:center;margin-bottom:14px}
.admin-search input{max-width:420px}
.admin-table{
  width:100%;
  min-width:760px;
  border-collapse:separate;
  border-spacing:0;
  font-size:13.5px;
}
.admin-table th{
  background:#f6f8fb;
  color:#172033;
  text-align:left;
  font-weight:950;
  padding:12px 13px;
  border-top:1px solid #e5eaf2;
  border-bottom:1px solid #e5eaf2;
}
.admin-table th:first-child{border-left:1px solid #e5eaf2;border-radius:16px 0 0 16px}
.admin-table th:last-child{border-right:1px solid #e5eaf2;border-radius:0 16px 16px 0}
.admin-table td{
  padding:12px 13px;
  border-bottom:1px solid #edf1f6;
  vertical-align:middle;
  color:#334155;
}
.admin-table tr:hover td{background:#fbfcff}
.inline-form{display:inline-flex;margin-left:8px;vertical-align:middle}
.inline-form button{
  border:0;
  background:transparent;
  color:#b42318;
  font-weight:900;
  cursor:pointer;
  padding:0;
}
.admin-body .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  border:0;
  border-radius:16px;
  padding:10px 15px;
  background:#111a2e;
  color:#fff;
  font-weight:950;
  font-size:13.5px;
  text-decoration:none;
  box-shadow:0 12px 26px rgba(17,26,46,.12);
  transition:.16s ease;
}
.admin-body .btn:hover{transform:translateY(-1px);text-decoration:none;color:#fff}
.admin-body .btn.full{width:100%}
.admin-body .btn-gold{
  background:linear-gradient(135deg,#9b7a32,#c8ad6f)!important;
  color:#fff!important;
}
.admin-body .btn-outline{
  background:#fff!important;
  color:#172033!important;
  border:1px solid #dfe5ef!important;
  box-shadow:none!important;
}
@media(max-width:980px){
  .admin-shell{grid-template-columns:1fr;width:min(100% - 24px,760px)}
  .admin-side{position:relative;top:auto;min-height:auto;border-radius:26px}
  .admin-side nav{grid-template-columns:repeat(2,minmax(0,1fr))}
  .stats-grid{grid-template-columns:1fr}
  .admin-form{grid-template-columns:1fr}
}
@media(max-width:560px){
  .login-card{width:calc(100% - 24px);padding:24px;border-radius:26px;margin:28px auto}
  .login-card h1,.admin-title h1{font-size:25px}
  .admin-shell{width:calc(100% - 18px);margin-top:12px}
  .admin-side{padding:18px}
  .admin-side nav{grid-template-columns:1fr}
  .admin-card{padding:18px;border-radius:24px}
  .admin-search{display:grid}
}
