:root{
  --bg:#ffffff;
  --bg-soft:#ffffff;
  --bg-tint:#f3f3f3;
  --text:#131722;
  --muted:#4f4f4f;
  --line:rgba(19,23,34,.1);
  --line-strong:rgba(19,23,34,.18);
  --shadow:0 20px 60px rgba(16,24,40,.08);
  --shadow-soft:0 14px 36px rgba(16,24,40,.06);
  --brand:#000000;
  --brand-2:#000000;
  --brand-3:#2a2a2a;
  --radius:24px;
  --radius-sm:18px;
  --container:min(1180px, calc(100vw - 28px));
}

body.theme-dark{
  --bg:#0f1218;
  --bg-soft:#171b22;
  --bg-tint:#171717;
  --text:#f4f7fb;
  --muted:#c9d2df;
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(255,255,255,.15);
  --shadow:0 24px 70px rgba(0,0,0,.35);
  --shadow-soft:0 14px 36px rgba(0,0,0,.22);
  --brand:#ffffff;
  --brand-2:#ffffff;
  --brand-3:#bbbbbb;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth; overflow-x:hidden}
body{
  margin:0;
  font:16px/1.6 Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(0,0,0,.05), transparent 24%),
    radial-gradient(circle at top right, rgba(0,0,0,.03), transparent 24%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-tint) 100%);
  overflow-x:hidden;
}
body.lock{overflow:hidden}
body.nav-open{overflow:hidden; overscroll-behavior:none}
a{color:inherit; text-decoration:none}
button{font:inherit}
img{display:block; max-width:100%; height:auto}
main{position:relative; z-index:1; padding-top:74px}
section[id]{scroll-margin-top:88px}
.container{width:var(--container); margin-inline:auto}
.section{padding:clamp(3.5rem, 7vw, 6.5rem) 0}
.section--soft{background:linear-gradient(180deg, rgba(255,255,255,.58), rgba(255,255,255,.16)); backdrop-filter:blur(6px)}
body.theme-dark .section--soft{background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02))}

.site-shell::before,
.site-shell::after{
  content:"";
  position:fixed;
  inset:auto;
  border-radius:999px;
  pointer-events:none;
  filter:blur(80px);
  opacity:.7;
  z-index:0;
}
.site-shell::before{width:240px; height:240px; top:8%; left:-80px; background:rgba(0,0,0,.05)}
.site-shell::after{width:320px; height:320px; right:-120px; top:32%; background:rgba(0,0,0,.035)}

.splash{position:fixed; inset:0; display:grid; place-items:center; background:#fff; z-index:9999; transition:opacity .55s ease, visibility .55s ease; overflow:hidden}
body.theme-dark .splash{background:rgba(15,18,24,.96)}
.splash--hide{opacity:0; visibility:hidden}
.splash__inner{display:grid; gap:18px; place-items:center; width:min(92vw, 560px)}
.splash__logo{width:min(72vw, 430px); filter:drop-shadow(0 12px 32px rgba(0,0,0,.08)); animation:splashLogoPulse 1.8s ease-in-out infinite}
.splash__scene{position:relative; width:min(43vw, 235px); height:62px; display:grid; place-items:center}
.splash__road{position:absolute; left:50%; bottom:5px; transform:translateX(-50%); width:100%; height:18px; border-radius:0; background:#000; box-shadow:none}
.splash__road::before{content:none}
.splash__road::after{content:""; position:absolute; left:0; right:0; top:50%; height:2px; transform:translateY(-50%); background:repeating-linear-gradient(90deg, transparent 0 11px, #fff 11px 25px, transparent 25px 42px); animation:splashRoadMarks 1.15s linear infinite; opacity:1}
.splash__bus-wrap{position:absolute; left:50%; bottom:17px; width:93px; height:30px; transform:translateX(-50%); animation:splashBusDrive 2.3s ease-in-out infinite}
.splash__bus{position:relative; width:78px; height:24px; border:2px solid #000; border-radius:0; background:linear-gradient(180deg, #fff 0%, #efefef 100%); box-shadow:none; box-sizing:border-box}
.splash__bus::before{content:none}
.splash__bus::after{content:""; position:absolute; left:4px; right:4px; bottom:4px; height:2px; border-radius:0; background:#000}
.splash__bus-wrap::after{content:""; position:absolute; left:8px; right:7px; bottom:-5px; height:6px; border-radius:50%; background:radial-gradient(ellipse at center, rgba(0,0,0,.22) 0%, rgba(0,0,0,.08) 58%, transparent 82%); filter:blur(1px)}
.splash__bus-window{position:absolute; top:4px; width:10px; height:6px; border-radius:0; background:rgba(0,0,0,.16); border:1px solid rgba(0,0,0,.22); box-sizing:border-box}
.splash__bus-window--driver{right:5px; width:8px; border-radius:0}
.splash__bus-window:nth-of-type(2){left:9px}
.splash__bus-window:nth-of-type(3){left:22px}
.splash__bus-window:nth-of-type(4){left:35px}
.splash__bus-light{position:absolute; right:-3px; top:8px; width:2px; height:5px; border-radius:0; background:#000}
.splash__wheel{position:absolute; bottom:-5px; width:11px; height:11px; border-radius:50%; background:rgba(0,0,0,.94)}
.splash__wheel::after{content:""; position:absolute; inset:3px; border-radius:50%; background:#fff; opacity:.88}
.splash__wheel--front{right:8px; animation:splashWheelSpin .7s linear infinite}
.splash__wheel--rear{left:9px; animation:splashWheelSpin .7s linear infinite}
body.theme-dark .splash__road{background:#000; box-shadow:none}
body.theme-dark .splash__road::before{content:none}
body.theme-dark .splash__road::after{background:repeating-linear-gradient(90deg, transparent 0 22px, #fff 22px 50px, transparent 50px 84px)}
body.theme-dark .splash__bus{border-color:#000; background:linear-gradient(180deg, #fff 0%, #efefef 100%); box-shadow:none}
body.theme-dark .splash__bus::before{content:none}
body.theme-dark .splash__bus::after, body.theme-dark .splash__bus-light, body.theme-dark .splash__wheel{background:#000}
body.theme-dark .splash__wheel::after{background:#fff}
body.theme-dark .splash__bus-window{background:rgba(0,0,0,.16); border-color:rgba(0,0,0,.22)}
@keyframes splashLogoPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.035)}}
@keyframes splashBusDrive{0%,100%{transform:translateX(calc(-50% - 10px)) translateY(0)}25%{transform:translateX(calc(-50% - 4px)) translateY(-1px)}50%{transform:translateX(calc(-50% + 9px)) translateY(0)}75%{transform:translateX(calc(-50% + 4px)) translateY(1px)} }
@keyframes splashRoadMarks{from{background-position:0 0}to{background-position:-42px 0}}
@keyframes splashWheelSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

.nav{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:90;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:12px max(16px, env(safe-area-inset-left)) 12px max(16px, env(safe-area-inset-right));
  width:100%;
  border-bottom:1px solid var(--line);
  border-radius:0;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(16px);
  box-shadow:var(--shadow-soft);
}
body.theme-dark .nav{background:rgba(15,18,24,.92)}
.nav--scrolled{box-shadow:0 20px 60px rgba(16,24,40,.12)}
.brand img{height:62px; width:auto}
.desktop-menu{display:flex; gap:1rem; align-items:center; flex-wrap:wrap}
.desktop-menu a{padding:.7rem .9rem; border-radius:999px; color:var(--muted); font-weight:700; transition:background .25s ease, color .25s ease, transform .25s ease}
.desktop-menu a:hover{background:rgba(0,0,0,.07); color:var(--text); transform:translateY(-1px)}
.nav__actions{display:flex; align-items:center; gap:.6rem; justify-content:flex-end}
.icon-btn{
  border:1px solid var(--line);
  background:var(--bg-soft);
  color:var(--text);
  width:46px;
  height:46px;
  border-radius:14px;
  display:grid;
  place-items:center;
  cursor:pointer;
  box-shadow:var(--shadow-soft);
}
.burger{padding:0}
.burger span{display:block; width:19px; height:2px; border-radius:999px; background:currentColor; margin:3px 0; transition:transform .25s ease, opacity .25s ease}
body.nav-open .burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

.mobile-panel{
  position:fixed;
  top:0;
  right:0;
  height:100dvh;
  width:min(92vw, 360px);
  padding:14px;
  background:rgba(255,255,255,.96);
  border-left:1px solid var(--line);
  box-shadow:-30px 0 70px rgba(16,24,40,.12);
  z-index:120;
  transform:translateX(102%);
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
  display:grid;
  grid-template-rows:auto 1fr auto;
}
body.theme-dark .mobile-panel{background:rgba(17,20,26,.98)}
body.nav-open .mobile-panel{transform:none}
.mobile-panel__head{display:flex; justify-content:space-between; align-items:center; padding:.2rem 0 .8rem}
.mobile-menu{display:grid; gap:.5rem; align-content:start; padding-top:.5rem}
.mobile-menu a{padding:1rem; border-radius:16px; background:var(--bg-soft); border:1px solid var(--line); font-weight:700}
.mobile-panel__cta{display:grid; gap:.8rem; padding-top:1rem}
.panel-backdrop{position:fixed; inset:0; background:transparent; border:0; opacity:0; visibility:hidden; z-index:110; transition:opacity .24s ease, visibility .24s ease}
body.nav-open .panel-backdrop{opacity:1; visibility:visible}

.hero{position:relative; min-height:calc(100dvh - 76px); display:grid; align-items:center; padding:1.2rem 0 2.4rem; overflow:hidden; isolation:isolate}
.hero::before{content:""; position:absolute; inset:0; z-index:-2; pointer-events:none; background:
  radial-gradient(circle at 14% 24%, rgba(255,255,255,.14) 0 0.6%, rgba(255,255,255,.14) 0 3.8%, transparent 7.8%),
  radial-gradient(circle at 28% 58%, rgba(255,255,255,.11) 0 4.8%, transparent 9.2%),
  radial-gradient(circle at 77% 20%, rgba(255,255,255,.12) 0 3.6%, transparent 7.4%),
  radial-gradient(circle at 84% 66%, rgba(255,255,255,.10) 0 4.4%, transparent 8.8%),
  radial-gradient(circle at 60% 40%, rgba(255,255,255,.08) 0 3.2%, transparent 6.8%),
  radial-gradient(circle at 42% 18%, rgba(255,255,255,.09) 0 2.8%, transparent 6.2%);
  filter:blur(10px);
  opacity:.85}
.hero::after{content:""; position:absolute; inset:0; z-index:-1; pointer-events:none; background:linear-gradient(180deg, rgba(0,0,0,.12) 0%, rgba(0,0,0,.06) 36%, rgba(0,0,0,.18) 100%)}
.hero__video{position:absolute; inset:-18px; width:calc(100% + 36px); height:calc(100% + 36px); object-fit:cover; z-index:-3; filter:saturate(1.02) contrast(1.02) brightness(.98) blur(2.6px); transform:scale(1.04)}
.hero__overlay{position:absolute; inset:0; z-index:-2; background:transparent; backdrop-filter:none}
body.theme-dark .hero__overlay{background:transparent; backdrop-filter:none}
.hero__content{display:grid; gap:1rem; padding:clamp(5.4rem, 10vw, 7.8rem) 0 2rem; text-shadow:0 2px 18px rgba(0,0,0,.28)}
.eyebrow,.section-kicker{display:inline-flex; align-items:center; gap:.55rem; padding:.5rem .85rem; border-radius:999px; background:rgba(255,255,255,.86); border:1px solid rgba(255,255,255,.26); width:max-content; font-size:.85rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--muted)}
body.theme-dark .eyebrow, body.theme-dark .section-kicker{background:rgba(255,255,255,.06)}
.hero__title{font-size:clamp(2.3rem, 7vw, 5.2rem); line-height:1.02; margin:0; max-width:12ch; letter-spacing:-.04em; color:#fff; text-shadow:0 0 18px rgba(0,0,0,.78), 0 14px 42px rgba(0,0,0,.62), 0 0 64px rgba(0,0,0,.42)}
.hero__text{max-width:720px; margin:0; font-size:clamp(1rem, 2vw, 1.2rem); color:#fff}
.hero__cta,.cta-row{display:flex; gap:.9rem; flex-wrap:wrap; align-items:center; justify-content:center}

.hero__title,.hero__text,.eyebrow{position:relative; z-index:1}
.hero__title{max-width:14ch}
.hero__text{max-width:60ch; color:rgba(255,255,255,.98); text-shadow:0 0 14px rgba(0,0,0,.72), 0 10px 30px rgba(0,0,0,.56), 0 0 34px rgba(0,0,0,.32)}
body.theme-dark .hero__text{color:rgba(244,247,251,.88)}
.scroll-indicator{position:absolute; left:50%; bottom:14px; transform:translateX(-50%); width:48px; height:72px; display:grid; place-items:center}
.scroll-indicator span{width:28px; height:46px; border-radius:999px; border:2px solid var(--line-strong); position:relative}
.scroll-indicator span::after{content:""; position:absolute; left:50%; top:9px; transform:translateX(-50%); width:6px; height:10px; border-radius:999px; background:var(--brand-2); animation:scrollDot 1.35s infinite}
@keyframes scrollDot{0%{opacity:0; transform:translate(-50%,0)}30%{opacity:1}100%{opacity:0; transform:translate(-50%,18px)}}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  min-height:50px;
  padding:.92rem 1.25rem;
  border-radius:16px;
  border:1px solid #000;
  background:#000;
  color:#fff;
  font-weight:800;
  box-shadow:0 18px 34px rgba(0,0,0,.16);
  transition:transform .25s ease, box-shadow .25s ease, opacity .25s ease;
}
.btn:hover{transform:translateY(-2px); box-shadow:0 20px 38px rgba(0,0,0,.22), 0 0 0 1px rgba(255,255,255,.14), 0 0 18px rgba(255,255,255,.12)}
.btn--soft{background:var(--bg-soft); color:var(--text); border-color:var(--line); box-shadow:var(--shadow-soft)}
.btn--soft:hover{box-shadow:0 18px 34px rgba(16,24,40,.12)}

.section-heading{display:grid; gap:.9rem; margin-bottom:1.8rem}
.section-heading h2{margin:0; font-size:clamp(1.8rem, 4.6vw, 3.35rem); line-height:1.08; letter-spacing:-.03em}
.section-heading p{margin:0; max-width:780px; color:var(--muted); font-size:1.05rem}

.service-grid{display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:1rem}
.service-grid--compact{grid-template-columns:repeat(3, minmax(0,1fr))}
.service-card,.fleet-card,.social-card,.contact-card,.map,.split-card,.album,.tour-carousel{
  border:1px solid var(--line);
  background:rgba(255,255,255,.78);
  box-shadow:var(--shadow);
  backdrop-filter:blur(10px);
}
body.theme-dark .service-card,
body.theme-dark .fleet-card,
body.theme-dark .social-card,
body.theme-dark .contact-card,
body.theme-dark .map,
body.theme-dark .split-card,
body.theme-dark .album,
body.theme-dark .tour-carousel{background:rgba(255,255,255,.04)}
.service-card{padding:1.35rem; border-radius:var(--radius); min-height:100%; transition:transform .25s ease, border-color .25s ease}
.service-card:hover{transform:translateY(-3px); border-color:rgba(0,0,0,.24)}
.service-card span{display:inline-flex; width:40px; height:40px; border-radius:12px; align-items:center; justify-content:center; background:rgba(0,0,0,.07); color:var(--brand-2); font-weight:800; margin-bottom:1rem}
.service-card h3{margin:.1rem 0 .55rem; font-size:1.22rem; line-height:1.22}
.service-card p{margin:0; color:var(--muted)}

.fleet-layout{display:grid; gap:1.5rem}
.fleet-grid{display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:1rem}
.fleet-card{border-radius:var(--radius); overflow:hidden; min-height:100%; display:grid; background:#fff; position:relative}
.fleet-card img{width:100%; aspect-ratio:4/3; object-fit:cover; background:#f7f7f7; padding:0; transition:transform .65s ease, filter .65s ease}
.fleet-card:hover img{transform:scale(1.04); filter:saturate(1.04)}
.fleet-card figcaption{display:none}

.album-list{display:grid; gap:1rem}
.album{border-radius:30px; overflow:hidden; transition:transform .25s ease, border-color .25s ease}
.album:hover{transform:translateY(-2px)}
.album__toggle{width:100%; border:0; background:transparent; color:inherit; display:grid; grid-template-columns:1.35fr minmax(96px, 200px); gap:1rem; align-items:stretch; padding:1rem; cursor:pointer}
.album__copy{display:grid; align-content:center; gap:.35rem; text-align:left; padding:1rem}
.album__copy small{text-transform:uppercase; letter-spacing:.12em; color:var(--brand-2); font-weight:800}
.album__copy strong{font-size:clamp(1.2rem, 2.8vw, 1.75rem); line-height:1.12}
.album__copy em{font-style:normal; color:var(--muted)}
.album__cover{border-radius:22px; overflow:hidden; min-height:140px; max-width:200px; justify-self:end; width:100%}
.album__cover img{width:100%; height:100%; object-fit:cover; transition:transform .55s ease}
.album:hover .album__cover img{transform:scale(1.05)}
.album__panel{display:grid; grid-template-rows:0fr; transition:grid-template-rows .35s ease, opacity .35s ease; opacity:0}
.album.is-open .album__panel{grid-template-rows:1fr; opacity:1}
.album__panel > *{overflow:hidden}
.album__grid{display:grid; grid-template-columns:repeat(5, minmax(0,1fr)); gap:.7rem; padding:0 1rem 1rem}
.gallery-shot{padding:0; border:0; border-radius:18px; overflow:hidden; cursor:pointer; background:#ececec; position:relative; aspect-ratio:1/1}
.gallery-shot img{width:100%; height:100%; object-fit:cover; transition:transform .45s ease, filter .45s ease}
.gallery-shot:hover img{transform:scale(1.06); filter:saturate(1.06)}

.split-card{border-radius:32px; padding:clamp(1.2rem, 4vw, 2rem); display:grid; grid-template-columns:1.05fr .95fr; gap:1.2rem}
.check-list{margin:0; padding-left:1.2rem; display:grid; gap:.8rem; color:var(--muted)}
.check-list li::marker{color:var(--brand-2)}

.tour-carousel{padding:1rem; border-radius:30px}
.tour-viewport{overflow:hidden; border-radius:24px}
.tour-track{display:flex; transition:transform .55s cubic-bezier(.2,.8,.2,1); touch-action:pan-y; will-change:transform}
.tour-slide{min-width:100%}
.tour-slide img{width:100%; aspect-ratio:16/9; object-fit:cover}
.tour-controls{display:flex; align-items:center; justify-content:space-between; gap:1rem; padding-top:1rem}
.tour-btn{width:52px; height:52px; border-radius:16px; border:1px solid var(--line); background:var(--bg-soft); color:var(--text); cursor:pointer; flex:0 0 auto}
.tour-dots{display:flex; justify-content:center; gap:.5rem; flex:1; flex-wrap:wrap}
.tour-dot{width:10px; height:10px; border-radius:999px; border:0; background:rgba(0,0,0,.2); padding:0; cursor:pointer}
.tour-dot.active{width:28px; background:#000}

.social-card{display:grid; grid-template-columns:auto 1fr auto; gap:1rem; align-items:center; border-radius:30px; padding:1.15rem}
.social-card__badge{width:62px; height:62px; border-radius:20px; display:grid; place-items:center; font-size:2rem; font-weight:900; color:#fff; background:#000}
.social-card h2{margin:.35rem 0 .35rem; font-size:clamp(1.45rem, 4vw, 2rem)}
.social-card p{margin:0; color:var(--muted)}

.contact-layout{display:grid; grid-template-columns:minmax(0, 380px) minmax(0,1fr); gap:1rem}
.contact-card{border-radius:30px; padding:1.4rem; display:grid; gap:.75rem; align-content:start}
.contact-card h3{margin:0 0 .35rem; font-size:1.35rem}
.contact-card a,.contact-card p{padding:.92rem 1rem; border-radius:18px; margin:0; border:1px solid var(--line); background:rgba(255,255,255,.55)}
.contact-card__address{text-align:center; justify-content:center; display:flex; align-items:center}
.btn--contact{background:#000; color:#fff; border-color:#000}
.btn--contact:hover{background:#111; border-color:#111; transform:translateY(-2px)}
body.theme-dark .contact-card a, body.theme-dark .contact-card p{background:rgba(255,255,255,.03)}
.map{border-radius:30px; overflow:hidden; min-height:100%}
.map iframe{width:100%; height:100%; min-height:420px; border:0; display:block}
.cta-row--stack{display:grid; grid-template-columns:1fr; gap:.75rem}

.footer{padding:1.4rem 1rem 2.6rem; text-align:center; color:var(--muted)}
.to-top{position:fixed; right:16px; bottom:16px; width:52px; height:52px; border:1px solid #000; border-radius:16px; background:#000; color:#fff; box-shadow:0 18px 34px rgba(0,0,0,.18); opacity:0; visibility:hidden; transform:translateY(10px); transition:.25s; cursor:pointer; z-index:95}
.to-top.show{opacity:1; visibility:visible; transform:none}

.lightbox{width:min(100vw - 18px, 1040px); border:0; padding:0; background:transparent}
.lightbox::backdrop{background:rgba(9,13,20,.74); backdrop-filter:blur(8px)}
.lightbox__figure{margin:0; position:relative; background:rgba(255,255,255,.98); border-radius:28px; overflow:hidden; border:1px solid rgba(255,255,255,.25)}
body.theme-dark .lightbox__figure{background:rgba(18,22,28,.98)}
.lightbox__figure img{width:100%; max-height:78dvh; object-fit:contain; background:#0d1117}
.lightbox__figure figcaption{padding:1rem 1.2rem; color:var(--text)}
.lightbox__close{position:absolute; top:12px; right:12px; z-index:2; width:44px; height:44px; border-radius:14px; border:0; background:rgba(17,24,39,.72); color:#fff; cursor:pointer}

.reveal{opacity:0; transform:translateY(24px) scale(.985); filter:blur(6px); transition:opacity .72s cubic-bezier(.22,.61,.36,1), transform .72s cubic-bezier(.22,.61,.36,1), filter .72s cubic-bezier(.22,.61,.36,1)}
.reveal-left{transform:translateX(-42px) translateY(12px)}
.reveal-right{transform:translateX(42px) translateY(12px)}
.reveal-zoom{transform:translateY(22px) scale(.92)}
.reveal-tilt{transform:translateY(26px) scale(.95) rotate(-2.2deg)}
.reveal-up{transform:translateY(54px)}
.reveal.is-visible{opacity:1; transform:none; filter:none}
.delay-1{transition-delay:.08s}
.delay-2{transition-delay:.16s}
.delay-3{transition-delay:.24s}
.delay-4{transition-delay:.32s}

@media (max-width: 1080px){
  .desktop-menu{display:none}
  .fleet-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
  .service-grid,.service-grid--compact,.contact-layout,.split-card{grid-template-columns:repeat(2, minmax(0,1fr))}
  .album__grid{grid-template-columns:repeat(4, minmax(0,1fr))}
}

@media (min-width: 1081px){
  .burger,.mobile-panel,.panel-backdrop{display:none}
}

@media (max-width: 720px){
  .album__grid{grid-template-columns:repeat(3, minmax(0,1fr))}

  :root{--container:min(100vw - 18px, 100%)}
  .nav{width:100%; padding:10px 10px}
  .brand img{height:50px}
  .hero{min-height:calc(100dvh - 76px)}
  .service-grid,
  .service-grid--compact,
  .fleet-grid,
  .contact-layout,
  .split-card,
  .social-card,
  .album__toggle{grid-template-columns:1fr}
  .social-card{align-items:start}
  .album__cover{min-height:150px; max-width:180px; justify-self:start}
  .section-heading h2{max-width:14ch}
  .tour-slide img{aspect-ratio:4/3}
  .map iframe{min-height:320px}
}

@media (max-width: 420px){
  .album__grid{grid-template-columns:repeat(2, minmax(0,1fr))}

  body{font-size:15px}
  .hero__content{padding-top:5rem}
  .hero__title{font-size:clamp(2rem, 10vw, 2.9rem)}
  .btn{width:100%}
  .hero__cta,.cta-row{display:grid; grid-template-columns:1fr}
  .icon-btn{width:42px; height:42px}
  .album,.contact-card,.map,.service-card,.tour-carousel,.social-card,.split-card{border-radius:22px}
  .album__copy{padding:.35rem}
  .album__panel .album__grid{padding:0 .75rem .75rem}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none !important; transition:none !important}
}

.contact-card a,.mobile-panel__cta .btn,.hero__cta .btn,.cta-row .btn{justify-content:center;text-align:center;}
.lightbox__figure figcaption{display:none;}


/* gallery modal redesign */
.album__panel{display:none !important}
.album__toggle{min-height:100%}
.album__toggle:focus-visible{outline:2px solid #000; outline-offset:4px}
.lightbox{width:min(100vw - 18px, 980px); max-width:none; border:0; padding:0; background:transparent}
.lightbox__shell{display:block}
.lightbox__figure{margin:0; position:relative; background:rgba(255,255,255,.99); border-radius:28px; overflow:hidden; border:1px solid rgba(0,0,0,.08); min-width:0; box-shadow:0 24px 60px rgba(0,0,0,.22)}
body.theme-dark .lightbox__figure{background:rgba(18,22,28,.98); border-color:rgba(255,255,255,.08)}
.lightbox__figure img{width:100%; max-height:82dvh; object-fit:contain; background:#ffffff}
.lightbox__meta{display:flex; align-items:center; justify-content:center; gap:.85rem; padding:.95rem 1rem 1.05rem; color:var(--text); font-weight:700}
.lightbox__nav,.lightbox__close{display:grid; place-items:center; cursor:pointer; border:1px solid rgba(0,0,0,.12); color:#111; background:#fff; box-shadow:0 8px 20px rgba(0,0,0,.08)}
body.theme-dark .lightbox__nav,body.theme-dark .lightbox__close{background:#111827; color:#fff; border-color:rgba(255,255,255,.14); box-shadow:none}
.lightbox__nav{width:44px; height:44px; border-radius:12px; font-size:1.1rem; line-height:1; flex:0 0 auto}
.lightbox__close{position:absolute; top:12px; right:12px; z-index:2; width:42px; height:42px; border-radius:12px}
#lightboxCounter{min-width:4.75rem; text-align:center; font-size:1rem; letter-spacing:.01em}
@media (max-width: 720px){
  .lightbox{width:min(100vw - 10px, 100%)}
  .lightbox__figure{border-radius:24px}
  .lightbox__figure img{max-height:74dvh}
  .lightbox__meta{gap:.75rem; padding:.85rem .85rem 1rem}
  .lightbox__nav{width:42px; height:42px; border-radius:11px}
}

.lightbox__figure img{transition:opacity .28s ease, transform .28s ease;}
.lightbox__figure img.is-switching{opacity:.18; transform:scale(.985);}


.lightbox__media{width:100%; height:auto; max-height:82dvh; overflow:hidden; display:flex; align-items:center; justify-content:center; background:#ffffff; transition:height .34s cubic-bezier(.22,.61,.36,1); will-change:height;}
.lightbox__figure img{display:block; width:100%; height:100%; max-height:none; object-fit:contain; background:#ffffff}
@media (max-width:720px){.lightbox__media{max-height:74dvh}}
body.theme-dark .lightbox__media{background:#0d1117}
body.theme-dark .lightbox__figure img{background:#0d1117}



.travel-showcase{display:grid; gap:1.35rem; margin-top:2rem}
.travel-showcase__head{display:grid; gap:.8rem}
.travel-showcase__head h3{margin:0; font-size:clamp(1.5rem, 3.8vw, 2.35rem); line-height:1.1; letter-spacing:-.03em}
.travel-showcase__head p{margin:0; color:var(--muted)}
.cta-row{margin-top:1.5rem}
.cta-row--travel{margin-top:1.9rem}
.mobile-menu a{display:flex; align-items:center; min-height:52px}
.hero__content{display:grid; gap:1rem; padding:clamp(5.4rem, 10vw, 7.8rem) 0 2rem; text-shadow:none}
.hero__content > *{filter:drop-shadow(0 10px 22px rgba(0,0,0,.18))}
.hero__cta .btn,.cta-row .btn,.mobile-panel__cta .btn,.contact-card .btn{min-width:min(100%, 250px)}
body.theme-light .lightbox__media, body.theme-light .lightbox__figure img{background:#fff}
@media (max-width: 720px){.travel-showcase{margin-top:1.7rem}.cta-row{margin-top:1.2rem}.cta-row--travel{margin-top:1.6rem}}

.travel-showcase__head .section-kicker{display:none}
.cta-row,.hero__cta{margin-top:1.4rem}


/* Performance and contact section refinements */
.section, .album, .tour-carousel, .service-grid, .fleet-grid, .contact-layout { content-visibility: auto; contain-intrinsic-size: 1px 900px; }
.gallery-shot img { width: 100%; height: 100%; aspect-ratio: 1 / 1; object-fit: cover; }
.contact-card > a:not(.btn), .contact-card__address {
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:56px;
  padding:0.9rem 1rem;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.72);
  text-align:center;
}
.contact-card .btn--contact {
  width:100%;
  background:#000;
  color:#fff;
  border-color:#000;
}
.contact-card .btn--contact:hover,
.contact-card .btn--contact:focus-visible {
  background:#111;
  color:#fff;
  border-color:#111;
}
