/* GovBB Design System — Base CSS */
/* CSS Custom Properties */
:root {
  --color-yellow-00:   #e8a833;
  --color-yellow-100:  #ffc726;
  --color-yellow-40:   #ffe9a8;
  --color-yellow-10:   #fff9e9;
  --color-blue-00:     #00164a;
  --color-blue-100:    #00267f;
  --color-blue-40:     #99a8cc;
  --color-blue-10:     #e5e9f2;
  --color-black-00:    #000000;
  --color-mid-grey-00: #595959;
  --color-grey-00:     #e0e4e9;
  --color-white-00:    #ffffff;
  --color-green-00:    #00654a;
  --color-green-100:   #1fbf84;
  --color-green-40:    #a5e5ce;
  --color-green-10:    #e9f9f3;
  --color-red-00:      #a42c2c;
  --color-red-100:     #ff6b6b;
  --color-red-40:      #ffc4c4;
  --color-red-10:      #fff0f0;
  --color-teal-00:     #0e5f64;
  --color-teal-100:    #30c0c8;
  --color-teal-40:     #ace6e9;
  --color-teal-10:     #eaf9f9;
  --color-purple-00:   #4a235a;
  --color-purple-100:  #a962c7;
  --color-pink-00:     #ad1157;
  --color-pink-100:    #ff94d9;

  --font-size-display:  5rem;
  --font-size-h1:       3.5rem;
  --font-size-h2:       2.5rem;
  --font-size-h3:       1.5rem;
  --font-size-h4:       1.25rem;
  --font-size-body-lg:  2rem;
  --font-size-body:     1.25rem;
  --font-size-caption:  1rem;

  --spacing-xs: 0.5rem;
  --spacing-s:  1rem;
  --spacing-xm: 1.5rem;
  --spacing-m:  2rem;
  --spacing-l:  4rem;
  --spacing-xl: 8rem;

  --radius-sm: 0.25rem;
  --radius-md: 0.375rem;
  --radius-lg: 0.5rem;

  --shadow-form-hover: inset 4px 4px 0px 0px rgba(0,0,0,0.10);
}

/* Reset & Base */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: Figtree, -apple-system, "system-ui", "Segoe UI", Roboto, sans-serif;
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 1.5;
  display: grid;
  min-height: 100vh;
  grid-template-rows: auto auto auto 1fr auto;
  background: var(--color-white-00);
  color: var(--color-black-00);
  -webkit-font-smoothing: antialiased;
  margin: 0;
}

/* Container */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

/* Visually hidden (screen reader only) */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* Signature canvas */
.sig-canvas {
  border: 2px solid var(--color-black-00);
  border-radius: var(--radius-sm);
  cursor: crosshair;
  display: block;
  touch-action: none;
}

/* Error summary */
.error-summary {
  border: 4px solid var(--color-red-00);
  padding: 1rem 1.5rem;
  margin-bottom: 2rem;
  background: var(--color-red-10);
}
.error-summary h2 {
  color: var(--color-red-00);
  font-size: 1.25rem;
  font-weight: 700;
  margin: 0 0 0.5rem 0;
}
.error-summary ul {
  margin: 0;
  padding-left: 1.25rem;
}
.error-summary li a {
  color: var(--color-red-00);
  font-weight: 600;
}

/* Field error message */
.field-error {
  color: var(--color-red-00);
  font-weight: 600;
  font-size: 1rem;
  margin-bottom: 0.25rem;
  display: block;
}

/* Summary list row */
.summary-row {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid var(--color-grey-00);
  align-items: start;
}
.summary-row:first-child { border-top: 1px solid var(--color-grey-00); }
.summary-row dt { font-weight: 600; }
.summary-row dd { margin: 0; word-break: break-word; }

/* Repeatable row */
.repeat-row {
  border: 1px solid var(--color-grey-00);
  border-radius: var(--radius-md);
  padding: 1rem;
  margin-bottom: 1rem;
  background: #fafafa;
}

/* Warning banner */
.warning-banner {
  background: var(--color-yellow-10);
  border-left: 4px solid var(--color-yellow-00);
  padding: 1rem 1.25rem;
  margin-bottom: 1.5rem;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

/* Ineligibility notice */
.ineligibility-notice {
  background: var(--color-red-10);
  border: 2px solid var(--color-red-00);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  margin-top: 1.5rem;
}

/* Earnings grid table */
.earnings-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 1rem;
}
.earnings-table th {
  background: var(--color-blue-10);
  padding: 0.5rem 0.75rem;
  text-align: left;
  font-weight: 700;
  border-bottom: 2px solid var(--color-blue-40);
}
.earnings-table td {
  padding: 0.5rem 0.75rem;
  border-bottom: 1px solid var(--color-grey-00);
  vertical-align: middle;
}
.earnings-table tr.total-row {
  background: var(--color-teal-10);
  font-weight: 700;
}
.earnings-table input {
  width: 100%;
  padding: 0.375rem 0.5rem;
  border: 1px solid var(--color-black-00);
  border-radius: var(--radius-sm);
  font-size: 1rem;
}

/* Confirmation panel */
.confirmation-panel {
  background: var(--color-teal-00);
  color: var(--color-white-00);
  padding: 2rem;
  border-radius: var(--radius-sm);
  margin-bottom: 2rem;
}
