/* ===========================================================
   Moldova-Bulgaria — mobile-first cinematic theme
   =========================================================== */
:root{
  --bg:#0a1424; --bg2:#0e1d35; --surface:#13253f; --surface2:#16294a;
  --text:#e9eff8; --muted:#9db0cc; --line:rgba(255,255,255,.10);
  --brand:#28d7e6; --brand2:#3b82f6; --gold:#ffb86b;
  --grad:linear-gradient(135deg,#22d3ee 0%,#3b82f6 100%);
  --radius:16px; --radius-sm:11px; --header-h:64px;
  --shadow:0 18px 50px -20px rgba(0,0,0,.55);
  --maxw:1180px;
  --c-top:#16223f; --c-bot:#2a6fb0;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:"Manrope",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{line-height:1.15;margin:0 0 .5em;font-weight:800;letter-spacing:-.02em;text-wrap:balance}
h1{font-size:clamp(2rem,7vw,3.6rem)}
h2{font-size:clamp(1.5rem,4.5vw,2.4rem)}
p{margin:0 0 1rem}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
.narrow{max-width:760px;margin-inline:auto}
.center{text-align:center}
.mt{margin-top:1.4rem}
.muted{color:var(--muted)}
.eyebrow{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--brand);margin-bottom:.6rem}
.lead{font-size:1.12rem;color:var(--muted);max-width:60ch}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:#fff;color:#000;padding:8px 14px;border-radius:8px;z-index:9999}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;cursor:pointer;border:0;
  font:inherit;font-weight:700;padding:.8rem 1.4rem;border-radius:999px;transition:transform .15s,box-shadow .2s,background .2s;
  white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--grad);color:#06121f;box-shadow:0 10px 28px -10px rgba(59,130,246,.7)}
.btn-primary:hover{box-shadow:0 14px 34px -10px rgba(40,215,230,.8);transform:translateY(-1px)}
.btn-ghost{background:rgba(255,255,255,.06);color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-sm{padding:.5rem .9rem;font-size:.86rem}
.btn-lg{padding:1rem 1.9rem;font-size:1.05rem}
.btn-block{display:flex;width:100%}
.btn-spinner{width:16px;height:16px;border:2px solid rgba(0,0,0,.3);border-top-color:#06121f;border-radius:50%;display:none}
.btn.is-loading .btn-spinner{display:inline-block;animation:spin .7s linear infinite}
.btn.is-loading .btn-label{opacity:.7}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background .3s,backdrop-filter .3s,box-shadow .3s}
.site-header.scrolled{background:rgba(8,17,32,.82);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
.header-inner{display:flex;align-items:center;gap:14px;height:var(--header-h)}
.brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:1.08rem;color:#fff}
.brand-name{white-space:nowrap}
@media(max-width:400px){.brand{font-size:.98rem}.brand-mark{width:30px;height:30px}}
.brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;background:var(--grad);color:#06121f}
.brand-dash{color:var(--brand)}
.brand-logo{display:block;height:36px;width:auto;max-width:190px;object-fit:contain}
.main-nav{display:none;gap:6px;margin-left:8px}
.main-nav a{padding:.5rem .8rem;border-radius:9px;color:#cdd9ec;font-weight:600;font-size:.95rem}
.main-nav a:hover{background:rgba(255,255,255,.08);color:#fff}
.main-nav a.active{color:var(--brand)}
.header-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.header-cta{display:none}
.lang-switch{position:relative}
.lang-btn{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.07);border:1px solid var(--line);
  color:#fff;padding:.45rem .7rem;min-height:44px;border-radius:999px;cursor:pointer;font:inherit;font-weight:700;font-size:.82rem}
.lang-btn .fi{border-radius:3px}
.lang-menu{position:absolute;right:0;top:calc(100% + 8px);background:var(--surface);border:1px solid var(--line);
  border-radius:12px;min-width:180px;padding:6px;list-style:none;margin:0;box-shadow:var(--shadow);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:.18s}
.lang-switch.open .lang-menu{opacity:1;visibility:visible;transform:none}
.lang-menu a{display:flex;align-items:center;gap:9px;padding:.55rem .7rem;border-radius:8px;font-weight:600;font-size:.92rem;color:#dce6f4}
.lang-menu a:hover{background:rgba(255,255,255,.08)}
.lang-menu a.active{color:var(--brand)}
.nav-toggle{display:flex;flex-direction:column;gap:5px;width:44px;height:44px;background:rgba(255,255,255,.07);
  border:1px solid var(--line);border-radius:10px;cursor:pointer;align-items:center;justify-content:center}
.nav-toggle span{width:18px;height:2px;background:#fff;border-radius:2px;transition:.25s}
body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .nav-toggle span:nth-child(2){opacity:0}
body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav drawer */
@media(max-width:859px){
  .main-nav{position:fixed;inset:var(--header-h) 0 auto 0;flex-direction:column;background:rgba(8,17,32,.97);
    backdrop-filter:blur(12px);padding:14px 20px 22px;gap:4px;border-bottom:1px solid var(--line);
    transform:translateY(-120%);transition:transform .3s;display:flex}
  body.nav-open .main-nav{transform:none}
  .main-nav a{padding:.85rem .6rem;font-size:1.05rem;border-bottom:1px solid var(--line)}
}
@media(min-width:860px){
  .main-nav{display:flex}
  .nav-toggle{display:none}
  .header-cta{display:inline-flex}
}

/* ---------- Sections ---------- */
.section{padding:clamp(3.4rem,8vw,6rem) 0}
.section-head{max-width:680px;margin-bottom:2.2rem}
body:not(.page-home) main{padding-top:var(--header-h)}
.page-hero{padding:calc(var(--header-h) + 2.6rem) 0 1rem;background:radial-gradient(120% 100% at 50% 0,rgba(40,215,230,.12),transparent 60%)}

/* ===========================================================
   CINEMATIC HERO
   =========================================================== */
.cinematic{position:relative;height:100vh}
.cine-stage{position:relative;height:100vh;width:100%;overflow:hidden;
  background:linear-gradient(180deg,var(--c-top) 0%,var(--c-bot) 100%)}
.cine-layer{position:absolute;inset:0;will-change:transform;pointer-events:none}
.cine-canvas{position:absolute;inset:0;z-index:7;pointer-events:none}
.cine-sky{z-index:0;background:radial-gradient(80% 50% at 70% 18%,rgba(255,255,255,.10),transparent 60%)}
.cine-sun{z-index:1;display:flex;justify-content:center;align-items:flex-start}
.sun-orb{margin-top:14vh;width:min(36vw,260px);height:min(36vw,260px);border-radius:50%;
  background:radial-gradient(circle at 50% 50%,#fff6e0 0%,#ffd27a 38%,rgba(255,184,107,.25) 65%,transparent 72%);
  filter:blur(2px)}
.cine-scene,.cine-mid,.cine-hills{bottom:0;top:auto;height:64vh}
.cine-scene svg,.cine-mid svg,.cine-hills svg{position:absolute;bottom:0;width:100%;height:100%}
.scene-city{z-index:2}.scene-mtn-far{z-index:2;opacity:0}.scene-coast{z-index:2;opacity:0}
.cine-mid{z-index:3}.cine-hills{z-index:4}
.cine-road{z-index:5;bottom:0;top:auto;height:34vh;overflow:hidden;
  background:linear-gradient(180deg,transparent,rgba(4,10,20,.6) 40%,#05101f)}
.road-surface{position:absolute;bottom:-2vh;left:50%;width:200%;height:40vh;transform:translateX(-50%) perspective(340px) rotateX(58deg);
  background:linear-gradient(180deg,#0b1d33,#06101d)}
.road-lines{position:absolute;top:0;left:50%;width:8px;height:200%;transform:translateX(-50%);
  background:repeating-linear-gradient(180deg,#ffd27a 0 28px,transparent 28px 64px);opacity:.7;
  animation:road 1.1s linear infinite}
@keyframes road{to{transform:translateX(-50%) translateY(64px)}}
.cine-van{z-index:6;display:flex;align-items:flex-end;justify-content:center;bottom:0;top:auto;height:62vh}
.cine-van img{width:min(86vw,720px);object-fit:contain;filter:drop-shadow(0 30px 40px rgba(0,0,0,.55));border-radius:14px}
.cine-vignette{z-index:8;background:radial-gradient(120% 80% at 50% 35%,transparent 55%,rgba(3,8,16,.7) 100%)}
.cine-content{position:absolute;z-index:10;left:0;right:0;top:18vh;text-align:center;padding-inline:20px}
.cine-kicker{display:inline-block;font-size:.8rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:#cdeffd;background:rgba(8,20,36,.45);border:1px solid rgba(255,255,255,.18);padding:.4rem .9rem;border-radius:999px;backdrop-filter:blur(6px)}
.cine-title{color:#fff;margin:.7rem auto .4rem;max-width:16ch;text-shadow:0 6px 30px rgba(0,0,0,.5)}
.cine-sub{color:#dbe9fb;max-width:54ch;margin:0 auto 1.4rem;text-shadow:0 2px 12px rgba(0,0,0,.5)}
.cine-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.cine-captions{position:absolute;z-index:9;left:0;bottom:16vh;width:100%;pointer-events:none}
.cine-caption{position:absolute;left:50%;transform:translateX(-50%);opacity:0;display:flex;align-items:center;gap:9px;
  font-weight:700;color:#fff;background:rgba(8,20,36,.5);border:1px solid rgba(255,255,255,.16);
  padding:.5rem 1rem;border-radius:999px;backdrop-filter:blur(6px);white-space:nowrap}
.cap-dot{width:9px;height:9px;border-radius:50%;background:var(--brand);box-shadow:0 0 12px var(--brand)}
.scroll-hint{position:absolute;z-index:11;bottom:22px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;
  align-items:center;gap:6px;color:#dbe9fb;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase}
.scroll-hint i{width:22px;height:34px;border:2px solid rgba(255,255,255,.5);border-radius:12px;position:relative}
.scroll-hint i::after{content:"";position:absolute;top:6px;left:50%;width:3px;height:7px;background:#fff;border-radius:2px;
  transform:translateX(-50%);animation:wheel 1.4s infinite}
@keyframes wheel{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,10px)}}

/* ---------- About ---------- */
.about-grid{display:grid;gap:2.2rem}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.about-stats>.stat{min-width:0}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem}
.stat b{display:block;font-size:1.5rem;color:#fff;overflow-wrap:anywhere}
.stat span{color:var(--muted);font-size:.9rem}
@media(max-width:400px){.about-stats{gap:10px}.stat{padding:.95rem}.stat b{font-size:1.3rem}}

/* ---------- Cards ---------- */
.cards-grid{display:grid;gap:16px;grid-template-columns:1fr}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem}
.card-ic{font-size:1.8rem;margin-bottom:.5rem}
.card h3{font-size:1.15rem}
.card p{color:var(--muted);margin-bottom:.5rem}
.card-link{color:var(--brand);font-weight:700}
.card--parcel .parcel-prices{margin-top:1rem;border-top:1px solid var(--line);padding-top:.8rem}
.parcel-route{display:block;font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem}
.parcel-row{display:flex;justify-content:space-between;padding:.25rem 0}
.parcel-row b{color:var(--brand)}

/* ---------- Routes grid ---------- */
.routes-grid{display:grid;gap:16px;grid-template-columns:1fr}
.route-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.3rem;transition:transform .18s,border-color .2s,box-shadow .2s}
.route-card:hover{transform:translateY(-3px);border-color:rgba(40,215,230,.45);box-shadow:var(--shadow)}
.route-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.7rem}
.route-flagpair{display:inline-flex;gap:4px}
.route-flagpair .fi{width:26px;height:18px;border-radius:3px;box-shadow:0 1px 4px rgba(0,0,0,.4)}
.route-flagpair.big .fi{width:38px;height:26px}
.route-price,.badge-weekly{font-size:.8rem;font-weight:700;color:var(--brand);background:rgba(40,215,230,.12);
  padding:.25rem .6rem;border-radius:999px}
.badge-weekly{color:var(--gold);background:rgba(255,184,107,.12)}
.route-name{font-size:1.3rem;margin:.2rem 0 .6rem}
.route-name .arrow{color:var(--brand);margin:0 .2em}
.route-meta{display:flex;flex-wrap:wrap;gap:12px;color:var(--muted);font-size:.88rem}
.route-card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding-top:.8rem;border-top:1px solid var(--line)}
.route-price-lg{font-weight:800;color:#fff}
.route-go{color:var(--brand);font-weight:700;font-size:.9rem;margin-top:.7rem;display:inline-block}

/* ---------- Gallery ---------- */
.gallery-grid{display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}
.gallery-item{margin:0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery-item:hover img{transform:scale(1.06)}

/* ---------- Testimonial / CTA ---------- */
.testimonial{background:var(--bg2)}
.stars{color:var(--gold);font-size:1.3rem;letter-spacing:.1em}
.testimonial blockquote{font-size:clamp(1.2rem,3vw,1.7rem);font-weight:700;margin:.6rem 0;color:#fff}
.testimonial cite{color:var(--muted);font-style:normal}
.cta-band{background:linear-gradient(135deg,rgba(34,211,238,.16),rgba(59,130,246,.16));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta-band h2{color:#fff}

/* ---------- Booking ---------- */
.booking-grid{display:grid;gap:2rem;grid-template-columns:1fr}
.booking-grid>*{min-width:0}/* let grid items shrink below map/long-string min-content (no h-scroll) */
.card-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem}
.booking-form{display:flex;flex-direction:column;gap:1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field-row{display:grid;gap:1rem;grid-template-columns:1fr}
label{font-weight:600;font-size:.92rem}
input,select,textarea{width:100%;font:inherit;color:var(--text);background:var(--bg2);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:.8rem .9rem;transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(40,215,230,.18)}
/* Consistent, visible keyboard-focus ring across interactive controls */
.btn:focus-visible,.hb-route:focus-visible,.hb-dirtab:focus-visible,.lang-btn:focus-visible,.nav-toggle:focus-visible,.cal-nav:focus-visible,.route-card:focus-visible,.card-link:focus-visible,.back-link:focus-visible,.header-cta:focus-visible,.aside-line:focus-visible,.route-go:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:8px}
.field.has-error input{border-color:#f87171}
.err{color:#fca5a5;font-size:.82rem}
.price-estimate{font-size:1.1rem}
.price-estimate b{color:var(--brand);font-size:1.3rem}

/* ── Booking availability calendar ── */
.calendar{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.6rem .55rem .75rem;-webkit-user-select:none;user-select:none}
.calendar.has-error{border-color:#f87171}
.cal-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}
.cal-title{font-weight:700;font-size:1rem;text-transform:capitalize}
.cal-nav{width:40px;height:40px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-size:1.5rem;line-height:1;border:1px solid var(--line);background:var(--surface);color:var(--text);border-radius:10px;cursor:pointer;touch-action:manipulation}
.cal-nav:hover:not(:disabled){background:var(--surface2);border-color:var(--brand)}
.cal-nav:disabled{opacity:.3;cursor:default}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-weekdays{margin-bottom:4px}
.cal-wd{text-align:center;font-size:.68rem;text-transform:uppercase;letter-spacing:.02em;color:var(--muted);padding:.2rem 0}
.cal-day{display:flex;align-items:center;justify-content:center;position:relative;min-height:clamp(40px,11.5vw,46px);font-size:.95rem;border-radius:10px;color:var(--muted);touch-action:manipulation}
.cal-day.is-empty{visibility:hidden}
.cal-day.is-closed{color:rgba(157,176,204,.32);text-decoration:line-through;text-decoration-thickness:1px}
.cal-day.is-open{color:var(--text);background:rgba(40,215,230,.10);border:1px solid rgba(40,215,230,.28);cursor:pointer;font-weight:600}
.cal-day.is-open::after{content:"";position:absolute;bottom:5px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--brand)}
.cal-day.is-open:hover{background:rgba(40,215,230,.2);border-color:var(--brand)}
.cal-day.is-open:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.cal-day.is-selected{background:var(--grad);color:#06121f;border-color:transparent;font-weight:800}
.cal-day.is-selected::after{background:#06121f}
.cal-empty{margin:.6rem 0 .2rem;text-align:center;color:var(--muted);font-size:.9rem}
.calendar-hint{margin:.5rem 0 0;font-size:.9rem;color:var(--muted);min-height:1.2em}
.calendar-hint.is-set{color:var(--text);font-weight:500}
/* Small phones: reclaim horizontal space for the form + calendar */
@media(max-width:480px){
  .booking-section .container{padding-left:14px;padding-right:14px}
  .booking-form.card-panel{padding:1.15rem}
  .calendar{padding:.55rem .4rem .7rem}
}
.form-alt{color:var(--muted);font-size:.9rem;text-align:center}
.form-alt a{color:var(--brand);font-weight:700}
.aside-title{font-size:1.1rem;margin-bottom:.7rem}
.route-map{height:300px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:#0a1424}
.route-map--booking{height:280px;margin-bottom:1rem}
.aside-contact{display:flex;flex-direction:column;gap:.5rem}
.aside-line{font-weight:600}

/* ---------- Route detail ---------- */
.route-hero{position:relative;height:62vh;min-height:420px;margin-top:0}
body:not(.page-home) main .route-hero{margin-top:calc(-1 * var(--header-h));padding-top:0}
.route-hero-map{position:absolute;inset:0;height:100%;background:#0a1424;z-index:1}
.route-hero-overlay{position:absolute;inset:0;z-index:2;display:flex;align-items:flex-end;
  background:linear-gradient(180deg,rgba(8,17,32,.5) 0,rgba(8,17,32,.2) 30%,rgba(8,17,32,.92) 100%);
  pointer-events:none}
.route-hero-overlay .container{padding-bottom:1.8rem;width:100%}
.route-hero-overlay a,.route-hero-overlay .btn{pointer-events:auto}
.back-link{display:inline-block;color:#cdeffd;font-weight:600;margin-bottom:.6rem}
.route-hero h1{color:#fff;margin:.4rem 0}
.route-hero-meta{display:flex;flex-wrap:wrap;gap:14px;color:#dbe9fb;margin-bottom:1rem}
.route-hero-cta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.route-hero-price{color:#fff;font-size:1.1rem}
.route-hero-price strong{color:var(--brand);font-size:1.4rem}
.route-body{display:grid;gap:2rem;grid-template-columns:1fr}
.route-about{font-size:1.08rem;color:#cdd9ec}
.dep-list{display:flex;flex-direction:column;gap:10px}
.dep-row{display:grid;grid-template-columns:1fr auto auto auto;gap:12px;align-items:center;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.8rem 1rem}
.dep-row.soldout{opacity:.55}
.dep-d{font-weight:700;display:block}
.dep-t{color:var(--muted);font-size:.85rem}
.pill{font-size:.78rem;font-weight:700;padding:.25rem .6rem;border-radius:999px}
.pill-ok{color:#34d399;background:rgba(52,211,153,.14)}
.pill-out{color:#fca5a5;background:rgba(248,113,113,.14)}
.dep-price{font-weight:700;color:#fff}
.info-callout{margin-top:1.6rem;background:rgba(40,215,230,.08);border:1px solid rgba(40,215,230,.25);border-radius:var(--radius);padding:1.2rem}
.muted-box{background:var(--surface);border:1px dashed var(--line);border-radius:var(--radius);padding:1.2rem;color:var(--muted)}
.facts .fact{display:flex;justify-content:space-between;padding:.55rem 0;border-bottom:1px solid var(--line)}
.facts .fact span{color:var(--muted)}
.facts .fact b{color:#fff}

/* ---------- Contact ---------- */
.contact-grid{display:grid;gap:14px;grid-template-columns:1fr}
.contact-card{display:block;text-align:center}
.contact-ic{font-size:1.8rem}
.contact-card h3{font-size:1rem;margin:.4rem 0 .2rem}
.contact-card p{color:var(--muted);margin:0}
.contact-foot{display:flex;flex-direction:column;gap:1rem;margin-top:1.4rem}
.contact-cities{color:var(--brand);font-weight:600}
.contact-foot-actions{display:flex;flex-direction:column;gap:1rem}
.contact-social{display:flex;gap:14px;flex-wrap:wrap}
.contact-social a{color:var(--muted);font-weight:600}
.contact-social a:hover{color:var(--brand)}

/* ---------- Success ---------- */
.success-section{padding-top:calc(var(--header-h) + 2rem)}
.success-card{text-align:center}
.success-check{width:62px;height:62px;border-radius:50%;background:var(--grad);color:#06121f;font-size:2rem;
  display:grid;place-items:center;margin:0 auto 1rem;font-weight:800}
.success-ref{display:inline-flex;flex-direction:column;gap:2px;background:var(--bg2);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:.7rem 1.4rem;margin:1rem auto}
.success-ref span{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.success-ref b{font-size:1.3rem;color:var(--brand);letter-spacing:.05em}
.success-summary{text-align:left;margin:1.4rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1rem 0}
.ssum-row{display:flex;justify-content:space-between;gap:12px;padding:.35rem 0}
.ssum-row span{color:var(--muted)}
.emailed{color:var(--muted);font-size:.86rem;margin-top:.6rem}
.addinfo{text-align:left;background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem;margin-top:1rem}
.addinfo-row{display:flex;gap:10px;flex-wrap:wrap}
.addinfo-row input{flex:1;min-width:180px}
.addinfo textarea{margin-top:.6rem}
.addinfo-done{color:#34d399;font-weight:700}
.success-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:1.4rem}

/* ---------- Footer ---------- */
.site-footer{background:#070f1d;border-top:1px solid var(--line);padding:3rem 0 1.4rem;margin-top:2rem}
.footer-grid{display:grid;gap:2rem;grid-template-columns:1fr}
.brand--footer{color:#fff;margin-bottom:.7rem}
.footer-tagline{color:var(--muted);max-width:30ch}
.footer-social{display:flex;gap:10px;margin-top:.8rem}
.footer-social a{width:38px;height:38px;display:grid;place-items:center;border-radius:10px;background:rgba(255,255,255,.06);color:#cdd9ec}
.footer-social a:hover{background:var(--grad);color:#06121f}
.footer-col h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:#fff;margin-bottom:.8rem}
.footer-col a,.footer-col span{display:block;color:var(--muted);padding:.22rem 0}
.footer-col a:hover{color:var(--brand)}
.footer-langs{display:flex;flex-wrap:wrap;gap:6px 14px}
.footer-langs a{display:inline}
.footer-langs a.active{color:var(--brand)}
.footer-bottom{display:flex;flex-direction:column;gap:.4rem;justify-content:space-between;border-top:1px solid var(--line);
  margin-top:2rem;padding-top:1.2rem;color:var(--muted);font-size:.85rem}
.footer-muted{color:#64748b}

/* ---------- Reveal (JS-gated so no-JS users still see content) ---------- */
html.js .reveal{opacity:0;transform:translateY(26px)}
html.js .reveal.in{opacity:1;transform:none;transition:opacity .7s,transform .7s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}
  .road-lines,.scroll-hint i::after{animation:none}}

/* ---------- Leaflet pins + route line ---------- */
.rm-pin{position:relative}
.rm-dot{position:absolute;left:50%;top:50%;width:14px;height:14px;border-radius:50%;transform:translate(-50%,-50%);
  background:var(--brand);border:2px solid #06121f;box-shadow:0 0 0 4px rgba(40,215,230,.3)}
.rm-pin--to .rm-dot{background:var(--gold);box-shadow:0 0 0 4px rgba(255,184,107,.3)}
.rm-pin--via .rm-dot{background:#a78bfa;width:10px;height:10px;box-shadow:0 0 0 3px rgba(167,139,250,.3)}
.rm-pin--stop .rm-dot{background:var(--brand);box-shadow:0 0 0 4px rgba(40,215,230,.32)}
.rm-label{position:absolute;left:14px;top:-4px;white-space:nowrap;font-weight:700;font-size:.72rem;color:#fff;
  background:rgba(8,17,32,.8);padding:2px 7px;border-radius:6px;border:1px solid var(--line)}
.rm-route{stroke-dasharray:10 8;animation:dash 1s linear infinite}
@keyframes dash{to{stroke-dashoffset:-18}}
.leaflet-container{background:#0a1424;font-family:inherit}

/* ---------- 404 ---------- */
.page-404{display:grid;place-items:center;min-height:100vh;text-align:center}
.error-wrap{padding:24px}
.error-code{font-size:clamp(4rem,18vw,9rem);font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.error-msg{color:var(--muted);max-width:40ch;margin:0 auto 1.4rem}
.error-foot{margin-top:1.6rem;color:var(--muted)}
.error-foot a{color:var(--brand)}

/* ===========================================================
   Desktop breakpoints
   =========================================================== */
@media(min-width:680px){
  .field-row{grid-template-columns:1fr 1fr}
  .field--seats{max-width:160px}
  .cards-grid{grid-template-columns:repeat(2,1fr)}
  .routes-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .contact-grid{grid-template-columns:repeat(2,1fr)}
  .footer-bottom{flex-direction:row}
  .contact-foot{flex-direction:row;justify-content:space-between;align-items:center}
  .contact-foot-actions{flex-direction:row;align-items:center}
}
@media(min-width:920px){
  .about-grid{grid-template-columns:1.2fr 1fr;align-items:center}
  .cards-grid{grid-template-columns:repeat(4,1fr)}
  .routes-grid{grid-template-columns:repeat(3,1fr)}
  .booking-grid{grid-template-columns:1.1fr .9fr;align-items:start}
  .route-body{grid-template-columns:1.6fr 1fr}
  .contact-grid{grid-template-columns:repeat(4,1fr)}
  .footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}
  .route-map--booking{height:420px}
}

/* ───────────── New hero + inline booking widget ───────────── */
.hero{position:relative;overflow:hidden;padding:calc(var(--header-h) + 1.4rem) 0 2.4rem;background:radial-gradient(125% 100% at 82% 0,#103056 0,#0a1424 58%)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-glow{position:absolute;border-radius:50%;filter:blur(64px);opacity:.5;pointer-events:none}
.hero-glow--a{width:60vw;height:60vw;background:rgba(40,215,230,.18);top:-14%;right:-12%}
.hero-glow--b{width:46vw;height:46vw;background:rgba(59,130,246,.16);bottom:-16%;left:-12%}
.hero-map{position:absolute;inset:0;width:100%;height:100%;opacity:.5}
.hero-line{fill:none;stroke:rgba(125,180,220,.4);stroke-width:1.4;stroke-linecap:round;stroke-dasharray:3 5}
.hero-line.is-active{stroke:var(--brand);stroke-width:2.3;stroke-dasharray:none;filter:drop-shadow(0 0 6px rgba(40,215,230,.6))}
.hero-dot{fill:#7fb4dc;transition:fill .2s}
.hero-dot.is-active,.hero-dot--hub{fill:var(--brand)}
.hero-dot--hub{filter:drop-shadow(0 0 7px rgba(40,215,230,.75))}
.hero-lbl{fill:#d4e6f6;font-size:11px;font-weight:600;text-anchor:middle;paint-order:stroke;stroke:#0a1424;stroke-width:3px;stroke-linejoin:round}
.hero-lbl--hub{fill:#fff;font-size:12px}
.hero-inner{position:relative;z-index:2;display:grid;gap:1.5rem;grid-template-columns:1fr}
.hero-copy>*{min-width:0}
.hero-kicker{display:inline-flex;align-items:center;gap:.5rem;color:var(--brand);font-weight:700;font-size:.76rem;text-transform:uppercase;letter-spacing:.09em;margin:0}
.hk-dot{width:8px;height:8px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 4px rgba(40,215,230,.18)}
.hero-title{font-size:clamp(1.95rem,7.4vw,3.2rem);line-height:1.07;margin:.55rem 0 .55rem;letter-spacing:-.02em;text-wrap:balance}
.hero-sub{color:var(--muted);font-size:1.02rem;max-width:46ch;margin:0;text-wrap:pretty}
.hero-trust{display:flex;flex-wrap:wrap;gap:.4rem .9rem;margin-top:1rem}
.ht-item{font-size:.82rem;color:#aac4e0;font-weight:600}

.hero-book{position:relative;z-index:2;padding:1.2rem 1.1rem 1.3rem;box-shadow:var(--shadow)}
.hb-progress{display:flex;gap:6px;list-style:none;padding:0;margin:0 0 1rem}
.hb-progress li{height:4px;flex:1;border-radius:3px;background:rgba(255,255,255,.12);transition:background .35s}
.hb-progress li.is-on{background:var(--grad)}
.hb-step[hidden]{display:none}
.hb-title{font-size:1.15rem;margin:0 0 .8rem}
.hb-dirtoggle{display:grid;grid-template-columns:1fr 1fr;gap:6px;background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:5px;margin-bottom:.9rem}
.hb-dirtab{padding:.6rem .4rem;border:0;background:transparent;color:var(--muted);font:inherit;font-weight:700;font-size:.85rem;border-radius:9px;cursor:pointer;touch-action:manipulation}
.hb-dirtab.is-on{background:var(--surface2);color:var(--text);box-shadow:0 2px 8px -5px rgba(0,0,0,.6)}
.hb-routes{display:flex;flex-direction:column;gap:.55rem}
.hb-route{display:flex;align-items:center;gap:.6rem;width:100%;text-align:left;padding:.8rem .9rem;border:1px solid var(--line);background:var(--bg2);border-radius:12px;color:var(--text);cursor:pointer;transition:border-color .15s,transform .08s;touch-action:manipulation}
.hb-route:hover{border-color:var(--brand)}
.hb-route:active{transform:scale(.99)}
.hb-route-main{display:flex;flex-direction:column;gap:.15rem;flex:1;min-width:0}
.hb-route-dir{font-weight:700;font-size:.98rem}
.hb-route-price{color:var(--brand);font-size:.83rem;font-weight:600}
.hb-route-go{font-size:1.5rem;line-height:1;color:var(--muted)}
.hb-empty{color:var(--muted);font-size:.9rem;text-align:center;padding:1rem 0}
.hb-back{display:inline-flex;align-items:center;gap:.25rem;min-height:42px;padding:.45rem .85rem .45rem .65rem;margin:0 0 .7rem;background:var(--bg2);border:1px solid var(--line);border-radius:11px;color:var(--muted);font:inherit;font-weight:600;font-size:.88rem;cursor:pointer;touch-action:manipulation;transition:color .15s,border-color .15s,background .15s,transform .08s}
.hb-back:hover{color:var(--text);border-color:var(--brand);background:rgba(40,215,230,.08)}
.hb-back:active{transform:scale(.97)}
.hb-back:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.hb-back .hb-back-i{font-size:1.2rem;line-height:1;margin-top:-2px}
.hb-routelabel{color:var(--brand);font-weight:600;font-size:.92rem;margin:.1rem 0 .8rem}
.hb-dropoff{margin:0 0 .9rem}
.hb-dropoff[hidden]{display:none}
.hb-dropoff label{display:block;font-size:.82rem;color:var(--muted);font-weight:600;margin-bottom:.35rem}
.hb-summary{color:var(--text);background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:.6rem .7rem;font-size:.9rem;font-weight:500;margin:.1rem 0 .85rem}
.hb-fields{display:flex;flex-direction:column;gap:.6rem}
.hb-row{display:grid;grid-template-columns:1fr 82px;gap:.6rem}
.hb-error{color:#fca5a5;font-size:.85rem;margin:.6rem 0 0}
.hb-fine{color:var(--muted);font-size:.84rem;text-align:center;margin:.7rem 0 0}
.hb-fine a{color:var(--brand);font-weight:700}
.hb-done{text-align:center;padding:.4rem 0}
.hb-check{width:72px;height:72px;margin:.2rem auto .7rem}
.hb-check svg{width:100%;height:100%;overflow:visible}
.hb-check-c{fill:none;stroke:var(--brand);stroke-width:2.5;stroke-dasharray:151;stroke-dashoffset:151}
.hb-check-p{fill:none;stroke:var(--brand);stroke-width:3.4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:30;stroke-dashoffset:30}
.hb-done-text{color:var(--muted);margin:.2rem 0 1rem}
.hb-ref{font-size:.95rem;margin:0 0 1.2rem}
.hb-ref b{color:var(--brand);letter-spacing:.05em}
.hero-scroll{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);z-index:2;width:26px;height:42px;border:2px solid rgba(255,255,255,.22);border-radius:14px;display:none}
.hero-scroll i{position:absolute;top:8px;left:50%;width:4px;height:8px;background:#fff;border-radius:2px;transform:translateX(-50%);animation:heroScroll 1.7s infinite}
@keyframes heroScroll{0%{opacity:0;top:8px}40%{opacity:1}80%{opacity:0;top:21px}}
@media(min-width:860px){
  .hero{padding:calc(var(--header-h) + 2.6rem) 0 3.4rem}
  .hero-inner{grid-template-columns:1.05fr .95fr;gap:2.6rem;align-items:center}
  .hero-title{margin-top:.7rem}
  .hero-map{opacity:.72}
  .hero-book{max-width:440px;margin-left:auto;padding:1.6rem 1.5rem}
}
@media(min-width:1100px){ .hero-inner{gap:3.2rem} .hero-title{font-size:3.3rem} }
@media(prefers-reduced-motion:reduce){.hero-scroll i{animation:none}}
