/* ===== DIAGNOSIS PAGE STYLES ===== */

/* ----- Header ----- */
.diag-header{
  background:#fff;border-bottom:1px solid #e2e8f0;
  padding:12px 0;position:sticky;top:0;z-index:50;
}
.diag-header-logo{
  font-size:15px;font-weight:800;
  background:linear-gradient(135deg,var(--primary),var(--purple));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  text-decoration:none;
}
.diag-header-back{
  font-size:13px;font-weight:600;color:var(--primary);
  text-decoration:none;transition:opacity .2s;
}
.diag-header-back:hover{opacity:.7}

/* ----- Landing ----- */
#landing{text-align:center;padding:40px 20px}
.hero-illust{font-size:80px;margin-bottom:20px}
.hero-illust-chars{display:flex;align-items:flex-end;justify-content:center;gap:8px;margin-bottom:20px}
.hero-illust-chars img{filter:drop-shadow(0 4px 12px rgba(0,0,0,.1))}
.hero-illust-chars .hero-illust-center{transform:translateY(-4px)}
.hero-badge-diag{
  display:inline-block;background:linear-gradient(135deg,var(--primary),var(--purple));
  color:#fff;font-size:12px;font-weight:700;padding:6px 16px;
  border-radius:20px;margin-bottom:20px;letter-spacing:.5px;
}
.hero-title{
  font-size:clamp(28px,6vw,40px);font-weight:800;line-height:1.3;margin-bottom:12px;
  background:linear-gradient(135deg,var(--primary),var(--purple));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-sub{font-size:16px;color:var(--text-light);margin-bottom:32px}
.hero-features{display:flex;justify-content:center;gap:24px;margin-bottom:36px;flex-wrap:wrap}
.hero-feat{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--text)}
.hero-feat .icon{font-size:20px}
.btn-start{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,var(--primary),var(--purple));
  color:#fff;border:none;font-size:18px;font-weight:700;
  padding:16px 48px;border-radius:60px;cursor:pointer;
  transition:all .3s;box-shadow:0 8px 24px rgba(37,99,235,.3);
}
.btn-start:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(37,99,235,.4)}
.hero-note{margin-top:16px;font-size:12px;color:var(--text-light)}

/* ----- Quiz ----- */
#quiz{display:none}
.progress-wrap{
  position:sticky;top:0;background:var(--card);
  padding:12px 0;z-index:10;border-bottom:1px solid var(--border);
}
.progress-info{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:8px;font-size:13px;color:var(--text-light);
}
.progress-bar{height:6px;background:#e2e8f0;border-radius:6px;overflow:hidden}
.progress-fill{
  height:100%;background:linear-gradient(90deg,var(--primary),var(--purple));
  border-radius:6px;transition:width .4s ease;
}
.q-category{
  display:inline-block;font-size:11px;font-weight:700;color:var(--primary);
  background:#eff6ff;padding:4px 12px;border-radius:12px;margin-bottom:8px;margin-top:20px;
}
.q-card{
  background:var(--card);border-radius:var(--radius);padding:28px 24px;
  margin-top:12px;box-shadow:var(--shadow);animation:fadeUp .4s ease;
}
.q-text{font-size:18px;font-weight:700;margin-bottom:20px;line-height:1.5}
.q-options{display:flex;flex-direction:column;gap:10px}
.q-opt{
  display:flex;align-items:center;gap:12px;background:#f8fafc;
  border:2px solid #e2e8f0;border-radius:12px;padding:14px 16px;
  cursor:pointer;transition:all .2s;font-size:15px;
}
.q-opt:hover{border-color:var(--primary);background:#eff6ff}
.q-opt.selected{border-color:var(--primary);background:#eff6ff;font-weight:600}
.q-opt .radio{
  width:20px;height:20px;border-radius:50%;border:2px solid #cbd5e1;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;
}
.q-opt.selected .radio{border-color:var(--primary);background:var(--primary)}
.q-opt.selected .radio::after{content:'';width:8px;height:8px;background:#fff;border-radius:50%}
.q-nav{display:flex;gap:12px;margin-top:20px}
.btn-nav{flex:1;padding:14px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;border:none;transition:all .2s}
.btn-prev{background:#f1f5f9;color:var(--text)}
.btn-next{background:var(--primary);color:#fff}
.btn-next:disabled{opacity:.4;cursor:not-allowed}
.btn-prev:hover{background:#e2e8f0}
.btn-next:hover:not(:disabled){background:var(--primary-dark)}

/* ----- Result ----- */
#result{display:none}
.result-header{
  text-align:center;padding:32px 20px;
  background:linear-gradient(135deg,var(--primary),var(--purple));
  border-radius:0 0 32px 32px;color:#fff;margin:-16px -16px 24px;
}
.result-label{font-size:13px;opacity:.8;margin-bottom:4px}
.result-char-img{display:block;margin:12px auto;filter:drop-shadow(0 6px 16px rgba(0,0,0,.2))}
.result-type-name{font-size:clamp(28px,7vw,38px);font-weight:800;margin-bottom:4px}
.result-type-sub{font-size:15px;opacity:.9}
.result-type-code{
  display:inline-block;background:rgba(255,255,255,.2);
  padding:4px 16px;border-radius:20px;font-size:13px;font-weight:600;margin-top:10px;
}
.r-card{
  background:var(--card);border-radius:var(--radius);padding:24px;
  margin-bottom:16px;box-shadow:var(--shadow);
}
.r-card h3{font-size:16px;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.r-card p{font-size:14px;color:var(--text-light);line-height:1.8}

/* ----- Traits ----- */
.traits{display:flex;flex-direction:column;gap:10px}
.trait{display:flex;align-items:center;gap:10px}
.trait-label{width:80px;font-size:13px;font-weight:600;flex-shrink:0}
.trait-bar{flex:1;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}
.trait-fill{height:100%;border-radius:4px;transition:width 1s ease}
.trait-fill.blue{background:linear-gradient(90deg,var(--primary),var(--purple))}
.trait-fill.green{background:linear-gradient(90deg,#10b981,#34d399)}
.trait-fill.orange{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.trait-fill.pink{background:linear-gradient(90deg,#ec4899,#f472b6)}
.trait-val{width:36px;text-align:right;font-size:13px;font-weight:600;color:var(--text-light)}

/* ----- Jobs ----- */
.jobs-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.job-tag{background:#f0fdf4;color:#166534;padding:8px 12px;border-radius:8px;font-size:13px;font-weight:600;text-align:center}

/* ----- CTA Agent Area ----- */
.cta-section{
  background:linear-gradient(135deg,#fffbeb,#fef3c7);border:2px solid #fbbf24;
  border-radius:var(--radius);padding:24px;margin:20px 0;text-align:center;
}
.cta-section h3{color:#92400e;font-size:17px;margin-bottom:8px}
.cta-section p{font-size:13px;color:#78350f;margin-bottom:16px}
.pr-badge{display:inline-block;background:#92400e;color:#fff;font-size:10px;padding:2px 8px;border-radius:4px;margin-bottom:10px}
.agent-cards{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.agent-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;text-align:left}
.agent-card .agent-name{font-weight:700;font-size:15px;margin-bottom:4px}
.agent-card .agent-desc{font-size:12px;color:var(--text-light);margin-bottom:10px}
.agent-card .agent-btn{
  display:block;text-align:center;background:var(--primary);color:#fff;
  text-decoration:none;padding:10px;border-radius:8px;font-size:14px;
  font-weight:600;transition:all .2s;border:none;cursor:pointer;width:100%;
}
.agent-card .agent-btn:hover{background:var(--primary-dark)}
.agent-card .agent-tag{
  display:inline-block;background:#eff6ff;color:var(--primary);
  font-size:11px;padding:2px 8px;border-radius:4px;margin-bottom:8px;font-weight:600;
}
.cta-note{font-size:11px;color:#92400e;margin-top:10px}

/* ----- Share ----- */
.share-section{text-align:center;padding:24px;margin:16px 0}
.share-section h3{font-size:16px;margin-bottom:12px}
.share-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.share-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;
  border:none;cursor:pointer;transition:all .2s;text-decoration:none;color:#fff;
}
.share-btn.x{background:#000}
.share-btn.line{background:#06c755}
.share-btn.copy{background:#6b7280}
.share-btn:hover{opacity:.85;transform:translateY(-1px)}

/* ----- Compat ----- */
.compat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.compat-item{background:#fdf2f8;padding:10px;border-radius:8px;text-align:center;font-size:13px;font-weight:600;color:#9d174d}

/* ----- Retry ----- */
.retry-section{text-align:center;padding:20px;margin-bottom:32px}
.btn-retry{
  background:#f1f5f9;color:var(--text);border:2px solid #e2e8f0;
  padding:12px 32px;border-radius:12px;font-size:15px;font-weight:600;
  cursor:pointer;transition:all .2s;
}
.btn-retry:hover{background:#e2e8f0}

/* ----- Survey CTA ----- */
.survey-cta{
  text-align:center;padding:24px 16px;margin:16px 0;
  background:linear-gradient(135deg,#f0fdf4,#ecfdf5);
  border:1px solid #bbf7d0;border-radius:16px;
}
.survey-cta p{font-size:14px;color:#1e293b;margin-bottom:14px;line-height:1.7}
.btn-survey{
  display:inline-flex;align-items:center;gap:8px;
  background:#16a34a;color:#fff;border:none;font-size:15px;font-weight:700;
  padding:12px 28px;border-radius:12px;cursor:pointer;transition:all .3s;
  box-shadow:0 4px 16px rgba(22,163,74,.3);
}
.btn-survey:hover{background:#15803d;transform:translateY(-2px);box-shadow:0 6px 20px rgba(22,163,74,.35)}

/* ----- Survey Modal ----- */
.survey-overlay{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(0,0,0,.5);z-index:200;
  align-items:center;justify-content:center;padding:20px;
}
.survey-overlay.active{display:flex}
.survey-modal{
  background:#fff;border-radius:20px;padding:32px 24px;
  max-width:420px;width:100%;max-height:90vh;overflow-y:auto;
  position:relative;box-shadow:0 20px 60px rgba(0,0,0,.2);
  animation:fadeUp .3s ease;
}
.survey-close{
  position:absolute;top:12px;right:16px;background:none;border:none;
  font-size:28px;color:#94a3b8;cursor:pointer;line-height:1;
}
.survey-close:hover{color:#1e293b}
.survey-modal h3{font-size:20px;font-weight:800;text-align:center;margin-bottom:4px}
.survey-sub{font-size:14px;color:#64748b;text-align:center;margin-bottom:20px}
.survey-field{margin-bottom:16px}
.survey-field label{display:block;font-size:13px;font-weight:700;color:#1e293b;margin-bottom:6px}
.survey-field input[type="text"],
.survey-field select,
.survey-field textarea{
  width:100%;padding:10px 14px;border:2px solid #e2e8f0;border-radius:10px;
  font-size:14px;font-family:inherit;transition:border-color .2s;
  background:#f8fafc;
}
.survey-field input:focus,
.survey-field select:focus,
.survey-field textarea:focus{border-color:#2563eb;outline:none;background:#fff}
.survey-field textarea{height:80px;resize:vertical}

/* Star rating */
.survey-stars{display:flex;gap:4px;flex-direction:row-reverse;justify-content:flex-end}
.survey-stars input{display:none}
.survey-stars label{
  font-size:32px;color:#e2e8f0;cursor:pointer;
  transition:color .2s,transform .2s;line-height:1;
}
.survey-stars label:hover,
.survey-stars label:hover~label,
.survey-stars input:checked~label{color:#f59e0b}
.survey-stars label:hover{transform:scale(1.2)}

.survey-notice{font-size:11px;color:#94a3b8;line-height:1.6;margin-bottom:16px}
.btn-survey-submit{
  display:block;width:100%;padding:14px;border:none;border-radius:12px;
  font-size:16px;font-weight:700;color:#fff;cursor:pointer;
  background:linear-gradient(135deg,#2563eb,#7c3aed);
  box-shadow:0 4px 16px rgba(37,99,235,.3);transition:all .3s;
}
.btn-survey-submit:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(37,99,235,.4)}
.btn-survey-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* Thank you */
.survey-thanks{display:none;text-align:center;padding:40px 20px}
.survey-thanks .thanks-icon{font-size:48px;margin-bottom:16px}
.survey-thanks h3{font-size:20px;font-weight:800;margin-bottom:12px;color:#1e293b}
.survey-thanks p{font-size:14px;color:#64748b;line-height:1.8}

/* ----- PR Section ----- */
.pr-section{
  position:relative;
  background:linear-gradient(135deg,#fffbeb,#fef3c7);
  border:2px solid #fbbf24;
  border-radius:16px;padding:24px;margin:20px 0;text-align:center;
}
.pr-section h3{color:#92400e;font-size:17px;font-weight:800;margin-bottom:16px}
.pr-badge{
  display:inline-block;background:#92400e;color:#fff;
  font-size:10px;font-weight:700;padding:2px 10px;border-radius:4px;margin-bottom:10px;
  letter-spacing:.5px;
}
.pr-card{
  background:#fff;border-radius:14px;padding:20px;
  text-align:left;box-shadow:0 2px 12px rgba(0,0,0,.06);
  position:relative;
}
.pr-card-header{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.pr-card-logo{
  width:48px;height:48px;border-radius:12px;
  background:linear-gradient(135deg,#1e3a5f,#2563eb);
  color:#fff;font-size:16px;font-weight:800;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.pr-card-name{font-size:16px;font-weight:800;color:#1e293b}
.pr-card-tagline{font-size:12px;color:#64748b;margin-top:2px}
.pr-features{
  list-style:none;padding:0;margin:0 0 16px;
  display:flex;flex-direction:column;gap:8px;
}
.pr-features li{
  font-size:13px;color:#1e293b;line-height:1.6;padding-left:22px;
  position:relative;
}
.pr-features li::before{
  content:"✓";position:absolute;left:0;
  color:#16a34a;font-weight:700;
}
.pr-card-btn{
  display:block;width:100%;text-align:center;
  background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;
  text-decoration:none;padding:14px;border-radius:12px;
  font-size:15px;font-weight:700;transition:all .3s;
  box-shadow:0 4px 16px rgba(37,99,235,.25);
}
.pr-card-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 24px rgba(37,99,235,.35);
}
.pr-card-note{
  font-size:11px;color:#92400e;margin-top:12px;text-align:center;
}

/* ----- Responsive ----- */
@media(max-width:480px){
  .q-card{padding:20px 16px}
  .hero-features{gap:16px}
  .result-header{padding:24px 16px;margin:-12px -12px 20px}
  .pr-section{padding:16px}
  .pr-card{padding:16px}
  .pr-card-name{font-size:15px}
  .pr-features li{font-size:12px}
}
