:root {
  --valet-bg: #f8fafc;
  --valet-surface: rgba(255, 255, 255, 0.92);
  --valet-surface-solid: #ffffff;
  --valet-text: #0f172a;
  --valet-muted: #475569;
  --valet-border: rgba(15, 23, 42, 0.12);
  --valet-shadow: 0 18px 45px rgba(15, 23, 42, 0.12);
  --valet-radius: 18px;
  --valet-radius-sm: 12px;
  --valet-accent-1: #ffd54f;
  --valet-accent-2: #ffb703;
  --valet-danger: #dc2626;
  --valet-success: #16a34a;
}

html,
body {
  height: 100%;
}

body {
  font-family: Roboto-Light, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  color: var(--valet-text);
}

/* =========================
   Backgrounds
   ========================= */

.body-mainpage {
  /* Keep the image vibe, but make it less "heavy". */
  background:
    radial-gradient(900px 600px at 12% 0%, rgba(255, 183, 3, 0.20), transparent 55%),
    radial-gradient(900px 600px at 88% 10%, rgba(59, 130, 246, 0.14), transparent 60%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.62) 45%, rgba(0, 0, 0, 0.55) 100%),
    url("../image/valet_background.jpg") no-repeat center center fixed;
  background-size: cover;
}

.body-valet {
  background:
    radial-gradient(1000px 650px at 12% -10%, rgba(255, 183, 3, 0.22), transparent 55%),
    radial-gradient(900px 650px at 92% 0%, rgba(2, 132, 199, 0.12), transparent 60%),
    linear-gradient(180deg, #0b1220 0px, #0b1220 220px, var(--valet-bg) 221px, var(--valet-bg) 100%);
  background-attachment: fixed;
}

/* =========================
   Navbar
   ========================= */

.navbar.navbar-inverse {
  margin-top: 0;
  background: rgba(11, 18, 32, 0.72);
  border: 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.10);
  backdrop-filter: blur(10px);
}

.navbar.navbar-inverse .navbar-brand {
  letter-spacing: 0.6px;
  text-transform: none;
  display: flex;
  align-items: center;
  gap: 10px;
}

.navbar.navbar-inverse .navbar-brand img {
  height: 28px;
  width: auto;
}

.navbar-form.navbar-right.text {
  color: rgba(255, 255, 255, 0.82);
  margin-top: 14px;
}

.navbar-inverse .form-control {
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.92);
  box-shadow: none;
}

.navbar-inverse .form-control::placeholder {
  color: rgba(255, 255, 255, 0.55);
}

.navbar-inverse .form-control:focus {
  border-color: rgba(255, 183, 3, 0.55);
  box-shadow: 0 0 0 3px rgba(255, 183, 3, 0.16);
}

/* =========================
   Cards / Panels
   ========================= */

.thumbnail,
.thumbnail-second {
  background: var(--valet-surface-solid);
  border: 1px solid var(--valet-border);
  border-radius: var(--valet-radius);
  box-shadow: var(--valet-shadow);
}

.thumbnail-second {
  margin-top: 18px;
}

.panel-body {
  padding: 22px;
}

.valet-modal-content {
  border-radius: 22px;
  border: 1px solid rgba(15, 23, 42, 0.14);
  overflow: hidden;
  box-shadow: var(--valet-shadow);
}

.valet-modal-content .modal-header,
.valet-modal-content .modal-footer {
  border-color: rgba(15, 23, 42, 0.10);
}

#legend {
  margin-bottom: 14px;
}

.legend {
  color: var(--valet-text);
  border: 0;
  padding-bottom: 0;
  margin-bottom: 10px;
}

.legend.archive-font {
  font-size: 18px;
  letter-spacing: 0.8px;
}

/* =========================
   Forms
   ========================= */

.body-valet .form-horizontal,
.body-mainpage .form-horizontal {
  color: var(--valet-text);
}

.body-valet .form-control,
.body-mainpage .form-control {
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.14);
  box-shadow: none;
}

.body-valet .form-control:focus,
.body-mainpage .form-control:focus {
  border-color: rgba(255, 183, 3, 0.65);
  box-shadow: 0 0 0 3px rgba(255, 183, 3, 0.18);
}

.valet-place-autocomplete-wrap {
  width: 100%;
}

.valet-place-autocomplete-wrap gmp-place-autocomplete,
.valet-place-autocomplete {
  width: 100%;
  display: block;
  background: transparent;
  color: var(--valet-text);
}

.valet-place-autocomplete-wrap gmp-place-autocomplete::part(input),
.valet-place-autocomplete::part(input) {
  min-height: 42px;
  background: #ffffff;
  color: var(--valet-text);
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.14);
  box-shadow: none;
}

.valet-place-autocomplete-wrap gmp-place-autocomplete::part(input):focus,
.valet-place-autocomplete::part(input):focus {
  background: #ffffff;
  border-color: rgba(255, 183, 3, 0.65);
  box-shadow: 0 0 0 3px rgba(255, 183, 3, 0.18);
}

.valet-place-autocomplete-wrap gmp-place-autocomplete::part(predictions),
.valet-place-autocomplete::part(predictions) {
  background: #ffffff;
  color: var(--valet-text);
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.10);
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.16);
}

.help-block {
  color: var(--valet-muted);
}

/* =========================
   Buttons
   ========================= */

.btn {
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: 0.2px;
}

.body-valet .btn-primary,
.body-valet .btn-success,
.body-mainpage .btn-primary,
.body-mainpage .btn-success {
  color: #111827;
  background: linear-gradient(120deg, var(--valet-accent-1), var(--valet-accent-2));
  border: 0;
  box-shadow: 0 14px 30px rgba(255, 183, 3, 0.32);
}

.body-valet .btn-primary:hover,
.body-valet .btn-success:hover,
.body-mainpage .btn-primary:hover,
.body-mainpage .btn-success:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 36px rgba(255, 183, 3, 0.38);
}

.body-valet .btn-default,
.body-mainpage .btn-default {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.14);
  color: var(--valet-text);
}

.body-valet .btn-default:hover,
.body-mainpage .btn-default:hover {
  background: rgba(15, 23, 42, 0.03);
}

.btn.valet-btn-danger {
  background: rgba(220, 38, 38, 0.10);
  color: #b91c1c;
  border: 1px solid rgba(220, 38, 38, 0.28);
  box-shadow: none;
}

.btn.valet-btn-danger:hover {
  background: rgba(220, 38, 38, 0.14);
}

/* =========================
   Alerts (toast-like)
   ========================= */

.valet-notifications {
  /* Render notifications like toasts: never reserve layout space, never block the UI when empty. */
  position: fixed;
  top: 58px;
  left: 0;
  right: 0;
  z-index: 1040;
  padding-top: 10px;
  pointer-events: none;
}

.valet-notifications .alert {
  max-width: 1100px;
  margin: 0 auto 10px auto;
  pointer-events: auto;
  backdrop-filter: blur(6px);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.22);
  padding: 14px 20px;
}

.alert {
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.14);
  font-weight: 600;
}

.alert-success {
  background: rgba(236, 253, 245, 0.96);
  border-color: rgba(22, 163, 74, 0.28);
  color: #065f46;
}

.alert-danger {
  background: rgba(254, 242, 242, 0.98);
  border-color: rgba(220, 38, 38, 0.32);
  color: #991b1b;
}

.alert-warning {
  background: rgba(255, 251, 235, 0.98);
  border-color: rgba(217, 119, 6, 0.28);
  color: #92400e;
}

.alert .close {
  color: inherit;
  opacity: 0.72;
  text-shadow: none;
}

.alert .close:hover,
.alert .close:focus {
  opacity: 1;
}

.alert i {
  margin-right: 8px;
}

/* =========================
   Tables (responsive)
   ========================= */

.valet-table {
  margin-top: 8px;
}

.valet-table.table > tbody > tr > th,
.valet-table.table > tbody > tr > td,
.valet-table.table > tr > th,
.valet-table.table > tr > td {
  border-top: 0;
}

.valet-table .table-title th {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(15, 23, 42, 0.58);
  padding: 10px 12px;
}

.valet-table .table-item td {
  padding: 12px;
  vertical-align: middle;
}

.valet-table .table-item {
  background: rgba(15, 23, 42, 0.02);
}

.valet-table .table-item:hover {
  background: rgba(255, 183, 3, 0.12);
}

.valet-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: rgba(255, 255, 255, 0.7);
  color: rgba(15, 23, 42, 0.84);
  font-size: 12px;
  font-weight: 700;
}

.valet-mono {
  font-family: ui-monospace, "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 12px;
  letter-spacing: 0.02em;
}

.valet-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.valet-empty {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px;
  background: rgba(15, 23, 42, 0.03);
  border: 1px dashed rgba(15, 23, 42, 0.18);
  border-radius: var(--valet-radius-sm);
  color: rgba(15, 23, 42, 0.72);
}

@media (max-width: 767px) {
  .valet-table,
  .valet-table tbody,
  .valet-table tr,
  .valet-table td,
  .valet-table th {
    display: block;
    width: 100%;
  }

  .valet-table tr.table-title {
    display: none;
  }

  .valet-table tr.table-item {
    margin: 0 0 12px 0;
    padding: 12px;
    border-radius: var(--valet-radius-sm);
    border: 1px solid rgba(15, 23, 42, 0.12);
    background: #ffffff;
  }

  .valet-table tr.table-item td {
    padding: 8px 0;
    display: flex;
    justify-content: space-between;
    gap: 12px;
  }

  .valet-table tr.table-item td::before {
    content: attr(data-label);
    font-weight: 800;
    color: rgba(15, 23, 42, 0.62);
    flex: 0 0 auto;
    max-width: 40%;
  }

  .valet-actions {
    justify-content: flex-start;
    margin-top: 10px;
  }
}

/* =========================
   Maps
   ========================= */

#map_canvas,
#map-canvas,
#map-canvas-destination,
#map-canvas-destination_reservation_edit {
  border-radius: var(--valet-radius);
  border: 1px solid rgba(15, 23, 42, 0.12);
  overflow: hidden;
}

/* =========================
   Auth page (login)
   ========================= */

.valet-auth-wrap {
  padding: 48px 0 70px;
}

.valet-auth-hero {
  text-align: center;
  color: rgba(255, 255, 255, 0.92);
  margin: 10px auto 24px;
  max-width: 720px;
}

.valet-auth-hero h1 {
  font-family: Archive, sans-serif;
  font-size: clamp(32px, 4.2vw, 46px);
  letter-spacing: 0.08em;
  margin: 10px 0 10px;
}

.valet-auth-hero p {
  color: rgba(255, 255, 255, 0.72);
  font-size: 16px;
  line-height: 1.7;
}

.valet-auth-card {
  max-width: 520px;
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.20);
  border-radius: 22px;
  box-shadow: 0 26px 70px rgba(0, 0, 0, 0.35);
  padding: 22px;
}

.valet-auth-card h2 {
  margin: 6px 0 16px;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.valet-auth-links {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-top: 14px;
  font-weight: 700;
}

.valet-auth-links a {
  color: rgba(15, 23, 42, 0.78);
  text-decoration: none;
}

.valet-auth-links a:hover {
  color: rgba(15, 23, 42, 1.0);
  text-decoration: underline;
}
