:root {
  --tsc-primary: #b30000;
  --tsc-dark: #3b3b3b;
  --tsc-gold: #c8a300;
  --app-bg: #f2f4f7;
  --app-surface: #ffffff;
  --app-border: #d9dee7;
  --app-text: #152033;
  --app-muted: #5f6c7b;
  --app-accent: var(--tsc-primary);
  --app-accent-dark: #8d0000;
  --app-soft: #f7f3f3;
}

body {
  font-family: "Montserrat", sans-serif;
  color: var(--app-text);
}

.portal-body,
.app-body,
.login-body {
  background:
    radial-gradient(circle at top right, rgba(31, 75, 122, 0.08), transparent 25%),
    linear-gradient(180deg, #f7f8fb 0%, var(--app-bg) 100%);
  min-height: 100vh;
}

.app-nav {
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(10px);
}

.navbar-brand img.logo {
  height: 36px;
  margin-right: 8px;
}

.login-brand {
  gap: 0.75rem;
}

.login-brand img.logo {
  height: clamp(44px, 8vw, 64px);
  width: auto;
  max-width: 100%;
  flex: 0 0 auto;
}

.login-brand .brand-name {
  min-width: 0;
  line-height: 1.3;
  word-break: break-word;
}

.navbar-brand,
.nav-link,
.section-title,
.shift-title {
  color: var(--app-text);
}

.nav-link.active,
.nav-link:hover {
  color: var(--app-accent);
}

.hero-card,
.content-card {
  background: var(--app-surface);
  border: 1px solid var(--app-border);
  border-radius: 1.25rem;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.06);
  padding: 1.5rem;
}

.hero-card {
  background:
    linear-gradient(135deg, rgba(179, 0, 0, 0.06), rgba(255, 255, 255, 0.95)),
    var(--app-surface);
}

.hero-panel {
  background: var(--app-soft);
  border: 1px solid rgba(179, 0, 0, 0.12);
  border-radius: 1rem;
  padding: 1.25rem;
}

.eyebrow {
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.75rem;
  color: var(--app-accent);
  margin-bottom: 0.75rem;
}

.display-title {
  font-size: clamp(2rem, 5vw, 3.25rem);
  line-height: 1;
  font-weight: 700;
  margin-bottom: 0.75rem;
}

.lead-text {
  color: var(--app-muted);
  line-height: 1.65;
}

.meta-label {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--app-muted);
}

.meta-value {
  font-size: 3rem;
  line-height: 1;
  font-weight: 700;
  margin: 0.35rem 0;
  color: var(--app-accent-dark);
}

.meta-note {
  color: var(--app-muted);
}

.section-title {
  font-size: 1.2rem;
  font-weight: 700;
}

.shift-card {
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfe 100%);
  border: 1px solid var(--app-border);
  border-radius: 1rem;
  padding: 1.1rem;
}

.shift-title {
  font-size: 1.05rem;
  font-weight: 700;
  margin: 0;
}

.shift-meta {
  color: var(--app-muted);
  font-size: 0.92rem;
}

.shift-details {
  color: var(--app-muted);
  line-height: 1.6;
  font-size: 0.95rem;
}

.btn-primary {
  background: var(--app-accent);
  border-color: var(--app-accent);
}

.btn-primary:hover,
.btn-primary:focus {
  background: var(--app-accent-dark);
  border-color: var(--app-accent-dark);
}

a {
  color: var(--tsc-primary);
}

.signup-table tbody tr.group-row td {
  background: var(--app-soft) !important;
  border-top: 2px solid var(--app-border);
  border-bottom: 1px solid var(--app-border);
}

.table > :not(caption) > * > * {
  box-shadow: none;
}

@media (max-width: 991.98px) {
  .hero-card,
  .content-card {
    padding: 1.15rem;
  }
}
