@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Space+Grotesk:wght@400;500;700&display=swap');

:root {
  --brand-primary: #1e1e1e;
  --brand-secondary: #e1c77a;
  --brand-accent: #c9a24d;
  --brand-light: #f5f5f5;
  --brand-primary-contrast: #ffffff;
}

body {
  font-family: "Space Grotesk", sans-serif;
  background: var(--brand-light);
  color: #222;
}

.sidebar {
  min-height: 100vh;
  background: var(--brand-primary);
  overflow: hidden;
}

.sidebar .nav-link,
.sidebar .navbar-brand {
  color: var(--brand-light) !important;
}

.sidebar .nav-link {
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
  line-height: 1.25;
  border-radius: 0.5rem;
  padding: 0.55rem 0.75rem;
}

.sidebar .nav-link.active,
.sidebar .nav-link:hover {
  background: color-mix(in srgb, var(--brand-secondary) 26%, transparent);
  color: var(--brand-primary-contrast);
}

.main-content {
  min-height: 100vh;
}

.badge-soft {
  background: color-mix(in srgb, var(--brand-secondary) 20%, white);
  color: var(--brand-primary);
}

.table td,
.table th {
  vertical-align: middle;
}

.mobile-topbar {
  background: var(--brand-primary);
}

.brand-logo {
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
}

.brand-logo-sidebar {
  width: 100%;
  height: auto;
  max-width: none;
}

.brand-logo-mobile {
  width: 100%;
  height: auto;
  max-width: none;
}

.brand-logo-offcanvas {
  width: 100%;
  height: auto;
  max-width: none;
}

.offcanvas-nav .nav-link {
  color: var(--brand-primary) !important;
  border-radius: 0.375rem;
  padding: 0.5rem 0.75rem;
}

.offcanvas-nav .nav-link:hover {
  background: color-mix(in srgb, var(--brand-secondary) 20%, white);
}

@media (max-width: 767.98px) {
  .main-content {
    padding-top: 1rem !important;
  }

  .table {
    font-size: 0.92rem;
  }
}

.feed-card .card-body {
  background: #fff;
}

.feed-image {
  width: 100%;
  max-height: 420px;
  object-fit: cover;
  border: 1px solid color-mix(in srgb, var(--brand-primary) 12%, white);
}

.feed-comment {
  background: var(--brand-light);
  border: 1px solid color-mix(in srgb, var(--brand-primary) 12%, white);
  border-radius: 0.375rem;
  padding: 0.35rem 0.5rem;
  margin-bottom: 0.35rem;
}

.street-hero {
  position: relative;
  overflow: hidden;
  border-radius: 1rem;
  background: linear-gradient(135deg, var(--brand-primary) 0%, color-mix(in srgb, var(--brand-primary) 70%, black) 45%, color-mix(in srgb, var(--brand-accent) 55%, black) 100%);
  color: #fff;
}

.street-grid {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 20px 20px;
  opacity: .35;
}

.street-stripe {
  position: absolute;
  height: 180px;
  width: 180px;
  border-radius: 999px;
  filter: blur(2px);
}

.street-stripe-a {
  top: -40px;
  right: 8%;
  background: radial-gradient(circle at 30% 30%, var(--brand-secondary), transparent 70%);
}

.street-stripe-b {
  bottom: -30px;
  left: 10%;
  background: radial-gradient(circle at 30% 30%, var(--brand-accent), transparent 70%);
}

.street-kicker {
  font-size: .78rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--brand-secondary);
}

.street-title {
  font-family: "Bebas Neue", sans-serif;
  letter-spacing: .03em;
  font-size: clamp(2.2rem, 7vw, 5rem);
  line-height: .95;
}

.street-title span {
  color: var(--brand-secondary);
}

.street-sub {
  max-width: 58ch;
  color: #d9e0e7;
}

.street-card {
  background: rgba(255,255,255,.92);
  color: #111;
  border: 2px solid var(--brand-secondary);
  border-radius: .9rem;
  padding: 1rem;
  box-shadow: 8px 8px 0 rgba(0,0,0,.28);
}

.street-meta li {
  padding: .2rem 0;
  border-bottom: 1px dashed #ddd;
}

.street-meta li:last-child {
  border-bottom: none;
}

.street-pill {
  display: inline-block;
  background: var(--brand-primary);
  color: var(--brand-secondary);
  padding: .35rem .65rem;
  border-radius: 999px;
  font-size: .8rem;
}

.street-panel {
  background: #fff;
  border-radius: .9rem;
  border: 1px solid color-mix(in srgb, var(--brand-primary) 16%, white);
  box-shadow: 0 16px 35px rgba(8, 15, 32, 0.08);
  padding: 1rem;
}

.street-panel-tag {
  font-size: .72rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--brand-primary) 54%, white);
  margin-bottom: .3rem;
}

.street-list {
  margin: 0 0 1rem 1rem;
}

.street-list li {
  margin-bottom: .35rem;
}

.street-banner {
  background: repeating-linear-gradient(-45deg, color-mix(in srgb, var(--brand-secondary) 88%, white), color-mix(in srgb, var(--brand-secondary) 88%, white) 12px, var(--brand-secondary) 12px, var(--brand-secondary) 24px);
  border: 2px solid var(--brand-primary);
  border-radius: .9rem;
  padding: 1rem;
  color: #111;
  box-shadow: 8px 8px 0 rgba(0,0,0,.14);
}

.shift-card {
  border: 1px solid color-mix(in srgb, var(--brand-primary) 14%, white);
  box-shadow: 0 10px 26px rgba(8, 15, 32, 0.06);
}

.shift-progress {
  height: 1.1rem;
}

.shift-volunteer-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: .6rem;
}

.shift-volunteer-item {
  display: flex;
  gap: .55rem;
  align-items: flex-start;
  padding: .55rem .65rem;
  border: 1px solid color-mix(in srgb, var(--brand-primary) 14%, white);
  border-radius: .5rem;
  background: #fff;
}

.shift-volunteer-item .form-check-input {
  margin-top: .25rem;
}

#shifts-calendar,
#my-shifts-calendar {
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--brand-primary) 14%, white);
  border-radius: .75rem;
  padding: .5rem;
}

.fc .fc-toolbar-title {
  font-size: 1.02rem;
  font-weight: 700;
}

.fc .fc-button-primary {
  background: var(--brand-primary);
  border-color: var(--brand-primary);
}

.fc .fc-button-primary:hover,
.fc .fc-button-primary:focus {
  background: color-mix(in srgb, var(--brand-primary) 86%, black);
  border-color: color-mix(in srgb, var(--brand-primary) 86%, black);
}

.fc .fc-timegrid-event {
  border-radius: .5rem;
  border: none;
  padding: 1px 2px;
}

.fc .fc-daygrid-event {
  border-radius: .45rem;
  border: none;
}

.my-shift-card {
  border: 2px solid var(--brand-accent);
}

.fc .my-shift-event {
  box-shadow: 0 0 0 2px var(--brand-accent) inset;
  font-weight: 700;
}

.btn-primary {
  --bs-btn-bg: var(--brand-primary);
  --bs-btn-border-color: var(--brand-primary);
  --bs-btn-color: #ffffff;
  --bs-btn-hover-bg: color-mix(in srgb, var(--brand-primary) 86%, black);
  --bs-btn-hover-border-color: color-mix(in srgb, var(--brand-primary) 86%, black);
  --bs-btn-hover-color: #ffffff;
  --bs-btn-active-bg: color-mix(in srgb, var(--brand-primary) 80%, black);
  --bs-btn-active-border-color: color-mix(in srgb, var(--brand-primary) 80%, black);
  --bs-btn-active-color: #ffffff;
}

.btn-outline-primary {
  --bs-btn-color: var(--brand-primary);
  --bs-btn-border-color: var(--brand-primary);
  --bs-btn-hover-bg: var(--brand-primary);
  --bs-btn-hover-border-color: var(--brand-primary);
  --bs-btn-active-bg: var(--brand-primary);
  --bs-btn-active-border-color: var(--brand-primary);
}

.text-primary {
  color: var(--brand-primary) !important;
}

.main-content a:not(.btn) {
  color: var(--brand-primary);
}

.main-content a:not(.btn):hover {
  color: color-mix(in srgb, var(--brand-primary) 80%, black);
}

.badge.bg-info {
  background-color: var(--brand-secondary) !important;
  color: #1e1e1e !important;
}

.badge.bg-danger {
  background-color: var(--brand-accent) !important;
}

.required-marker {
  color: var(--brand-accent);
  font-weight: 700;
}

.user-name-trigger {
  color: inherit !important;
  font: inherit;
  text-decoration: none !important;
}

.user-name-trigger:hover,
.user-name-trigger:focus {
  color: inherit !important;
  text-decoration: none !important;
}

@media (max-width: 767.98px) {
  #shifts-calendar,
  #my-shifts-calendar {
    padding: 0.25rem;
  }

  .fc .fc-toolbar {
    gap: 0.35rem;
    flex-wrap: wrap;
  }

  .fc .fc-toolbar-chunk {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    flex-wrap: wrap;
  }

  .fc .fc-toolbar-title {
    font-size: 0.95rem;
    line-height: 1.2;
  }

  .fc .fc-button {
    padding: 0.28rem 0.5rem;
    font-size: 0.82rem;
  }

  .fc .fc-list-day-text,
  .fc .fc-list-day-side-text {
    font-size: 0.9rem;
  }

  .fc .fc-timegrid-slot-label-cushion,
  .fc .fc-col-header-cell-cushion {
    font-size: 0.82rem;
  }
}
