
:root{ --opv-blue: #0080FF;
    --opv-blue-accent: #00D1FF;
    --opv-mid-gray: #7D7D7D;
    --opv-light-gray: #D9D9D9;
    --bg: #0B0B0B;
    --surface: #141416;
    --surface-elev: #1E1E22;
    --border: #2A2A2A;
    --text: #FFFFFF;
    --muted: #AFAFB3;
    --accent-warm: #FF6A3D;
    --accent-cyan: #00D1FF;
    --success: #3CC47A;
    --danger: #FF4C4C; }
*{font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
body.bg-dark{background:#000!important;color:#e9ecef}

/* Header */
#siteHeader{background:#212529!important;transition:transform .25s ease, background .2s ease;}
#siteHeader.nav-hide{transform:translateY(-110%);}
.navbar .nav-link{color:#cfd3d8}
.navbar .nav-link:hover,.navbar .nav-link:focus{color:#fff}
.navbar .dropdown-menu{background:#2b3035;border:0;padding:.5rem;border-radius:.5rem}
.navbar .dropdown-item{color:#cfd3d8}
.navbar .dropdown-item:hover{background:#383f45;color:#fff}
.btn-primary{background:var(--opv-blue);border-color:var(--opv-blue)}
.btn-outline-light{border-color:#ced4da;color:#fff}
.navbar-dark .navbar-toggler{ border-color: rgba(255,255,255,.6); }
.navbar-dark .navbar-toggler-icon{ filter:none; }

/* Footer */
.site-footer{background:#212529;color:#cfd3d8}
.site-footer .footer-section h6{color:#fff}
.footer-map{overflow:hidden;border-radius:.5rem;border:1px solid rgba(255,255,255,.12)}
.site-footer .border-top{padding-bottom:50px}

/* Page wrap spacing */
.page-wrap{padding-top:84px; padding-bottom:30px}

/* Hero */
.hero{min-height:100svh;display:flex;align-items:center;position:relative;background:#000 url('/stage/opv/images/terminalsmlr.jpg') center/cover no-repeat}
.hero.hero-first{margin-top:-84px}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom, rgba(0,0,0,.32), rgba(0,0,0,.32))}
.hero .inner{position:relative;z-index:2}
.hero h1{font-weight:800;letter-spacing:.2px;margin-bottom:1.6rem}
.hero .facts{font-weight:700;letter-spacing:.6px}
.hero .facts span{display:inline-block;margin:0 .4rem}
.hero .facts-pill{display:inline-flex;gap:.8rem;align-items:center;padding:.5rem .9rem;border-radius:999px;background:rgba(255,255,255,.16);backdrop-filter:saturate(120%) blur(2px)}
.hero .steps .step{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:.75rem;background:rgba(0,0,0,.35)}
.hero .steps .step img.icon{height:73px;width:auto;object-fit:contain;flex:0 0 73px}

/* Sections */
.section{padding:3rem 0}
#travelers{background:var(--opv-blue);}
#travelers .card{background:transparent;border:1px solid rgba(255,255,255,.35);text-align:center;padding:1.25rem;color:#fff}
#travelers .card img.icon{height:46px;width:auto; margin-bottom:.25rem; filter:brightness(0) invert(1)}

/* Testimonials */
#testimonials .card{background:#fff;border:1px solid #dee2e6;color:#343a40}
#testimonials .title{color:var(--opv-blue); font-weight:700}
#testimonials .title img.g{height:16px;width:16px;vertical-align:-2px;margin-right:6px}
#testimonials .body{color:#343a40}

/* Reservations */
.step-box{ background:#fff; color:#212529; border-radius:.75rem; padding:1.25rem; box-shadow:0 .25rem .75rem rgba(0,0,0,.25) }
.step-actions{ display:flex; justify-content:space-between; gap:1rem; margin-top:1rem }
.step-actions .btn{ min-width:120px }
.card-dark{background:#2b3035;border:1px solid #3a4046}
.btn-parking{border:1px solid #adb5bd;color:#212529;background:#fff}
.btn-check:checked + .btn-parking{background:#e9ecef}
.btn-parking img{vertical-align:-3px}
.picker-box,.time-box{position:relative}
.picker-box .click-overlay,.time-box .click-overlay{position:absolute;inset:0;cursor:pointer}

/* Add-ons cards */
.addons-title{font-size:1.15rem;font-weight:800}
.addons-grid .addon-card{ position:relative; cursor:pointer; }
.addons-grid .addon-card input.addon-input{ position:absolute; opacity:0; pointer-events:none; }
.addons-grid .addon-card .card{ background:#fff; color:var(--opv-blue); border:2px solid #e9ecef; border-radius:.75rem; transition:.15s ease; text-align:center; height:100%}
.addons-grid .addon-card .card .bi{ font-size:40px; display:block; margin-bottom:.35rem }
.addons-grid .addon-card .price{ font-weight:700; }
.addons-grid .addon-card input.addon-input:checked + .card{ border-color:var(--opv-blue); box-shadow:0 0 0 .25rem rgba(13,110,253,.15) }
.addon-icon{height:46px;width:auto;display:block;margin-bottom:.35rem}
.info-top-right{position:absolute;top:8px;right:10px;color:#6c757d}
.time-info .info-ico img{height:22px}

/* Payment logos */
.payment-logos img{ border:1px solid #dee2e6; border-radius:.375rem; padding:3px; background:#fff; height:28px }

.resbtnhdr{margin-left: 10px;background: #0080ff;color: #fff !important;border-radius: 8px;display: inline-block;
  padding-left: 10px;
  padding-right: 10px;}
/* Mobile hero spacing */
@media (max-width: 576px){
  .hero.hero-first{ margin-top:0 !important; }
  .hero .inner{ padding-top: 4.25rem !important; }
  .hero h1{ font-size:1.35rem !important; }
  .hero .facts{ font-size:.85rem !important; }
  .hero .steps .step{ padding:.75rem }
  .hero .steps .step .fw-bold{ font-size:.95rem }
  .hero .steps .step .small{ font-size:.85rem }
  .resbtnhdr{margin-left: 0px !important;}
}

@media (max-width: 990px){
    .resbtnhdr{margin-left: 0px !important;
    margin-top: 8px;
    margin-bottom: 10px;}
}
/* === Fix header-to-hero gap across the site === */

/* 1) Kill the thin line under the navbar */
.navbar { border-bottom: 0 !important; }

/* 2) Make first sections create a new formatting context
      so child top-margins can't "escape" upward */
.section-bleed, .section, .bg-brand, .bg-soft, .bg-subtle { display: flow-root; }

/* 3) Ensure the very first section hugs the header */
header + .section-bleed,
header + .section,
main > .section-bleed:first-child,
main > .section:first-child { margin-top: 35px !important; }

/* 4) Belt-and-suspenders: remove the first child’s top margin in the first section */
main > .section-bleed:first-child > *:first-child,
main > .section:first-child > *:first-child { margin-top: 0 !important; }

/* 5) Make sure <main> isn't adding space */
main { margin-top: 0px !important; padding-top: 0 !important; }
