/* Licences — Archival Document Aesthetic */

@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  /* Warm paper palette */
  --color-parchment: #f7f3eb;
  --color-paper: #fffdf8;
  --color-paper-shadow: #e8e2d6;
  --color-ink: #2c2416;
  --color-ink-faded: #6b5f4d;
  --color-ink-light: #9a8c75;

  /* Accent - warm terracotta */
  --color-rust: #b85c38;
  --color-rust-dark: #8f4429;
  --color-rust-light: #d4886a;

  /* Status colours */
  --color-safe: #4a7c59;
  --color-warning: #c9a227;
  --color-urgent: #c41e3a;    /* oxygenated blood red */
  --color-expired: #722f37;   /* deoxygenated blood red */
  --color-scheduled: #2563eb; /* blue - check scheduled */

  /* Typography */
  --font-display: "Libre Baskerville", Georgia, serif;
  --font-body: "DM Sans", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", monospace;

  /* Spacing */
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;

  /* Effects */
  --shadow-paper: 0 1px 3px rgba(44, 36, 22, 0.08), 0 4px 12px rgba(44, 36, 22, 0.04);
  --shadow-paper-hover: 0 2px 8px rgba(44, 36, 22, 0.12), 0 8px 24px rgba(44, 36, 22, 0.08);
  --radius-sm: 2px;
  --radius-md: 4px;
}

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

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--font-body);
  background-color: var(--color-parchment);
  color: var(--color-ink);
  line-height: 1.6;
  min-height: 100vh;

  /* Subtle paper texture */
  background-image:
    radial-gradient(circle at 20% 30%, rgba(200, 180, 150, 0.1) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(180, 160, 130, 0.08) 0%, transparent 50%);
}

/* Layout */
.app-container {
  max-width: 900px;
  margin: 0 auto;
  padding: var(--space-xl) var(--space-lg);
  min-height: 100vh;
}

/* Header */
.app-header {
  text-align: center;
  margin-bottom: var(--space-3xl);
  padding-bottom: var(--space-xl);
  border-bottom: 1px solid var(--color-paper-shadow);
  position: relative;
}

.app-header::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 3px;
  background: var(--color-rust);
}

.app-title {
  font-family: var(--font-display);
  font-size: 2.75rem;
  font-weight: 400;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-xs);
  color: var(--color-ink);
}

.app-tagline {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-style: italic;
  color: var(--color-ink-faded);
  font-weight: 400;
}

/* Stats bar */
.stats-bar {
  display: flex;
  justify-content: center;
  gap: var(--space-xl);
  margin-bottom: var(--space-2xl);
  padding: var(--space-md) 0;
}

.stat-item {
  text-align: center;
}

.stat-value {
  font-family: var(--font-mono);
  font-size: 1.75rem;
  font-weight: 500;
  color: var(--color-ink);
  display: block;
  line-height: 1.2;
}

.stat-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-ink-light);
}

.stat-value.warning {
  color: var(--color-warning);
}

.stat-value.urgent {
  color: var(--color-urgent);
}

/* Actions */
.actions-bar {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

/* Empty State */
.empty-state {
  text-align: center;
  padding: var(--space-3xl) var(--space-xl);
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-paper);
  position: relative;
  overflow: hidden;
}

.empty-state::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-rust) 0%, var(--color-rust-light) 50%, var(--color-rust) 100%);
}

.empty-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto var(--space-lg);
  color: var(--color-ink-light);
  opacity: 0.6;
}

.empty-state h2 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 400;
  margin-bottom: var(--space-sm);
  color: var(--color-ink);
}

.empty-state p {
  color: var(--color-ink-faded);
  margin-bottom: var(--space-lg);
  max-width: 320px;
  margin-left: auto;
  margin-right: auto;
}

.empty-hint {
  font-size: 0.875rem;
  color: var(--color-ink-light);
  font-style: italic;
  margin-top: var(--space-sm);
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-lg);
  font-family: var(--font-body);
  font-size: 0.9375rem;
  font-weight: 500;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all 0.2s ease;
  text-decoration: none;
}

.btn-primary {
  color: var(--color-paper);
  background-color: var(--color-rust);
  box-shadow: 0 2px 4px rgba(184, 92, 56, 0.2);
}

.btn-primary:hover:not(:disabled) {
  background-color: var(--color-rust-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(184, 92, 56, 0.25);
}

.btn-primary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.btn-secondary {
  color: var(--color-ink);
  background-color: transparent;
  border: 1px solid var(--color-paper-shadow);
}

.btn-secondary:hover {
  background-color: var(--color-paper);
  border-color: var(--color-ink-light);
}

/* Sort Selector */
.sort-selector {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
}

.sort-label {
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--color-ink-faded);
  font-weight: 500;
}

.sort-options {
  display: flex;
  gap: var(--space-xs);
}

.sort-option {
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 500;
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  background: var(--color-parchment);
  color: var(--color-ink-faded);
  cursor: pointer;
  transition: all 0.15s ease;
}

.sort-option:hover {
  background: var(--color-paper);
  border-color: var(--color-ink-light);
  color: var(--color-ink);
}

.sort-option.active {
  background: var(--color-rust);
  border-color: var(--color-rust);
  color: white;
}

/* Licence List */
.licence-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

/* Licence Card */
.licence-card {
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-paper);
  padding: var(--space-lg);
  position: relative;
  transition: all 0.2s ease;
  overflow: hidden;
}

.licence-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 4px;
  background: var(--color-safe);
}

.licence-card.expiring-soon::before {
  background: var(--color-warning);
}

.licence-card.urgent::before {
  background: var(--color-urgent);
}

.licence-card.expired::before {
  background: var(--color-expired);
}

.licence-card.scheduled::before {
  background: var(--color-scheduled);
}

.licence-card:hover {
  box-shadow: var(--shadow-paper-hover);
  transform: translateY(-2px);
}

.licence-card-inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-lg);
  align-items: start;
}

.licence-info {
  min-width: 0;
}

.licence-type {
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-ink-light);
  margin-bottom: var(--space-xs);
}

.licence-name {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--color-ink);
  margin-bottom: var(--space-xs);
}

.licence-details {
  font-size: 0.875rem;
  color: var(--color-ink-faded);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm) var(--space-md);
}

.licence-detail {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.licence-detail-label {
  color: var(--color-ink-light);
}

.licence-expiry {
  text-align: right;
  padding-left: var(--space-lg);
  border-left: 1px solid var(--color-paper-shadow);
}

.licence-expiry-detailed {
  text-align: right;
  padding-left: var(--space-lg);
  border-left: 1px solid var(--color-paper-shadow);
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  align-items: flex-end;
}

.licence-expiry-detailed .category-expiries {
  margin-top: 0.35rem;
  justify-content: flex-end;
}

.expiry-expired-note {
  font-size: 0.7rem;
  color: #a04030;
  padding: 0.1rem 0.4rem;
  background: linear-gradient(135deg, #fce8e6, #f9d9d5);
  border-radius: 3px;
  font-weight: 500;
}

.scheduled-check-note {
  font-size: 0.7rem;
  color: var(--color-scheduled);
  padding: 0.1rem 0.4rem;
  background: linear-gradient(135deg, #dbeafe, #bfdbfe);
  border-radius: 3px;
  font-weight: 500;
}

/* Past check - blue text on soft urgency background (action taken, awaiting processing) */
.scheduled-check-note.check-completed {
  color: var(--color-scheduled);
  background: linear-gradient(135deg, #e8e2d6, #ddd6c6);
  border: 1px solid var(--color-paper-shadow);
}

.scheduled-check-note.check-completed.urgent,
.scheduled-check-note.check-completed.expired {
  color: var(--color-scheduled);
  background: linear-gradient(135deg, #fde8e8, #fad4d4);
  border: 1px solid #f5c6c6;
}

.scheduled-check-note.check-completed.expiring-soon {
  color: var(--color-scheduled);
  background: linear-gradient(135deg, #fef3cd, #fde9a8);
  border: 1px solid #f5e19d;
}

.expiry-all-expired {
  color: var(--color-expired) !important;
}

.expiry-date {
  font-family: var(--font-mono);
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-ink);
  margin-bottom: var(--space-xs);
}

.expiry-countdown {
  font-size: 0.8125rem;
}

.countdown-safe {
  color: var(--color-safe);
}

.countdown-warning {
  color: var(--color-warning);
}

.countdown-urgent {
  color: var(--color-urgent);
}

.countdown-expired {
  color: var(--color-expired);
  font-weight: 500;
}

/* Controller Card */
.licence-card.controller-card {
  padding: 0;
  border-left: none;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

.licence-card.controller-card::before {
  display: none;
}

.controller-header {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-lg);
  align-items: start;
  padding: var(--space-lg);
  padding-left: calc(4px + var(--space-sm));
  border-bottom: 1px solid var(--color-paper-shadow);
  border-left: 4px solid var(--color-safe);
}

.controller-card.expiring-soon .controller-header {
  border-left-color: var(--color-warning);
}

.controller-card.urgent .controller-header {
  border-left-color: var(--color-urgent);
}

.controller-card.expired .controller-header {
  border-left-color: var(--color-expired);
}

.controller-card.scheduled .controller-header {
  border-left-color: var(--color-scheduled);
}

.controller-info {
  min-width: 0;
}

.form-sections {
  display: flex;
  flex-direction: column;
}

.form-section {
  position: relative;
  border-bottom: 1px solid var(--color-paper-shadow);
  border-left: 4px solid var(--color-safe);
}

.form-section:last-child {
  border-bottom: none;
}

.form-section.expiring-soon {
  border-left-color: var(--color-warning);
}

.form-section.urgent {
  border-left-color: var(--color-urgent);
}

.form-section.expired {
  border-left-color: var(--color-expired);
}

.form-section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: var(--space-md) var(--space-lg);
  padding-left: calc(4px + var(--space-sm));
  cursor: pointer;
  transition: background 0.15s ease;
  /* Reset button styles */
  background: none;
  border: none;
  text-align: left;
  font: inherit;
  color: inherit;
}

.form-section-header:hover {
  background: color-mix(in srgb, var(--color-ink) 3%, transparent);
}

.form-section-info {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  min-width: 0;
}

.form-id-badge {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 2px 6px;
  background: color-mix(in srgb, var(--color-ink) 8%, transparent);
  border-radius: var(--radius-sm);
  color: var(--color-ink-light);
  white-space: nowrap;
}

.form-title {
  font-size: 0.9375rem;
  color: var(--color-ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.form-section-meta {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-shrink: 0;
}

.valid-from-badge {
  font-size: 0.75rem;
  color: var(--color-ink-faded);
}

.next-expiry-badge {
  font-size: 0.75rem;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--color-safe) 12%, transparent);
  color: var(--color-safe);
}

.next-expiry-badge.countdown-warning {
  background: color-mix(in srgb, var(--color-warning) 15%, transparent);
  color: var(--color-warning);
}

.next-expiry-badge.countdown-urgent {
  background: color-mix(in srgb, var(--color-urgent) 12%, transparent);
  color: var(--color-urgent);
}

.next-expiry-badge.countdown-expired {
  background: color-mix(in srgb, var(--color-expired) 12%, transparent);
  color: var(--color-expired);
}

.form-section-content {
  padding: var(--space-md) var(--space-lg);
  padding-left: calc(4px + var(--space-sm));
  background: color-mix(in srgb, var(--color-ink) 2%, transparent);
  border-top: 1px solid var(--color-paper-shadow);
}

/* Status Badge */
.status-badge {
  display: inline-block;
  padding: var(--space-xs) var(--space-sm);
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-radius: var(--radius-sm);
}

.status-badge.safe {
  background: color-mix(in srgb, var(--color-safe) 12%, transparent);
  color: var(--color-safe);
}

.status-badge.warning {
  background: color-mix(in srgb, var(--color-warning) 15%, transparent);
  color: var(--color-warning);
}

.status-badge.urgent {
  background: color-mix(in srgb, var(--color-urgent) 12%, transparent);
  color: var(--color-urgent);
}

.status-badge.expired {
  background: color-mix(in srgb, var(--color-expired) 12%, transparent);
  color: var(--color-expired);
}

/* Section Headers */
.section-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}

.section-title {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 400;
  color: var(--color-ink);
}

.section-count {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--color-ink-light);
  background: var(--color-paper-shadow);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
}

.section-line {
  flex: 1;
  height: 1px;
  background: var(--color-paper-shadow);
}

/* Footer */
.app-footer {
  margin-top: var(--space-3xl);
  padding-top: var(--space-xl);
  border-top: 1px solid var(--color-paper-shadow);
  text-align: center;
}

.footer-text {
  font-size: 0.8125rem;
  color: var(--color-ink-light);
  font-style: italic;
}

/* Animations */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.licence-card {
  animation: fadeInUp 0.4s ease-out backwards;
}

.licence-card:nth-child(1) { animation-delay: 0.05s; }
.licence-card:nth-child(2) { animation-delay: 0.1s; }
.licence-card:nth-child(3) { animation-delay: 0.15s; }
.licence-card:nth-child(4) { animation-delay: 0.2s; }
.licence-card:nth-child(5) { animation-delay: 0.25s; }

/* Responsive */
@media (max-width: 600px) {
  .app-container {
    padding: var(--space-lg) var(--space-md);
  }

  .app-title {
    font-size: 2rem;
  }

  .stats-bar {
    gap: var(--space-md);
  }

  .stat-value {
    font-size: 1.5rem;
  }

  .licence-card-inner {
    grid-template-columns: 1fr;
    gap: var(--space-md);
  }

  .licence-expiry {
    text-align: left;
    padding-left: 0;
    padding-top: var(--space-md);
    border-left: none;
    border-top: 1px solid var(--color-paper-shadow);
  }
}

/* ═══════════════════════════════════════════════════════════════════
   Upload Page Styles
   ═══════════════════════════════════════════════════════════════════ */

/* Page Header */
.page-header {
  margin-bottom: var(--space-2xl);
}

.page-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-md);
}

.back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  color: var(--color-ink-faded);
  text-decoration: none;
  font-size: 0.875rem;
  margin-bottom: var(--space-md);
  transition: color 0.15s ease;
}

.back-link:hover {
  color: var(--color-ink);
}

.page-title {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 400;
}

/* Calendar page header with group selector inline */
.calendar-page .page-header .group-selector {
  margin-top: var(--space-md);
}

/* Drop Zone */
.drop-zone {
  background: var(--color-paper);
  border: 2px dashed var(--color-paper-shadow);
  border-radius: var(--radius-md);
  padding: var(--space-3xl) var(--space-xl);
  text-align: center;
  position: relative;
  transition: all 0.2s ease;
  cursor: pointer;
}

.drop-zone:hover,
.drop-zone.dragging {
  border-color: var(--color-rust);
  background: color-mix(in srgb, var(--color-rust) 3%, var(--color-paper));
}

.drop-zone.dragging {
  transform: scale(1.01);
}

.drop-zone-content {
  pointer-events: none;
}

.drop-icon {
  color: var(--color-ink-light);
  margin-bottom: var(--space-lg);
}

.drop-zone h2 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 400;
  margin-bottom: var(--space-xs);
}

.drop-zone p {
  color: var(--color-ink-faded);
}

.file-input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  pointer-events: auto;
  z-index: 10;
}

.drop-hint {
  margin-top: var(--space-lg);
  font-size: 0.875rem;
  color: var(--color-ink-light);
  font-style: italic;
}

/* Processing State */
.processing-state {
  text-align: center;
  padding: var(--space-3xl);
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
}

.spinner {
  width: 48px;
  height: 48px;
  border: 3px solid var(--color-paper-shadow);
  border-top-color: var(--color-rust);
  border-radius: 50%;
  margin: 0 auto var(--space-lg);
  animation: spin 1s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

.processing-state h2 {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 400;
  margin-bottom: var(--space-sm);
}

.file-name {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  color: var(--color-ink-faded);
  margin-bottom: var(--space-sm);
}

.processing-hint {
  font-size: 0.875rem;
  color: var(--color-ink-light);
}

/* Review Form */
.review-form {
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.confidence-banner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md) var(--space-lg);
  font-size: 0.875rem;
}

.confidence-banner[data-level="high"] {
  background: color-mix(in srgb, var(--color-safe) 10%, transparent);
  color: var(--color-safe);
}

.confidence-banner[data-level="medium"] {
  background: color-mix(in srgb, var(--color-warning) 10%, transparent);
  color: var(--color-warning);
}

.confidence-banner[data-level="low"] {
  background: color-mix(in srgb, var(--color-urgent) 10%, transparent);
  color: var(--color-urgent);
}

.confidence-value {
  font-family: var(--font-mono);
  font-weight: 500;
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md) var(--space-lg);
  padding: var(--space-lg);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.form-group.full-width {
  grid-column: 1 / -1;
}

.form-group label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-ink-faded);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.form-group input,
.form-group select {
  padding: var(--space-sm) var(--space-md);
  font-family: var(--font-body);
  font-size: 1rem;
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  background: var(--color-parchment);
  color: var(--color-ink);
  transition: border-color 0.15s ease;
}

.form-group input:focus,
.form-group select:focus {
  outline: none;
  border-color: var(--color-rust);
}

.form-group input::placeholder {
  color: var(--color-ink-light);
}

.form-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-md);
  padding: var(--space-lg);
  border-top: 1px solid var(--color-paper-shadow);
  background: var(--color-parchment);
}

/* Error State */
.error-state {
  text-align: center;
  padding: var(--space-3xl);
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
}

.error-icon {
  color: var(--color-urgent);
  margin-bottom: var(--space-lg);
}

.error-state h2 {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 400;
  margin-bottom: var(--space-sm);
}

.error-state p {
  color: var(--color-ink-faded);
  margin-bottom: var(--space-lg);
}

/* ═══════════════════════════════════════════════════════════════════
   Result State (Roster Upload)
   ═══════════════════════════════════════════════════════════════════ */

.result-state {
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
}

.result-header {
  text-align: center;
  margin-bottom: var(--space-lg);
}

.result-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-md);
}

.result-icon.success {
  background: var(--color-success-bg, #e8f5e9);
  color: var(--color-success, #2e7d32);
}

.result-header h2 {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 400;
  margin-bottom: var(--space-sm);
}

.result-stats {
  background: var(--color-paper-aged);
  border-radius: var(--radius-sm);
  padding: var(--space-md);
  margin-bottom: var(--space-lg);
}

.stat-row {
  display: flex;
  justify-content: space-between;
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--color-paper-shadow);
}

.stat-row:last-child {
  border-bottom: none;
}

.stat-label {
  color: var(--color-ink-faded);
}

.stat-value {
  font-family: var(--font-mono);
  font-weight: 500;
}

.stat-row.highlight-success .stat-value {
  color: var(--color-success, #2e7d32);
}

.unmatched-warning {
  background: var(--color-warning-bg, #fff8e1);
  border: 1px solid var(--color-warning-border, #ffcc80);
  border-radius: var(--radius-sm);
  padding: var(--space-md);
  margin-bottom: var(--space-lg);
}

.warning-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-weight: 500;
  color: var(--color-warning-text, #e65100);
  margin-bottom: var(--space-sm);
}

.warning-hint {
  font-size: 0.875rem;
  color: var(--color-ink-faded);
  margin-bottom: var(--space-sm);
}

.unmatched-list {
  list-style: none;
  padding: 0;
  margin: 0;
  font-family: var(--font-mono);
  font-size: 0.875rem;
  max-height: 150px;
  overflow-y: auto;
}

.unmatched-list li {
  padding: var(--space-xs) 0;
  border-bottom: 1px dashed var(--color-paper-shadow);
}

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

/* New Controllers Info (roster upload) */
.new-controllers-info {
  background: var(--color-success-bg, #e8f5e9);
  border: 1px solid var(--color-success-border, #81c784);
  border-radius: var(--radius-sm);
  padding: var(--space-md);
  margin-bottom: var(--space-lg);
}

.info-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-weight: 500;
  color: var(--color-success-text, #2e7d32);
  margin-bottom: var(--space-sm);
}

.info-hint {
  font-size: 0.875rem;
  color: var(--color-ink-faded);
  margin-bottom: var(--space-sm);
}

.new-controllers-list {
  list-style: none;
  padding: 0;
  margin: 0;
  font-family: var(--font-mono);
  font-size: 0.875rem;
  max-height: 150px;
  overflow-y: auto;
}

.new-controllers-list li {
  padding: var(--space-xs) 0;
  border-bottom: 1px dashed var(--color-paper-shadow);
}

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

/* ═══════════════════════════════════════════════════════════════════
   Medical Section (Upload Review Form)
   ═══════════════════════════════════════════════════════════════════ */

.medical-section {
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
}

.medical-explanation {
  font-size: 0.8125rem;
  color: var(--color-ink-light);
  font-style: italic;
  margin-bottom: var(--space-lg);
}

.medical-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}

@media (max-width: 600px) {
  .medical-grid {
    grid-template-columns: 1fr;
  }
}

.medical-conditions {
  margin-top: var(--space-lg);
  padding-top: var(--space-md);
  border-top: 1px dashed var(--color-paper-shadow);
}

.medical-conditions label {
  display: block;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-ink-light);
  margin-bottom: var(--space-sm);
}

.medical-conditions ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs) var(--space-sm);
}

.medical-conditions li {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--color-ink-faded);
  background: var(--color-parchment);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-paper-shadow);
}

/* ═══════════════════════════════════════════════════════════════════
   Items Section (Upload Review Form)
   ═══════════════════════════════════════════════════════════════════ */

.items-section {
  padding: 0 var(--space-lg) var(--space-lg);
}

.items-heading {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 400;
  color: var(--color-ink);
  margin-bottom: var(--space-lg);
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.items-count {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--color-ink-light);
  background: var(--color-paper-shadow);
  padding: 2px 10px;
  border-radius: var(--radius-sm);
}

.items-category {
  margin-bottom: var(--space-lg);
}

.items-category:last-child {
  margin-bottom: 0;
}

.category-heading {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-ink-light);
  margin-bottom: var(--space-sm);
  padding-bottom: var(--space-xs);
  border-bottom: 1px solid var(--color-paper-shadow);
}

.items-table-wrapper {
  overflow-x: auto;
}

.items-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.items-table th {
  text-align: left;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-ink-light);
  padding: var(--space-sm) var(--space-sm);
  border-bottom: 1px solid var(--color-paper-shadow);
}

.items-table td {
  padding: var(--space-xs) var(--space-sm);
  border-bottom: 1px solid color-mix(in srgb, var(--color-paper-shadow) 50%, transparent);
}

.items-table tbody tr:last-child td {
  border-bottom: none;
}

.item-input {
  width: 100%;
  padding: var(--space-xs) var(--space-sm);
  font-family: var(--font-body);
  font-size: 0.875rem;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-ink);
  transition: all 0.15s ease;
}

.item-input:hover {
  background: var(--color-parchment);
}

.item-input:focus {
  outline: none;
  background: var(--color-parchment);
  border-color: var(--color-rust);
}

.item-input.item-date {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  min-width: 120px;
}

/* Low confidence date styling */
.low-confidence-row {
  background: color-mix(in srgb, var(--color-warning) 8%, transparent);
}

.low-confidence-row td:first-child {
  position: relative;
}

.confidence-warning {
  margin-left: var(--space-xs);
  font-size: 0.75rem;
  cursor: help;
}

/* Date field with actions */
.date-field-wrapper {
  position: relative;
}

.date-field-row {
  display: flex;
  align-items: center;
  gap: 2px;
}

.date-field-row .item-input.item-date {
  flex: 1;
  min-width: 100px;
}

.date-action-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  padding: 0;
  border: none;
  background: var(--color-paper-shadow);
  color: var(--color-ink-light);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 0.875rem;
  line-height: 1;
  opacity: 0.6;
  transition: opacity 0.15s, background 0.15s;
}

.date-action-btn:hover {
  opacity: 1;
  background: var(--color-ink-light);
  color: var(--color-paper);
}

.date-clear-btn:hover {
  background: var(--color-expired);
}

.date-move-btn:hover {
  background: var(--color-rust);
}

.date-move-menu {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 2px;
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-paper);
  z-index: 10;
  min-width: 100px;
}

.date-move-option {
  display: block;
  width: 100%;
  padding: var(--space-xs) var(--space-sm);
  border: none;
  background: none;
  color: var(--color-ink);
  font-family: var(--font-body);
  font-size: 0.75rem;
  text-align: left;
  cursor: pointer;
  white-space: nowrap;
}

.date-move-option:hover {
  background: var(--color-parchment);
  color: var(--color-rust);
}

.date-move-option:first-child {
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}

.date-move-option:last-child {
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
}

/* ═══════════════════════════════════════════════════════════════════
   Dashboard Items Display
   ═══════════════════════════════════════════════════════════════════ */

.licence-meta {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-xs);
}

.items-badge {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--color-ink-light);
  background: var(--color-paper-shadow);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
}

.licence-items-preview {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px dashed var(--color-paper-shadow);
}

.items-preview-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-sm);
}

.items-preview-title {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-ink-light);
}

.toggle-items-btn {
  background: none;
  border: none;
  color: var(--color-rust);
  font-size: 0.75rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  transition: background 0.15s ease;
}

.toggle-items-btn:hover {
  background: color-mix(in srgb, var(--color-rust) 10%, transparent);
}

.items-preview-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.item-preview-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: var(--space-md);
  align-items: center;
  font-size: 0.8125rem;
  padding: var(--space-xs) 0;
}

.item-preview-name {
  color: var(--color-ink);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.item-preview-category {
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-ink-light);
  background: var(--color-parchment);
  padding: 1px 6px;
  border-radius: var(--radius-sm);
}

.item-preview-expiry {
  font-family: var(--font-mono);
  font-size: 0.75rem;
}

.item-preview-expiry.expiring {
  color: var(--color-warning);
}

.item-preview-expiry.urgent {
  color: var(--color-urgent);
}

.item-preview-expiry.expired {
  color: var(--color-expired);
}

.item-preview-expiry.safe {
  color: var(--color-safe);
}

.items-collapsed-summary {
  font-size: 0.8125rem;
  color: var(--color-ink-faded);
}

.next-expiry-highlight {
  color: var(--color-rust);
  font-family: var(--font-mono);
  font-weight: 500;
}

/* Responsive - Upload Page */
@media (max-width: 600px) {
  .form-grid {
    grid-template-columns: 1fr;
  }

  .form-group.full-width {
    grid-column: 1;
  }

  .items-table {
    font-size: 0.8125rem;
  }

  .items-table th,
  .items-table td {
    padding: var(--space-xs);
  }

  .item-input.item-date {
    min-width: 100px;
  }

  .item-preview-row {
    grid-template-columns: 1fr auto;
  }

  .item-preview-category {
    display: none;
  }
}

/* Email Check UI */
.email-check-banner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  margin-bottom: var(--space-lg);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  animation: slideDown 0.3s ease-out;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.email-check-banner.info {
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  color: var(--color-ink-faded);
}

.email-check-banner.success {
  background: rgba(74, 124, 89, 0.1);
  border: 1px solid var(--color-safe);
  color: var(--color-safe);
}

.email-check-banner.error {
  background: rgba(139, 58, 58, 0.1);
  border: 1px solid var(--color-expired);
  color: var(--color-expired);
}

.email-check-content {
  flex: 1;
}

.email-check-details {
  list-style: none;
  margin-top: var(--space-sm);
  padding-left: var(--space-md);
  font-family: var(--font-mono);
  font-size: 0.8125rem;
}

.email-check-details li {
  padding: var(--space-xs) 0;
}

.email-check-details li.success {
  color: var(--color-safe);
}

.email-check-details li.failed {
  color: var(--color-expired);
}

.dismiss-btn {
  background: none;
  border: none;
  font-size: 1.25rem;
  cursor: pointer;
  color: inherit;
  opacity: 0.6;
  padding: 0;
  line-height: 1;
}

.dismiss-btn:hover {
  opacity: 1;
}

.empty-state-actions {
  display: flex;
  gap: var(--space-md);
  justify-content: center;
  flex-wrap: wrap;
  margin-top: var(--space-lg);
}

.email-check-feedback {
  margin-top: var(--space-xl);
}

/* ═══════════════════════════════════════════════════════════════════
   Licence Detail View (Expanded)
   ═══════════════════════════════════════════════════════════════════ */

.licence-detail-view {
  margin-top: var(--space-md);
  animation: expandIn 0.3s ease-out;
}

@keyframes expandIn {
  from {
    opacity: 0;
    max-height: 0;
  }
  to {
    opacity: 1;
    max-height: 2000px;
  }
}

.detail-metadata {
  background: var(--color-parchment);
  border-radius: var(--radius-sm);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
}

.detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-md) var(--space-lg);
}

.detail-field {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.detail-label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-ink-light);
}

.detail-value {
  font-size: 0.9375rem;
  color: var(--color-ink);
}

.detail-value.mono {
  font-family: var(--font-mono);
  font-size: 0.875rem;
}

.detail-notes {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px dashed var(--color-paper-shadow);
}

.detail-notes-text {
  font-size: 0.875rem;
  color: var(--color-ink-faded);
  line-height: 1.5;
  white-space: pre-wrap;
}

.detail-items {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.detail-category {
  background: var(--color-parchment);
  border-radius: var(--radius-sm);
  padding: var(--space-md);
}

.detail-category-heading {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-rust);
  margin-bottom: var(--space-sm);
  padding-bottom: var(--space-xs);
  border-bottom: 2px solid var(--color-rust-light);
}

.detail-items-table-wrapper {
  overflow-x: auto;
  margin: 0 calc(var(--space-md) * -1);
  padding: 0 var(--space-md);
}

.detail-items-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8125rem;
}

.detail-items-table th {
  text-align: left;
  font-size: 0.625rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-ink-light);
  padding: var(--space-xs) var(--space-sm);
  border-bottom: 1px solid var(--color-paper-shadow);
  white-space: nowrap;
}

.detail-items-table td {
  padding: var(--space-sm) var(--space-sm);
  border-bottom: 1px solid rgba(232, 226, 214, 0.5);
  vertical-align: top;
}

.detail-items-table tbody tr:last-child td {
  border-bottom: none;
}

.detail-items-table tbody tr:hover {
  background: rgba(255, 253, 248, 0.5);
}

.item-name-cell {
  color: var(--color-ink);
  font-weight: 500;
}

.item-conditions {
  display: block;
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--color-ink-light);
  font-style: italic;
  margin-top: 2px;
}

.date-cell {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--color-ink-faded);
  white-space: nowrap;
}

.date-cell.expiring-soon {
  color: var(--color-warning);
}

.date-cell.urgent {
  color: var(--color-urgent);
  font-weight: 500;
}

.date-cell.expired {
  color: var(--color-expired);
  font-weight: 500;
}

/* Responsive - Detail View */
@media (max-width: 600px) {
  .detail-grid {
    grid-template-columns: 1fr 1fr;
  }

  .detail-items-table {
    font-size: 0.75rem;
  }

  .detail-items-table th {
    font-size: 0.5625rem;
    padding: var(--space-xs);
  }

  .detail-items-table td {
    padding: var(--space-xs);
  }

  .date-cell {
    font-size: 0.6875rem;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   Controller & Versioning UI
   ═══════════════════════════════════════════════════════════════════ */

/* Controller detection banner on upload page */
.controller-banner {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md);
  margin-bottom: var(--space-lg);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
}

.controller-banner.update {
  background: linear-gradient(135deg, #f0f4ff 0%, #e8f0ff 100%);
  border: 1px solid #c4d6f7;
  color: #2c5282;
}

.controller-banner.new {
  background: linear-gradient(135deg, #f0fff4 0%, #e8fff0 100%);
  border: 1px solid #b8e6c7;
  color: #276749;
}

.controller-banner svg {
  flex-shrink: 0;
}

.controller-banner strong {
  font-weight: 600;
}

.controller-banner .version-info {
  font-size: 0.75rem;
  opacity: 0.8;
  margin-left: var(--space-xs);
}

/* Type row with version badge */
.licence-type-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

/* Version badge */
.version-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 0.625rem;
  font-weight: 500;
  padding: 2px 6px;
  background: var(--color-rust-light);
  color: white;
  border-radius: 10px;
  letter-spacing: 0.02em;
}

/* Valid from badge */
.valid-from-badge {
  font-size: 0.6875rem;
  color: var(--color-ink-light);
  font-style: italic;
}

.licence-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
}

/* Responsive - Controller UI */
@media (max-width: 600px) {
  .controller-banner {
    font-size: 0.8125rem;
    padding: var(--space-sm) var(--space-md);
  }

  .controller-banner .version-info {
    display: block;
    margin-left: 0;
    margin-top: 2px;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   Licence Document Reconstruction (Form0016 Style)
   Official document recreation with serif typography
   ═══════════════════════════════════════════════════════════════════ */

.licence-document {
  background: #fff;
  border: 1px solid var(--color-ink-light);
  padding: var(--space-lg);
  font-family: "Times New Roman", Times, serif;
  font-size: 10pt;
  max-width: 210mm;
  margin: var(--space-md) auto;
  box-shadow: var(--shadow-paper);
}

/* Document Header */
.doc-header {
  text-align: center;
  border-bottom: 2px solid var(--color-ink);
  padding-bottom: var(--space-md);
  margin-bottom: var(--space-lg);
}

.doc-authority {
  font-size: 9pt;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-ink-faded);
  margin-bottom: var(--space-xs);
}

.doc-title {
  font-size: 13pt;
  font-weight: bold;
  margin: var(--space-sm) 0;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-ink);
}

.doc-form-id {
  font-size: 8pt;
  color: var(--color-ink-light);
  font-style: italic;
}

/* Holder Info Section */
.doc-holder-info {
  border: 1px solid var(--color-ink-light);
  padding: var(--space-md);
  margin-bottom: var(--space-lg);
  background: linear-gradient(to bottom, rgba(247, 243, 235, 0.5), transparent);
}

.doc-holder-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-sm) var(--space-lg);
}

.doc-field {
  display: flex;
  gap: var(--space-sm);
}

.doc-field-label {
  font-weight: bold;
  min-width: 4rem;
  color: var(--color-ink-faded);
  font-size: 9pt;
}

.doc-field-value {
  font-family: var(--font-mono);
  font-size: 9pt;
  color: var(--color-ink);
}

/* Document Sections */
.doc-section {
  margin-bottom: var(--space-lg);
  page-break-inside: avoid;
}

.doc-section-header {
  display: flex;
  gap: var(--space-md);
  border-bottom: 1px solid var(--color-ink);
  padding-bottom: var(--space-xs);
  margin-bottom: var(--space-sm);
  font-weight: bold;
  font-size: 10pt;
  text-transform: uppercase;
}

.doc-section-number {
  min-width: 2.5rem;
  color: var(--color-ink);
}

.doc-section-title {
  color: var(--color-ink);
  letter-spacing: 0.05em;
}

.doc-section-empty {
  font-style: italic;
  color: var(--color-ink-light);
  font-size: 9pt;
  padding: var(--space-sm) 0;
}

/* Section Table */
.doc-section-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 9pt;
}

.doc-section-table thead {
  background: rgba(247, 243, 235, 0.6);
}

.doc-section-table th {
  padding: var(--space-xs) var(--space-sm);
  text-align: left;
  font-weight: 600;
  font-size: 8pt;
  color: var(--color-ink-faded);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--color-ink-light);
}

.doc-section-table td {
  padding: var(--space-xs) var(--space-sm);
  border-bottom: 1px dotted var(--color-paper-shadow);
  vertical-align: top;
}

.doc-section-table tr:last-child td {
  border-bottom: none;
}

.doc-section-table .col-name {
  min-width: 40%;
}

.doc-section-table .col-date {
  font-family: var(--font-mono);
  font-size: 8pt;
  white-space: nowrap;
  text-align: center;
}

/* Expiry status colours in document view */
.doc-section-table .col-date.urgent,
.doc-section-table .col-date.expired {
  color: var(--color-urgent);
  font-weight: 600;
}

.doc-section-table .col-date.expiring-soon {
  color: var(--color-warning);
}

/* Conditions in document */
.doc-conditions {
  display: block;
  font-size: 8pt;
  font-style: italic;
  color: var(--color-ink-light);
  margin-top: 2px;
}

/* Document Footer */
.doc-footer {
  margin-top: var(--space-xl);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-ink);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  font-size: 8pt;
  color: var(--color-ink-faded);
}

.doc-printed-info {
  font-family: var(--font-mono);
}

.doc-page-info {
  font-style: italic;
}

/* Responsive Document */
@media (max-width: 600px) {
  .licence-document {
    padding: var(--space-md);
    margin: var(--space-sm);
    font-size: 9pt;
  }

  .doc-holder-grid {
    grid-template-columns: 1fr;
  }

  .doc-section-table {
    font-size: 8pt;
  }

  .doc-section-table th,
  .doc-section-table td {
    padding: var(--space-xs);
  }

  .doc-footer {
    flex-direction: column;
    gap: var(--space-sm);
    align-items: flex-start;
  }
}

/* Print styles for document */
@media print {
  .licence-document {
    box-shadow: none;
    border: none;
    padding: 0;
    max-width: 100%;
  }

  .doc-section {
    page-break-inside: avoid;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   CASA ATC Licence Document Reconstruction
   Exact replica of Form0016/Form0021 - A5 landscape (210mm x 148mm)
   Single page with thin black border and center vertical divider
   Typography: Arial, matching original PDF exactly
   ═══════════════════════════════════════════════════════════════════ */

/* Document wrapper */
.casa-doc {
  margin: var(--space-md) 0;
  animation: expandIn 0.3s ease-out;
}

.casa-doc,
.casa-doc * {
  text-transform: none !important;
  box-sizing: border-box;
}

/* A5 landscape page (= 2 × A6 portrait side by side)
   210mm × 148mm = aspect ratio 1.42:1 */
.casa-page {
  display: flex;
  flex-direction: row; /* CRITICAL: side by side */
  background: #fff;
  border: 1px solid #000;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 9px;
  line-height: 1.35;
  color: #000;
  width: 100%;
  aspect-ratio: 210 / 148; /* A5 landscape = 2 × A6 portrait */
}

/* Each half of the page */
.casa-half {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 12px 16px;
  position: relative;
  min-width: 0;
  overflow: hidden;
}

/* Center vertical dividing line */
.casa-divider {
  width: 1px;
  background: #000;
  flex-shrink: 0;
  align-self: stretch;
}

/* ─────────────────────────────────────────────
   Page numbers
   ───────────────────────────────────────────── */
.casa-page-num {
  font-size: 9px;
  font-weight: normal;
  margin-bottom: 4px;
}

.casa-page-num-left {
  text-align: left;
}

.casa-page-num-right {
  text-align: right;
}

/* ─────────────────────────────────────────────
   Page header - centered title and holder
   ───────────────────────────────────────────── */
.casa-header {
  text-align: center;
  margin-bottom: 12px;
}

.casa-title {
  font-size: 14px;
  font-weight: bold;
}

.casa-holder {
  font-size: 12px;
  font-weight: bold;
  margin-top: 4px;
}

/* ─────────────────────────────────────────────
   Section structure
   Line 1: Section number (IX., XII., XIII.)
   Line 2: Section title + column headers
   Line 3+: Data rows
   ───────────────────────────────────────────── */
.casa-section {
  margin-bottom: 12px;
}

/* Section number - own line */
.casa-section-num {
  font-size: 9px;
  font-weight: normal;
  margin-bottom: 1px;
}

/* Section title row - CSS Grid for columns */
.casa-section-title-row {
  display: grid;
  grid-template-columns: 3fr 1fr 1fr 1fr;
  gap: 4px;
  margin-bottom: 1px;
  align-items: end;
}

/* Medical has only 3 columns */
.casa-section-title-row-medical {
  grid-template-columns: 2fr 1fr 1fr;
}

.casa-section-title {
  font-size: 9px;
  font-weight: bold;
}

.casa-col-header {
  font-size: 9px;
  font-weight: bold;
}

.casa-col-spacer {
  /* Empty spacer for alignment */
}

.casa-col-expires-label {
  font-size: 9px;
  font-weight: bold;
  grid-column: span 2;
  text-align: left;
}

/* Subheader row - underlined column names */
.casa-subheader-row {
  display: grid;
  grid-template-columns: 3fr 1fr 1fr 1fr;
  gap: 4px;
  margin-bottom: 2px;
}

.casa-underline {
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Data rows - same grid as subheader */
.casa-row {
  display: grid;
  grid-template-columns: 3fr 1fr 1fr 1fr;
  gap: 4px;
  font-size: 9px;
  line-height: 1.4;
}

/* Medical rows - 3 columns */
.casa-row-medical {
  grid-template-columns: 2fr 1fr 1fr;
}

.casa-col-name {
  font-size: 9px;
  font-weight: normal;
}

.casa-col-date {
  font-size: 9px;
  font-weight: normal;
  white-space: nowrap;
}

/* Expiry status colors */
.casa-col-date.urgent,
.casa-col-date.expired {
  color: #c00;
}

.casa-col-date.expiring-soon {
  color: #b60;
}

/* Editable date cells */
.casa-col-date.editable {
  cursor: pointer;
  border-radius: 2px;
  padding: 1px 3px;
  margin: -1px -3px;
  transition: background-color 0.15s ease;
}

.casa-col-date.editable:hover {
  background-color: rgba(139, 115, 85, 0.15);
}

.casa-col-date.editable .empty-date {
  color: #999;
  font-style: italic;
}

.casa-col-date.editing {
  padding: 0;
}

.casa-col-date.editing input[type="date"] {
  font-family: Arial, sans-serif;
  font-size: 8px;
  padding: 1px 2px;
  border: 1px solid var(--color-rust);
  border-radius: 2px;
  width: 80px;
  background: white;
}

/* ─────────────────────────────────────────────
   Conditions section (below Medical)
   ───────────────────────────────────────────── */
.casa-conditions {
  margin-top: 8px;
  margin-left: 0;
}

.casa-conditions-title {
  font-size: 9px;
  font-weight: bold;
  margin-bottom: 2px;
}

.casa-conditions-list {
  display: flex;
  flex-direction: column;
}

.casa-condition-item {
  font-size: 9px;
  font-weight: normal;
  line-height: 1.4;
  margin-left: 8px;
}

/* ─────────────────────────────────────────────
   ARN line - bold, between Medical and Ratings
   ───────────────────────────────────────────── */
.casa-arn {
  margin: 16px 0 12px 0;
  font-size: 9px;
  font-weight: bold;
}

/* ─────────────────────────────────────────────
   Page footer
   ───────────────────────────────────────────── */
.casa-footer {
  margin-top: auto;
  font-size: 9px;
  padding-top: 8px;
}

.casa-printed {
  font-size: 9px;
  font-weight: normal;
}

.casa-form-id {
  font-size: 9px;
  font-style: italic;
  text-align: right;
}

/* ─────────────────────────────────────────────
   Responsive - Stack halves vertically on narrow screens
   ───────────────────────────────────────────── */
@media (max-width: 700px) {
  .casa-page {
    flex-direction: column;
    aspect-ratio: 148 / 210; /* Stacked vertically (A5 portrait) */
  }

  .casa-divider {
    width: 100%;
    height: 1px;
  }

  .casa-half {
    padding: 16px;
  }

  .casa-page-num-left,
  .casa-page-num-right {
    text-align: left;
  }
}

/* ─────────────────────────────────────────────
   Print styles
   ───────────────────────────────────────────── */
@media print {
  .casa-doc {
    margin: 0;
  }

  .casa-page {
    page-break-inside: avoid;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   Controller List Page
   ═══════════════════════════════════════════════════════════════════ */

/* Toolbar with filters and sort */
.controller-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
  flex-wrap: wrap;
}

/* Filter Pills */
.filter-pills {
  display: flex;
  gap: var(--space-xs);
  flex-wrap: wrap;
}

.filter-pill {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-xs) var(--space-md);
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-ink-light);
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: 20px;
  cursor: pointer;
  transition: all 0.15s ease;
}

.filter-pill:hover {
  background: var(--color-parchment);
  border-color: var(--color-ink-faded);
}

.filter-pill.active {
  background: var(--color-rust);
  color: var(--color-paper);
  border-color: var(--color-rust);
}

.filter-pill.active .filter-count {
  background: rgba(255, 255, 255, 0.2);
  color: var(--color-paper);
}

.filter-count {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 400;
  padding: 1px 6px;
  background: var(--color-paper-shadow);
  border-radius: 10px;
  color: var(--color-ink-faded);
}

/* Sort Dropdown */
.sort-dropdown {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.sort-label {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-ink-light);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.sort-select {
  padding: var(--space-xs) var(--space-md);
  font-family: var(--font-body);
  font-size: 0.8125rem;
  color: var(--color-ink);
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%232c2416' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 32px;
}

.sort-select:hover {
  border-color: var(--color-ink-faded);
}

.sort-select:focus {
  outline: none;
  border-color: var(--color-rust);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-rust) 20%, transparent);
}

/* Controller List */
.controller-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

/* Controller Card */
.controller-card {
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-left: 4px solid var(--color-ink-faded);
  border-radius: var(--radius-sm);
  padding: var(--space-md) var(--space-lg);
  transition: all 0.2s ease;
  animation: fadeInUp 0.3s ease-out both;
}

.controller-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(44, 36, 22, 0.08);
}

/* Status border colors */
.controller-card.safe {
  border-left-color: var(--color-safe);
}

.controller-card.expiring-soon {
  border-left-color: var(--color-warning);
}

.controller-card.urgent {
  border-left-color: var(--color-rust);
}

.controller-card.expired {
  border-left-color: var(--color-expired);
}

.controller-card.scheduled {
  border-left-color: var(--color-scheduled);
}

.controller-card.trainee-status {
  border-left-style: dashed;
  border-left-color: var(--color-safe);
}

/* Card Header */
.controller-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-sm);
}

.controller-badges {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  gap: var(--space-md);
}

/* Type Badge (ATC/TRAINEE) */
.type-badge {
  font-family: var(--font-mono);
  font-size: 0.625rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 3px 8px;
  border-radius: 3px;
}

.type-badge.atc {
  background: color-mix(in srgb, var(--color-safe) 15%, transparent);
  color: var(--color-safe);
}

.type-badge.trainee {
  background: color-mix(in srgb, var(--color-rust) 12%, transparent);
  color: var(--color-rust);
  border: 1px dashed var(--color-rust);
}

/* Source Badges */
.source-badges {
  display: flex;
  gap: var(--space-xs);
}

.source-badge {
  font-family: var(--font-mono);
  font-size: 0.5625rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 2px 6px;
  border-radius: 10px;
}

.source-badge.licence {
  background: color-mix(in srgb, var(--color-safe) 12%, transparent);
  color: var(--color-safe);
}

.source-badge.roster {
  background: color-mix(in srgb, var(--color-rust) 10%, transparent);
  color: var(--color-rust);
}

.source-badge.leave {
  background: color-mix(in srgb, #d97706 15%, transparent);
  color: #b45309;
}

.source-badge.leave-manual {
  background: color-mix(in srgb, #7c3aed 15%, transparent);
  color: #6d28d9;
}

/* On Leave card modifier */
.controller-card.on-leave {
  border-left-color: #d97706;
}

/* Stat value on-leave styling */
.stat-value.on-leave {
  color: #d97706;
}

/* Card Body */
.controller-card-body {
  margin-bottom: var(--space-md);
}

.controller-name {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 400;
  color: var(--color-ink);
  margin: 0 0 var(--space-xs) 0;
}

.controller-ids {
  display: flex;
  gap: var(--space-lg);
  flex-wrap: wrap;
}

.controller-id {
  font-size: 0.8125rem;
  color: var(--color-ink-light);
}

.id-label {
  font-weight: 500;
  margin-right: var(--space-xs);
}

.id-value {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  color: var(--color-ink);
}

.id-value.pending {
  font-style: italic;
  color: var(--color-ink-faded);
}

/* Card Footer */
.controller-card-footer {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  padding-top: var(--space-sm);
  border-top: 1px dashed var(--color-paper-shadow);
}

/* Licence Info Section */
.licence-info-section {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.licence-info-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.form-types {
  display: flex;
  gap: var(--space-xs);
}

.form-type-badge {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  padding: 2px 8px;
  background: var(--color-paper-shadow);
  border-radius: 3px;
  color: var(--color-ink);
}

/* Expiry summary (right side) */
.expiry-summary {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.8rem;
}

.expiry-next {
  font-weight: 500;
  color: var(--color-ink);
}

.expiry-next.safe {
  color: var(--color-safe);
}

.expiry-next.warning {
  color: var(--color-warning);
}

.expiry-next.urgent {
  color: var(--color-rust);
}

.expiry-next.expired {
  color: var(--color-expired);
}

.expiry-expired-count {
  font-size: 0.7rem;
  color: #a04030;
  padding: 0.1rem 0.4rem;
  background: linear-gradient(135deg, #fce8e6, #f9d9d5);
  border-radius: 3px;
  font-weight: 500;
}

/* Category expiries row */
.category-expiries {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.category-expiry {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.7rem;
  padding: 0.15rem 0.4rem;
  border-radius: 3px;
  background: color-mix(in srgb, var(--color-paper-dark) 40%, transparent);
}

.category-expiry .cat-label {
  color: var(--color-ink-light);
  font-weight: 500;
}

.category-expiry .cat-days {
  font-family: var(--font-mono);
  font-weight: 600;
}

.category-expiry.safe .cat-days {
  color: var(--color-safe);
}

.category-expiry.warning .cat-days {
  color: var(--color-warning);
}

.category-expiry.urgent .cat-days {
  color: var(--color-rust);
}

.category-expiry.expired .cat-days {
  color: var(--color-expired);
}

/* Roster Info Row */
.roster-info-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-sm);
  font-size: 0.8125rem;
  color: var(--color-ink-light);
}

.roster-count {
  font-family: var(--font-mono);
  font-size: 0.75rem;
}

.last-shift {
  font-size: 0.75rem;
}

/* No data states */
.no-licence-info,
.no-roster-info {
  font-size: 0.75rem;
  color: var(--color-ink-faded);
  font-style: italic;
}

/* Leave Toggle Button */
.leave-toggle-btn {
  background: transparent;
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  padding: 2px 6px;
  font-size: 0.75rem;
  cursor: pointer;
  color: var(--color-ink-light);
  transition: all 0.15s ease;
}

.leave-toggle-btn:hover {
  background: var(--color-paper-dark);
  color: var(--color-ink);
}

/* Leave Form */
.leave-form {
  margin-top: var(--space-sm);
  padding: var(--space-sm);
  background: var(--color-paper-dark);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-paper-shadow);
}

.leave-form-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: var(--space-sm);
}

.leave-form-row label {
  font-size: 0.6875rem;
  font-weight: 500;
  color: var(--color-ink-light);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.leave-form-row select,
.leave-form-row input {
  font-family: var(--font-body);
  font-size: 0.8125rem;
  padding: 6px 8px;
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  background: var(--color-paper);
}

.leave-form-row select:focus,
.leave-form-row input:focus {
  outline: none;
  border-color: var(--color-rust);
}

.leave-form-dates {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm);
}

.leave-form-actions {
  display: flex;
  gap: var(--space-xs);
  margin-top: var(--space-sm);
  padding-top: var(--space-sm);
  border-top: 1px dashed var(--color-paper-shadow);
}

.btn-sm {
  font-size: 0.75rem;
  padding: 4px 10px;
}

/* ─────────────────────────────────────────────
   Leave Timeline (Warm Journey Design)
   ───────────────────────────────────────────── */
.leave-timeline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  padding: 0.4rem 0.6rem;
  margin: 0 calc(-1 * var(--space-sm));
  background: linear-gradient(
    135deg,
    color-mix(in srgb, #f5ebe0 50%, transparent),
    color-mix(in srgb, #faf6f1 30%, transparent)
  );
  border-bottom: 1px solid color-mix(in srgb, var(--color-paper-shadow) 40%, transparent);
}

/* Base chip style */
.timeline-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.78rem;
  line-height: 1.2;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  white-space: nowrap;
}

/* Leave type pill - warm terracotta */
.chip-type {
  display: inline-block;
  padding: 0.15rem 0.4rem;
  background: linear-gradient(135deg, #d4715a, #c9684f);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  border-radius: 3px;
}

/* Date styling */
.chip-date {
  color: #5c574f;
  font-weight: 500;
}

/* Arrow connector */
.chip-arrow {
  color: #a39d93;
  font-size: 0.85rem;
  margin: 0 0.1rem;
}

/* Return date - sage green accent */
.chip-date.return {
  color: #3d6a3c;
  font-weight: 600;
  padding: 0.1rem 0.35rem;
  background: linear-gradient(135deg, #d8ead6, #cce3ca);
  border-radius: 3px;
}

/* Primary chip - subtle warm background */
.timeline-chip.primary {
  background: color-mix(in srgb, #f5ebe0 60%, transparent);
  border: 1px solid color-mix(in srgb, #d4cfc5 60%, transparent);
}

/* Secondary chip - softer, slightly muted */
.timeline-chip.secondary {
  background: transparent;
  border: 1px dashed #d4cfc5;
  font-size: 0.72rem;
}

.timeline-chip.secondary .chip-type {
  background: linear-gradient(135deg, #c9a87c, #bb9a70);
  font-size: 0.6rem;
  padding: 0.12rem 0.35rem;
}

.timeline-chip.secondary .chip-date {
  color: #7a746a;
  font-size: 0.72rem;
}

.chip-then {
  color: #9a948a;
  font-style: italic;
  font-size: 0.7rem;
}

.chip-duration {
  color: #8a847a;
  font-size: 0.68rem;
}

/* Training chip - soft blue */
.timeline-chip.training {
  background: linear-gradient(135deg, #e8f4f8, #dceef4);
  color: #2d6a7a;
  font-weight: 500;
  border: 1px solid #c5dfe8;
}

/* Departure chip - warm coral */
.timeline-chip.departure {
  background: linear-gradient(135deg, #fce8e6, #f9d9d5);
  color: #9a3c2e;
  font-weight: 500;
  border: 1px solid #f0c4be;
}

/* Today's shift emphasis */
.today-shift {
  color: var(--color-ink);
  font-weight: 500;
}

/* Empty Filter State */
.empty-filter-state {
  text-align: center;
  padding: var(--space-3xl) var(--space-lg);
  background: var(--color-paper);
  border: 1px dashed var(--color-paper-shadow);
  border-radius: var(--radius-sm);
}

.empty-filter-state p {
  color: var(--color-ink-light);
  margin-bottom: var(--space-md);
}

/* ─────────────────────────────────────────────
   Controller List Responsive
   ───────────────────────────────────────────── */
@media (max-width: 600px) {
  .controller-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .filter-pills {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: var(--space-xs);
    -webkit-overflow-scrolling: touch;
  }

  .filter-pill {
    flex-shrink: 0;
  }

  .sort-dropdown {
    justify-content: flex-end;
  }

  .controller-card {
    padding: var(--space-md);
  }

  .controller-ids {
    flex-direction: column;
    gap: var(--space-xs);
  }

  .licence-info-row,
  .roster-info-row {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ============================================
   Calendar Page
   ============================================ */

.calendar-page {
  max-width: 1100px;
}

.calendar-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-lg);
  padding: var(--space-md);
  background: var(--color-paper);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-paper);
}

.calendar-nav {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.calendar-range {
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--color-ink);
  margin-left: var(--space-sm);
}

.btn-icon {
  padding: var(--space-sm);
  background: transparent;
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  cursor: pointer;
  color: var(--color-ink-faded);
  transition: all 0.15s ease;
}

.btn-icon:hover {
  background: var(--color-parchment);
  color: var(--color-ink);
  border-color: var(--color-ink-light);
}

.calendar-toggles {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.toggle-pill {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-xs) var(--space-sm);
  background: var(--color-parchment);
  border: 1px solid var(--color-paper-shadow);
  border-radius: 999px;
  cursor: pointer;
  font-size: 0.85rem;
  color: var(--color-ink-faded);
  transition: all 0.15s ease;
}

.toggle-pill:has(input:checked) {
  background: var(--color-rust-light);
  border-color: var(--color-rust);
  color: var(--color-ink);
}

.toggle-pill input {
  display: none;
}

.toggle-pill.small {
  padding: 2px var(--space-xs);
  font-size: 0.75rem;
}

.toggle-pill.focus-toggle:has(input:checked) {
  background: color-mix(in srgb, var(--color-scheduled) 20%, var(--color-paper));
  border-color: var(--color-scheduled);
  color: var(--color-scheduled);
}

.toggle-group {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.toggle-group-label {
  font-size: 0.8rem;
  color: var(--color-ink-light);
  margin-right: var(--space-xs);
}

.toggle-actions {
  display: inline-flex;
  flex-direction: column;
  gap: 0;
  margin-right: var(--space-xs);
  vertical-align: middle;
}

.toggle-action-btn {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font-size: 0.7rem;
  line-height: 1;
  color: var(--color-ink-light);
  opacity: 0.6;
  transition: opacity 0.15s ease;
}

.toggle-action-btn:hover {
  opacity: 1;
}

/* Controller filter */
.calendar-controller-filter {
  margin-bottom: var(--space-lg);
  padding: var(--space-md);
  background: var(--color-paper);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-paper);
}

.filter-actions {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.btn-small {
  padding: var(--space-xs) var(--space-sm);
  font-size: 0.75rem;
  background: transparent;
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  cursor: pointer;
  color: var(--color-ink-faded);
}

.btn-small:hover {
  background: var(--color-parchment);
  border-color: var(--color-ink-light);
}

.btn-tiny {
  padding: 2px 6px;
  font-size: 0.65rem;
  background: transparent;
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  cursor: pointer;
  color: var(--color-ink-faded);
}

.btn-tiny:hover {
  background: var(--color-parchment);
  border-color: var(--color-ink-light);
}

.controller-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
}

.controller-chip {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: 4px var(--space-sm);
  background: var(--color-parchment);
  border: 1px solid var(--color-paper-shadow);
  border-radius: 999px;
  cursor: pointer;
  font-size: 0.8rem;
  color: var(--color-ink-faded);
  transition: all 0.15s ease;
}

.controller-chip:hover {
  border-color: var(--chip-colour, var(--color-ink-light));
}

.controller-chip.selected {
  background: color-mix(in srgb, var(--chip-colour) 15%, var(--color-paper));
  border-color: var(--chip-colour);
  color: var(--color-ink);
}

.chip-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--chip-colour);
  opacity: 0.4;
}

.controller-chip.selected .chip-dot {
  opacity: 1;
}

.chip-name {
  white-space: nowrap;
}

/* Loading */
.calendar-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-3xl);
  color: var(--color-ink-faded);
}

/* Agenda view */
.agenda-view {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.agenda-day {
  background: var(--color-paper);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-paper);
  overflow: hidden;
}

.agenda-day.is-today {
  box-shadow: 0 0 0 2px var(--color-rust-light), var(--shadow-paper);
}

.agenda-day-header {
  display: flex;
  align-items: baseline;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-parchment);
  border-bottom: 1px solid var(--color-paper-shadow);
  font-family: var(--font-display);
}

.agenda-day.is-today .agenda-day-header {
  background: color-mix(in srgb, var(--color-rust-light) 20%, var(--color-parchment));
}

.day-name {
  font-weight: 700;
  color: var(--color-ink);
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.05em;
}

.day-date {
  font-size: 0.95rem;
  color: var(--color-ink-faded);
}

.today-badge {
  margin-left: auto;
  padding: 2px var(--space-sm);
  background: var(--color-rust);
  color: var(--color-paper);
  border-radius: 999px;
  font-family: var(--font-body);
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.agenda-day-events {
  padding: var(--space-sm);
}

.agenda-empty {
  padding: var(--space-md);
  text-align: center;
  color: var(--color-ink-light);
  font-style: italic;
  font-size: 0.85rem;
}

/* Agenda events */
.agenda-event {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  border-left: 3px solid transparent;
  margin-bottom: 2px;
}

.agenda-event:last-child {
  margin-bottom: 0;
}

/* Roster events by shift category */
.agenda-event.roster.shift-operational {
  border-left-color: var(--color-rust);
  background: linear-gradient(135deg, rgba(184, 92, 56, 0.08), rgba(184, 92, 56, 0.02));
}

.agenda-event.roster.shift-leave {
  border-left-color: var(--color-safe);
  background: linear-gradient(135deg, rgba(74, 124, 89, 0.08), rgba(74, 124, 89, 0.02));
}

.agenda-event.roster.shift-training {
  border-left-color: #5b8fb9;
  background: linear-gradient(135deg, rgba(91, 143, 185, 0.08), rgba(91, 143, 185, 0.02));
}

.agenda-event.roster.shift-admin {
  border-left-color: #8b7355;
  background: linear-gradient(135deg, rgba(139, 115, 85, 0.08), rgba(139, 115, 85, 0.02));
}

.agenda-event.roster.shift-grey {
  border-left-color: #9ca3af;
  background: linear-gradient(135deg, rgba(156, 163, 175, 0.08), rgba(156, 163, 175, 0.02));
}

.agenda-event.roster.shift-check {
  border-left-color: var(--color-scheduled);
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.08), rgba(37, 99, 235, 0.02));
}

/* Orphan check - suspect data (claimed checker has no CHECK shift that day) */
.agenda-event.roster.check-orphan {
  border-left-color: var(--color-ink-light);
  background: linear-gradient(135deg, rgba(148, 163, 184, 0.08), rgba(148, 163, 184, 0.02));
  opacity: 0.7;
}

.agenda-event.roster.check-orphan .event-shift-comments {
  color: var(--color-ink-light);
}

/* Augmented indicator for inferred checks */
.augmented-indicator {
  font-size: 0.75em;
  color: var(--color-scheduled);
  margin-left: 0.25rem;
  font-weight: 600;
  opacity: 0.7;
}

.agenda-event.roster.shift-off {
  border-left-color: var(--color-ink-light);
  background: var(--color-paper);
}

.event-controller-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.event-controller-name {
  font-weight: 500;
  color: var(--color-ink);
  min-width: 140px;
}

.event-shift-type {
  color: var(--color-ink-faded);
  flex: 1;
}

.event-shift-comments {
  color: var(--color-ink-light);
  font-style: italic;
}

.event-time {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--color-ink-light);
}

/* Expiry events */
.agenda-event.expiry {
  padding-left: calc(var(--space-md) + var(--space-sm));
  border-left-width: 0;
  background: transparent;
}

.agenda-event.expiry.urgency-safe {
  color: var(--color-safe);
}

.agenda-event.expiry.urgency-warning {
  color: var(--color-warning);
}

.agenda-event.expiry.urgency-urgent {
  color: var(--color-urgent);
}

.agenda-event.expiry.urgency-expired {
  color: var(--color-expired);
}

.expiry-marker {
  font-size: 0.7rem;
}

.expiry-label {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  opacity: 0.8;
}

.expiry-category {
  font-size: 0.75rem;
  opacity: 0.9;
}

.expiry-item-name {
  font-size: 0.8rem;
  flex: 1;
}

.expiry-type-label {
  font-size: 0.7rem;
  font-style: italic;
  opacity: 0.8;
  margin-right: var(--space-sm);
}

.expiry-days {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 0.75rem;
}

/* Responsive */
@media (max-width: 768px) {
  .calendar-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .calendar-nav {
    justify-content: center;
  }

  .calendar-toggles {
    justify-content: center;
    flex-wrap: wrap;
  }

  .calendar-range {
    display: block;
    text-align: center;
    margin-left: 0;
    margin-top: var(--space-xs);
  }

  .event-controller-name {
    min-width: 100px;
  }

  .event-time {
    display: none;
  }
}

/* ===========================================
   Calendar View Controls
   ============================================ */

.calendar-view-controls {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

/* View mode toggle (Agenda/Month) */
.view-toggle {
  display: flex;
  background: var(--color-parchment);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.view-toggle-btn {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-xs) var(--space-sm);
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: 0.8rem;
  font-family: var(--font-body);
  color: var(--color-ink-faded);
  transition: all 0.15s ease;
}

.view-toggle-btn:first-child {
  border-right: 1px solid var(--color-paper-shadow);
}

.view-toggle-btn:hover {
  background: var(--color-paper);
  color: var(--color-ink-light);
}

.view-toggle-btn.active {
  background: var(--color-rust);
  color: var(--color-paper);
}

.view-toggle-btn.active svg {
  stroke: var(--color-paper);
}

/* Week length selector */
.week-length-selector {
  display: flex;
  background: var(--color-parchment);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.week-btn {
  padding: var(--space-xs) var(--space-sm);
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: 0.75rem;
  font-family: var(--font-mono);
  color: var(--color-ink-faded);
  transition: all 0.15s ease;
  min-width: 36px;
}

.week-btn:not(:last-child) {
  border-right: 1px solid var(--color-paper-shadow);
}

.week-btn:hover {
  background: var(--color-paper);
  color: var(--color-ink-light);
}

.week-btn.active {
  background: var(--color-rust-light);
  color: var(--color-ink);
  font-weight: 600;
}

/* Data toggles bar */
.calendar-data-toggles {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-paper);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-paper);
}

/* ===========================================
   Month View
   ============================================ */

.month-view-container {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.month-block {
  display: flex;
  flex-direction: column;
}

.month-block-header {
  padding: var(--space-sm) var(--space-md);
  margin-bottom: var(--space-xs);
}

.month-block-header .month-label {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-ink);
  letter-spacing: 0.02em;
}

.month-view {
  background: var(--color-paper);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-paper);
  overflow: hidden;
}

.month-header {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  background: var(--color-parchment);
  border-bottom: 1px solid var(--color-paper-shadow);
}

.month-header-cell {
  padding: var(--space-sm);
  text-align: center;
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-ink-faded);
}

.month-grid {
  display: flex;
  flex-direction: column;
}

.month-week {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  border-bottom: 1px solid var(--color-paper-shadow);
}

.month-week:last-child {
  border-bottom: none;
}

.month-cell {
  min-height: 100px;
  padding: var(--space-xs);
  border-right: 1px solid var(--color-paper-shadow);
  background: var(--color-paper);
  transition: background 0.15s ease;
}

.month-cell:last-child {
  border-right: none;
}

.month-cell:hover {
  background: var(--color-parchment);
}

.month-cell.is-today {
  background: color-mix(in srgb, var(--color-rust-light) 20%, var(--color-paper));
}

.month-cell.other-month {
  background: var(--color-parchment);
  opacity: 0.6;
}

.month-cell.empty {
  background: var(--color-parchment);
}

.month-cell-date {
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-ink-faded);
  margin-bottom: var(--space-xs);
}

.month-cell.is-today .month-cell-date {
  color: var(--color-rust);
}

.month-cell-events {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.month-event {
  display: flex;
  align-items: center;
  gap: 3px;
  padding: 2px 4px;
  border-radius: 3px;
  font-size: 0.65rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.month-event.roster.shift-operational {
  background: color-mix(in srgb, var(--color-rust) 15%, var(--color-paper));
  color: var(--color-rust);
}

.month-event.roster.shift-leave {
  background: color-mix(in srgb, var(--color-safe) 15%, var(--color-paper));
  color: var(--color-safe);
}

.month-event.roster.shift-training {
  background: color-mix(in srgb, #5b8fb9 15%, var(--color-paper));
  color: #5b8fb9;
}

.month-event.roster.shift-admin {
  background: color-mix(in srgb, #8b7355 15%, var(--color-paper));
  color: #8b7355;
}

.month-event.roster.shift-grey {
  background: color-mix(in srgb, #9ca3af 15%, var(--color-paper));
  color: #9ca3af;
}

.month-event.roster.shift-check {
  background: color-mix(in srgb, var(--color-scheduled) 15%, var(--color-paper));
  color: var(--color-scheduled);
}

/* Orphan check - suspect data */
.month-event.roster.check-orphan {
  background: color-mix(in srgb, var(--color-ink-light) 10%, var(--color-paper));
  color: var(--color-ink-light);
  opacity: 0.7;
}

/* Augmented indicator in month view */
.month-event .augmented-indicator {
  font-size: 0.65em;
  margin-left: 1px;
  opacity: 0.7;
}

.month-event.roster.shift-off {
  background: var(--color-parchment);
  color: var(--color-ink-light);
}

.month-event.expiry.urgency-safe {
  background: color-mix(in srgb, var(--color-safe) 15%, var(--color-paper));
  color: var(--color-safe);
}

.month-event.expiry.urgency-warning {
  background: color-mix(in srgb, var(--color-warning) 15%, var(--color-paper));
  color: var(--color-warning);
}

.month-event.expiry.urgency-urgent {
  background: color-mix(in srgb, var(--color-urgent) 15%, var(--color-paper));
  color: var(--color-urgent);
}

.month-event.expiry.urgency-expired {
  background: color-mix(in srgb, var(--color-expired) 15%, var(--color-paper));
  color: var(--color-expired);
}

.month-event-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.month-event-initials {
  font-weight: 600;
}

.month-event-shift {
  opacity: 0.8;
}

.month-event-marker {
  font-size: 0.5rem;
}

.month-event-cat {
  opacity: 0.8;
  text-transform: uppercase;
}

.month-event-item {
  opacity: 0.7;
  text-transform: capitalize;
}

.month-event-type {
  opacity: 0.6;
  font-style: italic;
  margin-left: 1px;
}

.month-cell-more {
  font-size: 0.6rem;
  color: var(--color-ink-light);
  padding: 2px 4px;
  text-align: center;
  font-style: italic;
}


/* Month view responsive */
@media (max-width: 768px) {
  .calendar-view-controls {
    flex-wrap: wrap;
    justify-content: center;
  }

  .month-cell {
    min-height: 60px;
    padding: 2px;
  }

  .month-cell-date {
    font-size: 0.7rem;
  }

  .month-event {
    font-size: 0.55rem;
    padding: 1px 2px;
  }

  .month-event-initials {
    display: none;
  }
}

/* ===========================================
   Licence Document Modal
   ============================================ */

/* Clickable expiry events */
.month-event.expiry.clickable,
.agenda-event.expiry.clickable {
  cursor: pointer;
  transition: transform 0.1s ease, box-shadow 0.1s ease;
}

.month-event.expiry.clickable:hover {
  transform: scale(1.05);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

.agenda-event.expiry.clickable:hover {
  background: color-mix(in srgb, var(--color-ink) 3%, transparent);
}

/* Floating licence popup (no overlay, hugs content, draggable) */
.licence-popup {
  position: fixed;
  z-index: 1000;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2), 0 2px 8px rgba(0, 0, 0, 0.1);
  cursor: grab;
}

.licence-popup.dragging {
  user-select: none;
  cursor: grabbing;
}

.licence-popup.resizing {
  user-select: none;
}

/* Resize handle in bottom-right corner */
.licence-popup-resize {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 20px;
  height: 20px;
  cursor: nwse-resize;
  z-index: 10;
  opacity: 0;
  transition: opacity 0.15s ease;
}

.licence-popup-resize::before {
  content: "";
  position: absolute;
  bottom: 4px;
  right: 4px;
  width: 10px;
  height: 10px;
  border-right: 2px solid rgba(0, 0, 0, 0.3);
  border-bottom: 2px solid rgba(0, 0, 0, 0.3);
}

.licence-popup:hover .licence-popup-resize {
  opacity: 1;
}

/* Close button - only visible on hover */
.licence-popup-close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 28px;
  height: 28px;
  border: none;
  background: rgba(0, 0, 0, 0.6);
  border-radius: 50%;
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
  color: white;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.15s ease;
}

.licence-popup:hover .licence-popup-close {
  opacity: 1;
}

.licence-popup-close:hover {
  background: rgba(0, 0, 0, 0.8);
}

/* Loading state */
.licence-popup-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-xl);
  background: var(--color-paper);
  min-width: 200px;
  min-height: 100px;
}

/* Error state */
.licence-popup-error {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
  background: var(--color-paper);
  color: var(--color-urgent);
  font-size: 0.85rem;
}

/* Fixed size CASA document inside popup - prevents resize on drag */
.licence-popup .casa-doc {
  margin: 0;
  padding: 0;
}

.licence-popup .casa-page {
  margin: 0;
  /* Lock the width so it doesn't reflow when dragged */
  width: 800px;
  min-width: 800px;
  max-width: 800px;
  flex-direction: row !important;
  aspect-ratio: 297 / 210 !important;
}

/* Rescan Section */
.rescan-section {
  margin-top: var(--space-lg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  overflow: hidden;
}

.rescan-toggle {
  width: 100%;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  background: none;
  border: none;
  cursor: pointer;
  font-size: 0.95rem;
  color: var(--color-text-muted);
  transition: background-color 0.2s ease, color 0.2s ease;
}

.rescan-toggle:hover {
  background: var(--color-hover);
  color: var(--color-text);
}

.rescan-toggle svg {
  flex-shrink: 0;
}

.rescan-toggle span:first-of-type {
  flex: 1;
  text-align: left;
}

.toggle-arrow {
  font-size: 0.75rem;
  transition: transform 0.2s ease;
}

.toggle-arrow.expanded {
  transform: rotate(180deg);
}

.rescan-list {
  border-top: 1px solid var(--color-border);
  padding: var(--space-md) var(--space-lg);
}

.rescan-hint {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  margin-bottom: var(--space-md);
}

.rescan-group {
  margin-bottom: var(--space-md);
}

.rescan-group:last-child {
  margin-bottom: 0;
}

.rescan-group-name {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--space-sm);
}

.rescan-items {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.rescan-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  padding: var(--space-sm) var(--space-md);
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all 0.2s ease;
}

.rescan-item:hover {
  border-color: var(--color-primary);
  background: var(--color-primary-subtle);
}

.rescan-item-type {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-text);
}

.rescan-item-date {
  font-size: 0.75rem;
  color: var(--color-text-muted);
}

/* CASA Document Actions */
.casa-doc-actions {
  display: flex;
  justify-content: flex-end;
  margin-bottom: var(--space-sm);
  gap: var(--space-sm);
}

.btn-sm {
  padding: var(--space-xs) var(--space-sm);
  font-size: 0.8rem;
}

/* ===== Group Selector ===== */
.group-selector {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  position: relative;
}

.group-selector-trigger {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-xs) var(--space-md);
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--color-ink);
  cursor: pointer;
  transition: all 0.15s ease;
}

.group-selector-trigger:hover {
  border-color: var(--color-ink-light);
  background: var(--color-parchment);
}

.group-selector-trigger .icon-chevron {
  width: 16px;
  height: 16px;
  transition: transform 0.2s ease;
}

.group-selector-trigger .icon-chevron.rotated {
  transform: rotate(180deg);
}

.group-selector-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: var(--space-xs);
  min-width: 200px;
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-paper-hover);
  z-index: 100;
  overflow: hidden;
}

.group-option {
  display: flex;
  align-items: center;
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  background: none;
  transition: background 0.1s ease;
}

.group-option:hover {
  background: var(--color-parchment);
}

.group-option.selected {
  background: var(--color-parchment);
}

.group-option-select {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  background: none;
  border: none;
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--color-ink);
  text-align: left;
  cursor: pointer;
  padding: 0;
}

.group-option.selected .group-option-select {
  font-weight: 500;
}

.group-option-select .icon-check {
  width: 14px;
  height: 14px;
  color: var(--color-rust);
}

.group-option-star {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: var(--space-xs);
  padding: 2px;
  background: none;
  border: none;
  cursor: pointer;
  opacity: 0.25;
  transition: opacity 0.15s ease;
}

.group-option:hover .group-option-star {
  opacity: 0.5;
}

.group-option-star:hover {
  opacity: 1 !important;
}

.group-option-star.is-default {
  opacity: 1;
  color: #c9a227;
}

.group-option-star .icon-star-outline,
.group-option-star .icon-star-filled {
  width: 10px;
  height: 10px;
}

.show-former-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-xs) var(--space-sm);
  font-size: 0.85rem;
  color: var(--color-ink-faded);
  cursor: pointer;
  user-select: none;
  border-radius: var(--radius-sm);
  transition: all 0.15s ease;
}

.show-former-toggle:hover {
  color: var(--color-ink);
  background: var(--color-parchment);
}

.show-former-toggle input[type="checkbox"] {
  margin: 0;
  cursor: pointer;
}

/* Searchable Group Selector */
.group-search {
  padding: var(--space-sm);
  border-bottom: 1px solid var(--color-paper-shadow);
}

.group-search-input {
  width: 100%;
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 0.875rem;
}

.group-search-input:focus {
  outline: none;
  border-color: var(--color-rust);
}

.group-options-list {
  max-height: 200px;
  overflow-y: auto;
}

.group-no-results {
  padding: var(--space-md);
  text-align: center;
  color: var(--color-ink-light);
  font-size: 0.875rem;
}

/* Default star in trigger button */
.group-selector-trigger .group-name {
  display: flex;
  align-items: center;
  gap: 0.25em;
}

.group-selector-trigger .default-star {
  width: 10px;
  height: 10px;
  color: #c9a227;
  flex-shrink: 0;
}

/* Current Group Badge (header display) */
.header-group-selector {
  margin-top: var(--space-md);
}

.current-group-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  margin-top: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background: rgba(184, 92, 56, 0.08);
  border: 1px solid rgba(184, 92, 56, 0.2);
  border-radius: var(--radius-md);
  font-size: 0.9rem;
}

.group-badge-label {
  color: var(--color-ink-light);
}

.group-badge-name {
  font-weight: 600;
  color: var(--color-rust);
}

.group-badge-former {
  font-size: 0.8rem;
  color: var(--color-ink-light);
  font-style: italic;
}

/* Loading State */
.loading-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-3xl);
  color: var(--color-ink-faded);
}

.loading-state .spinner {
  margin-bottom: var(--space-md);
}

/* ===== Departed Controller Styling ===== */
.controller-chip.departed {
  opacity: 0.5;
  border-style: dashed;
}

.controller-chip.departed .chip-name {
  text-decoration: line-through;
  text-decoration-color: var(--color-ink-light);
}

.agenda-roster-event.departed {
  opacity: 0.6;
  border-left-style: dashed;
}

.month-event.departed {
  opacity: 0.6;
}

.departed-badge {
  display: inline-block;
  padding: 0.125rem 0.375rem;
  font-size: 0.65rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background: var(--color-ink-light);
  color: var(--color-paper);
  border-radius: var(--radius-sm);
  margin-left: var(--space-xs);
}

.controller-card.departed {
  opacity: 0.6;
  border-style: dashed;
  border-left-style: dashed;
}

.controller-card.departed .controller-name {
  text-decoration: line-through;
  text-decoration-color: var(--color-ink-light);
}

/* Group selector in page headers */
.controllers-page .page-header .group-selector,
.calendar-page .page-header .group-selector {
  margin-top: var(--space-md);
}

/* ===== Groups Management Page ===== */
.groups-page {
  max-width: 1100px;
}

.groups-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--space-xl);
  min-height: 500px;
}

.groups-sidebar {
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  padding: var(--space-md);
}

.groups-sidebar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-paper-shadow);
}

.groups-sidebar-header h2 {
  font-size: 1rem;
  font-weight: 600;
  margin: 0;
}

.groups-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.group-item {
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background 0.15s ease;
  margin-bottom: var(--space-xs);
}

.group-item:hover {
  background: var(--color-parchment);
}

.group-item.selected {
  background: var(--color-parchment);
  border-left: 3px solid var(--color-rust);
  padding-left: calc(var(--space-md) - 3px);
}

.group-item-name {
  font-weight: 500;
  color: var(--color-ink);
}

.group-item-star {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: var(--space-xs);
  padding: 2px;
  background: none;
  border: none;
  cursor: pointer;
  opacity: 0.25;
  transition: opacity 0.15s ease;
  vertical-align: middle;
}

.group-item:hover .group-item-star {
  opacity: 0.5;
}

.group-item-star:hover {
  opacity: 1 !important;
}

.group-item-star.is-default {
  opacity: 1;
  color: #c9a227;
}

.group-item-code {
  display: block;
  font-size: 0.75rem;
  color: var(--color-ink-light);
  font-family: var(--font-mono);
}

.groups-main {
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
}

.group-detail-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--space-xl);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--color-paper-shadow);
}

.group-detail-header h2 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  margin: 0 0 var(--space-xs) 0;
}

.group-code {
  font-size: 0.85rem;
  color: var(--color-ink-light);
  font-family: var(--font-mono);
  margin: 0;
}

.group-description {
  font-size: 0.9rem;
  color: var(--color-ink-faded);
  margin: var(--space-sm) 0 0 0;
}

.group-actions {
  display: flex;
  gap: var(--space-sm);
}

.members-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-md);
}

.members-header-left {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.members-header h3 {
  font-size: 1rem;
  font-weight: 600;
  margin: 0;
}

.members-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.member-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md);
  background: var(--color-parchment);
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
}

.member-card.departed {
  opacity: 0.6;
  border-style: dashed;
  border-color: var(--color-paper-shadow);
}

.member-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.member-name {
  font-weight: 500;
  color: var(--color-ink);
}

.member-sap,
.member-joined,
.member-dates {
  font-size: 0.8rem;
  color: var(--color-ink-light);
}

.member-joined {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.edit-date-btn {
  background: transparent;
  border: none;
  padding: 2px;
  cursor: pointer;
  color: var(--color-ink-light);
  opacity: 0.5;
  transition: opacity 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 2px;
}

.edit-date-btn:hover {
  opacity: 1;
  color: var(--color-rust);
}

.member-reason {
  font-size: 0.75rem;
  color: var(--color-ink-faded);
  font-style: italic;
}

.former-members-divider {
  padding: var(--space-md) 0 var(--space-sm) 0;
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-ink-light);
  border-bottom: 1px dashed var(--color-paper-shadow);
  margin-top: var(--space-md);
}

.no-group-selected,
.groups-empty,
.members-empty {
  text-align: center;
  padding: var(--space-2xl);
  color: var(--color-ink-light);
}

/* Modal styles */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

.modal {
  background: var(--color-paper);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  max-width: 400px;
  width: 90%;
  box-shadow: var(--shadow-paper-hover);
}

.modal h3 {
  margin: 0 0 var(--space-lg) 0;
  font-family: var(--font-display);
}

.modal-subtitle {
  margin: -0.5rem 0 var(--space-lg) 0;
  color: var(--color-ink-faded);
}

.form-group {
  margin-bottom: var(--space-md);
}

.form-group label {
  display: block;
  font-size: 0.85rem;
  font-weight: 500;
  margin-bottom: var(--space-xs);
  color: var(--color-ink);
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: var(--space-sm);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 0.9rem;
  background: var(--color-paper);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--color-rust);
}

.form-hint {
  display: block;
  font-size: 0.75rem;
  color: var(--color-ink-light);
  margin-top: var(--space-xs);
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-sm);
  margin-top: var(--space-lg);
}

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

.btn-primary:hover:not(:disabled) {
  background: var(--color-rust-dark);
  border-color: var(--color-rust-dark);
}

.btn-primary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.btn-danger {
  background: var(--color-expired);
  color: var(--color-paper);
  border-color: var(--color-expired);
}

.btn-danger:hover {
  background: color-mix(in srgb, var(--color-expired) 85%, black);
}

.btn-outline {
  background: transparent;
  color: var(--color-ink-faded);
  border: 1px solid var(--color-paper-shadow);
}

.btn-outline:hover {
  background: var(--color-parchment);
  border-color: var(--color-ink-light);
}

.btn-link {
  background: none;
  border: none;
  color: var(--color-rust);
  text-decoration: underline;
  cursor: pointer;
  padding: var(--space-sm) var(--space-md);
}

.btn-link:hover {
  color: var(--color-rust-dark);
}

/* ============================================
   Export Modal Styles
   ============================================ */

.calendar-toolbar-right {
  display: flex;
  gap: var(--space-sm);
  align-items: center;
}

.calendar-toolbar-right .btn svg {
  margin-right: 0.25rem;
  vertical-align: -2px;
}

.export-modal {
  max-width: 520px;
}

.export-controller-actions {
  display: flex;
  gap: var(--space-sm);
  align-items: center;
  margin-bottom: var(--space-sm);
}

.export-count {
  font-size: 0.875rem;
  color: var(--color-ink-light);
  margin-left: auto;
}

.export-controller-list {
  max-height: 200px;
  overflow-y: auto;
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  padding: var(--space-sm);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-xs);
}

.export-controller-item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background-color 0.15s ease;
}

.export-controller-item:hover {
  background: var(--color-parchment);
}

.export-controller-item.selected {
  background: rgba(184, 92, 56, 0.1);
}

.export-controller-item input[type="checkbox"] {
  margin: 0;
}

.export-controller-item .controller-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.export-controller-item .controller-name {
  font-size: 0.875rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.export-date-presets {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  margin-bottom: var(--space-sm);
}

.preset-btn {
  padding: var(--space-xs) var(--space-sm);
  font-size: 0.875rem;
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  background: var(--color-paper);
  cursor: pointer;
  transition: all 0.15s ease;
}

.preset-btn:hover {
  border-color: var(--color-ink-light);
}

.preset-btn.active {
  background: var(--color-rust);
  color: var(--color-paper);
  border-color: var(--color-rust);
}

.export-custom-dates {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.export-custom-dates input[type="date"] {
  flex: 1;
}

.export-custom-dates span {
  color: var(--color-ink-light);
}

.checkbox-label {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
}

.checkbox-label input[type="checkbox"] {
  margin: 0;
}

.modal-actions .btn-link {
  margin-right: auto;
}

.modal-actions .btn svg {
  margin-right: 0.25rem;
  vertical-align: -2px;
}

/* ============================================
   Export Page Styles
   ============================================ */

.export-page .export-page-content {
  max-width: 700px;
}

.export-intro {
  margin-bottom: var(--space-xl);
  color: var(--color-ink-faded);
  font-size: 1rem;
  line-height: 1.6;
}

.export-section {
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
}

.export-section h2 {
  font-family: var(--font-display);
  font-size: 1.125rem;
  margin-bottom: var(--space-md);
  color: var(--color-ink);
}

.export-controller-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-sm);
}

.export-controller-card {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all 0.15s ease;
  background: var(--color-paper);
}

.export-controller-card:hover {
  border-color: var(--color-ink-light);
}

.export-controller-card.selected {
  border-color: var(--color-rust);
  background: rgba(184, 92, 56, 0.05);
}

.export-controller-card.departed {
  opacity: 0.7;
}

.export-controller-card input[type="checkbox"] {
  margin: 0;
  flex-shrink: 0;
}

.export-controller-card .controller-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}

.export-controller-card .controller-info {
  flex: 1;
  min-width: 0;
}

.export-controller-card .controller-name {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.export-controller-card .controller-initials {
  display: block;
  font-size: 0.75rem;
  color: var(--color-ink-light);
}

.export-controller-card .departed-tag {
  font-size: 0.625rem;
  padding: 0.125rem 0.375rem;
  background: var(--color-ink-light);
  color: var(--color-paper);
  border-radius: var(--radius-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.export-loading {
  text-align: center;
  color: var(--color-ink-light);
  padding: var(--space-xl);
}

.export-date-options {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.date-option {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all 0.15s ease;
}

.date-option:hover {
  border-color: var(--color-ink-light);
}

.date-option.active {
  border-color: var(--color-rust);
  background: rgba(184, 92, 56, 0.05);
}

.date-option input[type="radio"] {
  margin: 0;
}

.export-custom-range {
  display: flex;
  gap: var(--space-lg);
  margin-bottom: var(--space-md);
  padding: var(--space-md);
  background: var(--color-parchment);
  border-radius: var(--radius-md);
}

.date-input-group {
  flex: 1;
}

.date-input-group label {
  display: block;
  font-size: 0.75rem;
  color: var(--color-ink-light);
  margin-bottom: var(--space-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.date-input-group input {
  width: 100%;
}

.export-date-preview {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-parchment);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
}

.preview-label {
  color: var(--color-ink-light);
}

.preview-dates {
  font-weight: 500;
}

.preview-days {
  color: var(--color-ink-light);
}

.export-option {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  cursor: pointer;
}

.export-option input[type="checkbox"] {
  margin-top: 0.25rem;
}

.export-option .option-label {
  display: block;
  font-weight: 500;
}

.export-option .option-description {
  display: block;
  font-size: 0.875rem;
  color: var(--color-ink-light);
  margin-top: var(--space-xs);
}

.export-actions {
  text-align: center;
  padding: var(--space-xl) 0;
}

.export-actions .btn-large {
  font-size: 1rem;
  padding: var(--space-md) var(--space-xl);
}

.export-actions .btn svg {
  margin-right: var(--space-sm);
  vertical-align: -3px;
}

.export-hint {
  margin-top: var(--space-md);
  font-size: 0.875rem;
  color: var(--color-ink-light);
}

/* ============================================
   Select Mode & Bulk Actions
   ============================================ */

/* Button active state for Select toggle */
.btn.active {
  background-color: var(--color-scheduled);
  color: white;
  border-color: var(--color-scheduled);
}

.btn.active:hover {
  background-color: #1d4ed8;
  border-color: #1d4ed8;
}

/* Controller checkbox in select mode */
.controller-checkbox {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: var(--space-md);
  flex-shrink: 0;
}

.controller-checkbox input[type="checkbox"] {
  appearance: none;
  width: 22px;
  height: 22px;
  border: 2px solid var(--color-paper-shadow);
  border-radius: 4px;
  background: var(--color-paper);
  cursor: pointer;
  transition: all 0.15s ease;
  position: relative;
}

.controller-checkbox input[type="checkbox"]:hover {
  border-color: var(--color-scheduled);
  background: #f0f7ff;
}

.controller-checkbox input[type="checkbox"]:checked {
  background: var(--color-scheduled);
  border-color: var(--color-scheduled);
}

.controller-checkbox input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  left: 6px;
  top: 2px;
  width: 6px;
  height: 12px;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

/* Card in select mode */
.licence-card.select-mode {
  cursor: pointer;
  user-select: none;
}

.licence-card.select-mode .controller-header {
  display: flex;
  align-items: flex-start;
}

.licence-card.select-mode:hover {
  border-color: var(--color-scheduled);
}

/* Selected card highlight */
.licence-card.selected {
  border-color: var(--color-scheduled);
  background: linear-gradient(135deg, #fafcff 0%, #f0f7ff 100%);
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.15), var(--shadow-paper);
}

.licence-card.selected::before {
  background: var(--color-scheduled);
}

/* Bulk Action Bar - fixed floating at bottom */
.bulk-action-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  padding: var(--space-md) var(--space-xl);
  background: rgba(28, 25, 23, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-xl);
  animation: slideUpBar 0.25s ease-out;
}

@keyframes slideUpBar {
  from {
    transform: translateY(100%);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.bulk-action-info {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.bulk-selection-count {
  font-family: var(--font-mono);
  font-size: 0.9375rem;
  font-weight: 500;
  color: white;
  padding: var(--space-xs) var(--space-md);
  background: rgba(255, 255, 255, 0.12);
  border-radius: 100px;
  letter-spacing: 0.02em;
}

.bulk-action-buttons {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

/* Bulk action bar buttons */
.bulk-action-bar .btn {
  font-size: 0.875rem;
  padding: var(--space-sm) var(--space-md);
}

.bulk-action-bar .btn-primary {
  background: var(--color-scheduled);
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.35);
}

.bulk-action-bar .btn-primary:hover:not(:disabled) {
  background: #1d4ed8;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.4);
}

.bulk-action-bar .btn-secondary {
  color: rgba(255, 255, 255, 0.85);
  border-color: rgba(255, 255, 255, 0.25);
  background: transparent;
}

.bulk-action-bar .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.4);
  color: white;
}

/* Bulk Assign Dropdown */
.bulk-assign-dropdown {
  position: relative;
}

.bulk-assign-menu {
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  margin-bottom: var(--space-sm);
  min-width: 200px;
  background: var(--color-paper);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18), 0 4px 12px rgba(0, 0, 0, 0.12);
  overflow: hidden;
  animation: dropdownFadeIn 0.15s ease-out;
}

@keyframes dropdownFadeIn {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}

.bulk-assign-option {
  display: block;
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  background: none;
  border: none;
  text-align: left;
  font-family: var(--font-body);
  font-size: 0.9375rem;
  color: var(--color-ink);
  cursor: pointer;
  transition: all 0.12s ease;
}

.bulk-assign-option:hover {
  background: linear-gradient(135deg, #f0f7ff 0%, #e8f2ff 100%);
  color: var(--color-scheduled);
}

.bulk-assign-option:not(:last-child) {
  border-bottom: 1px solid var(--color-paper-shadow);
}

/* Add bottom padding to page when bulk action bar is visible */
.app-container:has(.bulk-action-bar) {
  padding-bottom: calc(var(--space-xl) + 70px);
}

/* Responsive adjustments for bulk action bar */
@media (max-width: 640px) {
  .bulk-action-bar {
    padding: var(--space-sm) var(--space-md);
    gap: var(--space-md);
  }

  .bulk-selection-count {
    font-size: 0.8125rem;
  }

  .bulk-action-bar .btn {
    font-size: 0.8125rem;
    padding: var(--space-xs) var(--space-sm);
  }

  .bulk-assign-menu {
    min-width: 160px;
  }
}

/* ============================================
   Groups Page - Unassigned Section
   ============================================ */

.groups-list-divider {
  height: 1px;
  background: var(--color-paper-shadow);
  margin: var(--space-sm) 0;
  list-style: none;
}

.group-item-unassigned {
  border-left: 3px solid var(--color-ink-light);
  opacity: 0.85;
}

.group-item-unassigned.selected {
  border-left-color: var(--color-scheduled);
  opacity: 1;
}

.member-card.unassigned {
  border-left: 3px solid var(--color-ink-light);
}

.member-arn {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  color: var(--color-ink-light);
}

.assign-group-select {
  font-family: var(--font-body);
  font-size: 0.875rem;
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-sm);
  background: var(--color-paper);
  color: var(--color-ink);
  cursor: pointer;
  min-width: 140px;
}

.assign-group-select:hover {
  border-color: var(--color-scheduled);
}

.assign-group-select:focus {
  outline: none;
  border-color: var(--color-scheduled);
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.15);
}

/* Pending Transfer indicator */
.member-card.pending-transfer {
  border-left: 3px solid var(--color-warning);
  background: linear-gradient(135deg, #fffdf8 0%, #fef9eb 100%);
}

.member-transfer-badge {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-warning);
  background: linear-gradient(135deg, #fef3cd, #fde9a8);
  padding: 0.15rem 0.5rem;
  border-radius: 3px;
  margin-top: var(--space-xs);
}

/* Incoming transfer - teal/welcoming */
.member-transfer-badge.incoming {
  color: #0d9488;
  background: linear-gradient(135deg, #ccfbf1, #99f6e4);
}

.member-card.incoming-transfer {
  border-left: 3px solid #0d9488;
  background: linear-gradient(135deg, #f0fdfa 0%, #e6fffa 100%);
}

/* ============================================================================
   Trainee Badge & Card Styling
   ============================================================================ */

.trainee-badge {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #5b8fb9;
  background: linear-gradient(135deg, #e0f0ff, #cce5ff);
  padding: 0.15rem 0.5rem;
  border-radius: 3px;
  margin-left: var(--space-sm);
  vertical-align: middle;
}

/* Trainee cards - neutral blue styling, no urgency */
.licence-card.trainee {
  border-left-color: #5b8fb9;
}

.licence-card.trainee .category-expiries {
  opacity: 0.5;
}

.licence-card.trainee .expiry-countdown {
  color: #5b8fb9;
}

/* ============================================================================
   Leave Badge & On-Leave Card Styling
   ============================================================================ */

.leave-badge {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #6b7280; /* neutral grey */
  background: linear-gradient(135deg, #f3f4f6, #e5e7eb);
  padding: 0.15rem 0.5rem;
  border-radius: 3px;
  margin-left: var(--space-sm);
  vertical-align: middle;
  border: 1px solid #d1d5db;
}

/* On-leave cards - muted grey styling, urgency suppressed */
.licence-card.on-leave {
  border-left-color: #9ca3af;
  opacity: 0.75;
}

.licence-card.on-leave .controller-header {
  background: linear-gradient(135deg, #f9fafb, #f3f4f6);
}

.licence-card.on-leave .expiry-date {
  color: #6b7280;
}

.licence-card.on-leave .expiry-countdown {
  color: #6b7280;
}

.licence-card.on-leave .category-expiries {
  opacity: 0.5;
}

.licence-card.on-leave .scheduled-check-note {
  color: #9ca3af;
}

/* ============================================================================
   Calendar Transfer Events
   ============================================================================ */

/* Agenda view - transfer events */
.agenda-event.transfer {
  padding-left: calc(var(--space-md) + var(--space-sm));
  border-left-width: 3px;
}

.agenda-event.transfer.transfer-arrival {
  border-left-color: #0d9488; /* teal-600 */
  background: linear-gradient(135deg, rgba(13, 148, 136, 0.08), rgba(13, 148, 136, 0.02));
  color: #0d9488;
}

.agenda-event.transfer.transfer-departure {
  border-left-color: #92714e; /* warm taupe */
  background: linear-gradient(135deg, rgba(146, 113, 78, 0.08), rgba(146, 113, 78, 0.02));
  color: #92714e;
}

.transfer-marker {
  font-size: 1rem;
  font-weight: 700;
  flex-shrink: 0;
}

.transfer-label {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  opacity: 0.9;
  min-width: 70px;
}

.transfer-group-name {
  font-size: 0.85rem;
  font-style: italic;
  opacity: 0.8;
  margin-left: auto;
}

/* Month view - transfer events (compact) */
.month-event.transfer {
  font-weight: 500;
}

.month-event.transfer.transfer-arrival {
  background: color-mix(in srgb, #0d9488 15%, var(--color-paper));
  color: #0d9488;
}

.month-event.transfer.transfer-departure {
  background: color-mix(in srgb, #92714e 15%, var(--color-paper));
  color: #92714e;
}

.month-event-transfer-label {
  font-size: 0.55rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  opacity: 0.85;
}

/* ============================================================
   FACADE SHELLS — Navigation for Licensing & Roster modes
   ============================================================ */

/* Licensing Shell — Full professional interface */
.licensing-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.licensing-nav {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-sm) var(--space-lg);
  background: var(--color-paper);
  border-bottom: 1px solid var(--color-paper-shadow);
  position: sticky;
  top: 0;
  z-index: 100;
}

.licensing-nav::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: var(--space-lg);
  right: var(--space-lg);
  height: 2px;
  background: linear-gradient(
    90deg,
    var(--color-rust) 0%,
    var(--color-rust-light) 50%,
    transparent 100%
  );
  opacity: 0.4;
}

.nav-brand {
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.nav-brand .brand-text {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-ink);
  letter-spacing: -0.01em;
}

.nav-brand:hover .brand-text {
  color: var(--color-rust);
}

.nav-links {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  margin-left: auto;
}

.nav-link {
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-ink-faded);
  text-decoration: none;
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-sm);
  transition: color 0.15s ease, background 0.15s ease;
  position: relative;
}

.nav-link::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 1px;
  background: var(--color-rust);
  transition: width 0.2s ease, left 0.2s ease;
}

.nav-link:hover {
  color: var(--color-ink);
  background: rgba(184, 92, 56, 0.05);
}

.nav-link:hover::after {
  width: 60%;
  left: 20%;
}

.nav-link.active {
  color: var(--color-rust);
  font-weight: 600;
}

.nav-link.active::after {
  width: 80%;
  left: 10%;
  height: 2px;
}

.licensing-main {
  flex: 1;
}

/* Roster Shell — Lighter, calendar-focused interface */
.roster-shell {
  --roster-accent: #16a34a;
  --roster-accent-light: #22c55e;
  --roster-accent-muted: rgba(22, 163, 74, 0.1);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.roster-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: 0.6rem var(--space-lg);
  background: var(--color-paper);
  border-bottom: 1px solid var(--color-paper-shadow);
  position: sticky;
  top: 0;
  z-index: 100;
}

.roster-brand {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  text-decoration: none;
  color: var(--roster-accent);
  transition: opacity 0.15s ease;
}

.roster-brand:hover {
  opacity: 0.8;
}

.roster-brand svg {
  width: 20px;
  height: 20px;
  stroke: var(--roster-accent);
}

.roster-brand .brand-text {
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-ink);
  letter-spacing: 0.01em;
}

.roster-nav {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  margin-left: var(--space-md);
}

.roster-nav-link {
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-ink-light);
  text-decoration: none;
  padding: 0.35rem 0.65rem;
  border-radius: 100px;
  transition: all 0.15s ease;
}

.roster-nav-link:hover {
  color: var(--color-ink);
  background: var(--roster-accent-muted);
}

.roster-nav-link.active {
  color: var(--roster-accent);
  background: var(--roster-accent-muted);
  font-weight: 600;
}

.roster-group-selector {
  margin-left: auto;
}

.roster-group-selector .group-selector-trigger {
  font-size: 0.8rem;
  padding: 0.35rem 0.7rem;
  background: var(--color-paper-tint);
  border-radius: var(--radius-sm);
}

.roster-header-right {
  display: flex;
  align-items: center;
  margin-left: var(--space-md);
}

/* Hide duplicate group selector in calendar page when in roster shell */
.roster-shell .page-header .group-selector {
  display: none;
}

/* Also hide the "Back to Licences" link in roster mode */
.roster-shell .page-header .back-link {
  display: none;
}

.manage-licence-link {
  font-family: var(--font-body);
  font-size: 0.75rem;
  color: var(--color-ink-light);
  text-decoration: none;
  padding: 0.3rem 0.6rem;
  border-radius: var(--radius-sm);
  transition: color 0.15s ease, background 0.15s ease;
  opacity: 0.7;
}

.manage-licence-link:hover {
  color: var(--color-rust);
  background: rgba(184, 92, 56, 0.06);
  opacity: 1;
}

.roster-main {
  flex: 1;
}

/* ============================================================
   SHARE MODAL STYLES
   ============================================================ */

.share-modal {
  max-width: 500px;
}

.share-controller-list {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  max-height: 200px;
  overflow-y: auto;
  padding: 0.5rem;
  background: var(--color-parchment);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-paper-shadow);
}

.share-controller-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.4rem 0.6rem;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background 0.15s ease;
}

.share-controller-item:hover {
  background: rgba(44, 36, 22, 0.04);
}

.share-controller-item.selected {
  background: rgba(184, 92, 56, 0.1);
}

.share-controller-item input[type="radio"] {
  margin: 0;
  accent-color: var(--color-rust);
}

.share-controller-item .controller-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.share-controller-item .controller-name {
  font-size: 0.9rem;
  color: var(--color-ink);
}

.share-label-input {
  width: 100%;
  padding: 0.5rem 0.75rem;
  font-family: var(--font-body);
  font-size: 0.9rem;
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  background: var(--color-paper);
  color: var(--color-ink);
}

.share-label-input:focus {
  outline: none;
  border-color: var(--color-rust);
  box-shadow: 0 0 0 2px rgba(184, 92, 56, 0.1);
}

.share-label-input::placeholder {
  color: var(--color-ink-light);
}

.share-result {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.share-result-success {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 1rem;
  background: rgba(74, 124, 89, 0.1);
  border-radius: var(--radius-md);
  color: var(--color-safe);
  font-weight: 500;
}

.share-result-success svg {
  stroke: var(--color-safe);
}

.share-link-box {
  display: flex;
  gap: 0.5rem;
}

.share-link-input {
  flex: 1;
  padding: 0.6rem 0.75rem;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  border: 1px solid var(--color-paper-shadow);
  border-radius: var(--radius-md);
  background: var(--color-parchment);
  color: var(--color-ink);
}

.share-link-input:focus {
  outline: none;
  border-color: var(--color-rust);
}

.share-link-hint {
  font-size: 0.8rem;
  color: var(--color-ink-light);
  text-align: center;
}

/* ============================================================
   SHARE PAGE — Personal Roster View
   A warm, welcoming calendar for sharing with family/partners
   ============================================================ */

/* Shift category colors - stronger fills for better visibility */
.share-page {
  /* Location-specific operational colors */
  /* MK: darker shade of cyan (same family as HM) */
  --share-color-mk: #0c5d6e;
  --share-color-mk-bg: rgba(12, 93, 110, 0.20);
  /* HM: lighter cyan */
  --share-color-hm: #0891b2;
  --share-color-hm-bg: rgba(8, 145, 178, 0.18);

  /* Default operational (for OPS TBA, etc) */
  --share-color-operational: #1a6b47;
  --share-color-operational-bg: rgba(26, 107, 71, 0.18);

  /* Other categories with stronger fills */
  --share-color-leave: #c76f1e;
  --share-color-leave-bg: rgba(199, 111, 30, 0.15);
  --share-color-training: #7047a3;
  --share-color-training-bg: rgba(112, 71, 163, 0.15);
  --share-color-admin: #2563eb;
  --share-color-admin-bg: rgba(37, 99, 235, 0.12);

  /* Off days - muted with stripe pattern */
  --share-color-off: #94a3b8;
  --share-color-off-bg: rgba(148, 163, 184, 0.04);
  --share-color-off-text: #9ca3af;
  --share-off-stripe: repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 4px,
    rgba(148, 163, 184, 0.12) 4px,
    rgba(148, 163, 184, 0.12) 8px
  );

  /* Grey days */
  --share-color-grey: #6b7280;
  --share-color-grey-bg: rgba(107, 114, 128, 0.10);

  /* Other/unknown */
  --share-color-other: #78716c;
  --share-color-other-bg: rgba(120, 113, 108, 0.10);

  /* Strengthened time-off border */
  --share-time-off-border: rgba(107, 130, 95, 0.50);
}

.share-page {
  min-height: 100vh;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  overflow-x: hidden;

  /* Warm gradient background */
  background:
    linear-gradient(180deg,
      #fefdfb 0%,
      #faf7f2 30%,
      #f5f0e8 100%
    );
}

/* Subtle decorative pattern */
.share-bg-pattern {
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.4;
  background-image:
    radial-gradient(circle at 20% 20%, rgba(184, 92, 56, 0.03) 0%, transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(45, 106, 79, 0.03) 0%, transparent 50%),
    radial-gradient(circle at 60% 40%, rgba(107, 76, 154, 0.02) 0%, transparent 40%);
}

/* Loading state */
.share-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  padding: 4rem 2rem;
  animation: shareFadeIn 0.5s ease-out;
}

.share-loading-icon {
  color: var(--color-rust);
  animation: sharePulse 1.5s ease-in-out infinite;
}

.share-loading p {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--color-ink-faded);
}

/* Error state */
.share-error {
  max-width: 400px;
  margin: 4rem auto;
  padding: 2.5rem;
  text-align: center;
  background: white;
  border-radius: 16px;
  box-shadow:
    0 4px 20px rgba(44, 36, 22, 0.06),
    0 0 0 1px rgba(44, 36, 22, 0.04);
  animation: shareFadeIn 0.4s ease-out;
}

.share-error-icon {
  color: var(--color-rust);
  margin-bottom: 1rem;
}

.share-error h1 {
  font-family: var(--font-display);
  font-size: 1.4rem;
  color: var(--color-ink);
  margin-bottom: 0.5rem;
}

.share-error p {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--color-ink-faded);
  line-height: 1.5;
}

/* Header */
.share-header {
  text-align: center;
  padding: 3rem 1.5rem 2rem;
  max-width: 600px;
  width: 100%;
  position: relative;
  animation: shareSlideDown 0.6s ease-out;
}

.share-header-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, var(--color-rust) 0%, #a04e30 100%);
  border-radius: 12px;
  color: white;
  margin-bottom: 1.25rem;
  box-shadow:
    0 4px 12px rgba(184, 92, 56, 0.25),
    0 0 0 4px rgba(184, 92, 56, 0.08);
}

.share-greeting {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--color-ink-light);
  margin-bottom: 0.25rem;
  letter-spacing: 0.02em;
}

.share-name {
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--color-ink);
  line-height: 1.1;
  margin-bottom: 0.25rem;
  letter-spacing: -0.02em;
}

.share-subtitle {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--color-ink-light);
  margin-bottom: 1rem;
  letter-spacing: 0.02em;
}

.share-label {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-rust);
  background: rgba(184, 92, 56, 0.1);
  padding: 0.35rem 0.85rem;
  border-radius: 100px;
  margin-bottom: 0.75rem;
}

.share-date-range {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--color-ink-faded);
  font-weight: 500;
}

/* Mini Calendar */
.share-mini-calendar {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem;
  padding: 0 1rem 1.5rem;
  max-width: 700px;
  width: 100%;
  animation: shareFadeIn 0.5s ease-out 0.2s backwards;
}

.share-mini-month {
  background: white;
  border-radius: 12px;
  padding: 0.75rem;
  box-shadow:
    0 2px 8px rgba(44, 36, 22, 0.04),
    0 0 0 1px rgba(44, 36, 22, 0.04);
  min-width: 200px;
}

.share-mini-month-label {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-ink);
  text-align: center;
  padding-bottom: 0.5rem;
  margin-bottom: 0.25rem;
  border-bottom: 1px solid rgba(44, 36, 22, 0.06);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.share-mini-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}

.share-mini-header {
  font-family: var(--font-body);
  font-size: 0.6rem;
  font-weight: 600;
  color: var(--color-ink-light);
  text-align: center;
  padding: 0.25rem 0;
}

.share-mini-cell {
  position: relative;
  aspect-ratio: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: background 0.15s ease;
}

.share-mini-cell.out-range {
  opacity: 0.3;
}

.share-mini-cell.in-range {
  background: rgba(44, 36, 22, 0.02);
}

.share-mini-cell.is-today {
  background: var(--color-rust) !important;
}

.share-mini-cell.is-today .share-mini-day {
  color: white;
  font-weight: 600;
}

.share-mini-day {
  font-family: var(--font-body);
  font-size: 0.65rem;
  color: var(--color-ink);
}

.share-mini-dot {
  position: absolute;
  bottom: 2px;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--color-ink-light);
}

/* Mini calendar category colors */
.share-mini-cell[data-category="operational"] .share-mini-dot { background: var(--share-color-operational); }
.share-mini-cell[data-category="leave"] .share-mini-dot { background: var(--share-color-leave); }
.share-mini-cell[data-category="training"] .share-mini-dot { background: var(--share-color-training); }
.share-mini-cell[data-category="admin"] .share-mini-dot { background: var(--share-color-admin); }
.share-mini-cell[data-category="off"] .share-mini-dot { background: var(--share-color-off); }
.share-mini-cell[data-category="grey"] .share-mini-dot { background: var(--share-color-grey); }

/* Legend */
.share-legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  animation: shareFadeIn 0.5s ease-out 0.3s backwards;
}

.share-legend-item {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-body);
  font-size: 0.75rem;
  color: var(--color-ink-faded);
}

.share-legend-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-ink-light);
}

.share-legend-item[data-category="operational"] .share-legend-dot { background: var(--share-color-operational); }
.share-legend-item[data-category="leave"] .share-legend-dot { background: var(--share-color-leave); }
.share-legend-item[data-category="training"] .share-legend-dot { background: var(--share-color-training); }
.share-legend-item[data-category="admin"] .share-legend-dot { background: var(--share-color-admin); }
.share-legend-item[data-category="off"] .share-legend-dot { background: var(--share-color-off); }

/* Roster container - Week Grid Layout */
.share-roster {
  max-width: 800px;
  width: 100%;
  padding: 0 1rem 2rem;
  display: flex;
  flex-direction: column;
}

/* Grid header (day names) */
.share-grid-header {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  background: white;
  border-radius: 12px 12px 0 0;
  border: 1px solid rgba(44, 36, 22, 0.08);
  border-bottom: none;
  overflow: hidden;
}

.share-grid-header-cell {
  padding: 0.6rem 0.25rem;
  text-align: center;
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--color-ink);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background: linear-gradient(180deg, rgba(44, 36, 22, 0.02) 0%, transparent 100%);
  border-right: 1px solid rgba(44, 36, 22, 0.04);
}

.share-grid-header-cell:last-child {
  border-right: none;
}

.share-grid-header-cell.is-weekend {
  background: linear-gradient(180deg, rgba(44, 36, 22, 0.04) 0%, rgba(44, 36, 22, 0.02) 100%);
  color: var(--color-ink-faded);
}

/* Week rows */
.share-week-row {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  background: white;
  border: 1px solid rgba(44, 36, 22, 0.08);
  border-top: none;
  animation: shareWeekReveal 0.4s ease-out backwards;
}

/* Month alternation for visual separation (cell-based) */
/* Even months (Feb, Apr, Jun...): sage green tint */
.share-cell.month-even {
  background: rgba(85, 130, 95, 0.10);
}

.share-cell.month-even.is-weekend {
  background: rgba(85, 130, 95, 0.14);
}

/* Odd months (Jan, Mar, May...): slate blue tint */
.share-cell.month-odd {
  background: rgba(85, 105, 140, 0.10);
}

.share-cell.month-odd.is-weekend {
  background: rgba(85, 105, 140, 0.14);
}

/* OFF/Leave days - plain white background for clear contrast */
.share-cell.is-time-off,
.share-cell.is-time-off.month-even,
.share-cell.is-time-off.month-odd,
.share-cell.is-time-off.is-weekend {
  background: white;
}

/* GREY days - white background like time-off, but keep the shift card styled */
.share-cell[data-category="grey"],
.share-cell[data-category="grey"].month-even,
.share-cell[data-category="grey"].month-odd,
.share-cell[data-category="grey"].is-weekend {
  background: white;
}

/* Muted text for off days */
.share-cell.is-time-off .share-cell-off {
  color: #8a9199;
  font-style: italic;
  font-size: 0.75rem;
}

/* Subtle border around time-off blocks (only on outside edges) */
.share-cell.is-time-off {
  --time-off-border: var(--share-time-off-border);
}

.share-cell.is-time-off.border-left {
  border-left: 1.5px solid var(--time-off-border);
}

.share-cell.is-time-off.border-right {
  border-right: 1.5px solid var(--time-off-border);
}

.share-cell.is-time-off.border-top {
  border-top: 1.5px solid var(--time-off-border);
}

.share-cell.is-time-off.border-bottom {
  border-bottom: 1.5px solid var(--time-off-border);
}

.share-week-row:last-of-type {
  border-radius: 0 0 12px 12px;
}

/* Day cells */
.share-cell {
  min-height: 80px;
  padding: 0.4rem;
  border-right: 1px solid rgba(44, 36, 22, 0.04);
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  position: relative;
  transition: background 0.15s ease;
}

.share-cell:last-child {
  border-right: none;
}

.share-cell.is-weekend {
  background: rgba(44, 36, 22, 0.015);
}

.share-cell.is-today {
  background: rgba(184, 92, 56, 0.08);
  box-shadow: inset 0 0 0 2px var(--color-rust);
}

.share-cell.is-empty {
  background: rgba(44, 36, 22, 0.01);
}

.share-cell-empty {
  background: repeating-linear-gradient(
    45deg,
    transparent,
    transparent 4px,
    rgba(44, 36, 22, 0.015) 4px,
    rgba(44, 36, 22, 0.015) 8px
  );
}

/* Cell date */
.share-cell-date {
  display: flex;
  align-items: center;
  gap: 0.3rem;
}

.share-cell-day {
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-ink);
  line-height: 1;
}

.share-cell.is-today .share-cell-day {
  color: var(--color-rust);
}

.share-cell-month {
  font-family: var(--font-body);
  font-size: 0.55rem;
  font-weight: 700;
  color: white;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  background: var(--color-rust);
  padding: 2px 5px;
  border-radius: 3px;
  margin-left: 4px;
}

.share-cell-today {
  font-family: var(--font-body);
  font-size: 0.55rem;
  font-weight: 700;
  color: white;
  background: var(--color-rust);
  padding: 0.1rem 0.3rem;
  border-radius: 3px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

/* Cell events */
.share-cell-events {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.share-cell-event {
  display: flex;
  flex-direction: column;
  padding: 0.25rem 0.35rem;
  border-radius: 4px;
  border-left: 4px solid var(--color-ink-light);
  background: rgba(44, 36, 22, 0.03);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

/* Cell event category colors */
.share-cell-event[data-category="operational"] {
  border-left-color: var(--share-color-operational);
  background: var(--share-color-operational-bg);
}

/* Location-specific operational colors */
.share-cell-event[data-location="MK"] {
  border-left-color: var(--share-color-mk);
  background: var(--share-color-mk-bg);
}
.share-cell-event[data-location="HM"] {
  border-left-color: var(--share-color-hm);
  background: var(--share-color-hm-bg);
}

.share-cell-event[data-category="leave"] {
  border-left-color: var(--share-color-leave);
  background: var(--share-color-leave-bg);
}
.share-cell-event[data-category="training"] {
  border-left-color: var(--share-color-training);
  background: var(--share-color-training-bg);
}
.share-cell-event[data-category="admin"] {
  border-left-color: var(--share-color-admin);
  background: var(--share-color-admin-bg);
}
.share-cell-event[data-category="off"] {
  border-left-color: var(--share-color-off);
  background: var(--share-color-off-bg);
}
.share-cell-event[data-category="grey"] {
  border-left-color: var(--share-color-grey);
  background: var(--share-color-grey-bg);
}

.share-cell-shift {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-ink);
  line-height: 1.2;
}

.share-cell-time {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  color: var(--color-ink-faded);
  white-space: nowrap;
}

.share-cell-off {
  font-family: var(--font-body);
  font-size: 0.7rem;
  color: var(--color-ink-light);
  font-style: italic;
  padding-top: 0.2rem;
}

/* Empty state */
.share-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  padding: 3rem 2rem;
  text-align: center;
  color: var(--color-ink-light);
}

.share-empty svg {
  opacity: 0.4;
}

.share-empty p {
  font-family: var(--font-body);
  font-size: 0.95rem;
}

/* Footer */
.share-footer {
  padding: 2rem 1rem 3rem;
  text-align: center;
  max-width: 600px;
  width: 100%;
}

.share-footer p {
  font-family: var(--font-body);
  font-size: 0.8rem;
  color: var(--color-ink-light);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
}

.share-footer-heart {
  color: #e57373;
  font-size: 0.9rem;
}

.share-footer-actions {
  margin-top: 1rem;
}

.share-subscribe-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 1.2rem;
  background: var(--share-color-operational);
  color: white;
  border-radius: 6px;
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  text-decoration: none;
  transition: background 0.15s ease, transform 0.1s ease;
}

.share-subscribe-btn:hover {
  background: var(--share-color-mk);
  transform: translateY(-1px);
}

.share-subscribe-btn svg {
  width: 18px;
  height: 18px;
}

/* Animations */
@keyframes shareFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes shareSlideDown {
  from {
    opacity: 0;
    transform: translateY(-15px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes shareDayReveal {
  from {
    opacity: 0;
    transform: translateX(-8px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes sharePulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.05); opacity: 0.8; }
}

@keyframes shareWeekReveal {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Mobile responsive - tablet */
@media (max-width: 768px) {
  .share-cell {
    min-height: 70px;
    padding: 0.3rem;
  }

  .share-cell-day {
    font-size: 0.85rem;
  }

  .share-cell-shift {
    font-size: 0.7rem;
  }

  .share-cell-time {
    font-size: 0.55rem;
  }

  .share-grid-header-cell {
    font-size: 0.6rem;
    padding: 0.5rem 0.15rem;
  }
}

/* Mobile responsive - phone */
@media (max-width: 480px) {
  .share-header {
    padding: 2rem 1rem 1.5rem;
  }

  .share-name {
    font-size: 2rem;
  }

  .share-mini-calendar {
    gap: 1rem;
  }

  .share-mini-month {
    min-width: calc(50% - 0.5rem);
  }

  .share-legend {
    gap: 0.75rem;
    flex-wrap: wrap;
    justify-content: center;
  }

  .share-legend-item {
    font-size: 0.7rem;
  }

  .share-roster {
    padding: 0 0.5rem 2rem;
  }

  .share-cell {
    min-height: 60px;
    padding: 0.2rem;
  }

  .share-cell-day {
    font-size: 0.75rem;
  }

  .share-cell-today {
    font-size: 0.45rem;
    padding: 0.08rem 0.2rem;
  }

  .share-cell-shift {
    font-size: 0.6rem;
  }

  .share-cell-time {
    display: none; /* Hide times on very small screens */
  }

  .share-cell-off {
    font-size: 0.55rem;
  }

  .share-grid-header-cell {
    font-size: 0.5rem;
    padding: 0.4rem 0.1rem;
  }

  .share-cell-event {
    padding: 0.15rem 0.25rem;
    border-left-width: 2px;
  }
}

/* Share page print styles */
@media print {
  .share-page {
    background: white !important;
    padding: 0;
  }

  .share-bg-pattern {
    display: none;
  }

  .share-header {
    padding: 0.5rem 1rem;
    border-bottom: 1px solid #ddd;
  }

  .share-header-icon {
    display: none;
  }

  .share-mini-calendar {
    display: none;
  }

  .share-legend {
    padding: 0.5rem 1rem;
    print-color-adjust: exact;
    -webkit-print-color-adjust: exact;
  }

  .share-roster {
    padding: 0 0.5rem;
  }

  .share-week-row {
    animation: none;
    border: 1px solid #ccc;
    break-inside: avoid;
  }

  .share-grid-header {
    border: 1px solid #ccc;
    print-color-adjust: exact;
    -webkit-print-color-adjust: exact;
  }

  .share-cell {
    border: 1px solid #e0e0e0;
    min-height: 50px;
    print-color-adjust: exact;
    -webkit-print-color-adjust: exact;
  }

  .share-cell.is-today {
    box-shadow: inset 0 0 0 2px #b85c38;
  }

  .share-cell-event {
    print-color-adjust: exact;
    -webkit-print-color-adjust: exact;
  }

  .share-footer {
    display: none;
  }
}

/* ============================================================
   CALENDAR PRINT STYLES — Professional roster printout
   ============================================================ */

@media print {
  /* Page setup */
  @page {
    margin: 1cm;
    size: A4;
  }

  /* Reset backgrounds and colors */
  body,
  html,
  .licensing-shell,
  .roster-shell,
  .calendar-page,
  .app-container {
    background: white !important;
    color: black !important;
  }

  /* Hide non-essential UI elements */
  .licensing-nav,
  .roster-header,
  .licensing-shell > nav,
  .calendar-toolbar,
  .calendar-data-toggles,
  .calendar-controller-filter,
  .calendar-view-controls,
  .calendar-toolbar-right,
  .page-header .back-link,
  .page-header .group-selector,
  .roster-group-selector,
  .btn,
  button,
  .view-toggle,
  .week-length-selector,
  .filter-actions,
  .controller-chips,
  .toggle-pill,
  .toggle-group,
  .licence-popup,
  .modal-overlay,
  .export-modal,
  .no-print {
    display: none !important;
  }

  /* Full width content */
  .calendar-page {
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .app-container {
    max-width: 100% !important;
    padding: 0 !important;
  }

  /* Simplified header - show title and date range */
  .page-header {
    text-align: center;
    padding: 0 0 0.4cm 0 !important;
    margin-bottom: 0.4cm !important;
    border-bottom: 2pt solid #333 !important;
    display: block !important;
  }

  .page-header h1,
  .page-title {
    font-size: 16pt !important;
    font-weight: 700 !important;
    margin: 0 !important;
    color: black !important;
  }

  /* Show date range prominently - needs to be visible in print header */
  .calendar-nav {
    display: block !important;
    text-align: center;
    margin-top: 0.2cm;
  }

  .calendar-nav .btn,
  .calendar-nav button {
    display: none !important;
  }

  .calendar-range {
    font-size: 12pt !important;
    color: #333 !important;
    display: block !important;
    font-weight: 500;
  }

  /* ============================================
     AGENDA VIEW PRINT STYLES
     ============================================ */

  .agenda-view {
    display: block !important;
  }

  .agenda-day {
    break-inside: avoid;
    page-break-inside: avoid;
    margin-bottom: 0.25cm;
    border: 1pt solid #999;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: white !important;
  }

  .agenda-day.is-today {
    border: 2pt solid #333 !important;
  }

  .agenda-day-header {
    background: #f0f0f0 !important;
    padding: 0.12cm 0.25cm !important;
    border-bottom: 1pt solid #ccc;
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center;
    gap: 0.3cm;
  }

  /* Actual class names from calendar.tsx */
  .agenda-day-header .day-name {
    font-size: 10pt !important;
    font-weight: 700 !important;
    color: black !important;
    text-transform: uppercase;
    letter-spacing: 0.5pt;
  }

  .agenda-day-header .day-date {
    font-size: 10pt !important;
    color: #444 !important;
  }

  .agenda-day-header .today-badge {
    font-size: 8pt !important;
    background: #333 !important;
    color: white !important;
    padding: 0.05cm 0.15cm;
    border-radius: 2pt;
    text-transform: uppercase;
    font-weight: 600;
  }

  .agenda-day-events {
    padding: 0.1cm 0.2cm !important;
  }

  .agenda-empty {
    font-size: 9pt !important;
    color: #888 !important;
    font-style: italic;
    padding: 0.1cm 0;
  }

  /* Roster events in agenda */
  .agenda-event {
    padding: 0.08cm 0 !important;
    border-bottom: 1pt dotted #ddd;
    display: flex !important;
    align-items: center;
    gap: 0.2cm;
    background: transparent !important;
    border-left: none !important;
    border-radius: 0 !important;
    margin: 0 !important;
    font-size: 9pt !important;
  }

  .agenda-event:last-child {
    border-bottom: none;
  }

  /* Controller dot - make it visible in print */
  .agenda-event .event-controller-dot {
    width: 6pt !important;
    height: 6pt !important;
    border-radius: 50%;
    flex-shrink: 0;
    print-color-adjust: exact;
    -webkit-print-color-adjust: exact;
  }

  .agenda-event .event-controller-name {
    font-size: 9pt !important;
    color: #333 !important;
    min-width: 3.5cm;
    font-weight: 500;
  }

  .agenda-event .event-shift-type {
    font-size: 9pt !important;
    font-weight: 600 !important;
    color: black !important;
    flex: 1;
  }

  .agenda-event .event-shift-comments {
    font-weight: 400 !important;
    color: #555 !important;
  }

  .agenda-event .event-time {
    font-size: 8pt !important;
    font-family: monospace !important;
    color: #444 !important;
    background: #f5f5f5 !important;
    padding: 0.02cm 0.1cm !important;
    border: 1pt solid #ddd;
  }

  /* Transfer events */
  .agenda-event.transfer {
    background: #f8f8f8 !important;
    padding: 0.1cm !important;
    border: 1pt dashed #999 !important;
    border-bottom: 1pt dashed #999 !important;
  }

  .agenda-event .transfer-marker {
    font-weight: 700;
    color: #333 !important;
  }

  .agenda-event .transfer-label {
    font-size: 8pt !important;
    text-transform: uppercase;
    font-weight: 600;
    color: #555 !important;
  }

  /* Expiry events in print */
  .agenda-event.expiry {
    background: #fafafa !important;
    border-left: 3pt solid #666 !important;
    padding-left: 0.15cm !important;
  }

  .agenda-event.expiry.urgency-urgent,
  .agenda-event.expiry.urgency-expired {
    border-left-color: #333 !important;
    background: #f5f5f5 !important;
  }

  .agenda-event .expiry-marker {
    color: #333 !important;
  }

  .agenda-event .expiry-label {
    font-size: 7pt !important;
    text-transform: uppercase;
    font-weight: 700;
    color: #555 !important;
    background: #e8e8e8 !important;
    padding: 0.02cm 0.1cm;
  }

  .agenda-event .expiry-item-name {
    font-weight: 600;
    color: black !important;
  }

  .agenda-event .expiry-type-label {
    font-size: 8pt !important;
    color: #666 !important;
  }

  .agenda-event .expiry-days {
    font-size: 8pt !important;
    color: #444 !important;
    font-weight: 500;
  }

  /* ============================================
     MONTH VIEW PRINT STYLES
     ============================================ */

  .month-view-container {
    display: block !important;
  }

  .month-block {
    break-inside: avoid;
    page-break-inside: avoid;
    margin-bottom: 0.5cm;
  }

  .month-block-header {
    text-align: center;
    padding: 0.15cm 0;
    border-bottom: 1pt solid #ccc;
    margin-bottom: 0.2cm;
  }

  .month-block-header .month-label {
    font-size: 12pt !important;
    font-weight: 700 !important;
    color: black !important;
  }

  .month-view {
    border: 1pt solid #333;
  }

  .month-header {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    background: #e8e8e8 !important;
    border-bottom: 1pt solid #333;
  }

  .month-header-cell {
    padding: 0.1cm !important;
    text-align: center;
    font-size: 8pt !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.5pt;
    color: black !important;
    border-right: 1pt solid #ccc;
  }

  .month-header-cell:last-child {
    border-right: none;
  }

  .month-grid {
    display: block !important;
  }

  .month-week {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    border-bottom: 1pt solid #ccc;
  }

  .month-week:last-child {
    border-bottom: none;
  }

  .month-cell {
    min-height: 1.8cm !important;
    border-right: 1pt solid #ccc;
    padding: 0.08cm !important;
    background: white !important;
    break-inside: avoid;
    page-break-inside: avoid;
    border-radius: 0 !important;
    box-shadow: none !important;
  }

  .month-cell:last-child {
    border-right: none;
  }

  .month-cell.empty {
    background: #fafafa !important;
  }

  .month-cell.is-today {
    background: white !important;
    outline: 2pt solid #333 !important;
    outline-offset: -2pt;
  }

  .month-cell-date {
    font-size: 9pt !important;
    font-weight: 700 !important;
    color: black !important;
    margin-bottom: 0.05cm;
  }

  .month-cell-events {
    display: flex;
    flex-direction: column;
    gap: 0.03cm;
  }

  .month-cell-more {
    font-size: 7pt !important;
    color: #666 !important;
    font-style: italic;
  }

  /* Month event items */
  .month-event {
    font-size: 6.5pt !important;
    padding: 0.03cm 0.06cm !important;
    background: #f0f0f0 !important;
    color: black !important;
    border-radius: 0 !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    border-left: 2pt solid #888;
    display: flex !important;
    align-items: center;
    gap: 0.05cm;
  }

  .month-event .month-event-dot {
    width: 4pt !important;
    height: 4pt !important;
    border-radius: 50%;
    flex-shrink: 0;
    print-color-adjust: exact;
    -webkit-print-color-adjust: exact;
  }

  .month-event .month-event-initials {
    font-weight: 600;
    font-size: 6pt !important;
  }

  .month-event .month-event-shift {
    font-weight: 400;
    font-size: 6pt !important;
  }

  /* Expiry events in month view */
  .month-event.expiry {
    border-left-color: #555 !important;
    background: #f5f5f5 !important;
  }

  .month-event.expiry.urgency-urgent,
  .month-event.expiry.urgency-expired {
    border-left-color: #333 !important;
    background: #eee !important;
  }

  .month-event .month-event-marker {
    font-size: 5pt !important;
    color: #333 !important;
  }

  .month-event .month-event-cat {
    font-size: 5pt !important;
    font-weight: 600;
  }

  /* Transfer events in month */
  .month-event.transfer {
    border-left-style: dashed !important;
    border-left-color: #666 !important;
  }

  /* ============================================
     PRINT UTILITIES
     ============================================ */

  /* Force page break before specific elements if needed */
  .print-page-break {
    page-break-before: always;
    break-before: page;
  }

  /* Ensure links don't show URLs */
  a {
    text-decoration: none !important;
    color: inherit !important;
  }

  a[href]::after {
    content: none !important;
  }

  /* Remove all animations */
  * {
    animation: none !important;
    transition: none !important;
  }

  /* Preserve colors for controller dots where possible */
  .event-controller-dot,
  .month-event-dot,
  .controller-dot {
    print-color-adjust: exact !important;
    -webkit-print-color-adjust: exact !important;
  }
}
