/* css4 - Minimal Glass Violet Theme
	 Identity: Deep indigo to violet gradient, glass panels, minimalist sans, vertical layering */

:root {
	--gv-bg1:#0f101d; --gv-bg2:#171b32; --gv-bg3:#231f48;
	--gv-surface: rgba(255,255,255,0.08);
	--gv-surface-alt: rgba(255,255,255,0.14);
	--gv-line: rgba(160,170,255,0.22);
	--gv-accent:#8d6bff;
	--gv-accent-alt:#c48bff;
	--gv-text:#eff1ff;
	--gv-muted:#9aa1c9;
	--gv-radius:32px;
	--gv-shadow:0 24px 70px -24px rgba(15,10,50,.65),0 10px 30px -10px rgba(15,10,50,.55);
}

html, body { background: linear-gradient(150deg,var(--gv-bg1),var(--gv-bg2) 55%,var(--gv-bg3)); color: var(--gv-text); }
header.top-bar { background: var(--gv-surface-alt); backdrop-filter: blur(20px); border:1px solid var(--gv-line); border-radius: var(--gv-radius); box-shadow:0 8px 30px -14px rgba(0,0,0,.55); }
header.top-bar .logo { color: var(--gv-accent); letter-spacing:1px; font-weight:600; }

.hero { min-height:500px; }
/* Grid restructured hero overlay for tighter layout */
.hero .overlay { position:relative; display:grid; grid-template-columns: minmax(420px,560px) minmax(420px,1fr); align-items:center; gap:46px 64px; background: linear-gradient(125deg,#191e3a,#1d2144 55%,#261d55); border:1px solid var(--gv-line); border-radius: var(--gv-radius); padding:50px 56px 56px; box-shadow: var(--gv-shadow); overflow:hidden; max-width:1250px; margin:0 auto; }
.hero .overlay:before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 75% 28%,rgba(200,140,255,.28),transparent 60%); mix-blend-mode:overlay; }
.hero-content h1 { font-size:clamp(2.3rem,3.9vw,3.35rem); line-height:1.05; background: linear-gradient(90deg,var(--gv-accent),var(--gv-accent-alt)); -webkit-background-clip:text; background-clip:text; color:transparent; letter-spacing:-0.6px; filter:drop-shadow(0 4px 14px rgba(0,0,0,.42)); margin:0 0 10px; }
.features { display:flex; gap:8px; flex-wrap:wrap; margin:16px 0 18px; }
.features li { background: var(--gv-surface); border:1px solid var(--gv-line); padding:8px 14px; font-size:10px; font-weight:600; letter-spacing:.85px; color: var(--gv-accent); border-radius:14px; position:relative; overflow:hidden; }
.features li:before { content:""; position:absolute; inset:0; background: radial-gradient(circle at 70% 30%,rgba(200,140,255,.3),transparent 70%); opacity:.35; }
.features li:hover { background: var(--gv-surface-alt); color:#fff; }

/* Call box in-flow with subtle highlight */
.call-box.main { background: linear-gradient(135deg,var(--gv-accent),var(--gv-accent-alt)); border:1px solid rgba(255,255,255,.25); box-shadow:0 16px 40px -18px rgba(140,110,255,.55); border-radius:18px; margin-top:10px; }

/* Hero media lowered emphasis, right aligned via self-end */
.hero-media { align-self:stretch; display:flex; justify-content:flex-end; }
.hero-media-inner { width:100%; max-width:540px; aspect-ratio: 16 / 10; border-radius:34px; background: var(--gv-surface-alt); border:1px solid var(--gv-line); backdrop-filter: blur(16px); box-shadow:0 34px 74px -30px rgba(0,0,0,.72); overflow:hidden; position:relative; }
.hero-media-inner:before { content:""; position:absolute; inset:0; background: linear-gradient(150deg,rgba(255,255,255,.28),rgba(255,255,255,0)); mix-blend-mode:overlay; }
.hero-media img { width:100%; height:100%; object-fit:cover; filter:saturate(1.15) contrast(1.05); }
/* Slider (shared) */
.slider { position:relative; width:100%; height:100%; }
.slider-track { display:flex; width:100%; height:100%; transition: transform .7s ease; }
.slide { flex:0 0 100%; width:100%; height:100%; position:relative; }
.slide img { width:100%; height:100%; object-fit:cover; }
.slider-nav { position:absolute; inset:0; display:flex; align-items:center; justify-content:space-between; pointer-events:none; padding:0 10px; }
.slider-btn { pointer-events:auto; background:var(--gv-surface-alt); border:1px solid var(--gv-line); width:38px; height:38px; display:flex; align-items:center; justify-content:center; border-radius:50%; font-size:17px; cursor:pointer; backdrop-filter:blur(8px); color:var(--gv-accent); transition:.3s; box-shadow:0 6px 22px -10px rgba(0,0,0,.6); }
.slider-btn:hover { background:var(--gv-surface); color:#fff; transform:scale(1.08); }
.slider-dots { position:absolute; left:0; right:0; bottom:10px; display:flex; gap:8px; justify-content:center; }
.slider-dots button { width:10px; height:10px; border-radius:50%; background:var(--gv-surface); border:1px solid var(--gv-accent); cursor:pointer; padding:0; transition:.3s; box-shadow:0 0 0 3px rgba(0,0,0,.35); }
.slider-dots button.active { background:var(--gv-accent); transform:scale(1.25); box-shadow:0 0 0 5px rgba(140,110,255,.45); }
.slide-caption { position:absolute; left:0; right:0; bottom:0; padding:14px 18px 18px; background:linear-gradient(180deg,rgba(20,20,40,0) 0%,rgba(20,20,40,.82) 95%); color:#fff; font-weight:600; letter-spacing:.45px; font-size:12px; }

/* Ratings (supports inline variant inside hero-content for css4) */
.ratings { display:flex; gap:18px; flex-wrap:wrap; }
.rating-card { background: var(--gv-surface-alt); border:1px solid var(--gv-line); border-radius:20px; padding:16px 18px; box-shadow:0 14px 38px -18px rgba(0,0,0,.6); position:relative; overflow:hidden; }
.rating-card:before { content:""; position:absolute; inset:0; background: radial-gradient(circle at 80% 30%,rgba(140,110,255,.4),transparent 70%); opacity:.4; }
.rating-card .icon { text-shadow:0 0 10px rgba(255,255,255,.35); }
/* Inline arrangement when moved inside hero-content */
.hero-content .ratings.inline { gap:18px; flex-wrap:nowrap; margin-top:6px; }
.hero-content .ratings.inline .rating-card { flex:0 0 auto; min-width:170px; }
/* Force always horizontal */
.hero-content .ratings.inline { flex-wrap:nowrap !important; }

/* Sub-call */
.sub-call { background: linear-gradient(90deg,#221f3f,#281f55,#2f1d66); color: var(--gv-text); }
.sub-call .call-box.alt { background: linear-gradient(135deg,var(--gv-accent),var(--gv-accent-alt)); border:none; box-shadow:0 14px 44px -20px rgba(140,110,255,.55); }

/* Form */
.search-box { background: linear-gradient(135deg,#1a1e37,#221e48); }
.flight-form { background: var(--gv-surface); border:1px solid var(--gv-line); backdrop-filter: blur(22px); border-radius:44px; padding:46px 54px; box-shadow: var(--gv-shadow); grid-template-columns: repeat(auto-fit,minmax(190px,1fr)); gap:26px; }
.flight-form label { font-size:10px; font-weight:600; letter-spacing:1.1px; text-transform:uppercase; color: var(--gv-muted); }
.flight-form input, .flight-form select { background:#181d32; color:var(--gv-text); border:1px solid #2a3355; border-radius:18px; font-size:15px; padding:14px 16px; }
.flight-form input[type="date"] { color:var(--gv-text); caret-color:var(--gv-accent); font-weight:500; }
.flight-form input[type="date"]::-webkit-calendar-picker-indicator { filter:brightness(1.15); cursor:pointer; }
.flight-form input[type="date"]::-webkit-calendar-picker-indicator:hover { filter:brightness(1.35); }
.flight-form input:focus, .flight-form select:focus { outline:none; border-color: var(--gv-accent); box-shadow:0 0 0 3px rgba(141,107,255,.35); }
.flight-form button { background: linear-gradient(135deg,var(--gv-accent),var(--gv-accent-alt)); border:none; border-radius:20px; font-size:16px; font-weight:600; letter-spacing:.7px; box-shadow:0 18px 46px -18px rgba(140,110,255,.6); }
.passenger-dropdown { border-radius:24px; }

/* Benefits */
.benefits { background: linear-gradient(180deg,#161a30,#1e1e41); gap:74px; padding-top:100px; }
.benefit { background: var(--gv-surface); border:1px solid var(--gv-line); border-radius:40px; padding:40px 38px; backdrop-filter: blur(26px); box-shadow:0 30px 80px -30px rgba(0,0,0,.7); position:relative; overflow:hidden; }
.benefit:before { content:""; position:absolute; inset:0; background: radial-gradient(circle at 72% 26%,rgba(140,110,255,.4),transparent 70%); opacity:.5; }
.benefit h3 { color: var(--gv-accent); letter-spacing:.5px; }
.benefit .icon { font-size:52px; }

footer.site-footer { background:#14172b; color: var(--gv-text); position:relative; border-top:3px solid var(--gv-accent); }
footer.site-footer:before { content:""; position:absolute; inset:0; background: radial-gradient(circle at 24% 18%,rgba(140,110,255,.28),transparent 70%); }
footer.site-footer a { color: var(--gv-accent); }
footer.site-footer a:hover { color:#fff; }

/* Gallery & Split Sections (css4 distinct minimalist glass) */
.theme-gallery { padding:120px 0 50px; }
.theme-gallery .gallery-wrapper { width:min(1250px,92%); margin:0 auto; }
.theme-gallery .gallery-head h2 { font-size:46px; margin:0 0 10px; background:linear-gradient(90deg,var(--gv-accent),var(--gv-accent-alt)); -webkit-background-clip:text; background-clip:text; color:transparent; letter-spacing:-1px; }
.theme-gallery .gallery-head p { color: var(--gv-muted); font-size:15px; margin:0 0 36px; }
.gallery-grid { display:grid; grid-template-columns: repeat(12,1fr); gap:16px; }
.gallery-grid .g-item { position:relative; overflow:hidden; border-radius:30px; background:var(--gv-surface); border:1px solid var(--gv-line); aspect-ratio: 4 / 3; box-shadow:0 20px 50px -18px rgba(0,0,0,.6); }
.gallery-grid .g-item.wide { grid-column: span 6; }
.gallery-grid .g-item.tall { grid-column: span 3; aspect-ratio: 3 / 4; }
.gallery-grid img { width:100%; height:100%; object-fit:cover; filter:saturate(1.15); transition: transform .7s ease; }
.gallery-grid figure:hover img { transform: scale(1.14); }
.gallery-grid figcaption { position:absolute; inset:auto 0 0 0; padding:14px 18px 18px; font-size:13px; letter-spacing:.6px; background:linear-gradient(180deg,rgba(20,20,40,0) 0%,rgba(20,20,40,.85) 95%); color:#fff; font-weight:600; }

.theme-feature-split { padding:60px 0 130px; }
.theme-feature-split .split-inner { width:min(1180px,92%); margin:0 auto; display:grid; grid-template-columns: minmax(320px,520px) minmax(360px,1fr); gap:110px; align-items:center; }
.split-media { position:relative; }
.split-media img { width:100%; aspect-ratio: 16 / 11; object-fit:cover; border-radius:48px; background:var(--gv-surface-alt); border:1px solid var(--gv-line); backdrop-filter:blur(20px); box-shadow:0 46px 90px -36px rgba(0,0,0,.7); }
.split-content h2 { font-size:58px; line-height:1.05; margin:0 0 26px; background:linear-gradient(90deg,var(--gv-accent),var(--gv-accent-alt)); -webkit-background-clip:text; background-clip:text; color:transparent; letter-spacing:-1.2px; }
.split-content p { font-size:17px; line-height:1.65; color: var(--gv-muted); margin:0 0 30px; max-width:640px; }
.split-content .points { list-style:none; margin:0 0 36px; padding:0; display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:14px 30px; }
.split-content .points li { position:relative; padding-left:26px; font-size:14px; font-weight:600; color: var(--gv-text); }
.split-content .points li:before { content:"▹"; position:absolute; left:0; top:0; color: var(--gv-accent-alt); }
.split-cta { display:inline-block; background:linear-gradient(135deg,var(--gv-accent),var(--gv-accent-alt)); color:#fff; font-weight:600; padding:16px 34px; border-radius:22px; letter-spacing:.8px; box-shadow:0 20px 46px -20px rgba(140,110,255,.6); }
.split-cta:hover { filter:brightness(1.1); transform:translateY(-3px); }

@media (max-width:1200px){ .gallery-grid { grid-template-columns: repeat(10,1fr); } .gallery-grid .g-item.wide { grid-column: span 5; } }
@media (max-width:1020px){ .gallery-grid { grid-template-columns: repeat(8,1fr); } .gallery-grid .g-item.wide { grid-column: span 4; } .theme-feature-split .split-inner { gap:80px; } }
@media (max-width:920px){ .split-content h2 { font-size:52px; } }
@media (max-width:880px){ .gallery-grid { grid-template-columns: repeat(6,1fr); } .gallery-grid .g-item.wide { grid-column: span 3; } .theme-feature-split .split-inner { grid-template-columns:1fr; gap:70px; } }
@media (max-width:720px){ .split-content h2 { font-size:46px; } }
@media (max-width:640px){ .gallery-grid { grid-template-columns: repeat(4,1fr); } .gallery-grid .g-item.wide { grid-column: span 2; } }
@media (max-width:560px){ .gallery-grid { grid-template-columns: repeat(3,1fr); } .split-content h2 { font-size:40px; } }
@media (max-width:500px){ .gallery-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width:430px){ .gallery-grid { grid-template-columns:1fr; } .split-content h2 { font-size:36px; } }
/* Inspiration slider wrapper override */
.inspiration-slider-wrapper { position:relative; width:100%; border-radius:34px; }
.inspiration-slider-wrapper .slider { aspect-ratio: 16 / 9; border-radius:34px; overflow:hidden; background:var(--gv-surface-alt); border:1px solid var(--gv-line); box-shadow:0 30px 70px -28px rgba(0,0,0,.65); }
.inspiration-slider-wrapper .slider-track { height:100%; }
.inspiration-slider-wrapper .slide { position:relative; }
.inspiration-slider-wrapper .slide img { filter:saturate(1.12) contrast(1.05); }
.inspiration-slider-wrapper .slide-caption { font-size:14px; letter-spacing:.6px; }
.inspiration-slider-wrapper .slider-btn { background:var(--gv-surface); border:1px solid var(--gv-line); color:var(--gv-accent); }
.inspiration-slider-wrapper .slider-btn:hover { background:var(--gv-surface-alt); color:#fff; }
.inspiration-slider-wrapper .slider-dots button { background:var(--gv-surface); border-color: var(--gv-accent); }
.inspiration-slider-wrapper .slider-dots button.active { background:var(--gv-accent); }

/* Passenger selector dark alignment */
.passenger-selector .passenger-input { background:#1a1f37; border:1px solid #2a3355; color:var(--gv-text); }
.passenger-selector .passenger-input:hover { background:#1f2744; border-color: var(--gv-accent); }
.passenger-selector .passenger-input.open { background:#202c4a; border-color: var(--gv-accent); }
.passenger-selector .passenger-dropdown { background:#181d32; border:1px solid #2a3355; border-top:none; box-shadow:0 20px 60px -20px rgba(0,0,0,.75); }
.passenger-selector .passenger-row { border-bottom:1px solid #232b46; }
.passenger-selector .passenger-row:last-of-type { border-bottom:none; }
.passenger-selector .passenger-btn { background:#202a48; border:1px solid #303d63; color: var(--gv-accent); }
.passenger-selector .passenger-btn:hover:not(:disabled) { background:#273358; border-color: var(--gv-accent-alt); }
.passenger-selector .passenger-btn:disabled { opacity:.45; }
.passenger-selector .passenger-count { color: var(--gv-accent-alt); }

/* Date inputs */
.flight-form input[type=date] { background:#181d32; color:var(--gv-text); }
.flight-form input[type=date]:hover { background:#202844; }
.flight-form input[type=date]:focus { background:#253055; }

/* Responsive (grid adjustments + single column collapse) */
@media (max-width:1220px){ .hero .overlay { grid-template-columns: minmax(380px,520px) minmax(360px,1fr); padding:46px 50px 52px; gap:40px 52px; } }
@media (max-width:1040px){ .hero-content h1 { font-size:clamp(2.2rem,4.2vw,3.05rem); } }
@media (max-width:900px){ .hero .overlay { grid-template-columns:1fr; padding:44px 46px 48px; gap:40px; } }
@media (max-width:780px){ .hero .overlay { padding:40px 40px 44px; gap:36px; } .hero-content h1 { font-size:clamp(2rem,5vw,2.8rem); } }
@media (max-width:640px){ .hero .overlay { padding:36px 34px 40px; gap:30px; } .hero-content h1 { font-size:clamp(1.9rem,5.8vw,2.55rem); } }
@media (max-width:560px){ .hero .overlay { padding:32px 28px 36px; gap:26px; } .hero-content h1 { font-size:clamp(1.8rem,6.2vw,2.4rem); } .flight-form { padding:34px 30px; } }
@media (max-width:480px){ .hero .overlay { padding:30px 24px 34px; gap:24px; } .hero-content h1 { font-size:clamp(1.7rem,7vw,2.25rem); } .flight-form { padding:30px 28px; } }
@media (max-width:420px){ .hero-content h1 { font-size:clamp(1.65rem,7.5vw,2.15rem); } }
@media (max-width:420px){ .hero-content .ratings.inline .rating-card { padding:14px 14px; } }
