/* ============================================
   ひと・会社マッチングアセスメント — 統合プラットフォーム CSS
   ============================================ */

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --nav-height: 60px;
  --accent: #6366f1;
  --accent-dark: #4f46e5;
  --accent-light: #818cf8;
  --bg: #f5f7fb;
  --bg-card: #ffffff;
  --text: #1e293b;
  --text-sub: #64748b;
  --text-muted: #94a3b8;
  --border: #e2e8f0;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 30px rgba(0,0,0,0.12);
  --radius: 12px;
  --font: 'Inter','Noto Sans JP',-apple-system,sans-serif;
}

html { font-size:16px; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  overflow-x: hidden;
}

/* ===== TOP NAV ===== */
.top-nav {
  position: fixed; top:0; left:0; right:0; z-index:9999;
  height: var(--nav-height);
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
}
.nav-inner {
  max-width: 1200px; margin:0 auto;
  height: 100%;
  display: flex; align-items:center; justify-content:space-between;
  padding: 0 24px;
}
.nav-brand {
  display:flex; align-items:center; gap:10px;
}
.brand-icon { font-size:1.6rem; }
.brand-text {
  font-size:1.1rem; font-weight:800;
  background: linear-gradient(135deg,#4f46e5,#0ea5e9);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.nav-tabs { display:flex; gap:4px; }
.nav-tab {
  display:flex; align-items:center; gap:6px;
  padding: 8px 18px;
  border:none; border-radius:9999px;
  background:transparent;
  font-family:var(--font); font-size:0.85rem; font-weight:600;
  color: var(--text-sub);
  cursor:pointer;
  transition: all 200ms ease;
}
.nav-tab:hover { background:rgba(99,102,241,0.08); color:var(--accent); }
.nav-tab.active {
  background: linear-gradient(135deg,#6366f1,#0ea5e9);
  color:#fff;
  box-shadow: 0 2px 10px rgba(99,102,241,0.3);
}
.tab-icon { font-size:1rem; }

/* ===== TAB PANELS ===== */
.tab-panel {
  display:none;
  position:fixed;
  top: var(--nav-height); left:0; right:0; bottom:0;
}
.tab-panel.active { display:block; }
.tab-panel iframe {
  width:100%; height:100%; border:none;
}

/* ===== IMPORT PANEL ===== */
#panel-import { overflow-y:auto; }
.import-container {
  max-width:800px; margin:0 auto;
  padding:40px 24px 80px;
}
.import-header { text-align:center; margin-bottom:36px; }
.import-title {
  font-size:clamp(1.4rem,4vw,2rem); font-weight:800;
  color:var(--text); margin-bottom:8px;
}
.import-subtitle { color:var(--text-sub); font-size:0.92rem; line-height:1.7; }

.import-card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:28px;
  margin-bottom:20px;
  box-shadow:var(--shadow-sm);
  transition: all 300ms ease;
}
.import-card:hover { box-shadow:var(--shadow-md); }

.import-card-header {
  display:flex; align-items:flex-start; gap:16px;
  margin-bottom:20px;
}
.card-icon-lg { font-size:2rem; flex-shrink:0; }
.import-card-header h2 { font-size:1.05rem; font-weight:700; color:var(--text); margin-bottom:4px; }
.import-card-header p { font-size:0.85rem; color:var(--text-sub); line-height:1.6; }

.link-card { border-left:3px solid var(--accent); }
.code-card { border-left:3px solid #10b981; }
.preview-card { border-left:3px solid #059669; }

.test-link-wrap {
  display:flex; gap:8px; margin-bottom:8px;
}
.test-link-input {
  flex:1; padding:10px 14px;
  font-family:var(--font); font-size:0.85rem;
  background:rgba(99,102,241,0.04);
  border:1px solid rgba(99,102,241,0.2);
  border-radius:8px; color:var(--accent-dark);
}
.test-link-input:focus { outline:none; border-color:var(--accent); }
.btn-copy-link {
  padding:10px 20px; border:none; border-radius:8px;
  background:var(--accent); color:#fff;
  font-family:var(--font); font-size:0.85rem; font-weight:600;
  cursor:pointer; transition:all 200ms ease; white-space:nowrap;
}
.btn-copy-link:hover { background:var(--accent-dark); transform:translateY(-1px); }
.link-note { font-size:0.78rem; color:var(--text-muted); }

.import-code-textarea {
  width:100%; padding:14px;
  font-family:'Inter',monospace; font-size:0.82rem;
  background:rgba(16,185,129,0.03);
  border:1px solid rgba(16,185,129,0.2);
  border-radius:8px; color:var(--text);
  resize:vertical; line-height:1.5;
  margin-bottom:12px;
}
.import-code-textarea:focus { outline:none; border-color:#10b981; box-shadow:0 0 0 3px rgba(16,185,129,0.1); }
.import-code-textarea::placeholder { color:var(--text-muted); }

.import-actions { display:flex; justify-content:flex-end; }
.btn-import {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 28px; border:none; border-radius:9999px;
  background:linear-gradient(135deg,#10b981,#059669);
  color:#fff; font-family:var(--font);
  font-size:0.95rem; font-weight:600;
  cursor:pointer;
  box-shadow:0 4px 14px rgba(16,185,129,0.3);
  transition:all 200ms ease;
}
.btn-import:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(16,185,129,0.4); }

.import-status {
  margin-top:12px; padding:12px 16px;
  border-radius:8px; font-size:0.88rem; font-weight:500;
}
.import-status.success {
  background:rgba(5,150,105,0.08); border:1px solid rgba(5,150,105,0.2); color:#059669;
}
.import-status.error {
  background:rgba(239,68,68,0.08); border:1px solid rgba(239,68,68,0.2); color:#dc2626;
}

.preview-scores {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:10px; margin-top:12px;
}
.preview-score-item {
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 12px; border-radius:8px;
  background:rgba(5,150,105,0.04);
  border:1px solid rgba(5,150,105,0.12);
  font-size:0.82rem;
}
.preview-score-name { color:var(--text-sub); font-weight:500; }
.preview-score-val { font-weight:700; color:#059669; }

/* ===== REPORT PANEL ===== */
#panel-report { overflow-y:auto; }
.report-container {
  max-width:900px; margin:0 auto;
  padding: 40px 24px 80px;
}
.report-header-section { text-align:center; margin-bottom:40px; }
.report-main-title {
  font-size: clamp(1.6rem,4vw,2.4rem);
  font-weight:800;
  background: linear-gradient(135deg,#4f46e5,#0ea5e9);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
  margin-bottom:8px;
  display:flex; align-items:center; justify-content:center; gap:12px;
}
.rpt-icon { -webkit-text-fill-color:initial; }
.report-subtitle { color:var(--text-sub); font-size:0.95rem; }

/* Status Cards */
.report-status-cards {
  display:grid; grid-template-columns:1fr 1fr; gap:16px;
  margin-bottom:32px;
}
.status-card {
  display:flex; align-items:center; gap:16px;
  padding:20px 24px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  transition: all 300ms ease;
}
.status-card.done {
  border-color:rgba(5,150,105,0.3);
  background: linear-gradient(135deg,rgba(5,150,105,0.04),rgba(14,165,233,0.04));
}
.status-icon { font-size:2rem; }
.status-label { font-size:0.8rem; color:var(--text-muted); font-weight:600; }
.status-value { font-size:1.1rem; font-weight:700; color:var(--text); }
.status-card.done .status-value { color:#059669; }

/* Empty State */
.report-empty {
  text-align:center; padding:60px 24px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}
.empty-icon { font-size:3rem; margin-bottom:16px; }
.report-empty h2 { font-size:1.3rem; margin-bottom:8px; color:var(--text); }
.report-empty p { color:var(--text-sub); font-size:0.9rem; line-height:1.8; margin-bottom:24px; }
.empty-steps { display:flex; flex-direction:column; gap:10px; max-width:400px; margin:0 auto; text-align:left; }
.step {
  display:flex; align-items:center; gap:12px;
  padding:12px 16px;
  background:rgba(99,102,241,0.04);
  border:1px solid rgba(99,102,241,0.12);
  border-radius:8px;
  font-size:0.88rem; color:var(--text-sub);
}
.step-num {
  width:28px; height:28px;
  display:flex; align-items:center; justify-content:center;
  background:var(--accent); color:#fff;
  border-radius:50%; font-size:0.8rem; font-weight:700; flex-shrink:0;
}

/* Report Content */
.report-content { animation: fadeUp 0.5s ease-out; }
.report-actions-top { text-align:right; margin-bottom:24px; }
.btn-print-report {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 28px;
  background:linear-gradient(135deg,#6366f1,#0ea5e9);
  border:none; border-radius:9999px;
  color:#fff; font-family:var(--font);
  font-size:0.9rem; font-weight:600;
  cursor:pointer;
  box-shadow:0 4px 16px rgba(99,102,241,0.3);
  transition:all 200ms ease;
}
.btn-print-report:hover {
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(99,102,241,0.4);
}

.rpt-section {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  margin-bottom:24px;
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.rpt-section-title {
  display:flex; align-items:center; gap:10px;
  padding:18px 24px;
  font-size:1.1rem; font-weight:700;
  border-bottom:1px solid var(--border);
  background:rgba(99,102,241,0.03);
  color:var(--text);
}
.rpt-section-title span { font-size:1.2rem; }

/* Report inner content */
.rpt-body-inner { padding:24px; }
.rpt-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:20px; }
.rpt-metric {
  padding:16px; border-radius:10px;
  border:1px solid var(--border);
  background:rgba(245,247,251,0.6);
}
.rpt-metric-label { font-size:0.78rem; color:var(--text-muted); font-weight:600; margin-bottom:4px; }
.rpt-metric-value { font-size:1.6rem; font-weight:800; }
.rpt-metric-sub { font-size:0.75rem; color:var(--text-sub); margin-top:2px; }

.rpt-bar-group { margin-bottom:12px; }
.rpt-bar-label { display:flex; justify-content:space-between; font-size:0.82rem; margin-bottom:4px; }
.rpt-bar-name { font-weight:600; color:var(--text); }
.rpt-bar-val { font-weight:700; }
.rpt-bar-track { height:8px; background:rgba(0,0,0,0.06); border-radius:9999px; overflow:hidden; }
.rpt-bar-fill { height:100%; border-radius:9999px; transition:width 1s ease-out; }

.rpt-insight {
  padding:16px 20px;
  border-left:3px solid var(--accent);
  background:rgba(99,102,241,0.04);
  border-radius:0 8px 8px 0;
  margin-top:16px;
  font-size:0.9rem; color:var(--text-sub); line-height:1.7;
}
.rpt-insight strong { color:var(--text); }

.rpt-combined-summary {
  display:grid; grid-template-columns:1fr 1fr 1fr; gap:16px; margin-bottom:20px;
}
.rpt-combined-card {
  padding:20px; border-radius:10px; text-align:center;
  border:1px solid var(--border);
}
.rpt-combined-card-title { font-size:0.78rem; color:var(--text-muted); font-weight:600; margin-bottom:6px; }
.rpt-combined-card-val { font-size:2rem; font-weight:800; }
.rpt-combined-card-desc { font-size:0.75rem; color:var(--text-sub); margin-top:4px; }

/* Color variants */
.color-action { color:#e11d48; }
.color-thinking { color:#7c3aed; }
.color-teamwork { color:#0891b2; }
.color-new { color:#059669; }
.color-accent { color:#6366f1; }
.color-match { color:#10b981; }

.bg-action { background:#e11d48; }
.bg-thinking { background:#7c3aed; }
.bg-teamwork { background:#0891b2; }
.bg-new { background:#059669; }
.bg-accent { background:#6366f1; }

@keyframes fadeUp {
  from { opacity:0; transform:translateY(20px); }
  to { opacity:1; transform:translateY(0); }
}

/* ===== RESPONSIVE ===== */
@media (max-width:700px) {
  .nav-inner { padding:0 12px; }
  .brand-text { display:none; }
  .nav-tab { padding:8px 12px; }
  .tab-label { display:none; }
  .tab-icon { font-size:1.2rem; }
  .report-status-cards { grid-template-columns:1fr; }
  .rpt-grid { grid-template-columns:1fr; }
  .rpt-combined-summary { grid-template-columns:1fr; }
  .report-container { padding:24px 16px 60px; }
}

@media print {
  .top-nav, .report-actions-top, .report-status-cards, .report-empty { display:none !important; }
  .tab-panel { display:none !important; }
  #panel-report {
    display:block !important;
    position:static !important;
    top:auto !important;
    left:auto !important;
    right:auto !important;
    bottom:auto !important;
    overflow:visible !important;
  }
  .report-container { max-width:100%; padding:0 !important; margin:0 !important; }
  .report-header-section { margin-bottom:16px !important; }
  .report-main-title {
    background:none !important;
    -webkit-text-fill-color:#1e293b !important;
    color:#1e293b !important;
    font-size:1.4rem !important;
    margin-bottom:4px !important;
  }
  .report-subtitle { margin-bottom:8px !important; }
  #report-content { display:block !important; }
  .rpt-section { break-inside:avoid; box-shadow:none !important; border:1px solid #ddd !important; margin-bottom:16px !important; }
  .rpt-body-inner { padding:16px !important; }
  body { background:#fff !important; }
}
