/* route-hero.css — an EXACT replica of the homepage hero for static route
   pages. Everything is scoped under .rhero (and .route-intro) so it never
   collides with a route page's own .hero/.sf/.chip rules, and it defines its
   own CSS variables because route pages use hard-coded colours (no :root vars). */
.rhero{
  --navy:#0f1f52;--navy-dk:#0a1540;--navy-lt:#1a3080;--blue:#3d5af1;
  --sky:#3aaeee;--sky-lt:#7dd4f8;--yellow:#ffe600;--white:#fff;
  min-height:calc(100vh - 88px);position:relative;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:0 1.5rem 5rem;text-align:center;
}
.rhero::before{content:'';position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(58,174,238,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(58,174,238,.06) 1px,transparent 1px);
  background-size:52px 52px}
.rhero-glow{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 70% 60% at 50% 40%,rgba(61,90,241,.45) 0%,transparent 65%),radial-gradient(ellipse 40% 40% at 15% 80%,rgba(58,174,238,.2) 0%,transparent 55%),radial-gradient(ellipse 40% 40% at 85% 80%,rgba(58,174,238,.15) 0%,transparent 55%)}
/* animated flight arcs (identical to homepage) */
.rhero-arc{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}
.rhero-arc-path{fill:none;stroke-width:1;stroke-dasharray:900;stroke-dashoffset:900;animation:rh-drawArc 3s ease-out forwards}
.rhero-arc-path:nth-child(1){stroke:rgba(58,174,238,.18)}
.rhero-arc-path:nth-child(2){stroke:rgba(61,90,241,.13);animation-delay:.4s}
.rhero-arc-path:nth-child(3){stroke:rgba(58,174,238,.09);animation-delay:.9s}
.rhero-arc-dot{opacity:0;animation:rh-dotFly 3s ease-in-out forwards}
.rhero-arc-dot:nth-child(4){fill:var(--sky)}
.rhero-arc-dot:nth-child(5){fill:var(--yellow);animation-delay:.4s}
.rhero-arc-dot:nth-child(6){fill:var(--sky);animation-delay:.9s}
.rhero-inner{position:relative;z-index:5;width:100%;max-width:1040px;display:flex;flex-direction:column;align-items:center;gap:1.2rem;transform:translateY(-46px)}
.rhero-h1{font-size:clamp(1.9rem,4.2vw,3.1rem);font-weight:900;line-height:1.05;letter-spacing:-.04em;color:var(--white);opacity:0;animation:rh-fadeUp .7s ease .15s both}
.rhero .h1-yellow{color:var(--yellow)}
.rhero .h1-sky{color:var(--sky)}
/* scroll cue (identical to homepage) */
.rhero-cue{position:absolute;left:50%;bottom:1.1rem;transform:translateX(-50%);z-index:6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.28rem;width:66px;height:78px;border-radius:16px;border:2px solid rgba(58,174,238,.55);background:rgba(10,21,64,.5);box-shadow:0 10px 28px rgba(0,0,0,.35);cursor:pointer;backdrop-filter:blur(8px);animation:rh-cueFloat 2s ease-in-out infinite;padding:0}
.rhero-cue:hover{border-color:rgba(255,230,0,.9);box-shadow:0 12px 32px rgba(255,230,0,.18)}
.rhero-mouse{width:24px;height:34px;border:2.2px solid var(--sky-lt);border-radius:13px;display:flex;align-items:flex-start;justify-content:center;padding-top:6px}
.rhero-wheel{width:4px;height:9px;border-radius:999px;background:var(--yellow);animation:rh-wheel 1.6s ease-in-out infinite}
.rhero-arrow{font-size:1rem;line-height:1;color:var(--sky-lt)}

/* ---- search bar (mirrors homepage) ---- */
.rhero .search-wrap{width:100%;max-width:1040px;opacity:0;animation:rh-fadeUp .7s ease .35s both}
.rhero .search-bar{display:flex;align-items:stretch;background:rgba(8,18,50,.75);border:1.2px solid rgba(58,174,238,.30);border-radius:24px;backdrop-filter:blur(20px);box-shadow:0 0 0 1px rgba(61,90,241,.12),0 28px 66px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.06);transition:border-color .3s,box-shadow .3s}
.rhero .search-bar:focus-within{border-color:rgba(58,174,238,.55);box-shadow:0 0 0 3px rgba(58,174,238,.12),0 24px 60px rgba(0,0,0,.45)}
.rhero .sf{flex:1;padding:1.22rem 1.48rem;cursor:pointer;position:relative;transition:background .2s;border-radius:20px;min-width:0;text-align:left;background:none;border:0;font-family:inherit}
.rhero .sf:hover{background:rgba(58,174,238,.07)}
.rhero .sf+.sf::before{content:'';position:absolute;left:0;top:20%;height:60%;width:1px;background:rgba(58,174,238,.18)}
.rhero .sf-label{font-size:.72rem;font-weight:700;letter-spacing:normal;text-transform:none;color:var(--sky);opacity:.78;margin-bottom:.36rem;display:flex;align-items:center;gap:.42rem}
.rhero .sf-label img{width:16px;height:16px;object-fit:contain;opacity:1}
.rhero .sf-value{display:block;font-size:1.16rem;font-weight:800;color:var(--white);letter-spacing:-.02em;line-height:1.02;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rhero .sf-sub{display:block;font-size:.84rem;color:rgba(255,255,255,.80);margin-top:.28rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rhero .swap-wrap{position:relative;display:flex;align-items:center;flex:0 0 0;width:0;z-index:6}
.rhero .swap-btn{position:absolute;left:0;top:50%;transform:translate(-75%,-50%);width:2.45rem;height:2.45rem;border-radius:50%;border:1px solid rgba(58,174,238,.4);background:var(--navy-dk);color:var(--sky);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:4;transition:all .22s;box-shadow:0 3px 10px rgba(0,0,0,.4)}
.rhero .swap-btn:hover{background:rgba(58,174,238,.2);transform:translate(-75%,-50%) rotate(180deg)}
.rhero .sf-search{flex-shrink:0;display:flex;align-items:center;padding:.7rem}
.rhero .search-btn{background:var(--yellow);color:#070e24;border:none;border-radius:16px;padding:0 2.05rem;height:100%;min-height:62px;font-size:.95rem;font-weight:800;cursor:pointer;display:flex;align-items:center;gap:.58rem;box-shadow:0 5px 22px rgba(255,230,0,.4);transition:all .15s;white-space:nowrap;font-family:inherit;text-decoration:none}
.rhero .search-btn:hover{background:#ffed33;box-shadow:0 6px 28px rgba(255,230,0,.6);transform:scale(1.02)}
.rhero .chips-row{display:flex;flex-wrap:wrap;gap:.55rem;justify-content:center;margin-top:1.08rem}
.rhero .chip{font-size:.86rem;font-weight:600;padding:.5rem 1.15rem;border-radius:100px;border:1px solid rgba(58,174,238,.4);color:var(--sky-lt);background:rgba(58,174,238,.06)}

/* ---- route intro (moved below the hero) ---- */
.route-intro{max-width:1160px;margin:0 auto;padding:1.6rem 8rem .2rem;text-align:left}
.route-intro h1{font-size:clamp(1.8rem,3.4vw,2.7rem);font-weight:900;line-height:1.14;letter-spacing:-.02em;color:#0f1f52;margin:0 0 .9rem}
.route-intro h1 .h1-yellow{color:#3d5af1}
.route-intro h1 .h1-sky{color:#3aaeee}
.route-intro-sub{font-size:1.05rem;line-height:1.65;color:#6b7280;max-width:900px;margin:0}
.route-intro-sub b{color:#3d5af1;font-weight:800}

/* ---- pickers: EXACT homepage modals ---- */
.datepicker-overlay,.pax-overlay,.rh-city-overlay{--yellow:#ffe600;--sky:#3aaeee;--sky-lt:#7dd4f8;--blue:#3d5af1;--navy-dk:#0a1540;--navy-lt:#1a3080;--border:rgba(58,174,238,0.18);--white:#fff}
.datepicker-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(5px);z-index:4000;display:none;align-items:center;justify-content:center;padding:1rem}
.datepicker-overlay.open{display:flex}
.datepicker{position:relative;background:#0d1b45;border:1px solid rgba(58,174,238,.3);border-radius:18px;padding:1.2rem;width:100%;max-width:360px;box-shadow:0 20px 60px rgba(0,0,0,.6);z-index:4001;animation:rh-fadeUp .2s ease}
.dp-header{display:flex;align-items:center;justify-content:center;margin-bottom:1rem;gap:.7rem}
.dp-month-year-wrap{min-width:0;display:flex;align-items:center}
.dp-month-year{font-size:.95rem;font-weight:800;letter-spacing:-.02em}
.dp-month-year-selects{display:none;gap:.45rem;align-items:center}
.dp-select{appearance:none;-webkit-appearance:none;background:rgba(58,174,238,.08);border:1px solid rgba(58,174,238,.3);color:var(--white);border-radius:8px;padding:.38rem .5rem;font-size:.78rem;font-weight:700;outline:none;min-width:104px;font-family:inherit;cursor:pointer}
.dp-select:focus{border-color:rgba(58,174,238,.55);background:rgba(58,174,238,.14)}
.dp-select option{background:#0d1b45;color:#fff}
.dp-nav{display:flex;gap:.4rem}
.dp-nav-btn{width:28px;height:28px;border-radius:8px;border:1px solid rgba(58,174,238,.25);background:transparent;color:var(--sky-lt);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all .15s;font-family:inherit}
.dp-nav-btn:hover{background:rgba(58,174,238,.15)}
.dp-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:.4rem}
.dp-wd{text-align:center;font-size:.6rem;font-weight:700;color:rgba(255,255,255,.74);padding:.3rem 0}
.dp-days{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.dp-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;border:1px solid transparent}
.dp-day:hover:not(.dp-empty):not(.dp-past){background:rgba(58,174,238,.18);color:var(--white)}
.dp-day.dp-empty{cursor:default}
.dp-day.dp-past{color:rgba(255,255,255,.18);cursor:not-allowed}
.dp-day.dp-today{border-color:rgba(58,174,238,.4);color:var(--sky-lt)}
.dp-day.dp-selected{background:var(--yellow);color:#070e24;font-weight:900;border-color:var(--yellow)}
.pax-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(5px);z-index:4000;display:none;align-items:center;justify-content:center;padding:1rem}
.pax-overlay.open{display:flex}
.pax-modal{background:#0d1b45;border:1px solid rgba(58,174,238,.25);border-radius:20px;padding:1.5rem;width:100%;max-width:360px;box-shadow:0 20px 60px rgba(0,0,0,.6);animation:rh-fadeUp .2s ease}
.pax-modal-title{font-size:.95rem;font-weight:800;margin-bottom:1.2rem}
.pax-row{display:flex;align-items:center;justify-content:space-between;gap:.9rem;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.05)}
.pax-row:last-of-type{border-bottom:none}
.pax-row-label{font-size:.85rem;font-weight:700}
.pax-row-sub{font-size:.62rem;color:rgba(255,255,255,.76);margin-top:.1rem}
.pax-row>div:first-child{min-width:0;flex:1}
.pax-counter{display:flex;align-items:center;gap:.6rem}
.pax-btn{width:30px;height:30px;border-radius:8px;border:1px solid rgba(58,174,238,.3);background:transparent;color:var(--sky-lt);font-size:.95rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;line-height:1;font-family:inherit}
.pax-btn:hover{background:rgba(58,174,238,.18)}
.pax-btn:disabled{opacity:.25;cursor:not-allowed}
.pax-count{font-size:.95rem;font-weight:800;min-width:20px;text-align:center}
.cabin-row{margin-top:1rem}
.cabin-label{font-size:.6rem;font-weight:700;text-transform:uppercase;color:rgba(255,255,255,.94);margin-bottom:.6rem;display:block}
.cabin-btns{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}
.cabin-btn{padding:.5rem;border-radius:9px;border:1px solid rgba(255,255,255,.1);background:transparent;color:rgba(255,255,255,.80);font-size:.72rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;text-align:center}
.cabin-btn.on{background:rgba(61,90,241,.3);border-color:var(--blue);color:var(--white)}
.pax-done-btn{width:100%;margin-top:1.2rem;background:var(--yellow);color:#070e24;border:none;border-radius:12px;padding:.75rem;font-size:.9rem;font-weight:800;cursor:pointer;font-family:inherit;transition:all .15s}
.pax-done-btn:hover{background:#ffed33}
.rh-city-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);z-index:4000;display:none;align-items:center;justify-content:center;padding:1rem}
.rh-city-overlay.open{display:flex}
.rh-city-modal{background:var(--navy-lt);border:1px solid var(--border);border-radius:20px;padding:1.5rem;width:100%;max-width:480px}
.rh-city-title{font-size:.95rem;font-weight:800;text-align:center;margin-bottom:1rem}
.rh-finput{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(58,174,238,.25);border-radius:12px;padding:.75rem .9rem;color:#fff;font-size:1rem;font-family:inherit;margin-bottom:1rem;outline:none}
.rh-finput:focus{border-color:rgba(58,174,238,.55)}
.rh-city-list{display:flex;flex-direction:column;gap:.4rem;max-height:320px;overflow-y:auto}
.rh-city-item{display:flex;align-items:center;gap:.8rem;width:100%;text-align:left;background:rgba(255,255,255,.03);border:1px solid transparent;border-radius:12px;padding:.7rem .85rem;cursor:pointer;color:#fff;font-family:inherit}
.rh-city-item:hover{background:rgba(58,174,238,.12);border-color:rgba(58,174,238,.3)}
.rh-city-code{font-size:.92rem;font-weight:800;color:var(--sky);min-width:40px}
.rh-city-name{font-size:.93rem;font-weight:700}
.rh-city-air{font-size:.74rem;color:rgba(255,255,255,.55)}
.rhero .swap-btn svg{width:17px;height:17px}

@keyframes rh-fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes rh-drawArc{to{stroke-dashoffset:0}}
@keyframes rh-dotFly{0%{opacity:0}10%{opacity:1}85%{opacity:1}100%{opacity:0}}
@keyframes rh-cueFloat{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-8px)}}
@keyframes rh-wheel{0%{transform:translateY(0);opacity:1}60%{transform:translateY(8px);opacity:.25}100%{transform:translateY(0);opacity:1}}

@media(max-width:860px){
  .rhero{min-height:calc(100vh - 64px);padding:1.5rem 1rem 3rem}
  .rhero-inner{transform:translateY(0)}
  .rhero .search-bar{flex-direction:column}
  .rhero .swap-wrap{width:100%;height:0}
  .rhero .swap-btn{left:50%;top:0;transform:translate(-50%,-50%) rotate(90deg)}
  .rhero .swap-btn:hover{transform:translate(-50%,-50%) rotate(270deg)}
  .rhero .sf{border-bottom:1px solid rgba(58,174,238,.14)}
  .rhero .sf-search{padding:.7rem 1rem 1rem}
  .rhero .search-btn{width:100%;justify-content:center}
  .rhero-cue{display:none}
  .route-intro{padding:1.3rem 1.5rem .2rem}
}
