/* Cultiva HRD App — brand greens, clean internal tool styling */

/* ── Mont (Cultiva typeface), self-hosted — no external font CDN ──── */
@font-face {
  font-family: "Mont"; font-style: normal; font-weight: 300; font-display: swap;
  src: url("fonts/Mont-Light.ttf") format("truetype");
}
@font-face {
  font-family: "Mont"; font-style: normal; font-weight: 350; font-display: swap;
  src: url("fonts/Mont-Book.ttf") format("truetype");
}
@font-face {
  font-family: "Mont"; font-style: normal; font-weight: 400; font-display: swap;
  src: url("fonts/Mont-Regular.ttf") format("truetype");
}
@font-face {
  font-family: "Mont"; font-style: normal; font-weight: 700; font-display: swap;
  src: url("fonts/Mont-Bold.ttf") format("truetype");
}

:root {
  --green-primary: #00643C;
  --green-secondary: #008453;
  --gray-body: #6D6E71;
  --gray-secondary: #939598;
  --gray-light: #BCBEC0;
  --gray-bg: #F5F5F5;
  --white: #FFFFFF;
  --answer-highlight: #FFF9C4;
  --answer-border: #F9A825;
  --danger: #C0392B;
  --font-stack: 'Mont', 'Montserrat', 'Segoe UI', system-ui, -apple-system, sans-serif;
}

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

html { font-size: 16px; scroll-behavior: smooth; }

body {
  font-family: var(--font-stack);
  color: var(--gray-body);
  background: var(--gray-bg);
  line-height: 1.6;
}

/* ── Layout ─────────────────────────────────────────────── */

.site-header {
  background: var(--green-primary);
  color: var(--white);
  padding: 1rem 1.5rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}

.site-header .brand-lockup {
  display: flex;
  align-items: center;
  gap: .85rem;
  text-decoration: none;
}

.site-header .brand-logo {
  height: 38px;
  width: auto;
  display: block;
}

.site-header .brand-divider {
  width: 1px;
  height: 28px;
  background: rgba(255, 255, 255, .35);
}

.site-header .logo-text {
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: .03em;
  color: var(--white);
}

.site-header .subtitle {
  font-size: .85rem;
  color: var(--white);
  opacity: .85;
}

.container {
  max-width: 900px;
  margin: 2rem auto;
  padding: 0 1rem;
}

.container-wide {
  max-width: 1200px;
  margin: 2rem auto;
  padding: 0 1rem;
}

/* ── Cards / Fieldsets ───────────────────────────────────── */

.card {
  background: var(--white);
  border-radius: 8px;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}

.card h2 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--green-primary);
  margin-bottom: 1rem;
  padding-bottom: .5rem;
  border-bottom: 2px solid var(--green-primary);
  text-transform: uppercase;
  letter-spacing: .05em;
}

/* ── Form elements ───────────────────────────────────────── */

.form-group {
  margin-bottom: 1rem;
}

label {
  display: block;
  font-size: .85rem;
  font-weight: 600;
  color: var(--gray-body);
  margin-bottom: .3rem;
}

label .required { color: var(--danger); margin-left: 2px; }

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="date"],
select,
textarea {
  width: 100%;
  padding: .5rem .75rem;
  border: 1px solid var(--gray-light);
  border-radius: 5px;
  font-family: var(--font-stack);
  font-size: .9rem;
  color: var(--gray-body);
  background: var(--white);
  transition: border-color .15s;
}

input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--green-primary);
  box-shadow: 0 0 0 3px rgba(0,100,60,.1);
}

textarea { resize: vertical; min-height: 80px; }

.radio-group, .checkbox-group {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
  margin-top: .3rem;
}

.radio-group label, .checkbox-group label {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-weight: 400;
  cursor: pointer;
}

/* ── Repeatable table grids ─────────────────────────────── */

.table-grid {
  width: 100%;
  border-collapse: collapse;
  font-size: .85rem;
}

.table-grid th {
  background: var(--green-primary);
  color: var(--white);
  padding: .5rem .6rem;
  text-align: left;
  font-weight: 600;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.table-grid td {
  padding: .35rem .4rem;
  border-bottom: 1px solid var(--gray-bg);
}

.table-grid tr:nth-child(even) td { background: #FAFAFA; }

.table-grid input, .table-grid select {
  padding: .3rem .4rem;
  font-size: .82rem;
}

/* ── Assessment answer inputs ────────────────────────────── */

.answer-input {
  background: var(--answer-highlight);
  border: 1px solid var(--answer-border);
  border-radius: 4px;
  padding: .3rem .5rem;
  width: 100%;
  font-size: .9rem;
}

.answer-input:focus {
  outline: none;
  border-color: #F57F17;
  box-shadow: 0 0 0 3px rgba(249,168,37,.2);
}

/* Likert scale radio row */
.likert-row {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  margin-top: .3rem;
}

.likert-option {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .2rem;
  min-width: 70px;
  background: var(--answer-highlight);
  border: 1px solid var(--answer-border);
  border-radius: 6px;
  padding: .5rem .3rem;
  cursor: pointer;
  flex: 1;
  text-align: center;
}

.likert-option input[type="radio"] { accent-color: var(--green-primary); }
.likert-option .scale-val { font-size: .7rem; font-weight: 700; color: var(--gray-body); }
.likert-option .scale-label { font-size: .68rem; color: var(--gray-secondary); line-height: 1.2; }

.likert-option:has(input:checked) {
  background: #E8F5E9;
  border-color: var(--green-primary);
}

/* Forced choice DISC */
.disc-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: .5rem;
  margin-top: .4rem;
}

.disc-option {
  display: flex;
  align-items: center;
  gap: .5rem;
  background: var(--answer-highlight);
  border: 1px solid var(--answer-border);
  border-radius: 6px;
  padding: .6rem .75rem;
  cursor: pointer;
  font-size: .85rem;
}

.disc-option:has(input:checked) {
  background: #E8F5E9;
  border-color: var(--green-primary);
}

.disc-option input { accent-color: var(--green-primary); }
.disc-key { font-weight: 700; color: var(--green-primary); margin-right: .1rem; }

/* ── Assessment section header ───────────────────────────── */

.section-header {
  background: var(--green-primary);
  color: var(--white);
  padding: 1rem 1.5rem;
  border-radius: 8px 8px 0 0;
}

.section-header h3 { font-size: 1rem; font-weight: 700; }
.section-header .instructions { font-size: .85rem; opacity: .9; margin-top: .4rem; }
.section-header .instructions-id { font-style: italic; opacity: .75; font-size: .8rem; }

.assessment-section {
  background: var(--white);
  border-radius: 8px;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
  margin-bottom: 2rem;
  overflow: hidden;
}

.assessment-items { padding: 1rem 1.5rem; }

.assessment-item {
  padding: .75rem 0;
  border-bottom: 1px solid var(--gray-bg);
}
.assessment-item:last-child { border-bottom: none; }

.item-prompt {
  font-size: .9rem;
  font-weight: 600;
  color: #333;
  margin-bottom: .2rem;
}

.item-prompt-id {
  font-size: .82rem;
  color: var(--gray-secondary);
  font-style: italic;
  margin-bottom: .5rem;
}

.item-number {
  display: inline-block;
  background: var(--green-primary);
  color: var(--white);
  font-size: .72rem;
  font-weight: 700;
  padding: .1rem .4rem;
  border-radius: 3px;
  margin-right: .4rem;
}

/* ── Buttons ─────────────────────────────────────────────── */

.btn {
  display: inline-block;
  padding: .65rem 1.5rem;
  border: none;
  border-radius: 5px;
  font-family: var(--font-stack);
  font-size: .9rem;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  transition: background .15s, opacity .15s;
}

.btn-primary {
  background: var(--green-primary);
  color: var(--white);
}
.btn-primary:hover { background: var(--green-secondary); }

.btn-secondary {
  background: var(--gray-light);
  color: var(--gray-body);
}
.btn-secondary:hover { background: var(--gray-secondary); color: var(--white); }

.btn-sm { padding: .35rem .75rem; font-size: .8rem; }

/* ── Progress indicator ──────────────────────────────────── */

.step-indicator {
  display: flex;
  gap: .5rem;
  margin-bottom: 1.5rem;
}

.step {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: .82rem;
  color: var(--gray-secondary);
}

.step.active { color: var(--green-primary); font-weight: 700; }
.step.done { color: var(--gray-light); }

.step-num {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--gray-light);
  color: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .75rem;
  font-weight: 700;
}

.step.active .step-num { background: var(--green-primary); }
.step-sep { color: var(--gray-light); font-size: .8rem; }

/* ── Admin dashboard table ───────────────────────────────── */

.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .85rem;
  background: var(--white);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
}

.admin-table th {
  background: var(--green-primary);
  color: var(--white);
  padding: .7rem 1rem;
  text-align: left;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.admin-table td {
  padding: .6rem 1rem;
  border-bottom: 1px solid var(--gray-bg);
}

.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: #F0F9F4; }

/* ── Profile detail panels ───────────────────────────────── */

.profile-section {
  background: var(--white);
  border-radius: 8px;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
  margin-bottom: 1.5rem;
  overflow: hidden;
}

.profile-section h3 {
  background: var(--green-primary);
  color: var(--white);
  padding: .75rem 1.25rem;
  font-size: .9rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.profile-body { padding: 1.25rem; }

.dim-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
}

.dim-card {
  background: var(--gray-bg);
  border-radius: 6px;
  padding: .75rem 1rem;
  border-left: 4px solid var(--green-primary);
}

.dim-card.genius-tier { border-left-color: #00643C; background: #E8F5E9; }
.dim-card.competency-tier { border-left-color: #FFA000; background: #FFF8E1; }
.dim-card.frustration-tier { border-left-color: #C62828; background: #FFEBEE; }

.dim-name { font-weight: 700; font-size: .85rem; color: #333; }
.dim-score { font-size: 1.4rem; font-weight: 700; color: var(--green-primary); }
.dim-band { font-size: .75rem; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; color: var(--gray-body); margin-top: .1rem; }
.dim-meaning { font-size: .78rem; color: var(--gray-secondary); margin-top: .4rem; line-height: 1.4; }
.dim-tier-badge { font-size: .7rem; font-weight: 700; text-transform: uppercase; padding: .1rem .4rem; border-radius: 3px; display: inline-block; margin-top: .3rem; }
.badge-genius { background: #00643C; color: #fff; }
.badge-competency { background: #FFA000; color: #fff; }
.badge-frustration { background: #C62828; color: #fff; }

/* ── DISC summary bar ────────────────────────────────────── */

.disc-bar {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

.disc-style-card {
  background: var(--gray-bg);
  border-radius: 6px;
  padding: .6rem .9rem;
  border-left: 4px solid var(--green-secondary);
  min-width: 120px;
}

.disc-style-card.primary { border-left-color: var(--green-primary); background: #E8F5E9; }
.disc-style-card.secondary { border-left-color: var(--gray-secondary); }

.disc-letter { font-size: 1.6rem; font-weight: 700; color: var(--green-primary); }
.disc-count { font-size: .78rem; color: var(--gray-secondary); }

/* ── Alerts ──────────────────────────────────────────────── */

.alert {
  padding: .75rem 1rem;
  border-radius: 5px;
  margin-bottom: 1rem;
  font-size: .9rem;
}

.alert-error { background: #FFEBEE; color: #C62828; border-left: 4px solid #C62828; }
.alert-success { background: #E8F5E9; color: #2E7D32; border-left: 4px solid #2E7D32; }

/* ── Declaration box ─────────────────────────────────────── */

.declaration-box {
  background: #FFF9C4;
  border: 1px solid #F9A825;
  border-radius: 6px;
  padding: 1rem 1.25rem;
  font-size: .88rem;
  color: #555;
  line-height: 1.6;
  margin-bottom: 1rem;
}

/* ── Bio key-value display ───────────────────────────────── */

.kv-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: .5rem 1.5rem;
}

.kv { display: flex; flex-direction: column; padding: .3rem 0; }
.kv-label { font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; color: var(--gray-secondary); }
.kv-value { font-size: .88rem; color: #333; }

/* ── Responsive ──────────────────────────────────────────── */

@media (max-width: 640px) {
  .likert-row { gap: .25rem; }
  .likert-option { min-width: 55px; padding: .4rem .2rem; }
  .disc-options { grid-template-columns: 1fr 1fr; }
  .dim-grid { grid-template-columns: 1fr; }
  .kv-grid { grid-template-columns: 1fr; }
}

/* ── Form actions bar ────────────────────────────────────── */

.form-actions {
  display: flex;
  justify-content: flex-end;
  gap: .75rem;
  padding: 1rem 0;
}

/* ── Thank you page ──────────────────────────────────────── */

.thankyou-box {
  text-align: center;
  padding: 3rem 1rem;
}

.thankyou-box .check-icon {
  font-size: 3rem;
  color: var(--green-primary);
  margin-bottom: 1rem;
}

.thankyou-box h1 {
  color: var(--green-primary);
  font-size: 1.5rem;
  margin-bottom: .5rem;
}

/* ── Misc ────────────────────────────────────────────────── */

.text-muted { color: var(--gray-secondary); font-size: .82rem; }
.text-green { color: var(--green-primary); }
.mt-1 { margin-top: .5rem; }
.mt-2 { margin-top: 1rem; }
.mb-1 { margin-bottom: .5rem; }
.nav-links { display: flex; gap: 1rem; align-items: center; margin-left: auto; }
.nav-links a { color: rgba(255,255,255,.8); font-size: .85rem; text-decoration: none; }
.nav-links a:hover { color: var(--white); }

/* ── Access-code admin ───────────────────────────────────── */

.code-value { font-family: monospace; letter-spacing: .08em; font-size: 1rem; font-weight: 700; color: var(--green-primary); }
.code-link { font-family: monospace; font-size: .72rem; color: var(--gray-secondary); word-break: break-all; }
.code-badge { font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; padding: .12rem .45rem; border-radius: 3px; display: inline-block; white-space: nowrap; }
.code-available { background: #E8F5E9; color: #2E7D32; }
.code-inuse { background: #FFF3E0; color: #E65100; }
.code-usedup { background: var(--gray-bg); color: var(--gray-secondary); }
.code-revoked { background: #FFEBEE; color: #C62828; }
