:root{
  --surface-1:rgba(255,255,255,.045);
  --surface-2:rgba(255,255,255,.028);
  --surface-3:rgba(95,156,255,.08);
  --line-strong:rgba(255,255,255,.14);
  --glow:0 18px 50px rgba(0,0,0,.28);
  --glow-soft:0 8px 26px rgba(40,110,255,.12);
}
html{scroll-behavior:smooth}
body{font-synthesis-weight:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body:not(.site-ready){opacity:.985}
.topbar,.sidebar,.section,.card,.hero-card,.section-card,.user-card,.nav-card,.mini-stat-card,.vehicle-card,.order-card,.ticket-msg,.panel,.profile-card{
  box-shadow:var(--glow);
}
.card,.section,.hero-card,.section-card,.user-card,.nav-card,.panel,.profile-card,.vehicle-card{
  background:linear-gradient(180deg,var(--surface-1),var(--surface-2));
  border-color:var(--line);
  backdrop-filter:blur(14px);
}
.btn,.pill-btn,.nav a,.nav-link,.quick-link,.badge,.pill,.status-pill{
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease, opacity .18s ease;
}
.btn:hover,.pill-btn:hover,.quick-link:hover{box-shadow:var(--glow-soft)}
.btn:focus-visible,.pill-btn:focus-visible,.nav a:focus-visible,.nav-link:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,button:focus-visible{
  outline:2px solid rgba(99,179,255,.85);
  outline-offset:2px;
}
.btn.primary,.btn-primary{box-shadow:0 10px 30px rgba(72,129,255,.24)}
input,select,textarea,.input{
  background:rgba(2,10,24,.56)!important;
  border:1px solid rgba(255,255,255,.1)!important;
  color:var(--text,#eef4ff)!important;
  border-radius:16px!important;
}
input::placeholder,textarea::placeholder{color:rgba(235,242,255,.42)}
.table-wrap,table{
  border-radius:18px;
  overflow:hidden;
}
.hero-title,.topbar-left h1,.header h2,h1,h2,h3{letter-spacing:-.02em}
.muted,.small,.crumbs{color:var(--muted)!important}
.footer{color:rgba(240,245,255,.68)!important}
.global-hours-mini{
  margin:18px 0 6px;
  text-align:center;
  font-size:12px;
  color:rgba(235,242,255,.72);
}
.home-hours-hero{margin:0 0 18px;padding:18px 20px}
.home-hours-hero .eyebrow{
  font-size:12px;
  color:#8dd7ff;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:800;
  margin-bottom:10px;
}
.home-hours-title{font-size:clamp(24px,3vw,34px);font-weight:800;margin-bottom:8px}
.loading-shimmer,.skeleton,
[data-loading="true"]{
  position:relative;
  overflow:hidden;
}
.loading-shimmer::after,.skeleton::after,[data-loading="true"]::after{
  content:"";
  position:absolute;inset:0;
  transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);
  animation:dukeShimmer 1.5s infinite;
}
@keyframes dukeShimmer{100%{transform:translateX(100%)}}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
@media (max-width:1100px){
  .topbar-inner,.header,.content{padding-left:16px!important;padding-right:16px!important}
}
