/* talent.css — arch.crowny.org Design System v1 적용
   bank/talent + bank/talent-admin 공용
   디자인 표준 원형: arch.crowny.org (verdant 비율 참고)
*/

:root {
  --bg: #07080e;
  --bg2: #0c0e16;
  --bg3: #10131c;
  --surface: #161a26;
  --surface2: #1e2232;
  --border: #242838;
  --border-light: #303648;
  --text: #e4e6f0;
  --text2: #9ca0b8;
  --text3: #606480;
  --accent: #4a90c8;
  --accent-light: #6ab0e8;
  --accent-dark: #3070a0;
  --accent-glow: rgba(74, 144, 200, 0.10);
  --steel: #8090a8;
  --green: #60b080;
  --amber: #c8a050;
  --red: #c06060;
  --indigo: #818cf8;
  --radius: 16px;
  --radius-sm: 10px;
  --radius-xs: 6px;
  --shadow: 0 8px 32px rgba(0,0,0,0.5);
  --shadow-sm: 0 2px 12px rgba(0,0,0,0.3);
  --transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Apple SD Gothic Neo', 'Noto Sans KR', sans-serif;
  background: var(--bg); color: var(--text); line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--accent-light); text-decoration: none; transition: var(--transition); }
a:hover { color: var(--accent); }
code { font-family: ui-monospace, 'SF Mono', Menlo, monospace; font-size: 0.85em; background: var(--surface); padding: 2px 6px; border-radius: var(--radius-xs); color: var(--text2); }

.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.container-narrow { max-width: 880px; margin: 0 auto; padding: 0 24px; }

/* Nav */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; background: rgba(7,8,14,0.90); backdrop-filter: blur(20px) saturate(1.5); border-bottom: 1px solid rgba(36,40,56,0.5); }
.nav-inner { max-width: 1200px; margin: 0 auto; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; height: 60px; }
.logo { display: flex; align-items: center; gap: 10px; }
.logo-mark { width: 32px; height: 32px; background: var(--accent); color: #fff; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 14px; letter-spacing: -1px; }
.logo-text { font-size: 15px; font-weight: 600; color: var(--text); letter-spacing: -0.2px; }
.nav-links { display: flex; align-items: center; gap: 24px; }
.nav-links a { color: var(--text3); font-size: 13px; font-weight: 500; }
.nav-links a:hover { color: var(--text); }
.nav-links a.active { color: var(--accent); }
.nav-table-badge { color: var(--indigo); font-size: 11px; letter-spacing: 1px; padding: 3px 10px; border: 1px solid rgba(129,140,248,0.3); border-radius: 999px; }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; padding: 12px 28px; border-radius: var(--radius-sm); font-weight: 600; font-size: 14px; border: none; cursor: pointer; transition: var(--transition); letter-spacing: -0.1px; }
.btn-primary { background: var(--accent); color: #fff; }
.btn-primary:hover { background: var(--accent-light); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(74,144,200,0.3); }
.btn-ghost { background: transparent; color: var(--text2); border: 1px solid var(--border); }
.btn-ghost:hover { border-color: var(--text3); color: var(--text); }
.btn-lg { padding: 14px 32px; font-size: 15px; }

/* Hero */
.hero { min-height: 70vh; display: flex; align-items: center; justify-content: center; text-align: center; padding: 120px 24px 60px; position: relative; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background: radial-gradient(ellipse 800px 600px at 50% 40%, rgba(74,144,200,0.06) 0%, transparent 70%), linear-gradient(180deg, var(--bg) 0%, var(--bg2) 100%); }
.hero-grid { position: absolute; inset: 0; opacity: 0.025; background-image: linear-gradient(var(--accent) 1px, transparent 1px), linear-gradient(90deg, var(--accent) 1px, transparent 1px); background-size: 80px 80px; }
.hero-inner { position: relative; z-index: 1; max-width: 760px; }
.hero-badge { display: inline-block; padding: 6px 16px; border-radius: 20px; background: rgba(129,140,248,0.10); border: 1px solid rgba(129,140,248,0.25); color: var(--indigo); font-size: 11.5px; letter-spacing: 1.5px; font-weight: 500; margin-bottom: 28px; text-transform: uppercase; }
.hero h1 { font-size: clamp(28px, 4.5vw, 46px); line-height: 1.3; margin-bottom: 20px; font-weight: 300; letter-spacing: -0.5px; }
.hero h1 strong { font-weight: 700; background: linear-gradient(135deg, var(--accent), var(--accent-light)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.hero-sub { color: var(--text2); font-size: 16px; line-height: 1.8; margin-bottom: 24px; max-width: 620px; margin-left: auto; margin-right: auto; }
.hero-quote { color: var(--text); font-size: 14px; font-style: italic; padding: 14px 20px; border-left: 2px solid var(--accent); background: rgba(74,144,200,0.04); border-radius: 0 8px 8px 0; max-width: 580px; margin: 0 auto; }

/* Section */
.section { padding: 80px 0; }
.section-dark { background: var(--bg2); }
.section-header { text-align: center; margin-bottom: 48px; }
.tag { display: inline-block; color: var(--accent); font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; font-weight: 600; margin-bottom: 14px; }
.section-header h2 { font-size: clamp(24px, 3vw, 32px); margin-bottom: 14px; font-weight: 600; letter-spacing: -0.3px; }
.section-header p { color: var(--text2); font-size: 15px; line-height: 1.75; max-width: 560px; margin: 0 auto; }

/* Declare box */
.declare { background: linear-gradient(135deg, var(--surface) 0%, var(--surface2) 100%); border: 1px solid var(--accent-dark); border-radius: var(--radius); padding: 40px 32px; margin: 32px 0; text-align: center; box-shadow: var(--shadow-sm); }
.declare .label { color: var(--accent); font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; font-weight: 700; margin-bottom: 16px; }
.declare h3 { font-size: 22px; margin-bottom: 16px; font-weight: 600; line-height: 1.5; }
.declare p { color: var(--text2); font-size: 15px; line-height: 1.8; max-width: 640px; margin: 0 auto; }
.declare .accent { color: var(--accent-light); font-weight: 600; }
.declare .sig { color: var(--text3); font-size: 13px; margin-top: 20px; }

/* Card */
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 28px; margin-bottom: 20px; transition: var(--transition); }
.card:hover { border-color: var(--border-light); }
.card h3 { font-size: 17px; font-weight: 600; margin-bottom: 12px; color: var(--text); }
.card p, .card li { color: var(--text2); font-size: 14px; line-height: 1.75; }
.card ul { padding-left: 20px; margin-top: 8px; }
.card li { margin-bottom: 6px; }
.card .accent { color: var(--accent-light); font-weight: 600; }
.card .hl { color: var(--text); font-weight: 600; }

/* Quote in card */
.quote { background: var(--bg2); border-left: 2px solid var(--accent); border-radius: 0 8px 8px 0; padding: 16px 20px; margin: 16px 0; font-style: italic; font-size: 14px; color: var(--text2); }
.quote .src { display: block; margin-top: 6px; color: var(--text3); font-size: 12px; font-style: normal; }

/* Table */
.tbl-wrap { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
table.tbl { width: 100%; border-collapse: collapse; font-size: 14px; }
table.tbl th, table.tbl td { padding: 14px 18px; text-align: left; border-bottom: 1px solid var(--border); }
table.tbl th { color: var(--accent); font-weight: 600; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; background: var(--bg2); }
table.tbl td.num, table.tbl th.num { text-align: right; font-variant-numeric: tabular-nums; }
table.tbl tr.highlight td { background: rgba(74,144,200,0.04); color: var(--text); font-weight: 600; }
table.tbl tr:last-child td { border-bottom: none; }

/* Step grid */
.step-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 10px; margin: 24px 0; }
@media (max-width: 768px) { .step-grid { grid-template-columns: repeat(3, 1fr); } }
.step { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 16px 10px; text-align: center; transition: var(--transition); }
.step:hover { border-color: var(--accent-dark); }
.step-n { color: var(--text3); font-size: 10px; letter-spacing: 1.5px; font-weight: 600; }
.step-v { color: var(--accent-light); font-size: 18px; font-weight: 700; margin: 6px 0 2px; font-variant-numeric: tabular-nums; }
.step-d { color: var(--text3); font-size: 11px; }

/* Two-pane */
.pair { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin: 20px 0; }
@media (max-width: 600px) { .pair { grid-template-columns: 1fr; } }
.pane { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; border-top: 3px solid var(--accent); }
.pane.warn { border-top-color: var(--red); }
.pane h4 { font-size: 16px; margin-bottom: 10px; font-weight: 600; color: var(--text); }
.pane .verdict { font-size: 13px; font-weight: 700; margin: 6px 0 10px; letter-spacing: 0.5px; }
.pane .verdict.ok { color: var(--accent-light); }
.pane .verdict.no { color: var(--red); }
.pane p { color: var(--text2); font-size: 13.5px; line-height: 1.7; }

/* Admin: KPI grid */
.kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 28px; }
@media (max-width: 900px) { .kpi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .kpi-grid { grid-template-columns: 1fr; } }
.kpi { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px 22px; position: relative; overflow: hidden; }
.kpi::after { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--accent); }
.kpi.warn::after { background: var(--amber); }
.kpi.danger::after { background: var(--red); }
.kpi.green::after { background: var(--green); }
.kpi-label { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--text3); margin-bottom: 8px; font-weight: 600; }
.kpi-value { font-size: 26px; font-weight: 700; color: var(--text); font-variant-numeric: tabular-nums; line-height: 1.1; }
.kpi-sub { color: var(--text3); font-size: 12px; margin-top: 6px; }

/* Admin: 9-member board */
.member-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 760px) { .member-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .member-grid { grid-template-columns: 1fr; } }
.member { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 18px; transition: var(--transition); }
.member:hover { border-color: var(--accent-dark); }
.member.founder { border-color: var(--accent); }
.member-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.member-id { font-family: ui-monospace, 'SF Mono', monospace; font-size: 12px; color: var(--text); font-weight: 600; }
.member-role { font-size: 10px; letter-spacing: 1px; color: var(--text3); padding: 2px 8px; border-radius: 999px; border: 1px solid var(--border); text-transform: uppercase; }
.member.founder .member-role { color: var(--accent); border-color: var(--accent-dark); }
.member-amount { font-size: 18px; color: var(--accent-light); font-weight: 700; font-variant-numeric: tabular-nums; }
.member-bar { height: 5px; background: var(--bg2); border-radius: 3px; overflow: hidden; margin: 10px 0 6px; }
.member-bar-fill { height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent-light)); }
.member-meta { font-size: 11px; color: var(--text3); display: flex; justify-content: space-between; }
.member-status { font-size: 10px; padding: 2px 8px; border-radius: 999px; }
.member-status.확정대기 { background: rgba(200,160,80,0.12); color: var(--amber); }
.member-status.확정 { background: rgba(96,176,128,0.12); color: var(--green); }

/* Stage progress */
.stage-bars { display: flex; flex-direction: column; gap: 10px; }
.stage-row { display: grid; grid-template-columns: 70px 1fr 110px; gap: 12px; align-items: center; font-size: 13px; }
.stage-label { color: var(--text3); font-size: 11px; letter-spacing: 1px; font-weight: 600; }
.stage-bar { height: 8px; background: var(--bg2); border-radius: 4px; overflow: hidden; }
.stage-bar-fill { height: 100%; background: linear-gradient(90deg, var(--accent-dark), var(--accent-light)); }
.stage-num { font-variant-numeric: tabular-nums; color: var(--text); text-align: right; font-weight: 600; }

/* Footer */
footer { padding: 60px 24px 40px; border-top: 1px solid var(--border); margin-top: 80px; }
.foot-inner { max-width: 1200px; margin: 0 auto; }
.foot-meta { color: var(--text3); font-size: 13px; text-align: center; }
.foot-sign { color: var(--accent); font-weight: 600; font-size: 14px; margin: 8px 0 16px; text-align: center; }
.disclaimer { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 20px 24px; margin-top: 24px; }
.disclaimer h4 { color: var(--text3); font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 10px; font-weight: 600; }
.disclaimer p { color: var(--text3); font-size: 12.5px; line-height: 1.7; margin: 4px 0; }

/* Selcore rule badge (셀코어 룰 베이스 표시) */
.rule-tag { display: inline-block; font-size: 10px; color: var(--text3); background: var(--bg2); border: 1px solid var(--border); padding: 2px 8px; border-radius: var(--radius-xs); font-family: ui-monospace, 'SF Mono', monospace; margin-left: 8px; }
