/* CLA Workforce Planner brand stylesheet.
   Extracted from the mock-up at /wfp-tool/index.html.
   Hard brand rules apply: Midnight Blue nav, Convergence headings, Montserrat body,
   no em dashes, no emojis, no Google Fonts at runtime. */

@font-face {
  font-family: 'Convergence';
  src: url('fonts/Convergence-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Montserrat';
  src: url('fonts/Montserrat-VariableFont_wght.ttf') format('truetype-variations');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --navy: #034554;
  --navy2: #045a6e;
  --teal: #5ec2a7;
  --teal-dk: #2e8a74;
  --teal-lt: #e8f8f4;
  --amber: #febc11;
  --amber-dk: #c9960d;
  --amber-lt: #fff8e1;
  --lavender: #bbc0e2;
  --lav-lt: #f0f1f9;
  --lav-dk: #5a5f91;
  --cream: #fdf5e4;
  --sand: #f7f5ef;
  --paper: #ffffff;
  --border: #e6ded0;
  --text: #1a2a24;
  --muted: #4a6860;
  --hint: #7a9a90;
  --red: #b53535;
  --red-lt: #fbe9e9;
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;
  --ff-head: 'Convergence', 'Avenir Next', Arial, system-ui, sans-serif;
  --ff-body: 'Montserrat', 'Avenir Next', Arial, system-ui, sans-serif;
}

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

body {
  font-family: var(--ff-body);
  font-weight: 300;
  background: var(--sand);
  color: var(--text);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5 {
  font-family: var(--ff-head);
  font-weight: 400;
  color: var(--navy);
  line-height: 1.15;
}

a {
  color: var(--teal-dk);
  text-decoration: none;
  border-bottom: 1px dotted var(--teal);
}

a:hover {
  color: var(--navy);
}

/* Top bar */
.topbar {
  background: var(--paper);
  border-bottom: 1px solid var(--border);
  height: 64px;
  display: flex;
  align-items: center;
  padding: 0 24px;
  gap: 16px;
  position: sticky;
  top: 0;
  z-index: 100;
}

.tb-logo {
  display: flex;
  align-items: center;
  gap: 12px;
}

.tb-logo .mark {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--navy);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--amber);
  font-family: var(--ff-head);
  font-size: 18px;
  font-weight: 700;
}

.tb-logo .name {
  font-family: var(--ff-head);
  font-size: 16px;
  color: var(--navy);
}

.tb-logo .name small {
  display: block;
  font-family: var(--ff-body);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 2px;
}

.tb-spacer {
  flex: 1;
}

.tb-badge {
  display: inline-flex;
  align-items: center;
  padding: 5px 12px;
  border-radius: 999px;
  background: var(--lav-lt);
  color: var(--lav-dk);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

/* Hero block */
.hero {
  max-width: 960px;
  margin: 60px auto 36px;
  padding: 48px 36px;
  background: linear-gradient(180deg, var(--cream) 0%, var(--paper) 100%);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}

.hero .eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--teal-dk);
  margin-bottom: 14px;
}

.hero h1 {
  font-size: 36px;
  margin-bottom: 14px;
}

.hero .lede {
  font-size: 16px;
  color: var(--text);
  max-width: 720px;
  line-height: 1.6;
}

.hero .actions {
  margin-top: 22px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: var(--paper);
  font-family: var(--ff-body);
  font-size: 13.5px;
  font-weight: 500;
  color: var(--navy);
  cursor: pointer;
  transition: all .15s;
}

.btn:hover {
  background: var(--cream);
  border-color: var(--teal);
}

.btn.primary {
  background: var(--navy);
  color: var(--paper);
  border-color: var(--navy);
}

.btn.primary:hover {
  background: var(--navy2);
  color: var(--paper);
}

/* Status panel */
.status-wrap {
  max-width: 960px;
  margin: 0 auto 60px;
  padding: 0 24px;
}

.status-card {
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 28px 32px;
  margin-bottom: 18px;
}

.status-card h2 {
  font-size: 22px;
  margin-bottom: 8px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--teal);
}

.status-card p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text);
  margin-bottom: 8px;
}

.status-list {
  margin: 14px 0 4px 0;
  list-style: none;
}

.status-list li {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  font-size: 13.5px;
}

.status-list li:last-child {
  border-bottom: none;
}

.status-list .item-label {
  flex: 1;
  color: var(--text);
}

.status-list .item-target {
  color: var(--muted);
  font-size: 12px;
  font-family: 'Consolas', 'Courier New', monospace;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  background: var(--teal-lt);
  color: var(--teal-dk);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.status-pill.amber {
  background: var(--amber-lt);
  color: var(--amber-dk);
}

.frame {
  background: var(--cream);
  border-left: 4px solid var(--amber);
  padding: 14px 18px;
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  margin: 18px 0;
  font-size: 13.5px;
  line-height: 1.6;
}

.frame.teal {
  border-left-color: var(--teal);
  background: var(--teal-lt);
}

.frame strong {
  color: var(--navy);
  font-weight: 600;
}

/* Footer */
.foot {
  padding: 24px 24px;
  color: var(--muted);
  font-size: 11.5px;
  border-top: 1px solid var(--border);
  background: var(--paper);
  text-align: center;
}

.foot .foot-logo {
  font-family: var(--ff-head);
  color: var(--navy);
  font-size: 13px;
  margin-bottom: 4px;
}

.foot .foot-by {
  color: var(--muted);
}
