/* =====================================================================
   Underclass — application tracker
   Extends the CVExpress warm-ivory / brass palette into a working tool.
   ===================================================================== */

/* ---- Design tokens (stolen from cvexpress, extended) ------------- */
:root {
  --bg:          #f6f1e7;
  --surface:     #fffdf8;
  --surface-alt: #f0e8d8;
  --ink:         #1a1714;
  --text:        #2b2620;
  --muted:       #6b5d4a;
  --accent:      #b08a3e;
  --accent-deep: #8a6a26;
  --line:        #d9ccb3;
  --line-strong: #b8a988;

  /* status colors (muted, on-palette) */
  --st-open:     #5b7c99;
  --st-applied:  #b08a3e;
  --st-pending:  #8a6a26;
  --st-rejected: #a04040;
  --st-offer:    #3e7a5b;
  --st-closed:   #6b5d4a;

  --font-display: 'Cormorant Garamond', 'Georgia', serif;
  --font-body:    'Inter', 'Helvetica Neue', Arial, sans-serif;

  --radius:    14px;
  --radius-sm: 6px;
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  20px;
  --space-5:  32px;
  --space-6:  48px;
  --shadow:    0 2px 18px rgba(60, 42, 12, 0.08);
  --rule-deco: 3px double var(--accent);
  --rule-thin: 1px solid var(--line);
  --maxw: 1080px;
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  font-weight: 300;
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: var(--accent-deep); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }

/* ---- Layout shell (from cvexpress) ------------------------------- */
.page {
  max-width: var(--maxw);
  margin: var(--space-6) auto;
  padding: var(--space-5) var(--space-4);
}
.sheet {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: var(--space-5) var(--space-4);
  position: relative;
}
.sheet::before,
.sheet::after {
  content: "";
  position: absolute;
  width: 22px; height: 22px;
  border: 2px solid var(--accent);
  opacity: .6;
}
.sheet::before { top: 10px; left: 10px;  border-right: 0; border-bottom: 0; }
.sheet::after  { bottom: 10px; right: 10px; border-left: 0; border-top: 0; }

/* ---- Header ------------------------------------------------------ */
.header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: var(--rule-deco);
  margin-bottom: var(--space-4);
}
.header h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.8rem, 4vw, 2.4rem);
  margin: 0;
  letter-spacing: .5px;
  color: var(--ink);
}
.header h1::first-letter { color: var(--accent-deep); }
.title-role {
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: .74rem;
  color: var(--accent-deep);
  margin-top: 2px;
}
.header-action button.lang {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: .78rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  border: 1px solid var(--line-strong);
  background: transparent;
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all .15s ease;
}
.header-action button.lang:hover {
  color: var(--surface);
  background: var(--accent);
  border-color: var(--accent);
}

.footer {
  margin-top: var(--space-5);
  padding-top: var(--space-3);
  border-top: var(--rule-thin);
  text-align: center;
  font-size: .74rem;
  letter-spacing: .1em;
  color: var(--muted);
  text-transform: uppercase;
}

/* ---- Stats strip ------------------------------------------------- */
.stats-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.stat-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 6px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface);
  font-size: .82rem;
  text-decoration: none;
  transition: all .15s ease;
}
.stat-chip:hover { border-color: var(--accent); text-decoration: none; }
.stat-chip.active {
  border-color: var(--accent);
  background: var(--surface-alt);
}
.stat-label {
  font-weight: 500;
  color: var(--text);
  letter-spacing: .04em;
}
.stat-count {
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--accent-deep);
  font-size: 1rem;
}

/* ---- Tier filter ------------------------------------------------- */
.tier-filter {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  margin-bottom: var(--space-4);
  font-size: .78rem;
}
.tier-chip {
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid transparent;
  color: var(--muted);
  text-decoration: none;
  letter-spacing: .04em;
  cursor: pointer;
}
.tier-chip:hover { color: var(--accent-deep); text-decoration: none; }
.tier-chip.active {
  background: var(--accent);
  color: var(--surface);
}

/* ---- Filter row (tier + label) ----------------------------------- */
.filter-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}
.label-filter select {
  font-family: var(--font-body);
  font-size: .82rem;
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 4px 28px 4px 12px;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%238a6a26' fill='none' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
}
.label-filter select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(176, 138, 62, 0.15);
}

/* ---- Native select styling (art-deco) --------------------------- */
select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%238a6a26' fill='none' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 28px !important;
  cursor: pointer;
}
select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(176, 138, 62, 0.15);
}

/* ---- Create form ------------------------------------------------- */
.create-wrap {
  margin-bottom: var(--space-4);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface);
}
.create-wrap > summary {
  padding: var(--space-2) var(--space-3);
  cursor: pointer;
  font-weight: 500;
  font-size: .88rem;
  color: var(--accent-deep);
  letter-spacing: .04em;
  list-style: none;
}
.create-wrap > summary::-webkit-details-marker { display: none; }
.create-wrap[open] > summary { border-bottom: 1px solid var(--line); }
.create-form { padding: var(--space-3); }
.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}
.form-grid label,
.form-notes {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: .78rem;
  color: var(--muted);
  letter-spacing: .06em;
  text-transform: uppercase;
}
.form-notes { margin-bottom: var(--space-3); }
.form-grid input,
.form-grid select,
.form-notes textarea {
  font-family: var(--font-body);
  font-size: .92rem;
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 8px 10px;
  text-transform: none;
  letter-spacing: normal;
  font-weight: 300;
}
.form-notes textarea { resize: vertical; }
.form-grid input:focus,
.form-grid select:focus,
.form-notes textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(176, 138, 62, 0.15);
}
.primary-btn {
  background: var(--accent);
  color: var(--surface);
  border: none;
  padding: 8px 18px;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: .88rem;
  letter-spacing: .04em;
  cursor: pointer;
  transition: background .15s ease;
}
.primary-btn:hover { background: var(--accent-deep); }
.danger-btn {
  background: transparent;
  color: var(--st-rejected);
  border: 1px solid var(--st-rejected);
  padding: 6px 14px;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: .82rem;
  cursor: pointer;
}
.danger-btn:hover { background: var(--st-rejected); color: var(--surface); }

/* ---- Prospect cards ---------------------------------------------- */
.prospect-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.prospect-card {
  border: 1px solid var(--line);
  border-left: 3px solid var(--muted);
  border-radius: var(--radius-sm);
  background: var(--surface);
  padding: var(--space-3);
  transition: border-color .15s ease, box-shadow .15s ease;
}
.prospect-card:hover { box-shadow: 0 1px 8px rgba(60, 42, 12, 0.06); }
.prospect-card.tier-moonshot { border-left-color: #7c5cff; }
.prospect-card.tier-tier1    { border-left-color: var(--accent); }
.prospect-card.tier-tier2    { border-left-color: var(--line-strong); }
.prospect-card.tier-tier3    { border-left-color: var(--muted); }
.prospect-card.tier-monitor  { border-left-color: var(--line); }

.pc-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}
.pc-title { display: flex; align-items: baseline; gap: var(--space-2); flex-wrap: wrap; }
.pc-company {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.15rem;
  color: var(--ink);
}
.pc-role { color: var(--text); font-size: .92rem; }
.pc-meta { display: flex; align-items: center; gap: var(--space-2); flex-shrink: 0; }
.pc-tier {
  font-size: .68rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
}
.pc-status {
  font-size: .68rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid currentColor;
}
.status-open     { color: var(--st-open); }
.status-applied  { color: var(--st-applied); }
.status-pending  { color: var(--st-pending); }
.status-rejected { color: var(--st-rejected); }
.status-offer    { color: var(--st-offer); }
.status-closed   { color: var(--st-closed); }

.pc-body {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  font-size: .84rem;
  color: var(--muted);
  margin-bottom: var(--space-2);
}
.pc-body .pc-k {
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent-deep);
  margin-right: 4px;
  font-weight: 500;
}
.pc-url { color: var(--accent-deep); }

/* ---- Label chips on cards ---------------------------------------- */
.pc-labels {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: var(--space-2);
}
.pc-label {
  font-size: .68rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--accent-deep);
  background: rgba(176, 138, 62, 0.08);
  border: 1px solid rgba(176, 138, 62, 0.25);
  border-radius: 3px;
  padding: 2px 7px;
}
.pc-notes {
  margin: 0 0 var(--space-2);
  font-size: .88rem;
  color: var(--text);
  font-style: italic;
  border-left: 2px solid var(--line);
  padding-left: var(--space-2);
}

.pc-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.pc-actions select {
  font-family: var(--font-body);
  font-size: .8rem;
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 4px 8px;
  cursor: pointer;
}
.pc-edit { margin-top: var(--space-2); font-size: .78rem; }
.pc-edit > summary {
  cursor: pointer;
  color: var(--muted);
  letter-spacing: .04em;
  list-style: none;
  display: inline-block;
}
.pc-edit > summary::-webkit-details-marker { display: none; }
.pc-edit > summary:hover { color: var(--accent-deep); }
.pc-edit[open] { margin-top: var(--space-3); padding-top: var(--space-2); border-top: var(--rule-thin); }
.pc-edit form { margin-top: var(--space-2); }
.pc-edit-actions { display: flex; gap: var(--space-2); align-items: center; margin-top: var(--space-2); }

.empty {
  text-align: center;
  color: var(--muted);
  font-style: italic;
  padding: var(--space-5);
}

/* ---- Login page -------------------------------------------------- */
.login-body {
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
}
.login-shell { width: 100%; max-width: 380px; padding: var(--space-4); }
.login-card {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: var(--space-5) var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  border: 1px solid var(--line);
}
.login-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 2rem;
  color: var(--ink);
  margin: 0;
  text-align: center;
}
.login-title::first-letter { color: var(--accent-deep); }
.login-sub {
  text-align: center;
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent-deep);
  margin: 0 0 var(--space-2);
}
.login-err {
  color: var(--st-rejected);
  font-size: .84rem;
  text-align: center;
  padding: var(--space-2);
  background: rgba(160, 64, 64, 0.06);
  border-radius: var(--radius-sm);
}
.login-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: .74rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
}
.login-field input {
  font-family: var(--font-body);
  font-size: .95rem;
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  text-transform: none;
  letter-spacing: normal;
  font-weight: 300;
}
.login-field input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(176, 138, 62, 0.15);
}
.login-btn {
  background: var(--accent);
  color: var(--surface);
  border: none;
  padding: 10px;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: .92rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  cursor: pointer;
  margin-top: var(--space-2);
  transition: background .15s ease;
}
.login-btn:hover { background: var(--accent-deep); }

/* ---- Responsive -------------------------------------------------- */
@media (max-width: 640px) {
  .page { padding: var(--space-3); }
  .sheet { padding: var(--space-3); }
  .header { flex-direction: column; align-items: flex-start; }
  .pc-head { flex-direction: column; align-items: flex-start; }
}