/* Big Bet Jobs — editorial design system v2 */

a, button, input, select, textarea, [onclick] {
  -webkit-tap-highlight-color: transparent;
}

:root {
  /* Brand palette */
  --cream: #e7e2bf;
  --sand:  #e5dab7;
  --sage:  #c8c9ac;
  --olive: #928b61;
  --olive-deep: #6e6845;
  --black: #090808;

  /* Surfaces */
  --paper: #f6f3e3;
  --paper-2: #ece6cd;
  --paper-3: #d8d4b6;
  --rule: #c8c2a0;
  --rule-soft: #d9d3b3;

  /* Text */
  --ink: #090808;
  --ink-2: #1f1d18;
  --ink-3: #56523f;
  --ink-4: #8a8466;

  /* Accent */
  --khaki: #928b61;
  --khaki-deep: #6e6845;
  --accent: #928b61;
  --accent-tint: rgba(146, 139, 97, 0.18);
  --hot: #b54e2c;

  --serif: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;

  --content-w: 1280px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { background: var(--paper); color: var(--ink); }
body {
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.5;
  font-feature-settings: "ss01", "cv11";
  letter-spacing: -0.005em;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
input, select { font: inherit; color: inherit; }

/* ===== Top bar ===== */
.topbar {
  border-bottom: 1px solid var(--rule);
  background: var(--paper-3);
  position: sticky; top: 0; z-index: 40;
}
.topbar .nav .nav-signin { display: none; }
.topbar .nav { color: var(--ink-3); }
.topbar .nav a:hover { color: var(--ink); }
.topbar .nav a.active { color: var(--ink); border-bottom-color: var(--olive); }
.topbar .brand { color: var(--ink); }
.topbar .stats { display: flex; gap: 20px; font-size: 12px; color: var(--ink-3); }
.topbar .stats b { font-size: 13px; font-weight: 600; color: var(--ink); margin-right: 4px; }
.topbar .topbar-actions { color: var(--ink-3); margin-left: auto; display: flex; align-items: center; gap: 16px; }
.topbar .topbar-actions a.muted { color: var(--ink-3); }
.signin-btn { background: var(--olive-deep); color: #fff; border: none; border-radius: 6px; padding: 6px 14px; font-size: 13px; font-weight: 500; cursor: pointer; font-family: var(--sans); }
.signin-btn:hover { background: var(--olive); }
.auth-avatar { width: 28px; height: 28px; border-radius: 50%; cursor: pointer; }
.auth-avatar-initials { width: 28px; height: 28px; border-radius: 50%; cursor: pointer; background: var(--olive-deep); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 600; }
.auth-menu { position: absolute; right: 0; top: 100%; margin-top: 6px; background: var(--cream); border: 1px solid var(--rule); border-radius: 8px; box-shadow: 0 4px 12px rgba(0,0,0,0.12); padding: 8px 0; z-index: 200; min-width: 140px; }
.auth-menu-name { padding: 6px 14px; font-size: 12px; color: var(--ink-3); border-bottom: 1px solid var(--rule); margin-bottom: 4px; }
.auth-menu button, .auth-menu-link { display: block; width: 100%; text-align: left; background: none; border: none; padding: 6px 14px; font-size: 13px; cursor: pointer; color: var(--ink-2); text-decoration: none; box-sizing: border-box; }
.auth-menu button:hover, .auth-menu-link:hover { background: var(--sand); }
.signed-in .desktop-signin,
.signed-in .nav-signin,
.signed-in .signin-btn,
.signed-in #static-signin-btn,
.signed-in #static-signin-btn-mobile { display: none !important; }
/* Saved Jobs tab is always shown, but greyed for logged-out users (click prompts sign-in) */
html:not(.signed-in) #nav-saved { opacity: 0.5; }
html:not(.signed-in) #nav-saved:hover { opacity: 0.75; }
.topbar .topbar-actions a.muted:hover { color: var(--ink); }
.topbar .search {
  background: rgba(255,255,255,0.5);
  border-color: var(--rule);
  color: var(--ink-3);
}
.topbar .search:focus-within {
  border-color: var(--olive);
  color: var(--ink);
  box-shadow: 0 0 0 3px rgba(146, 139, 97, 0.18);
}
.topbar .search input { color: var(--ink); }
.topbar .search input::placeholder { color: var(--ink-4); }
.topbar .kbd {
  background: rgba(255,255,255,0.5);
  border-color: var(--rule);
  color: var(--ink-4);
}
.topbar-inner {
  max-width: var(--content-w);
  margin: 0 auto;
  padding: 14px 32px;
  display: flex; align-items: center; gap: 32px;
  min-height: 64px;
  box-sizing: border-box;
}
.brand {
  display: flex; align-items: center;
}
.brand-logo {
  height: 28px;
  width: auto;
}
.nav {
  display: flex; gap: 24px;
  font-size: 13.5px;
  color: var(--ink-3);
}
.nav a { padding: 6px 0; border-bottom: 1px solid transparent; }
.nav a:hover { color: var(--ink); }
.nav a.active { color: var(--ink); border-bottom-color: var(--ink); }
.topbar-actions {
  margin-left: auto;
  display: flex; align-items: center; gap: 16px;
  font-size: 13px;
}
.search {
  display: flex; align-items: center; gap: 8px;
  border: 1px solid var(--rule);
  background: var(--sand);
  border-radius: 6px;
  padding: 4px 10px;
  width: 280px;
  color: var(--ink-3);
}
.search:focus-within { border-color: var(--olive); color: var(--ink); box-shadow: 0 0 0 3px var(--accent-tint); background: var(--cream); }
.search input {
  border: 0; outline: 0; background: transparent;
  width: 100%;
  font-size: 13.5px;
}
.search svg { flex-shrink: 0; opacity: 0.7; }
.filter-btn-mobile { display: none; }
.kbd {
  font-family: var(--mono);
  font-size: 10.5px;
  border: 1px solid var(--rule);
  padding: 1px 5px;
  border-radius: 4px;
  color: var(--ink-4);
  background: var(--paper);
}
.btn {
  font-size: 13px;
  padding: 7px 14px;
  border: 1px solid var(--ink);
  background: var(--ink);
  color: #fff;
  border-radius: 6px;
  font-weight: 500;
  text-decoration: none;
  display: inline-block;
}
.btn.ghost {
  background: var(--sand);
  color: var(--ink);
  border-color: var(--rule);
}
.btn:hover { opacity: 0.9; }

/* ===== Page header ===== */
.page {
  max-width: var(--content-w);
  margin: 0 auto;
  padding: 28px 32px 80px;
}
.eyebrow {
  font-size: 12px;
  color: var(--ink-3);
  font-weight: 500;
}
.eyebrow a { color: var(--olive); }
.eyebrow a:hover { text-decoration: underline; }
.page-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 32px;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 20px;
  margin-bottom: 28px;
}
.page-head h1 {
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 600;
  margin-top: 4px;
}
.page-head .stats {
  display: flex; gap: 28px;
  font-size: 12px;
  color: var(--ink-3);
}
.page-head .stats b {
  display: block;
  font-size: 18px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.01em;
  margin-bottom: 2px;
}
.page-intro {
  max-width: 78ch;
  font-size: 14px;
  line-height: 1.65;
  color: var(--ink-3);
  margin: -8px 0 28px;
}

/* ===== Tabs ===== */
.tabs {
  display: flex; gap: 0;
  margin-bottom: 18px;
  align-items: center;
  justify-content: flex-end;
}
.tablist { display: flex; gap: 28px; }
.tab {
  padding: 10px 0;
  margin-bottom: -1px;
  font-size: 13px;
  color: var(--ink-3);
  border-bottom: 1.5px solid transparent;
  display: flex; gap: 6px; align-items: baseline;
  cursor: pointer;
  background: none; border-top: 0; border-left: 0; border-right: 0;
}
.tab .count {
  font-size: 11.5px;
  color: var(--ink-3);
  font-variant-numeric: tabular-nums;
  background: var(--sand);
  padding: 1px 6px;
  border-radius: 999px;
  font-weight: 500;
}
.tab.active .count {
  background: var(--olive);
  color: var(--cream);
}
.tab.active { color: var(--ink); border-bottom-color: var(--khaki); font-weight: 500; }

.tab-tools {
  display: flex; align-items: center; gap: 14px;
  font-size: 12.5px;
  color: var(--ink-3);
}
.tab-tools .sort { display: flex; align-items: center; gap: 6px; position: relative; }
.sort-btn {
  display: inline-flex; align-items: center; gap: 5px;
  border: 0; background: transparent; cursor: pointer;
  font: inherit; font-size: 12.5px; color: var(--ink-3);
  padding: 0;
}
.sort-btn:focus, .sort-btn:focus-visible { outline: none; }
.sort-btn .sort-value { color: var(--ink); font-weight: 500; }
.sort-btn .sort-caret { color: var(--ink-3); transition: transform .15s ease; }
.sort.open .sort-btn .sort-caret { transform: rotate(180deg); }
/* Dropdown panel — matches the site's .auth-menu surface */
.sort-menu {
  display: none; position: absolute; right: 0; top: 100%; margin-top: 6px;
  background: var(--cream); border: 1px solid var(--rule); border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12); padding: 6px 0; z-index: 200; min-width: 150px;
}
.sort.open .sort-menu { display: block; }
.sort-menu [role="option"] {
  display: block; width: 100%; box-sizing: border-box; text-align: left;
  background: none; border: 0; cursor: pointer;
  padding: 7px 14px; font: inherit; font-size: 12.5px; color: var(--ink-2);
}
.sort-menu [role="option"]:hover { background: var(--sand); color: var(--ink); }
.sort-menu [role="option"][aria-selected="true"] { color: var(--ink); font-weight: 600; }
.sort-menu [role="option"]:focus, .sort-menu [role="option"]:focus-visible { outline: none; }

/* ===== Layout ===== */
.with-sidebar {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 48px;
  align-items: flex-start;
}
.with-sidebar.no-sidebar {
  grid-template-columns: 1fr;
}

/* ===== Filter sidebar ===== */
.filter-side h3 {
  font-size: 12px;
  color: var(--ink-3);
  font-weight: 600;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--rule);
}
.filter-group { margin-bottom: 12px; }
.filter-group-title {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 14px; font-weight: 500;
  padding: 10px 0;
  color: var(--ink);
  cursor: pointer;
  user-select: none;
}
.filter-group-title:hover { color: var(--olive-deep); }
.filter-arrow { font-size: 0; width: 8px; height: 8px; border-right: 2px solid var(--ink-3); border-bottom: 2px solid var(--ink-3); transform: rotate(45deg); transition: transform 0.15s; margin-left: auto; margin-right: 6px; }
.filter-group.open .filter-arrow { transform: rotate(-135deg); }
.filter-list { display: none; flex-direction: column; gap: 4px; padding-top: 6px; }
.filter-group.open .filter-list { display: flex; }
.filter-group-title .count {
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--ink-4);
}
.filter-list label {
  display: flex; gap: 10px; align-items: center;
  font-size: 13px;
  color: var(--ink-2);
  cursor: pointer;
  padding: 3px 0;
}
.filter-list label:hover { color: var(--ink); }
.filter-list .num {
  margin-left: auto;
  font-size: 11.5px;
  color: var(--ink-4);
  font-variant-numeric: tabular-nums;
}
.filter-list input[type="checkbox"] {
  appearance: none;
  width: 13px; height: 13px;
  border: 1px solid var(--ink-4);
  border-radius: 1px;
  background: var(--paper);
  position: relative;
  cursor: pointer;
  flex-shrink: 0;
}
.filter-list input[type="checkbox"]:checked {
  background: var(--ink);
  border-color: var(--ink);
}
.filter-list input[type="checkbox"]:checked::after {
  content: ""; position: absolute;
  left: 3px; top: 0px; width: 4px; height: 8px;
  border: solid var(--paper);
  border-width: 0 1.5px 1.5px 0;
  transform: rotate(45deg);
}
.filter-search-input {
  width: 100%;
  padding: 4px 8px;
  font-size: 12px;
  border: 1px solid var(--rule);
  border-radius: 4px;
  background: var(--paper);
  margin-bottom: 6px;
  outline: none;
  color: var(--ink);
  font-family: inherit;
}
.filter-search-input:focus {
  border-color: var(--ink-4);
}
.date-preset {
  display: flex; gap: 10px; align-items: center;
  font-size: 13px; color: var(--ink-2); cursor: pointer; padding: 3px 0;
}
.date-preset:hover { color: var(--ink); }
.date-preset input[type="radio"] {
  appearance: none; width: 13px; height: 13px;
  border: 1px solid var(--ink-4); border-radius: 50%;
  background: var(--paper); cursor: pointer; flex-shrink: 0;
}
.date-preset input[type="radio"]:checked {
  background: var(--ink); border-color: var(--ink);
}
.date-custom { margin-top: 8px; display: flex; flex-direction: column; gap: 6px; }
.date-custom label { font-size: 12px; color: var(--ink-3); display: flex; align-items: center; gap: 6px; }
.date-custom input[type="date"] {
  flex: 1; padding: 4px 6px; font-size: 12px;
  border: 1px solid var(--rule); border-radius: 4px;
  background: var(--paper); color: var(--ink); font-family: inherit;
}
.filter-clear {
  font-size: 12px;
  color: var(--ink-3);
  border-top: 1px solid var(--rule);
  padding-top: 14px;
  margin-top: 6px;
}
.filter-clear:hover { color: var(--ink); }
.filter-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--rule);
}
.filter-header h3 { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
#filter-clear-inline {
  font-size: 11px;
  color: var(--ink-4);
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
}
#filter-clear-inline:hover { color: var(--ink); }

/* ===== Job cards ===== */
.job-feed { display: flex; flex-direction: column; }
.job-row {
  position: relative;
  border-bottom: 1px solid var(--rule);
  padding: 18px 14px;
  margin: 0 -14px;
  display: grid;
  grid-template-columns: 40px 1fr auto;
  gap: 16px;
  align-items: flex-start;
  transition: background 0.12s;
  text-decoration: none;
  color: inherit;
}
.save-btn-card {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  border: 1px solid var(--rule);
  background: var(--sand);
  border-radius: 5px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 500;
  color: var(--ink-3);
  font-family: var(--sans);
}
.save-btn-card:hover { background: var(--rule-soft); color: var(--ink); }
.save-btn-card.saved { border-color: var(--olive-deep); color: var(--olive-deep); }
.save-btn-card.saved svg { fill: var(--olive-deep); }
/* Logged-out "Save" buttons (feed cards + job detail): greyed, click prompts sign-in */
.save-btn-locked { opacity: 0.5; }
.save-btn-locked:hover { opacity: 0.75; }
.job-side-top { display: flex; align-items: center; justify-content: flex-end; gap: 10px; }
.job-row:first-child { border-top: 1px solid var(--rule); }
.job-row:hover { background: var(--accent-tint); }
.job-logo {
  width: 40px; height: 40px;
  border: 1px solid var(--rule);
  background: #fff;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.02em;
  overflow: hidden;
}
.job-logo img {
  width: 100%; height: 100%;
  object-fit: contain;
}
.job-main {
  min-width: 0;
}
.job-row .meta-line {
  font-size: 12px;
  color: var(--ink-3);
  display: flex; gap: 10px; align-items: center;
  margin-bottom: 6px;
}
.meta-line .dot { width: 2px; height: 2px; background: var(--ink-4); border-radius: 50%; flex-shrink: 0; }
.meta-line .new {
  color: var(--cream);
  background: var(--olive);
  padding: 1px 7px;
  border-radius: 3px;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.02em;
}
.promoted-badge {
  color: var(--olive-deep);
  background: var(--sand);
  padding: 1px 7px;
  border-radius: 3px;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.02em;
  margin-left: auto;
}
.translated-badge {
  color: var(--ink-4);
  background: var(--bg-2);
  padding: 1px 7px;
  border-radius: 3px;
  font-size: 11px;
  letter-spacing: 0.02em;
}
.detail-main > .translated-badge {
  display: inline-block;
  margin-bottom: 16px;
  font-size: 12px;
  padding: 3px 10px;
}
.admin-link { display: none; }
.admin-view { padding: 24px; max-width: 900px; margin: 0 auto; box-sizing: border-box; }
/* Keep the admin area at page width; overflow scrolls horizontally inside the tab */
#admin-view { max-width: 100vw; overflow-x: hidden; }
#admin-tab-content { overflow-x: auto; }
.admin-view h2 { font-size: 20px; margin-bottom: 16px; }
/* Tabs scroll horizontally within their own box rather than widening the page */
.admin-tabs { overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none; }
.admin-tabs::-webkit-scrollbar { display: none; }
.admin-tab { flex-shrink: 0; white-space: nowrap; }
.admin-search { width: 100%; padding: 8px 12px; border: 1px solid var(--rule); border-radius: 6px; font-size: 14px; margin-bottom: 16px; font-family: var(--sans); background: var(--paper-3); }
.admin-job-list { list-style: none; padding: 0; margin: 0; }
.admin-job-list li { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--rule-soft); }
.admin-job-list .job-info { flex: 1; min-width: 0; }
.admin-job-list .job-title { font-weight: 500; font-size: 14px; }
.admin-job-list .job-company { font-size: 12px; color: var(--ink-3); }
.admin-promote-btn { background: var(--olive-deep); color: #fff; border: none; border-radius: 6px; padding: 6px 14px; font-size: 12px; font-weight: 500; cursor: pointer; font-family: var(--sans); flex-shrink: 0; }
.admin-promote-btn:hover { background: var(--olive); }
.admin-promote-btn.demote { background: var(--paper-3); color: var(--ink-2); border: 1px solid var(--rule); }
.admin-promote-btn.demote:hover { background: var(--sand); }
.admin-divider { margin: 24px 0 12px; }
.admin-divider h3 { font-size: 14px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-4); }
.drag-handle { cursor: grab; color: var(--ink-4); font-size: 18px; user-select: none; padding: 0 4px; }
.admin-job-list li[draggable="true"] { cursor: grab; }
.admin-job-list li.dragging { opacity: 0.4; }

/* Admin: Recommendations tab */
.rec-controls { border: 1px solid var(--rule); border-radius: 8px; padding: 16px; margin-bottom: 24px; background: var(--sand); box-sizing: border-box; }
.rec-controls-head { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; margin-bottom: 12px; }
.rec-weights { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 8px 14px; margin-bottom: 14px; }
.rec-w { display: flex; flex-direction: column; gap: 3px; font-size: 12px; color: var(--ink-2); min-width: 0; }
.rec-w input { width: 100%; box-sizing: border-box; padding: 5px 8px; border: 1px solid var(--rule); border-radius: 4px; font-family: var(--sans); font-size: 13px; background: var(--paper); color: var(--ink); }
.rec-controls-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.rec-controls-actions .auth-submit-btn { width: auto; margin: 0; padding: 8px 18px; }
.rec-digest-email { padding: 7px 10px; border: 1px solid var(--rule); border-radius: 6px; font-size: 13px; font-family: var(--sans); background: var(--paper); color: var(--ink); width: 180px; max-width: 100%; box-sizing: border-box; }
.rec-secondary-btn { background: var(--paper); color: var(--ink-2); border: 1px solid var(--rule); border-radius: 6px; padding: 8px 16px; font-size: 13px; font-family: var(--sans); cursor: pointer; }
.rec-secondary-btn:hover { background: var(--sand); }
.rec-secondary-btn:disabled { opacity: 0.6; cursor: default; }
.rec-topn { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--ink-2); }
.rec-topn input { width: 56px; padding: 5px 8px; border: 1px solid var(--rule); border-radius: 4px; background: var(--paper); color: var(--ink); }
.rec-user { margin-bottom: 28px; }
.rec-user h3 { font-size: 14px; margin-bottom: 6px; color: var(--ink); }
.rec-check { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--ink-2); cursor: pointer; }
.rec-section-label { font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-4); margin: 14px 0 2px; font-weight: 600; }
.rec-section-count { font-weight: 400; letter-spacing: 0; text-transform: none; }
.rec-empty { font-size: 12.5px; color: var(--ink-4); padding: 9px 0; border-top: 1px solid var(--rule-soft); }
.rec-row { display: flex; gap: 12px; align-items: flex-start; padding: 9px 0; border-top: 1px solid var(--rule-soft); }
.rec-rank { width: 30px; color: var(--ink-4); font-size: 13px; font-variant-numeric: tabular-nums; flex-shrink: 0; }
.rec-main { flex: 1; min-width: 0; }
.rec-main a { font-weight: 500; font-size: 14px; color: var(--ink); overflow-wrap: anywhere; }
.rec-company { font-size: 12.5px; color: var(--ink-3); margin-top: 1px; overflow-wrap: anywhere; }
.rec-reasons { font-size: 11.5px; color: var(--ink-4); margin-top: 3px; overflow-wrap: anywhere; }
.rec-score { font-size: 13px; color: var(--olive-deep); font-variant-numeric: tabular-nums; white-space: nowrap; flex-shrink: 0; }
.admin-job-list li.drag-over { border-top: 2px solid var(--olive); }
.admin-job-list .job-title a { color: inherit; text-decoration: none; border-bottom: 1px solid var(--rule-soft); }
.admin-job-list .job-title a:hover { border-color: var(--olive); }
.job-row h2 {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.3;
}
.job-row h2 a:hover { text-decoration: underline; text-decoration-color: var(--khaki); text-underline-offset: 4px; }
.job-row .desc {
  margin-top: 8px;
  color: var(--ink-3);
  font-size: 14px;
  line-height: 1.55;
  max-width: 100%;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.job-row .desc.expanded {
  -webkit-line-clamp: unset;
  display: block;
}
.desc-expand {
  display: none;
  background: none;
  border: none;
  color: var(--olive);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  padding: 4px 0 0;
  font-family: var(--sans);
}
.desc-expand.visible { display: inline-block; }
.desc-expand:hover { text-decoration: underline; }
.tag-row {
  display: flex; gap: 6px; flex-wrap: wrap;
  margin-top: 12px;
}
.tag {
  font-size: 11.5px;
  padding: 2px 8px;
  border: 1px solid var(--rule);
  border-radius: 4px;
  color: var(--ink-2);
  background: var(--sand);
  font-weight: 500;
}
.tag:nth-child(2n) { background: var(--cream); }
.tag[data-filter] { cursor: pointer; }
.tag[data-filter]:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.tag-active { border-width: 2px; border-color: var(--ink); }
.tag:nth-child(3n) { background: var(--sage); }
.tag.ink { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.tag.khaki { background: var(--khaki); color: #fff; border-color: var(--khaki); }
.job-side {
  text-align: right;
  display: flex; flex-direction: column; gap: 6px;
  padding-top: 4px;
  font-size: 12.5px;
  color: var(--ink-3);
  min-width: 110px;
}
.job-side .ts {
  font-size: 12px;
  color: var(--ink-3);
}
.job-side .salary-hint {
  font-size: 12px;
  color: var(--ink-4);
  font-variant-numeric: tabular-nums;
}

/* ===== Pagination ===== */
.pager {
  margin-top: 32px;
  display: flex; gap: 6px; align-items: center; justify-content: center;
  font-size: 13px;
}
.pager a, .pager span {
  padding: 6px 11px;
  border: 1px solid var(--rule);
  color: var(--ink-2);
  border-radius: 6px;
  font-size: 12.5px;
  font-variant-numeric: tabular-nums;
  background: var(--cream);
  cursor: pointer;
}
.pager a:hover { background: var(--sand); }
.pager .current { background: var(--olive); color: var(--cream); border-color: var(--olive-deep); }
/* Jobs-per-page selector (menu opens upward; styled like the sort/auth dropdowns) */
.per-page {
  margin-top: 14px;
  display: flex; gap: 7px; align-items: center; justify-content: center;
  font-size: 12.5px; color: var(--ink-3);
}
.per-page-select { position: relative; }
.per-page-btn {
  display: inline-flex; align-items: center; gap: 5px;
  border: 1px solid var(--rule); border-radius: 6px; background: var(--cream); cursor: pointer;
  padding: 5px 9px; font: inherit; font-size: 12.5px; color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.per-page-btn:focus, .per-page-btn:focus-visible { outline: none; }
.per-page-caret { color: var(--ink-3); transition: transform .15s ease; }
.per-page.open .per-page-caret { transform: rotate(180deg); }
.per-page-menu {
  display: none; position: absolute; bottom: calc(100% + 6px); left: 50%; transform: translateX(-50%);
  min-width: 100%;
  background: var(--cream); border: 1px solid var(--rule); border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12); padding: 6px 0; z-index: 200;
}
.per-page.open .per-page-menu { display: block; }
.per-page-menu [role="option"] {
  display: block; width: 100%; box-sizing: border-box; text-align: center;
  background: none; border: 0; cursor: pointer;
  padding: 7px 16px; font: inherit; font-size: 12.5px; color: var(--ink-2);
  font-variant-numeric: tabular-nums;
}
.per-page-menu [role="option"]:hover { background: var(--sand); color: var(--ink); }
.per-page-menu [role="option"][aria-selected="true"] { color: var(--ink); font-weight: 600; }
.per-page-menu [role="option"]:focus, .per-page-menu [role="option"]:focus-visible { outline: none; }

/* ===== Footer ===== */
footer {
  border-top: 1px solid var(--rule);
  margin-top: 80px;
  padding: 40px 32px 60px;
  background: var(--paper-3);
}
.foot-inner {
  max-width: var(--content-w);
  margin: 0 auto;
  display: grid; grid-template-columns: 1.6fr repeat(4, 1fr); gap: 40px;
}
.foot-inner h4 {
  font-size: 12px;
  color: var(--ink-3);
  font-weight: 600;
  margin-bottom: 12px;
}
.foot-inner ul { list-style: none; display: flex; flex-direction: column; gap: 8px; font-size: 13px; color: var(--ink-2); }
.foot-inner ul a:hover { color: var(--ink); text-decoration: underline; text-underline-offset: 3px; }
.foot-tag {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-bottom: 10px;
}
.foot-bottom {
  max-width: var(--content-w);
  margin: 32px auto 0;
  padding-top: 20px;
  border-top: 1px solid var(--rule);
  display: flex; justify-content: space-between;
  font-size: 12px;
  color: var(--ink-3);
}

/* ===== Job detail ===== */
.detail-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 64px;
  align-items: flex-start;
}
.detail-main h1 {
  font-size: 28px;
  letter-spacing: -0.025em;
  font-weight: 600;
  line-height: 1.2;
  margin-top: 8px;
  margin-bottom: 12px;
}
.detail-deck {
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink-3);
  max-width: 100%;
  margin-bottom: 24px;
}
.detail-meta {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: 32px;
}
.section-h {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.005em;
  padding-top: 24px;
  margin-top: 28px;
  margin-bottom: 12px;
}
.prose { font-size: 15.5px; line-height: 1.65; color: var(--ink-2); max-width: 64ch; overflow-wrap: anywhere; }
.prose p { margin-bottom: 14px; }
.prose ul { margin-left: 18px; margin-bottom: 16px; }
.prose ul li { margin-bottom: 6px; }
.prose strong { color: var(--ink); font-weight: 600; }

.detail-side {
  position: sticky; top: 88px;
  border: 1px solid var(--rule);
  padding: 20px;
  background: var(--cream);
  border-radius: 8px;
}
.detail-side dl {
  margin-top: 4px;
  display: grid; grid-template-columns: auto 1fr;
  gap: 10px 16px;
  font-size: 13px;
}
.detail-side dt {
  font-size: 12px;
  color: var(--ink-3);
  align-self: center;
}
.detail-side dd { color: var(--ink); }
.detail-side .apply {
  display: block;
  text-align: center;
  padding: 10px 14px;
  background: var(--ink);
  color: #fff;
  font-size: 13px;
  font-weight: 500;
  border-radius: 6px;
  margin-bottom: 8px;
  text-decoration: none;
}
.detail-side .apply:hover { opacity: 0.9; }
.detail-side .save-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--rule);
  font-size: 13px;
  font-weight: 500;
  background: var(--sand);
  border-radius: 6px;
  margin-bottom: 8px;
  cursor: pointer;
  color: var(--ink);
}
.detail-side .save-btn:hover { background: var(--rule-soft); }
.detail-side .save-btn.saved { border-color: var(--olive-deep); color: var(--olive-deep); }
.detail-side .save-btn.saved svg { fill: var(--olive-deep); }
.detail-side .alert-similar-btn {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  width: 100%; padding: 10px 14px;
  border: 1px solid var(--olive);
  font-size: 13px; font-weight: 500; font-family: var(--sans);
  background: var(--cream); color: var(--olive-deep);
  border-radius: 6px; margin-bottom: 18px; cursor: pointer;
}
.detail-side .alert-similar-btn:hover { background: var(--sand); }
.detail-side .alert-similar-btn:focus, .detail-side .alert-similar-btn:focus-visible { outline: none; }
.detail-side .save {
  display: block;
  text-align: center;
  padding: 10px 14px;
  border: 1px solid var(--rule);
  font-size: 13px;
  font-weight: 500;
  background: var(--sand);
  border-radius: 6px;
  width: 100%;
  margin-bottom: 18px;
}

.crumbs {
  font-size: 12px;
  color: var(--ink-3);
  display: flex; gap: 8px; align-items: center;
  margin-bottom: 16px;
}
.crumbs a:hover { color: var(--ink); }
.crumbs .sep { opacity: 0.5; }

/* ===== Prose / trust pages (about, contact, privacy, terms) ===== */
.prose {
  max-width: 70ch;
  font-size: 15px;
  line-height: 1.7;
  color: var(--ink-2);
}
.prose h2 {
  font-size: 20px;
  color: var(--ink);
  margin: 36px 0 12px;
}
.prose h3 {
  font-size: 16px;
  color: var(--ink);
  margin: 24px 0 8px;
}
.prose p { margin-bottom: 14px; }
.prose ul { margin: 0 0 14px 20px; }
.prose li { margin-bottom: 6px; }
.prose a { color: var(--olive); text-decoration: underline; text-underline-offset: 3px; }
.soon-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--olive);
  background: var(--paper-3);
  border: 1px solid var(--rule);
  border-radius: 999px;
  padding: 2px 8px;
  margin-left: 8px;
  vertical-align: middle;
}

/* Contact form */
.contact-form { display: flex; flex-direction: column; gap: 16px; max-width: 480px; margin-top: 8px; }
.contact-label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--ink-3); font-weight: 600; }
.contact-label-text { font-size: 13px; color: var(--ink-3); font-weight: 600; }
.contact-label input, .contact-label textarea, .contact-label select {
  font: inherit; font-size: 15px; font-weight: 400; color: var(--ink);
  padding: 10px 12px; border: 1px solid var(--rule); border-radius: 8px; background: var(--paper);
  width: 100%; box-sizing: border-box;
}
.contact-label textarea { resize: vertical; }
.contact-label select {
  appearance: none; -webkit-appearance: none; -moz-appearance: none;
  cursor: pointer; padding-right: 34px;
  background-color: var(--paper);
  background-image: linear-gradient(45deg, transparent 50%, var(--ink-3) 50%),
                    linear-gradient(135deg, var(--ink-3) 50%, transparent 50%);
  background-position: right 16px center, right 11px center;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
}
.contact-label input:focus, .contact-label textarea:focus, .contact-label select:focus { outline: none; border-color: var(--olive); }
.contact-label .req { color: var(--olive); font-weight: 600; }
.contact-notice {
  font-size: 12.5px; color: var(--ink-3); line-height: 1.5; margin: 0;
}
.contact-notice a { color: var(--olive); text-decoration: underline; text-underline-offset: 2px; }
.contact-hp { position: absolute; left: -5000px; width: 1px; height: 1px; overflow: hidden; }

/* HTML site map */
.sitemap-groups { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 32px 40px; }
.sitemap-group h2 { font-size: 14px; color: var(--ink-3); font-weight: 600; margin-bottom: 12px; }
.sitemap-group ul { list-style: none; display: flex; flex-direction: column; gap: 8px; font-size: 14px; }
.sitemap-group a { color: var(--ink-2); }
.sitemap-group a:hover { color: var(--olive); text-decoration: underline; text-underline-offset: 3px; }

/* ===== Expired banner ===== */
.expired-banner {
  background: rgba(181, 78, 44, 0.1);
  border: 1px solid rgba(181, 78, 44, 0.3);
  border-radius: 6px;
  padding: 14px 18px;
  margin-bottom: 20px;
  font-size: 14px;
  color: var(--hot);
}
.expired-banner strong { display: block; margin-bottom: 2px; }
.expired-banner p { font-size: 13px; margin-top: 4px; }

/* ===== Company page ===== */
.company-head {
  display: grid;
  grid-template-columns: 88px 1fr auto;
  gap: 28px;
  align-items: center;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 28px;
  margin-bottom: 32px;
}
.company-logo {
  width: 64px; height: 64px;
  border: 1px solid var(--rule);
  background: var(--olive);
  color: var(--cream);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.025em;
  overflow: hidden;
}
.company-logo img {
  width: 100%; height: 100%;
  object-fit: contain;
  background: #fff;
}
.company-head h1 {
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.2;
}
.company-head .meta-line {
  font-size: 13px;
  color: var(--ink-3);
  margin-top: 6px;
  display: flex; gap: 12px; align-items: center;
}
.company-head .meta-line .dot { width: 3px; height: 3px; background: var(--ink-4); border-radius: 50%; }
.company-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-bottom: 1px solid var(--rule);
  margin-bottom: 36px;
}
.company-stats > div {
  padding: 18px 24px;
  border-right: 1px solid var(--rule);
}
.company-stats > div:last-child { border-right: 0; }
.company-stats dt {
  font-size: 12px;
  color: var(--ink-3);
}
.company-stats dd {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: -0.02em;
  margin-top: 4px;
}

.company-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 64px;
  align-items: flex-start;
}
.company-grid .about {
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--ink-2);
  max-width: 100%;
}
.company-grid .about p { margin-bottom: 14px; }

.company-side .panel {
  border: 1px solid var(--rule);
  padding: 22px;
  margin-bottom: 18px;
  background: var(--cream);
  border-radius: 8px;
}
.company-side h3 {
  font-size: 12px;
  color: var(--ink-3);
  font-weight: 500;
  margin-bottom: 10px;
}
.company-side .row {
  display: flex; justify-content: space-between; gap: 12px;
  font-size: 13px;
  padding: 6px 0;
  border-bottom: 1px solid var(--rule-soft);
}
.company-side .row:last-child { border-bottom: 0; }
.company-side .row b { font-weight: 500; }
.company-side .row span { color: var(--ink-3); font-family: var(--mono); font-size: 12px; }

/* ===== Companies directory ===== */
.co-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--rule); }
.co-card {
  padding: 22px 24px;
  border-bottom: 1px solid var(--rule);
  border-right: 1px solid var(--rule);
  display: flex; gap: 16px; align-items: flex-start;
  text-decoration: none; color: inherit;
}
.co-card:nth-child(3n) { border-right: 0; }
.co-card:hover { background: rgba(146,139,97,0.06); }
.co-card .lg {
  width: 48px; height: 48px;
  border: 1px solid var(--rule);
  background: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
  border-radius: 8px;
  overflow: hidden;
}
.co-card .lg img {
  width: 100%; height: 100%;
  object-fit: contain;
}
.co-card h3 { font-size: 16px; font-weight: 600; letter-spacing: -0.01em; }
.co-card .sub { font-family: var(--mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-4); margin-top: 4px; }
.co-card .roles { margin-top: 10px; font-size: 13px; color: var(--ink-2); }
.co-card .roles b { font-size: 18px; font-weight: 600; letter-spacing: -0.01em; }

/* Companies directory search */
.co-search {
  display: flex; align-items: center; gap: 8px;
  border: 1px solid var(--rule); border-radius: 8px;
  padding: 9px 14px; margin-bottom: 20px;
  max-width: 360px; color: var(--ink-3); background: var(--cream);
}
.co-search:focus-within { border-color: var(--olive); }
.co-search svg { flex-shrink: 0; opacity: 0.7; }
.co-search input { border: none; background: none; outline: none; width: 100%; font-size: 14px; font-family: var(--sans); color: var(--ink); }

/* Company page: filter tools row + nested filter sidebar */
.co-filter-tools { display: flex; gap: 10px; align-items: stretch; margin-bottom: 16px; justify-content: flex-end; }
.co-filter-tools .search { width: 360px; max-width: 100%; }
.filter-clear-inline { font-size: 11px; color: var(--ink-4); cursor: pointer; background: none; border: none; padding: 0; }
.filter-clear-inline:hover { color: var(--ink); }

/* Hidden job cards (client-side filter) */
.job-row.hidden { display: none; }

/* ===== Helpers ===== */
.muted { color: var(--ink-3); }
.mono { font-family: var(--mono); }
.serif { font-family: var(--serif); }
.divider { border-top: 1px solid var(--rule); margin: 32px 0; }
.hidden { display: none !important; }

/* ===== Dark mode ===== */
body.theme-dark {
  --paper: #14130f;
  --paper-2: #1c1a14;
  --paper-3: #1c1a14;
  --rule: #2a271f;
  --rule-soft: #221f18;
  --ink: #f0ead8;
  --ink-2: #d6cfb9;
  --ink-3: #978f78;
  --ink-4: #6a6452;
  --khaki: #c8c9ac;
  --khaki-deep: #928b61;
  --cream: #1c1a14;
  --sand: #221f18;
  --sage: #2a271f;
}
body.theme-dark .job-logo,
body.theme-dark .company-logo { background: #1c1a14; }
body.theme-dark .search,
body.theme-dark .detail-side,
body.theme-dark .company-side .panel { background: rgba(255,255,255,0.02); }
body.theme-dark .tag { background: rgba(255,255,255,0.02); }

/* ===== Tone variant: ink-forward ===== */
body.tone-ink {
  --paper: #ffffff;
  --paper-2: #f7f5ef;
  --paper-3: #efeae0;
  --rule: #e8e3d4;
  --rule-soft: #efeae0;
  --ink: #14130f;
  --ink-2: #2a2722;
  --ink-3: #5a564b;
  --ink-4: #8a8474;
  --khaki: #6e6845;
}

/* Hidden on desktop, shown on mobile */
.menu-btn { display: none; }

/* ===== Responsive: tablet & mobile ===== */
@media (max-width: 900px) {
  :root { --content-w: 100%; }
  body { font-size: 14px; }

  /* Topbar: collapse to hamburger */
  .topbar-inner {
    padding: 12px 16px;
    gap: 12px;
    flex-wrap: wrap;
  }
  .topbar .nav,
  .topbar .topbar-actions a.muted { display: none; }
  .topbar .stats { display: none; }
  .topbar .signin-btn:not(.signin-btn-mobile),
  .topbar .desktop-signin { display: none !important; }
  .topbar .topbar-actions { gap: 8px; }
  .menu-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px;
    border: none;
    background: none;
    color: var(--ink);
  }
  .menu-btn svg { width: 18px; height: 18px; }

  /* Mobile nav drawer — drops below the topbar row */
  body.nav-open .topbar .nav {
    display: flex;
    flex-direction: column;
    width: 100%;
    order: 99;
    gap: 0;
    background: var(--paper-3);
    border-top: 1px solid var(--rule);
    margin: 12px -16px -12px;
    padding: 8px 16px 12px;
  }
  body.nav-open .topbar .nav a {
    padding: 12px 0;
    border-bottom: 1px solid var(--rule-soft);
    font-size: 15px;
  }
  body.nav-open .topbar .nav .nav-signin {
    display: block;
    font-weight: 600;
    color: var(--ink);
    margin-bottom: 4px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--rule);
  }
  .page { padding: 16px 16px 60px; }

  /* Page head: stack stats below */
  .page-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
    padding-bottom: 14px;
    margin-bottom: 16px;
  }
  .page-head .stats {
    width: 100%;
    gap: 0;
    border-top: 1px solid var(--rule-soft);
    padding-top: 12px;
  }
  .page-head .stats > div {
    flex: 1;
    border-right: 1px solid var(--rule-soft);
    padding-right: 12px;
  }
  .page-head .stats > div:last-child { border-right: 0; }
  .page-head .stats b { font-size: 16px; }

  /* Tabs: horizontal scroll */
  .tabs {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    margin-bottom: 14px;
  }
  .tablist {
    overflow-x: auto;
    gap: 18px;
    padding-bottom: 2px;
    scrollbar-width: none;
    -ms-overflow-style: none;
    flex-wrap: nowrap;
  }
  .tablist::-webkit-scrollbar { display: none; }
  .tab { white-space: nowrap; flex-shrink: 0; }
  .tabs { margin: 0 -16px 14px; padding: 0 16px; }
  .tab-tools { font-size: 12px; gap: 8px; width: 100%; display: flex; flex-wrap: nowrap; padding-bottom: 12px; }
  .tab-tools span:first-child { display: none; }
  .tab-tools .search { flex: 1; width: auto; min-width: 0; }
  .tab-tools .sort { display: none; }
  .co-filter-tools .search { flex: 1; width: auto; min-width: 0; }

  /* Sidebar → fullscreen filter overlay */
  .with-sidebar { display: block; }
  .filter-side { display: none; }
  .no-sidebar .filter-side { display: none !important; }
  body.filters-open .filter-side {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 100;
    background: var(--paper);
    padding: 60px 20px 20px;
    overflow-y: auto;
  }
  body.filters-open::after {
    content: "✕";
    position: fixed; top: 14px; right: 18px;
    z-index: 101;
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    border: 1px solid var(--rule);
    background: var(--cream);
    border-radius: 50%;
    color: var(--ink);
    font-size: 16px;
    cursor: pointer;
  }

  /* Show filter button on mobile */
  .filter-btn-mobile {
    display: flex; align-items: center; justify-content: center;
    width: 36px; align-self: stretch; flex-shrink: 0;
    border: 1px solid var(--rule);
    background: var(--cream);
    border-radius: 6px;
    color: var(--ink-3);
    cursor: pointer;
  }
  .filter-btn-mobile:hover { color: var(--ink); border-color: var(--olive); }

  /* Job cards: compact layout */
  .job-row {
    grid-template-columns: 36px 1fr;
    grid-template-rows: auto auto;
    gap: 12px;
    padding: 14px 10px;
    margin: 0 -10px;
  }
  .job-logo { width: 36px; height: 36px; font-size: 12px; }
  .job-row .meta-line {
    flex-wrap: wrap;
    gap: 6px 10px;
    font-size: 11.5px;
  }
  .job-row h2 { font-size: 15px; }
  .job-row .meta-line { padding-right: 36px; }
  .job-row .desc {
    font-size: 13px;
    -webkit-line-clamp: 3;
  }
  .job-side {
    grid-column: 2 / -1;
    text-align: left;
    flex-direction: row;
    align-items: center;
    gap: 12px;
    min-width: 0;
    padding-top: 0;
    margin-top: 4px;
  }
  .save-btn-card {
    position: absolute;
    top: 12px;
    right: 10px;
    padding: 6px;
  }
  .save-btn-card span { display: none; }
  .tag-row { gap: 5px; margin-top: 10px; }
  .tag { font-size: 11px; padding: 1px 7px; }

  /* Job detail */
  .detail-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .detail-main h1 { font-size: 22px; }
  .detail-deck { font-size: 14.5px; }
  .detail-side {
    position: static;
    order: -1;
    padding: 16px;
  }
  .detail-side dl {
    grid-template-columns: 1fr 1fr;
    font-size: 12.5px;
  }
  .crumbs {
    font-size: 11.5px;
    flex-wrap: wrap;
    gap: 4px 6px;
  }

  /* Company page */
  .company-head {
    grid-template-columns: 56px 1fr;
    gap: 14px;
    padding-bottom: 18px;
    margin-bottom: 18px;
  }
  .company-head > div:last-child {
    grid-column: 1 / -1;
    display: flex;
    gap: 8px;
  }
  .company-head > div:last-child .btn { flex: 1; }
  .company-logo { width: 56px; height: 56px; font-size: 18px; }
  .company-head h1 { font-size: 22px; }
  .company-head .meta-line {
    font-size: 12px;
    flex-wrap: wrap;
    gap: 6px 10px;
  }
  .company-stats {
    grid-template-columns: 1fr 1fr;
    margin-bottom: 24px;
  }
  .company-stats > div {
    padding: 14px 16px;
    border-bottom: 1px solid var(--rule);
  }
  .company-stats > div:nth-child(2) { border-right: 0; }
  .company-stats > div:nth-last-child(-n+2) { border-bottom: 0; }
  .company-stats dd { font-size: 18px; }
  .company-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  /* Companies directory */
  .co-grid { grid-template-columns: 1fr !important; }
  .co-card { border-right: 0 !important; padding: 16px !important; }

  /* Footer */
  footer { padding: 28px 16px 32px; margin-top: 40px; }
  .foot-inner {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .foot-bottom {
    margin: 24px 16px 0;
    flex-direction: column;
    gap: 6px;
    font-size: 11px;
  }

  /* Pager */
  .pager { flex-wrap: wrap; gap: 4px; }
  .pager a, .pager span { padding: 5px 9px; font-size: 12px; }
}

/* ===== Responsive: small phones ===== */
@media (max-width: 480px) {
  .page-head .stats { font-size: 11px; }
  .page-head .stats > div { padding-right: 8px; }
  .page-head .stats b { font-size: 14px; }
  .detail-side dl { grid-template-columns: 1fr; gap: 6px 12px; }
  .detail-side dl dt { padding-top: 6px; border-top: 1px solid var(--rule-soft); }
  .detail-side dl dt:first-of-type { border-top: 0; padding-top: 0; }
}

/* ===== Auth Modal ===== */
.auth-modal { position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; }
.auth-modal-backdrop { position: absolute; inset: 0; background: rgba(9,8,8,0.45); }
.auth-modal-inner { position: relative; background: var(--paper); border: 1px solid var(--rule); border-radius: 12px; padding: 32px 28px; width: 380px; max-width: calc(100vw - 32px); box-shadow: 0 8px 32px rgba(0,0,0,0.18); }
.auth-modal-close { position: absolute; top: 12px; right: 14px; background: none; border: none; font-size: 22px; cursor: pointer; color: var(--ink-3); line-height: 1; }
.auth-modal-close:hover { color: var(--ink); }
.auth-modal-inner h2 { font-size: 20px; font-weight: 600; margin-bottom: 20px; }
.auth-divider { display: flex; align-items: center; gap: 12px; margin: 18px 0; color: var(--ink-4); font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; }
.auth-divider::before, .auth-divider::after { content: ""; flex: 1; height: 1px; background: var(--rule); }
#auth-form input:not([type="checkbox"]) { display: block; width: 100%; padding: 10px 12px; margin-bottom: 10px; border: 1px solid var(--rule); border-radius: 6px; font-size: 14px; font-family: var(--sans); background: var(--cream); color: var(--ink); box-sizing: border-box; }
#auth-form input:not([type="checkbox"]):focus { outline: none; border-color: var(--olive); }
.auth-error { color: var(--hot); font-size: 13px; margin-bottom: 8px; }
.auth-submit-btn { display: block; width: 100%; padding: 10px; background: var(--olive-deep); color: #fff; border: none; border-radius: 6px; font-size: 14px; font-weight: 500; cursor: pointer; font-family: var(--sans); }
.auth-submit-btn:hover { background: var(--olive); }
.auth-submit-btn:disabled { opacity: 0.6; cursor: default; }
.danger-btn { display: inline-block; padding: 9px 16px; background: var(--hot); color: #fff; border: none; border-radius: 6px; font-size: 13px; font-weight: 500; cursor: pointer; font-family: var(--sans); }
.danger-btn:hover { filter: brightness(0.92); }
.settings-actions { display: flex; justify-content: flex-end; align-items: center; gap: 12px; margin-top: 16px; }
.settings-actions .danger-btn { margin-right: auto; }
.settings-actions .auth-submit-btn { width: auto; margin-top: 0; padding: 9px 22px; }
.danger-btn:disabled { opacity: 0.45; cursor: default; filter: none; }
.delete-check { display: flex; gap: 10px; align-items: flex-start; font-size: 13px; color: var(--ink-2); cursor: pointer; margin-bottom: 12px; line-height: 1.4; }
.delete-check input { margin-top: 2px; flex-shrink: 0; }
.auth-mailing-list-label, .auth-privacy-label { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; color: var(--ink-2); cursor: pointer; margin: 10px 0; line-height: 1.4; }
.auth-mailing-list-label input, .auth-privacy-label input { margin-top: 2px; flex-shrink: 0; }
.auth-privacy-label a { color: var(--olive); text-decoration: underline; text-underline-offset: 2px; }
.auth-toggle { margin-top: 14px; font-size: 13px; color: var(--ink-3); text-align: center; }
.auth-legal-note { margin-top: 12px; font-size: 11.5px; line-height: 1.4; color: var(--ink-4); text-align: center; }
.auth-legal-note a { color: var(--ink-3); text-decoration: underline; text-underline-offset: 2px; }
.auth-toggle a { color: var(--olive-deep); text-decoration: underline; }
.auth-toggle a:hover { color: var(--olive); }
.signin-btn-mobile { display: none; }
.mailing-list-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 500;
  font-family: var(--sans);
  background: var(--olive-deep);
  color: #fff;
  border: none;
  border-radius: 6px;
  cursor: pointer;
}
.mailing-list-btn:hover { background: var(--olive); }
.mailing-list-btn svg, .nav-mailing-list svg { flex-shrink: 0; vertical-align: middle; transform: translateY(-0.25px); }
.nav-mailing-list { display: none !important; }
.ml-hidden { display: none !important; }
.ml-subscribed #mailing-list-btn, .ml-subscribed #nav-mailing-list { display: none !important; }
.ml-modal-inner { max-height: calc(100vh - 48px); overflow-y: auto; width: 440px; scrollbar-width: none; -ms-overflow-style: none; }
.ml-modal-inner::-webkit-scrollbar { display: none; }
.ml-subtitle { font-size: 13px; color: var(--ink-3); margin-bottom: 16px; }
.ml-section { border: 1px solid var(--rule); border-radius: 6px; margin-bottom: 8px; }
.ml-section-title {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 14px; font-size: 14px; font-weight: 500; cursor: pointer;
  color: var(--ink-2); user-select: none;
}
.ml-section-title:hover { color: var(--ink); }
.ml-arrow { font-size: 0; width: 8px; height: 8px; border-right: 2px solid var(--ink-3); border-bottom: 2px solid var(--ink-3); transform: rotate(45deg); transition: transform 0.15s; }
.ml-section.open .ml-arrow { transform: rotate(-135deg); }
.ml-section-body {
  display: none; padding: 4px 12px 12px;
  column-count: 2; column-gap: 8px;
}
.ml-section.open .ml-section-body { display: block; }
.ml-section-body label {
  display: flex; gap: 8px; align-items: center;
  font-size: 12px; color: var(--ink-2); padding: 3px 0; cursor: pointer;
  break-inside: avoid;
}
.ml-section-body input[type="text"],
.ml-section-body input[type="number"] {
  width: 100%; padding: 7px 10px; font-size: 13px;
  border: 1px solid var(--rule); border-radius: 4px;
  font-family: var(--sans); margin-bottom: 6px;
  background: var(--paper); color: var(--ink);
}
#ml-form > input[type="email"] {
  width: 100%; padding: 10px 12px; font-size: 14px;
  border: 1px solid var(--rule); border-radius: 6px;
  margin-bottom: 12px; font-family: var(--sans);
  background: var(--paper); color: var(--ink);
  box-sizing: border-box;
}
#ml-form .auth-submit-btn { margin-top: 12px; }
.ml-multi-input { display: flex; flex-direction: column; gap: 6px; column-span: all; }
.ml-multi-input input { margin-bottom: 0; }
.ml-multi-row { display: flex; gap: 6px; align-items: center; }
.ml-multi-row input { flex: 1; min-width: 0; }
.ml-remove-btn {
  flex-shrink: 0; width: 18px; text-align: center; align-self: center;
  background: none; border: none; font-size: 18px; cursor: pointer;
  color: var(--ink-3); padding: 0; line-height: 1;
}
.ml-remove-btn:hover { color: var(--ink); }
.ml-remove-hidden { visibility: hidden; pointer-events: none; }
.ml-add-btn {
  background: none; border: none; font-size: 12px; cursor: pointer;
  color: var(--olive-deep); padding: 6px 0 0; font-family: var(--sans);
}
.ml-add-btn:hover { color: var(--olive); }

/* Locations (Google Places picker) + deal-breaker toggles */
.ml-text-input { column-span: all; }
.ml-ac-mount { column-span: all; margin-bottom: 6px; }
/* Force the Places element to light mode so it doesn't mirror the OS dark theme */
.ml-ac-mount gmp-place-autocomplete, gmp-place-autocomplete { width: 100%; color-scheme: light; }
.ml-chips { column-span: all; display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 6px; }
.ml-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--sand); border: 1px solid var(--rule); border-radius: 14px;
  padding: 3px 6px 3px 10px; font-size: 12px; color: var(--ink);
}
.ml-chip button { background: none; border: none; cursor: pointer; color: var(--ink-3); font-size: 15px; line-height: 1; padding: 0; }
.ml-chip button:hover { color: var(--hot); }
.ml-radius-row { column-span: all; font-size: 12px; color: var(--ink-2); display: flex; align-items: center; gap: 6px; }
.ml-radius-input { width: 64px !important; margin-bottom: 0 !important; }
.ml-must {
  display: none; align-items: center; gap: 6px; margin-left: auto; margin-right: 10px;
  font-size: 11px; color: var(--ink-3); font-weight: 400; cursor: pointer;
}
.ml-section.open .ml-must { display: inline-flex; }
.ml-must input { margin: 0; cursor: pointer; }

/* Preference + dealbreaker + subscribe checkboxes match the job-filter sidebar style */
.ml-section-body input[type="checkbox"], .ml-db, #settings-subscribed {
  appearance: none; -webkit-appearance: none;
  width: 13px; height: 13px; margin: 0;
  border: 1px solid var(--ink-4); border-radius: 1px;
  background: var(--paper); position: relative; cursor: pointer; flex-shrink: 0;
}
.ml-section-body input[type="checkbox"]:checked, .ml-db:checked, #settings-subscribed:checked {
  background: var(--ink); border-color: var(--ink);
}
.ml-section-body input[type="checkbox"]:checked::after, .ml-db:checked::after, #settings-subscribed:checked::after {
  content: ""; position: absolute; left: 3px; top: 0px; width: 4px; height: 8px;
  border: solid var(--paper); border-width: 0 1.5px 1.5px 0; transform: rotate(45deg);
}

/* Settings: standalone alert-frequency row (boxed like the preference sections) */
.settings-freq-row { border: 1px solid var(--rule); border-radius: 6px; padding: 12px 14px; margin: 0 0 16px; }
.settings-freq-label { font-size: 14px; font-weight: 500; color: var(--ink-2); margin-bottom: 10px; }

/* Alert-frequency radios: custom round radios styled to match the site */
[data-radio="alert_frequency"] input[type="radio"] {
  appearance: none; -webkit-appearance: none;
  width: 14px; height: 14px; margin: 0;
  border: 1px solid var(--ink-4); border-radius: 50%;
  background: var(--paper); position: relative; cursor: pointer; flex-shrink: 0;
}
[data-radio="alert_frequency"] input[type="radio"]:checked { border-color: var(--ink); }
[data-radio="alert_frequency"] input[type="radio"]:checked::after {
  content: ""; position: absolute; left: 50%; top: 50%;
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--ink); transform: translate(-50%, -50%);
}

/* "See more preferences" disclosure */
.ml-more-toggle {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; margin: 6px 0 8px; padding: 8px;
  background: none; border: none; cursor: pointer;
  color: var(--olive-deep); font-size: 13px; font-family: var(--sans);
}
.ml-more-toggle:hover { color: var(--olive); }
.ml-more-toggle.open .ml-arrow { transform: rotate(-135deg); }

/* Step 2 (alert frequency) */
.ml-freq-options { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.ml-freq-options label { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--ink); cursor: pointer; }
.ml-back-btn { display: block; width: 100%; margin-top: 10px; background: none; border: none; color: var(--ink-3); font-size: 13px; cursor: pointer; font-family: var(--sans); }
.ml-back-btn:hover { color: var(--ink); }
/* Google Places autocomplete dropdown must sit above the modal */
.pac-container { z-index: 100000 !important; }

/* Language rows with CEFR level dropdown */
.ml-lang-row { display: flex; gap: 6px; align-items: stretch; }
.ml-lang-combo { position: relative; flex: 1; min-width: 0; }
.ml-lang-row .ml-lang-input { width: 100%; height: 34px; box-sizing: border-box; }
/* Language name dropdown — scrollable, capped height, mirrors the CEFR level menu */
.ml-lang-menu {
  display: none; position: absolute; top: calc(100% + 3px); left: 0; right: 0; z-index: 30;
  background: var(--paper); border: 1px solid var(--rule); border-radius: 6px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.14);
  max-height: 200px; overflow-y: auto; padding: 4px 0;
  scrollbar-width: none; -ms-overflow-style: none;  /* scrolls, but no visible scrollbar */
}
.ml-lang-menu::-webkit-scrollbar { width: 0; height: 0; display: none; }
.ml-lang-combo.open .ml-lang-menu { display: block; }
.ml-lang-opt { padding: 7px 12px; font-size: 13px; cursor: pointer; color: var(--ink-2); white-space: nowrap; }
.ml-lang-opt:hover { background: var(--sand); color: var(--ink); }
.ml-lang-empty { padding: 7px 12px; font-size: 13px; color: var(--ink-4); }
.ml-level { position: relative; flex-shrink: 0; }
.ml-level-btn {
  display: inline-flex; align-items: center; justify-content: space-between; gap: 4px;
  width: 84px; height: 34px; padding: 0 8px; box-sizing: border-box;
  border: 1px solid var(--rule); border-radius: 4px;
  background: var(--paper); font-size: 13px; cursor: pointer;
  font-family: var(--sans);
}
.ml-level-txt { color: var(--ink-4); }
.ml-level:not([data-level=""]) .ml-level-txt { color: var(--ink); }
.ml-level-caret { color: var(--ink-3); flex-shrink: 0; }
.ml-level-menu {
  display: none; position: absolute; top: calc(100% + 3px); right: 0; z-index: 20;
  background: var(--paper); border: 1px solid var(--rule); border-radius: 6px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.14); min-width: 170px; overflow: hidden; padding: 4px 0;
}
.ml-level-menu.open { display: block; }
.ml-level-opt { padding: 7px 12px; font-size: 13px; cursor: pointer; color: var(--ink-2); white-space: nowrap; }
.ml-level-opt:hover { background: var(--sand); color: var(--ink); }
@media (max-width: 900px) {
  .signin-btn-mobile { display: inline-block; font-size: 12px; padding: 5px 10px; }
  .mailing-list-btn { display: none; }
  .nav-mailing-list:not(.ml-hidden) { display: block !important; font-weight: 500; color: var(--olive-deep) !important; }
  .ml-section-body { column-count: 1; }
}
