/* ============================================================
   Let's Start Planning — Shared Styles
   Dark, minimal, editorial. Consistent across intake + dashboard.
   ============================================================ */

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

body {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  margin: 0;
  background: #0b0b0d;
  color: #f2f2f4;
  line-height: 1.6;
}

.wrap {
  max-width: 860px;
  margin: 0 auto;
  padding: 36px 18px 80px;
}

/* ---- Typography ---- */
h1 { font-size: 26px; margin: 0 0 8px; letter-spacing: -0.3px; }
h2 { font-size: 20px; margin: 0 0 12px; }
h3 { font-size: 15px; margin: 18px 0 8px; color: #b7b7c3; text-transform: uppercase; letter-spacing: 0.05em; }
p  { margin: 0 0 12px; }

.sub { color: #8a8a9a; font-size: 15px; margin: 0 0 28px; }

/* ---- Cards (intake questions) ---- */
.card {
  background: #141419;
  border: 1px solid #242430;
  border-radius: 14px;
  padding: 18px 16px;
  margin: 12px 0;
}

.card > label:first-child {
  display: block;
  font-weight: 600;
  margin-bottom: 14px;
  color: #f2f2f4;
}

/* ---- Inputs ---- */
input[type="text"],
input[type="email"],
input:not([type]),
select {
  width: 100%;
  padding: 11px 14px;
  border-radius: 10px;
  border: 1px solid #2b2b38;
  background: #0f0f14;
  color: #f2f2f4;
  font-size: 15px;
  outline: none;
  transition: border-color 0.15s;
}

input:focus, select:focus {
  border-color: #5555aa;
}

/* ---- Radio options ---- */
.opts { display: flex; flex-direction: column; gap: 10px; }

.opts label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  color: #d8d8e8;
  font-size: 15px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid transparent;
  transition: background 0.12s, border-color 0.12s;
}

.opts label:hover {
  background: #1c1c25;
  border-color: #2b2b38;
}

.opts input[type="radio"] {
  width: auto;
  margin-top: 2px;
  flex-shrink: 0;
  accent-color: #a0a0ff;
}

/* ---- Buttons ---- */
.btn {
  display: block;
  width: 100%;
  margin-top: 20px;
  padding: 14px;
  border: none;
  border-radius: 12px;
  background: #f2f2f4;
  color: #111;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.15s;
}
.btn:hover { opacity: 0.88; }
.btn:disabled { opacity: 0.45; cursor: not-allowed; }

.btn-sm {
  padding: 7px 12px;
  border: none;
  border-radius: 8px;
  background: #f2f2f4;
  color: #111;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.15s;
  white-space: nowrap;
}
.btn-sm:hover { opacity: 0.82; }

.btn-ghost {
  padding: 7px 12px;
  border: 1px solid #2b2b38;
  border-radius: 8px;
  background: transparent;
  color: #b7b7c3;
  font-size: 13px;
  cursor: pointer;
}
.btn-ghost:hover { border-color: #5555aa; color: #f2f2f4; }

/* ---- Utility ---- */
.hidden  { display: none !important; }
.req     { color: #ff8080; }
.err     { color: #ff8080; font-size: 14px; margin-top: 10px; }

/* ---- Row (flex helpers) ---- */
.row {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  margin: 10px 0 16px;
}

.row input, .row select {
  flex: 1;
  min-width: 140px;
}

/* ---- Table ---- */
.tbl {
  width: 100%;
  border-collapse: collapse;
  margin-top: 10px;
  font-size: 14px;
}
.tbl th {
  text-align: left;
  padding: 10px 12px;
  border-bottom: 1px solid #242430;
  color: #8a8a9a;
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.tbl td {
  padding: 11px 12px;
  border-bottom: 1px solid #1a1a22;
  vertical-align: middle;
}
.tbl tr:hover td { background: #141419; }

/* ---- Tier badges ---- */
.tier {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.tier-Green  { background: #0d2b1a; color: #4ade80; border: 1px solid #166534; }
.tier-Yellow { background: #2b2200; color: #fbbf24; border: 1px solid #854d0e; }
.tier-Red    { background: #2b0d0d; color: #f87171; border: 1px solid #7f1d1d; }

/* ---- Status badges ---- */
.status {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
}
.status-New      { background: #1a1a2e; color: #a0a0ff; border: 1px solid #3030aa; }
.status-Reviewed { background: #1a1a1a; color: #b7b7c3; border: 1px solid #3a3a4a; }
.status-Accepted { background: #0d2b1a; color: #4ade80; border: 1px solid #166534; }
.status-Declined { background: #2b0d0d; color: #f87171; border: 1px solid #7f1d1d; }

/* ---- Pre / code ---- */
.pre {
  background: #0f0f14;
  border: 1px solid #2b2b38;
  border-radius: 10px;
  padding: 14px;
  overflow: auto;
  font-size: 13px;
  font-family: "SF Mono", "Fira Code", monospace;
  color: #b7b7c3;
  white-space: pre-wrap;
  word-break: break-word;
  margin: 8px 0;
}

/* ---- Modal ---- */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  display: grid;
  place-items: center;
  padding: 18px;
  z-index: 100;
  overflow-y: auto;
}

.modal-card {
  width: min(700px, 100%);
  background: #141419;
  border: 1px solid #242430;
  border-radius: 18px;
  padding: 24px;
}

.modal-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 18px;
}

.modal-head h2 { margin: 0; }

/* ---- Action hint ---- */
.action-hint {
  padding: 12px 14px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 500;
  margin: 8px 0 16px;
}
.action-Green  { background: #0d2b1a; color: #4ade80; border: 1px solid #166534; }
.action-Yellow { background: #2b2200; color: #fbbf24; border: 1px solid #854d0e; }
.action-Red    { background: #2b0d0d; color: #f87171; border: 1px solid #7f1d1d; }

/* ---- Details/summary (show answers toggle) ---- */
details { margin-top: 14px; }
details summary {
  cursor: pointer;
  color: #8a8a9a;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 8px 0;
  user-select: none;
}
details summary:hover { color: #f2f2f4; }

/* ---- Thank you screen ---- */
.thanks {
  text-align: center;
  padding: 60px 20px;
}
.thanks h2 { font-size: 22px; margin-bottom: 12px; }
.thanks p  { color: #8a8a9a; max-width: 440px; margin: 0 auto; }

/* ---- Responsive ---- */
@media (max-width: 600px) {
  .tbl th:nth-child(3),
  .tbl td:nth-child(3) { display: none; }
}
