/* AL FOS7A Plus — cinematic blue redesign */
:root{
  /* Deep ocean → electric blue palette */
  --c-primary:#040B1A;          /* near-black navy */
  --c-primary-2:#081530;
  --c-surface:#0A1A35;
  --c-card:rgba(13,29,60,.78);
  --c-glass:rgba(255,255,255,.04);

  --c-blue:#3DA9FC;             /* electric accent */
  --c-blue-2:#7CC4FF;            /* lighter */
  --c-blue-3:#1B6FE0;             /* deep */
  --c-blue-glow:rgba(61,169,252,.32);
  --c-cyan:#5BC0EB;

  /* Back-compat aliases (old class names still resolve) */
  --c-gold:var(--c-blue);
  --c-gold-2:var(--c-blue-2);
  --c-gold-glow:var(--c-blue-glow);

  --c-text:#EAF2FF;
  --c-muted:rgba(234,242,255,.62);
  --c-border:rgba(124,196,255,.18);

  --ease:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --radius:16px;
  --maxw:1280px;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--c-primary);
  color:var(--c-text);
  font-family:'Lora',serif;
  font-size:16px; line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.rtl{font-family:'Tajawal',sans-serif}
body.is-loading{overflow:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .3s var(--ease)}
a:hover{color:var(--c-blue-2)}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:600;line-height:1.05;margin:0 0 .5em;letter-spacing:-.01em}
body.rtl h1,body.rtl h2,body.rtl h3,body.rtl h4{font-family:'Amiri',serif}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative}
.muted{color:var(--c-muted)}
.eyebrow{font-family:'Outfit',sans-serif;letter-spacing:.3em;text-transform:uppercase;color:var(--c-blue);font-size:11px;font-weight:500;display:inline-block}
body.rtl .eyebrow{font-family:'Cairo',sans-serif;letter-spacing:.05em;font-size:13px}

/* === Page Loader =================================================== */
.page-loader{
  position:fixed;inset:0;z-index:9999;
  background:radial-gradient(circle at 50% 50%,#0a1a3a 0%,#040b1a 70%);
  display:grid;place-items:center;
  transition:opacity .9s var(--ease),visibility .9s var(--ease);
}
.page-loader::before{
  content:"";position:absolute;inset:-2px;
  background:
    radial-gradient(circle at 20% 30%,rgba(61,169,252,.18),transparent 40%),
    radial-gradient(circle at 80% 70%,rgba(91,192,235,.14),transparent 40%);
  animation:loader-glow 4s var(--ease) infinite alternate;
}
@keyframes loader-glow{from{opacity:.5;transform:scale(1)}to{opacity:1;transform:scale(1.1)}}
.loader-inner{position:relative;text-align:center}
.loader-logo{
  width:96px;height:96px;object-fit:contain;margin:0 auto 24px;
  filter:drop-shadow(0 0 24px var(--c-blue-glow));
  animation:loader-pulse 2s var(--ease) infinite;
}
@keyframes loader-pulse{
  0%,100%{transform:scale(1) rotateY(0)}
  50%{transform:scale(1.06) rotateY(180deg)}
}
.loader-bar{
  width:200px;height:2px;background:rgba(255,255,255,.08);
  border-radius:2px;overflow:hidden;margin:0 auto 18px;
}
.loader-bar span{
  display:block;height:100%;width:40%;
  background:linear-gradient(90deg,transparent,var(--c-blue),transparent);
  animation:loader-slide 1.4s ease-in-out infinite;
}
@keyframes loader-slide{
  0%{transform:translateX(-100%)}
  100%{transform:translateX(350%)}
}
.loader-text{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;letter-spacing:.4em;color:var(--c-text);text-transform:uppercase;
}
.loader-text span{color:var(--c-blue);margin-inline-start:6px}
body.loaded .page-loader{opacity:0;visibility:hidden;pointer-events:none}

/* === Custom Cursor ================================================= */
@media (hover:hover) and (pointer:fine){
  body{cursor:none}
  a, button, input, textarea, select, [data-cursor]{cursor:none}
  .cursor-dot,.cursor-ring{
    position:fixed;top:0;left:0;pointer-events:none;z-index:9998;
    border-radius:50%;will-change:transform;
    mix-blend-mode:difference;
  }
  .cursor-dot{
    width:6px;height:6px;background:#fff;
    transform:translate(-50%,-50%);
    transition:width .25s var(--ease),height .25s var(--ease),background .25s var(--ease);
  }
  .cursor-ring{
    width:36px;height:36px;border:1.5px solid rgba(255,255,255,.85);
    transform:translate(-50%,-50%);
    transition:width .35s var(--ease),height .35s var(--ease),border-color .25s var(--ease),background .25s var(--ease);
  }
  body.cursor-lg .cursor-ring{width:64px;height:64px;border-color:var(--c-blue-2);background:rgba(61,169,252,.12)}
  body.cursor-lg .cursor-dot{width:0;height:0}
}

/* === Header ======================================================== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(4,11,26,.55);backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--c-border);
  transition:background .35s var(--ease),padding .35s var(--ease);
}
.site-header.scrolled{background:rgba(4,11,26,.92);box-shadow:0 12px 40px rgba(0,0,0,.45)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:78px;gap:24px}
.brand{display:flex;align-items:center;gap:8px;height:100%}
.brand-logo{height:48px;width:auto;object-fit:contain;transition:.4s var(--ease);filter:drop-shadow(0 4px 12px var(--c-blue-glow))}
.brand:hover .brand-logo{transform:scale(1.06) rotate(-2deg)}
.primary-nav{display:flex;gap:30px;font-family:'Outfit',sans-serif;font-size:13px;letter-spacing:.12em;text-transform:uppercase;font-weight:500}
body.rtl .primary-nav{font-family:'Cairo',sans-serif;text-transform:none;letter-spacing:0;font-size:15px}
.primary-nav a{position:relative;padding:6px 0;color:var(--c-text)}
.primary-nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:linear-gradient(90deg,var(--c-blue),var(--c-cyan));transition:width .35s var(--ease)}
.primary-nav a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:12px}
.lang-toggle{display:inline-grid;place-items:center;width:38px;height:38px;border:1px solid var(--c-border);border-radius:50%;font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;transition:.3s var(--ease)}
.lang-toggle:hover{background:var(--c-blue);color:var(--c-primary);border-color:var(--c-blue);box-shadow:0 8px 24px var(--c-blue-glow)}
.nav-toggle{display:none;background:none;border:0;width:36px;height:32px;flex-direction:column;justify-content:center;gap:5px;cursor:pointer}
.nav-toggle span{display:block;height:2px;width:100%;background:var(--c-text);transition:.3s}

/* Currency switch */
.currency-switch{position:relative}
.cs-toggle{
  background:rgba(255,255,255,.04);border:1px solid var(--c-border);
  color:var(--c-text);padding:8px 14px;border-radius:999px;
  font-family:'Outfit',sans-serif;font-size:12px;font-weight:600;letter-spacing:.1em;
  cursor:pointer;transition:.3s var(--ease);
}
.cs-toggle:hover{border-color:var(--c-blue);background:rgba(61,169,252,.1)}
.cs-caret{font-size:10px;margin-inline-start:4px;opacity:.7}
.cs-menu{
  position:absolute;top:calc(100% + 10px);inset-inline-end:0;
  min-width:200px;background:rgba(8,21,48,.97);backdrop-filter:blur(20px);
  border:1px solid var(--c-border);border-radius:12px;padding:8px;
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:.3s var(--ease);box-shadow:0 20px 60px rgba(0,0,0,.5);
  z-index:120;
}
.currency-switch.open .cs-menu{opacity:1;visibility:visible;transform:translateY(0)}
.cs-menu a{
  display:block;padding:10px 14px;border-radius:8px;font-size:13px;
  font-family:'Outfit',sans-serif;color:var(--c-muted);transition:.2s;
}
.cs-menu a:hover{background:rgba(61,169,252,.12);color:var(--c-text)}
.cs-menu a.active{background:var(--c-blue);color:var(--c-primary);font-weight:600}

/* === Buttons ======================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 30px;border-radius:999px;
  font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  cursor:pointer;border:1px solid transparent;
  transition:.4s var(--ease);position:relative;overflow:hidden;
}
body.rtl .btn{font-family:'Cairo',sans-serif;letter-spacing:0;text-transform:none}
.btn::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);
  transform:translateX(-100%);transition:transform .8s var(--ease);
}
.btn:hover::before{transform:translateX(100%)}
.btn-gold{background:linear-gradient(135deg,var(--c-blue) 0%,var(--c-blue-3) 100%);color:#fff;box-shadow:0 8px 24px var(--c-blue-glow)}
.btn-gold:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 16px 40px var(--c-blue-glow);color:#fff}
.btn-ghost{border-color:var(--c-border);color:var(--c-text);background:rgba(255,255,255,.02)}
.btn-ghost:hover{border-color:var(--c-blue);color:var(--c-blue-2);transform:translateY(-2px)}
.btn-gold-sm{background:linear-gradient(135deg,var(--c-blue),var(--c-blue-3));color:#fff;padding:9px 18px;border-radius:999px;font-family:'Outfit',sans-serif;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;box-shadow:0 6px 18px var(--c-blue-glow)}
body.rtl .btn-gold-sm{font-family:'Cairo',sans-serif;text-transform:none;letter-spacing:0;font-size:13px}
.btn-gold-sm:hover{transform:translateY(-2px);color:#fff;box-shadow:0 10px 28px var(--c-blue-glow)}

/* === Hero ========================================================== */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  padding:120px 0 80px;overflow:hidden;perspective:1400px;
  background:
    radial-gradient(ellipse at 80% 10%,rgba(61,169,252,.22),transparent 55%),
    radial-gradient(ellipse at 10% 80%,rgba(91,192,235,.18),transparent 60%),
    linear-gradient(180deg,#040B1A 0%,#081530 100%);
}
.hero::before{
  content:"";position:absolute;inset:-5%;
  background-image:url('https://images.unsplash.com/photo-1507525428034-b723cf961d3e?w=2400&q=85');
  background-size:cover;background-position:center;
  opacity:.42;filter:saturate(1.1) contrast(1.05);
  animation:kenburns 28s ease-in-out infinite alternate;
  transform:translateZ(0);will-change:transform;
}
.hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(4,11,26,.35) 0%,rgba(4,11,26,.92) 100%);
}
@keyframes kenburns{
  from{transform:scale(1) translate(0,0)}
  to{transform:scale(1.15) translate(-2%,-2%)}
}
.hero-inner{position:relative;z-index:2;max-width:780px;transform-style:preserve-3d}
.hero h1{
  font-size:clamp(52px,9vw,128px);margin:18px 0 26px;
  letter-spacing:-.02em;line-height:.96;
  background:linear-gradient(180deg,#fff 0%,#cbd9ee 80%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 80px rgba(124,196,255,.15);
}
.hero p.lead{font-size:clamp(17px,1.5vw,21px);max-width:580px;color:var(--c-muted);margin-bottom:40px}
.hero-cta{display:flex;flex-wrap:wrap;gap:16px}
.hero-stats{display:flex;gap:56px;margin-top:72px;flex-wrap:wrap}
.hero-stats .stat strong{display:block;font-family:'Cormorant Garamond',serif;font-size:48px;background:linear-gradient(135deg,var(--c-blue) 0%,var(--c-cyan) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;font-weight:700}
.hero-stats .stat span{font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--c-muted)}
body.rtl .hero-stats .stat span{font-family:'Cairo',sans-serif;letter-spacing:0;text-transform:none;font-size:13px}

/* Floating ambient orbs */
.hero-orb{
  position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none;
  animation:float 14s ease-in-out infinite;will-change:transform;
}
.hero-orb.o1{width:340px;height:340px;background:rgba(61,169,252,.35);top:-80px;right:-80px;animation-delay:-2s}
.hero-orb.o2{width:260px;height:260px;background:rgba(91,192,235,.28);bottom:60px;left:-60px;animation-delay:-7s}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(30px,-40px) scale(1.08)}
  66%{transform:translate(-20px,30px) scale(.95)}
}

/* === Marquee ======================================================= */
.services-strip{
  background:rgba(8,21,48,.85);
  border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border);
  padding:18px 0;overflow:hidden;
}
.marquee{display:flex;gap:48px;animation:marquee 38s linear infinite;white-space:nowrap;font-family:'Outfit',sans-serif;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted)}
body.rtl .marquee{font-family:'Cairo',sans-serif;text-transform:none;letter-spacing:0}
.marquee span{display:inline-flex;align-items:center;gap:10px}
.marquee span::before{content:"✦";color:var(--c-blue)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
body.rtl .marquee{animation-direction:reverse}

/* === Section ======================================================= */
.section{padding:120px 0;position:relative}
.section-head{text-align:center;max-width:720px;margin:0 auto 64px}
.section-head h2{font-size:clamp(38px,5.5vw,72px);margin:14px 0}
.section-head p{color:var(--c-muted);font-size:17px}
.gold-divider{display:block;width:60px;height:2px;background:linear-gradient(90deg,transparent,var(--c-blue),transparent);margin:0 auto 18px}

/* === About panel =================================================== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-grid img{
  border-radius:var(--radius);height:580px;width:100%;object-fit:cover;
  box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 0 1px var(--c-border);
  transform-style:preserve-3d;will-change:transform;
  transition:.6s var(--ease);
}
.about-grid img:hover{transform:scale(1.02) rotateY(-2deg)}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:80px;border-top:1px solid var(--c-border);padding-top:56px}
.stats-row .stat{text-align:center}
.stats-row .stat strong{display:block;font-family:'Cormorant Garamond',serif;font-size:64px;background:linear-gradient(135deg,var(--c-blue) 0%,var(--c-cyan) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;font-weight:700}
.stats-row .stat span{font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--c-muted)}
body.rtl .stats-row .stat span{font-family:'Cairo',sans-serif;letter-spacing:0;text-transform:none}

/* === Trip cards (3D tilt) ========================================== */
.trips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:32px;perspective:1600px}
.trip-card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:var(--c-card);border:1px solid var(--c-border);
  display:flex;flex-direction:column;min-height:460px;
  transition:transform .6s var(--ease),box-shadow .6s var(--ease),border-color .4s var(--ease);
  transform-style:preserve-3d;will-change:transform;
  box-shadow:0 6px 20px rgba(0,0,0,.25);
}
.trip-card:hover{
  border-color:var(--c-blue);
  box-shadow:0 30px 80px rgba(0,0,0,.55),0 0 60px var(--c-blue-glow);
}
.trip-card .cover{position:relative;height:260px;overflow:hidden}
.trip-card .cover img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease);filter:saturate(1.05)}
.trip-card:hover .cover img{transform:scale(1.12)}
.trip-card .cover::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(4,11,26,.9))}
.trip-card .body{padding:26px;flex:1;display:flex;flex-direction:column;transform:translateZ(20px)}
.trip-card .country{font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--c-blue);font-family:'Outfit',sans-serif;font-weight:600}
body.rtl .trip-card .country{font-family:'Cairo',sans-serif;letter-spacing:0;text-transform:none;font-size:13px}
.trip-card h3{font-size:26px;margin:10px 0 14px}
.trip-card .meta{display:flex;justify-content:space-between;font-size:13px;color:var(--c-muted);border-top:1px dashed var(--c-border);padding-top:16px;margin-top:auto}
.trip-card .price{color:var(--c-blue-2);font-weight:600;font-family:'Outfit',sans-serif}
.promo-badge{
  position:absolute;top:18px;inset-inline-end:18px;
  background:linear-gradient(135deg,var(--c-blue),var(--c-cyan));color:#fff;
  padding:7px 14px;border-radius:999px;font-size:11px;letter-spacing:.12em;
  font-family:'Outfit',sans-serif;font-weight:700;z-index:2;
  box-shadow:0 8px 24px var(--c-blue-glow);
  animation:shimmer 2.4s infinite;
}
@keyframes shimmer{0%,100%{box-shadow:0 4px 18px var(--c-blue-glow)}50%{box-shadow:0 8px 36px rgba(124,196,255,.55)}}

/* === Reviews ======================================================= */
.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px}
.review-card{
  background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--radius);
  padding:36px;transition:.5s var(--ease);position:relative;overflow:hidden;
}
.review-card::before{
  content:"\201C";position:absolute;top:-30px;inset-inline-end:20px;
  font-family:'Cormorant Garamond',serif;font-size:160px;color:var(--c-blue);opacity:.12;line-height:1;
}
.review-card:hover{border-color:var(--c-blue);transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.4)}
.review-card .stars{color:var(--c-blue);margin-bottom:14px;letter-spacing:3px;font-size:18px}
.review-card blockquote{margin:0 0 18px;font-family:'Cormorant Garamond',serif;font-size:21px;line-height:1.5;font-style:italic;color:var(--c-text)}
body.rtl .review-card blockquote{font-family:'Amiri',serif;font-style:normal}
.review-card .name{color:var(--c-blue);font-family:'Outfit',sans-serif;font-size:13px;letter-spacing:.1em;font-weight:600}
body.rtl .review-card .name{font-family:'Cairo',sans-serif;letter-spacing:0}

/* === Service cards ================================================= */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}
.svc-card{
  background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--radius);
  padding:36px 26px;text-align:center;transition:.5s var(--ease);position:relative;overflow:hidden;
}
.svc-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(61,169,252,.18),transparent 60%);opacity:0;transition:.5s var(--ease)}
.svc-card:hover::before{opacity:1}
.svc-card:hover{border-color:var(--c-blue);transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.svc-card .ico{width:60px;height:60px;border-radius:50%;display:grid;place-items:center;background:rgba(61,169,252,.15);color:var(--c-blue);margin:0 auto 18px;font-size:24px;border:1px solid var(--c-border)}
.svc-card h3{font-size:23px;margin:0 0 12px;position:relative;z-index:1}
.svc-card .price{color:var(--c-blue-2);font-family:'Outfit',sans-serif;font-weight:600;margin-top:10px;position:relative;z-index:1}

/* === Sponsors ====================================================== */
.sponsors-strip{display:flex;flex-wrap:wrap;gap:18px;justify-content:center}
.sponsor-pill{
  background:var(--c-card);border:1px solid var(--c-border);
  padding:16px 30px;border-radius:999px;font-family:'Outfit',sans-serif;
  font-size:14px;letter-spacing:.05em;color:var(--c-muted);
  transition:.4s var(--ease);
}
.sponsor-pill:hover{border-color:var(--c-blue);color:var(--c-blue-2);transform:translateY(-3px);box-shadow:0 10px 30px var(--c-blue-glow)}
body.rtl .sponsor-pill{font-family:'Cairo',sans-serif}

/* === Vlog cards ==================================================== */
.vlog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:28px}
.vlog-card{
  background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--radius);
  overflow:hidden;transition:.5s var(--ease);
}
.vlog-card:hover{transform:translateY(-6px);border-color:var(--c-blue);box-shadow:0 24px 60px rgba(0,0,0,.5)}
.vlog-card .cover{height:220px;overflow:hidden}
.vlog-card .cover img{width:100%;height:100%;object-fit:cover;transition:.7s var(--ease)}
.vlog-card:hover .cover img{transform:scale(1.08)}
.vlog-card .body{padding:26px}
.vlog-card .cat{font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--c-blue);font-family:'Outfit',sans-serif;font-weight:600}
.vlog-card h3{font-size:23px;margin:10px 0}

/* === CTA strip ===================================================== */
.cta-band{
  position:relative;padding:140px 0;text-align:center;overflow:hidden;
  background:
    linear-gradient(180deg,rgba(4,11,26,.6),rgba(4,11,26,.92)),
    url('https://images.pexels.com/photos/14886046/pexels-photo-14886046.jpeg?w=2400') center/cover fixed;
}
.cta-band::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(61,169,252,.18),transparent 60%);pointer-events:none}
.cta-band h2{font-size:clamp(42px,6vw,84px);margin-bottom:24px;position:relative;z-index:1}
.cta-band .actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:36px;position:relative;z-index:1}

/* === Forms ========================================================= */
.form-card{background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--radius);padding:44px;max-width:720px;margin:0 auto;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.form-row.full{grid-template-columns:1fr}
.field label{display:block;font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted);margin-bottom:10px;font-weight:600}
body.rtl .field label{font-family:'Cairo',sans-serif;letter-spacing:0;text-transform:none;font-size:13px}
.field input,.field select,.field textarea{
  width:100%;background:rgba(255,255,255,.04);
  color:var(--c-text);border:1px solid var(--c-border);
  border-radius:12px;padding:14px 16px;font-family:inherit;font-size:15px;
  transition:.3s var(--ease);
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--c-blue);background:rgba(61,169,252,.08);box-shadow:0 0 0 4px var(--c-blue-glow)}
.field textarea{min-height:140px;resize:vertical}

/* === Footer ======================================================== */
.site-footer{background:#020713;border-top:1px solid var(--c-border);padding:80px 0 28px;margin-top:120px;position:relative}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--c-blue),transparent)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.footer-grid h4{font-family:'Outfit',sans-serif;font-size:12px;letter-spacing:.25em;text-transform:uppercase;color:var(--c-blue);margin:0 0 18px;font-weight:600}
body.rtl .footer-grid h4{font-family:'Cairo',sans-serif;letter-spacing:0;text-transform:none;font-size:15px}
.footer-grid a{display:block;color:var(--c-muted);margin-bottom:10px;font-size:14px}
.footer-grid a:hover{color:var(--c-blue-2)}
.socials{display:flex;flex-direction:column;gap:8px}
.footer-bottom{display:flex;justify-content:space-between;border-top:1px solid var(--c-border);margin-top:56px;padding-top:24px;font-size:13px;color:var(--c-muted)}

/* === Floating WhatsApp ============================================= */
.whatsapp-fab{
  position:fixed;bottom:32px;inset-inline-end:32px;z-index:200;
  width:60px;height:60px;border-radius:50%;
  background:#25D366;color:#fff;display:grid;place-items:center;
  box-shadow:0 14px 36px rgba(37,211,102,.45);
  animation:fab-bounce 2.6s ease-in-out infinite;
  transition:transform .3s var(--ease);
}
.whatsapp-fab:hover{transform:scale(1.12);color:#fff}
.whatsapp-fab::after{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:2px solid #25D366;animation:fab-pulse 2s ease-out infinite;
}
@keyframes fab-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes fab-pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.5);opacity:0}}

/* === Flash ========================================================= */
.flash{margin:96px 0 -24px;padding:14px 20px;border-radius:12px;border:1px solid var(--c-border)}
.flash-success{background:rgba(46,204,113,.15);border-color:#2ecc71;color:#bdf6d2}
.flash-error{background:rgba(231,76,60,.15);border-color:#e74c3c;color:#ffd2cc}
.flash-info{background:rgba(61,169,252,.15);border-color:var(--c-blue);color:#cfe6ff}

/* === Page hero (subpages) ========================================== */
.page-hero{padding:180px 0 90px;text-align:center;border-bottom:1px solid var(--c-border);background:radial-gradient(ellipse at top,rgba(61,169,252,.18),transparent 60%),linear-gradient(180deg,#040B1A,#081530)}
.page-hero h1{font-size:clamp(48px,7vw,96px);margin:14px 0;background:linear-gradient(180deg,#fff,#cbd9ee);-webkit-background-clip:text;background-clip:text;color:transparent}
.page-hero p{color:var(--c-muted);max-width:660px;margin:0 auto;font-size:17px}

/* === Detail page =================================================== */
.detail-grid{display:grid;grid-template-columns:1fr 400px;gap:56px;align-items:start}
.detail-cover{height:560px;border-radius:var(--radius);overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.detail-cover img{width:100%;height:100%;object-fit:cover}
.detail-side{position:sticky;top:110px;background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--radius);padding:36px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.detail-side .price{font-family:'Cormorant Garamond',serif;font-size:52px;background:linear-gradient(135deg,var(--c-blue),var(--c-cyan));-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;font-weight:700}
.detail-side .row{display:flex;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--c-border);font-size:14px}
.detail-side .row:last-of-type{border:0}

/* === Reveal animations (3D entrance) =============================== */
[data-reveal]{
  opacity:0;transform:translateY(60px) rotateX(8deg) scale(.96);
  transition:opacity 1.1s var(--ease),transform 1.1s var(--ease);
  transform-origin:50% 100%;
}
[data-reveal].is-visible{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.1s}
[data-reveal][data-delay="2"]{transition-delay:.2s}
[data-reveal][data-delay="3"]{transition-delay:.3s}
[data-reveal][data-delay="4"]{transition-delay:.4s}

/* Stagger children */
.trips-grid > *{transition-delay:calc(var(--i,0) * 80ms)}

/* === Responsive ==================================================== */
@media (max-width:1024px){
  .about-grid{grid-template-columns:1fr}
  .about-grid img{height:380px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .detail-grid{grid-template-columns:1fr}
  .detail-side{position:static}
  .section{padding:80px 0}
}
@media (max-width:760px){
  .primary-nav{position:fixed;inset:78px 0 auto 0;background:rgba(4,11,26,.98);flex-direction:column;padding:24px;gap:14px;border-bottom:1px solid var(--c-border);transform:translateY(-110%);transition:transform .4s var(--ease)}
  .primary-nav.open{transform:translateY(0)}
  .nav-toggle{display:flex}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .section{padding:64px 0}
  .hero{padding:110px 0 60px;min-height:90vh}
  .currency-switch .cs-toggle{padding:7px 10px;font-size:11px}
  .brand-logo{height:42px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.1s !important}
  [data-reveal]{opacity:1 !important;transform:none !important}
}

/* ====================================================================
   v3 — Hero video, scroll progress, magnetic, scene connector, polish
   ==================================================================== */

/* Scroll progress bar */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0;z-index:9999;
  background:linear-gradient(90deg,var(--c-blue),var(--c-cyan),var(--c-blue-2));
  background-size:200% 100%;
  box-shadow:0 0 16px var(--c-blue-glow);
  transition:width .12s linear;
  animation:progress-shimmer 2.5s linear infinite;
}
@keyframes progress-shimmer{from{background-position:0 0}to{background-position:200% 0}}

/* Hero video */
.hero{padding-bottom:120px}
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:0;
  filter:saturate(1.1) contrast(1.05) brightness(.65);
  transform:scale(1.04);will-change:transform;
}
.hero-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse at 80% 10%,rgba(61,169,252,.30),transparent 55%),
    radial-gradient(ellipse at 10% 80%,rgba(91,192,235,.22),transparent 60%),
    linear-gradient(180deg,rgba(4,11,26,.45) 0%,rgba(4,11,26,.92) 100%);
}
.hero::before{display:none} /* video replaces ken-burns image */
.hero-inner{z-index:2}

/* Scroll cue */
.hero-scroll-cue{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;
  width:26px;height:42px;border:1.5px solid rgba(255,255,255,.5);border-radius:14px;
  display:grid;place-items:flex-start;justify-content:center;padding-top:8px;
  transition:.3s var(--ease);
}
.hero-scroll-cue:hover{border-color:var(--c-blue);box-shadow:0 0 24px var(--c-blue-glow)}
.hero-scroll-cue span{
  display:block;width:3px;height:8px;border-radius:2px;background:var(--c-blue-2);
  animation:scroll-cue 2s ease-in-out infinite;
}
@keyframes scroll-cue{
  0%{transform:translateY(0);opacity:1}
  60%{transform:translateY(14px);opacity:.2}
  100%{transform:translateY(0);opacity:1}
}

/* Hero headline character split (filled in by JS) */
.split-char{
  display:inline-block;opacity:0;transform:translateY(40%) rotateX(40deg);
  transition:opacity .8s var(--ease),transform .8s var(--ease);
  transform-origin:50% 100%;
}
.split-ready .split-char{opacity:1;transform:none}

/* === Scene connector (sticky parallax flow) ======================== */
.section-connect{position:relative;z-index:1}
.section-connect::before{
  content:"";position:absolute;left:50%;top:-40px;height:80px;width:1px;
  background:linear-gradient(180deg,transparent,var(--c-blue) 50%,transparent);
  opacity:.5;transform:translateX(-50%);
}
.section-connect::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:-1;
  background:radial-gradient(circle at var(--mx,50%) var(--my,30%),rgba(61,169,252,.06),transparent 50%);
  transition:opacity .6s var(--ease);
}

/* Parallax helpers */
[data-parallax]{will-change:transform}

/* About media wrap with luxury frame + glow */
.about-media{position:relative;border-radius:var(--radius);overflow:visible}
.about-media img{position:relative;z-index:2}
.about-media-glow{
  position:absolute;inset:-4%;border-radius:calc(var(--radius) + 12px);
  background:radial-gradient(circle at 30% 30%,var(--c-blue-glow),transparent 65%);
  filter:blur(40px);opacity:.7;z-index:1;
  animation:about-pulse 6s ease-in-out infinite alternate;
}
@keyframes about-pulse{from{opacity:.4;transform:scale(.98)}to{opacity:.85;transform:scale(1.04)}}

/* === Magnetic buttons ============================================== */
[data-magnetic]{will-change:transform;transition:transform .35s var(--ease-spring)}

/* Tilt cards explicit class (JS-driven) */
.tilt{transform-style:preserve-3d;will-change:transform}

/* === Premium hover edge glow on cards ============================== */
.trip-card,.vlog-card,.svc-card,.review-card{
  background-image:
    linear-gradient(var(--c-card),var(--c-card)),
    linear-gradient(135deg,rgba(61,169,252,0) 0%,rgba(61,169,252,.55) 50%,rgba(61,169,252,0) 100%);
  background-origin:border-box;
  background-clip:padding-box,border-box;
  border:1px solid transparent;
}

/* === Refined section divider line ================================== */
.gold-divider{height:1px;background:linear-gradient(90deg,transparent,var(--c-blue) 30%,var(--c-cyan) 70%,transparent)}

/* === Scene fade-edges (gives "connected" feeling) ================== */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:99;
  background:radial-gradient(ellipse at 50% 100%,transparent 60%,rgba(4,11,26,.5));
  opacity:.3;
}

/* === Hero video on smaller screens ================================= */
@media (max-width:760px){
  .hero-video{filter:saturate(1.05) brightness(.55)}
  .hero-scroll-cue{display:none}
}

/* Ensure no double cursor flicker on touch */
@media (hover:none){
  .cursor-dot,.cursor-ring{display:none}
  body{cursor:auto}
}

/* =====================================================================
   v4 — LUXURY HOME REDESIGN
   Aurora hero / How it works / Destinations / Service flip cards /
   Review slider / Social cards / Newsletter / extra animations
   ===================================================================== */

/* --- Aurora text + line shimmer ------------------------------------ */
.aurora-text{
  background:linear-gradient(120deg,#7CC4FF 0%,#3DA9FC 30%,#5BC0EB 50%,#7CC4FF 70%,#3DA9FC 100%);
  background-size:300% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:aurora-flow 9s linear infinite;
}
@keyframes aurora-flow{0%{background-position:0% 50%}100%{background-position:300% 50%}}
.shimmer-line{position:relative;overflow:hidden}
.shimmer-line::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);
  transform:translateX(-100%);animation:shimmer-sweep 4s var(--ease) infinite;
}
@keyframes shimmer-sweep{0%{transform:translateX(-100%)}60%{transform:translateX(100%)}100%{transform:translateX(100%)}}

/* --- Hero aurora orbs (cinematic depth) ---------------------------- */
.hero-cinema{position:relative}
.hero-aurora{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.hero-aurora .aurora{position:absolute;border-radius:50%;filter:blur(90px);opacity:.55;mix-blend-mode:screen}
.hero-aurora .a1{width:520px;height:520px;background:radial-gradient(circle,#3DA9FC,transparent 60%);top:-10%;left:-10%;animation:orbit-a 18s ease-in-out infinite alternate}
.hero-aurora .a2{width:420px;height:420px;background:radial-gradient(circle,#5BC0EB,transparent 60%);bottom:-15%;right:-10%;animation:orbit-b 22s ease-in-out infinite alternate}
.hero-aurora .a3{width:340px;height:340px;background:radial-gradient(circle,#1B6FE0,transparent 60%);top:35%;left:55%;animation:orbit-c 26s ease-in-out infinite alternate;opacity:.4}
@keyframes orbit-a{from{transform:translate(0,0) scale(1)}to{transform:translate(120px,80px) scale(1.15)}}
@keyframes orbit-b{from{transform:translate(0,0) scale(1)}to{transform:translate(-100px,-60px) scale(1.1)}}
@keyframes orbit-c{from{transform:translate(0,0) scale(.95)}to{transform:translate(-80px,40px) scale(1.2)}}

/* Hero stats glassy panel */
.hero-stats-glass{
  background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  border:1px solid rgba(124,196,255,.15);border-radius:20px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:18px 24px;margin-top:36px;display:flex;flex-wrap:wrap;gap:32px;justify-content:center;
}
.hero-title{font-size:clamp(48px,8vw,128px);line-height:.95;margin-bottom:.3em}
.hero-lead{max-width:640px;margin:0 auto 28px}

/* Button shine sweep */
.has-shine{position:relative;overflow:hidden;isolation:isolate}
.has-shine::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  transform:translateX(-100%);transition:transform .9s var(--ease);
}
.has-shine:hover::after{transform:translateX(100%)}
.btn .arrow{display:inline-block;margin-inline-start:6px;transition:transform .35s var(--ease-spring)}
.btn:hover .arrow{transform:translateX(6px)}

/* Marquee glow tweak */
.marquee-glow span{text-shadow:0 0 24px rgba(61,169,252,.25)}

/* --- About section v4 ---------------------------------------------- */
.kenburns img{animation:kenburns 22s var(--ease) infinite alternate;will-change:transform}
@keyframes kenburns{from{transform:scale(1) translate(0,0)}to{transform:scale(1.08) translate(-1.5%,-1%)}}
.about-media-frame{
  position:absolute;inset:14px;border:1px solid rgba(124,196,255,.25);
  border-radius:calc(var(--radius) - 4px);pointer-events:none;z-index:3;
  box-shadow:inset 0 0 60px rgba(61,169,252,.08);
}
.about-points{list-style:none;padding:0;margin:24px 0 28px;display:grid;gap:12px}
.about-points li{display:flex;align-items:center;gap:14px;color:var(--c-muted);font-size:15px}
.about-points .dot{
  width:8px;height:8px;border-radius:50%;flex:0 0 8px;
  background:radial-gradient(circle,var(--c-blue-2),var(--c-blue-3));
  box-shadow:0 0 12px var(--c-blue-glow);
  animation:dot-pulse 2.4s ease-in-out infinite;
}
.about-points li:nth-child(2) .dot{animation-delay:.3s}
.about-points li:nth-child(3) .dot{animation-delay:.6s}
.about-points li:nth-child(4) .dot{animation-delay:.9s}
@keyframes dot-pulse{0%,100%{transform:scale(1);box-shadow:0 0 12px var(--c-blue-glow)}50%{transform:scale(1.4);box-shadow:0 0 24px var(--c-blue-glow)}}

/* --- How it works -------------------------------------------------- */
.how-section{position:relative}
.how-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-top:48px;position:relative}
.how-grid::before{
  content:"";position:absolute;left:0;right:0;top:60px;height:1px;
  background:linear-gradient(90deg,transparent,var(--c-blue) 20%,var(--c-cyan) 50%,var(--c-blue) 80%,transparent);
  opacity:.35;display:none;
}
@media (min-width:900px){.how-grid::before{display:block}}
.how-step{
  background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--radius);
  padding:32px 28px;position:relative;overflow:hidden;
  transition:transform .5s var(--ease-spring),border-color .5s var(--ease),box-shadow .5s var(--ease);
}
.how-step::before{
  content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0,rgba(61,169,252,.15),transparent 60%);
  opacity:0;transition:opacity .5s var(--ease);
}
.how-step:hover{transform:translateY(-6px);border-color:rgba(124,196,255,.5);box-shadow:0 24px 60px -20px rgba(61,169,252,.35)}
.how-step:hover::before{opacity:1}
.how-num{
  font-family:'Cormorant Garamond',serif;font-size:56px;line-height:1;font-weight:600;
  background:linear-gradient(135deg,var(--c-blue-2),var(--c-blue));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  margin-bottom:16px;letter-spacing:-.04em;
}
.how-step h3{font-size:22px;margin-bottom:10px}
.how-step p{font-size:14.5px;line-height:1.6;margin:0}

/* --- Destinations -------------------------------------------------- */
.dest-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:48px}
.dest-card{
  position:relative;display:block;height:280px;border-radius:var(--radius);
  overflow:hidden;isolation:isolate;cursor:pointer;
  background:var(--bg) center/cover no-repeat;
  transition:transform .7s var(--ease);
}
.dest-card:hover{transform:scale(1.015)}
.dest-card::before{
  content:"";position:absolute;inset:0;background:inherit;
  transition:transform 1.6s var(--ease);transform:scale(1);z-index:-1;
}
.dest-card:hover::before{transform:scale(1.12)}
.dest-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(4,11,26,.1) 0%,rgba(4,11,26,.55) 55%,rgba(4,11,26,.92) 100%);
  transition:opacity .5s var(--ease);
}
.dest-content{position:absolute;left:0;right:0;bottom:0;padding:24px 26px;color:#fff;z-index:1}
.dest-content h3{font-size:34px;margin:6px 0 6px;line-height:1}
.dest-content p{margin:0;font-size:13px;color:rgba(234,242,255,.85);letter-spacing:.02em}
.dest-card::after{
  content:"→";position:absolute;top:18px;right:18px;width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.08);backdrop-filter:blur(8px);
  display:grid;place-items:center;color:#fff;font-size:18px;
  border:1px solid rgba(255,255,255,.18);
  transition:background .35s var(--ease),transform .45s var(--ease-spring);
  opacity:0;transform:translateX(-8px);
}
.dest-card:hover::after{opacity:1;transform:translateX(0);background:var(--c-blue)}
body.rtl .dest-card::after{right:auto;left:18px;content:"←"}

/* --- Service flip cards ------------------------------------------- */
.svc-flip{perspective:1000px;background:transparent !important;border:none !important;padding:0 !important;cursor:pointer}
.svc-flip-inner{position:relative;width:100%;min-height:200px;transition:transform .8s var(--ease);transform-style:preserve-3d}
.svc-flip:hover .svc-flip-inner{transform:rotateY(180deg)}
.svc-flip-front,.svc-flip-back{
  position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;
  background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--radius);
  padding:28px 22px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;
}
.svc-flip-back{transform:rotateY(180deg);background:linear-gradient(135deg,rgba(61,169,252,.16),rgba(91,192,235,.08))}
.svc-flip-front .ico{
  width:54px;height:54px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle,rgba(61,169,252,.25),transparent 70%);
  font-size:28px;color:var(--c-blue-2);margin-bottom:6px;
  animation:svc-ico-float 4s ease-in-out infinite;
}
@keyframes svc-ico-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.svc-flip-front h3{font-size:18px;margin:6px 0 4px}
.svc-cat{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted);font-family:'Outfit',sans-serif}

/* --- Review slider ------------------------------------------------- */
.review-slider{position:relative;max-width:820px;margin:48px auto 0;text-align:center;min-height:220px}
.review-slide{
  position:absolute;inset:0;opacity:0;transform:translateY(16px);
  transition:opacity .9s var(--ease),transform .9s var(--ease);
  pointer-events:none;padding:0 24px;
}
.review-slide.is-active{opacity:1;transform:none;pointer-events:auto;position:relative}
.review-slide blockquote{font-family:'Cormorant Garamond',serif;font-size:clamp(22px,3vw,32px);line-height:1.45;margin:18px 0;color:var(--c-text)}
.review-slide .stars{color:var(--c-blue-2);font-size:20px;letter-spacing:.2em}
.review-slide .name{margin-top:12px;font-size:14px;letter-spacing:.04em}
.review-dots{display:flex;gap:8px;justify-content:center;margin-top:20px}
.review-dots span{width:8px;height:8px;border-radius:50%;background:rgba(124,196,255,.25);transition:all .4s var(--ease);cursor:pointer}
.review-dots span.is-active{background:var(--c-blue);width:28px;border-radius:4px}

/* --- Social cards -------------------------------------------------- */
.social-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:48px}
.social-card{
  position:relative;display:block;padding:36px 28px;border-radius:var(--radius);
  background:var(--c-card);border:1px solid var(--c-border);overflow:hidden;
  transition:transform .55s var(--ease-spring),border-color .55s var(--ease);
  text-align:center;isolation:isolate;
}
.social-card:hover{transform:translateY(-8px) rotate(-.5deg)}
.social-glow{
  position:absolute;inset:-40%;border-radius:50%;filter:blur(60px);opacity:0;z-index:-1;
  transition:opacity .8s var(--ease);
}
.social-card:hover .social-glow{opacity:.65}
.social-ig .social-glow{background:radial-gradient(circle,#E1306C,#F77737,#FCAF45,transparent 70%)}
.social-fb .social-glow{background:radial-gradient(circle,#1877F2,#3DA9FC,transparent 70%)}
.social-tt .social-glow{background:radial-gradient(circle,#25F4EE,#FE2C55,transparent 70%)}
.social-ico{
  width:64px;height:64px;border-radius:50%;display:grid;place-items:center;margin:0 auto 14px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  color:#fff;transition:transform .55s var(--ease-spring),background .55s var(--ease);
}
.social-card:hover .social-ico{transform:rotate(-8deg) scale(1.06);background:rgba(255,255,255,.12)}
.social-card h3{font-size:24px;margin:0 0 4px}
.social-card p{margin:0;color:var(--c-muted);font-size:14px;letter-spacing:.04em}
.social-cta{display:inline-block;margin-top:14px;font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--c-blue-2)}

/* --- Newsletter ---------------------------------------------------- */
.newsletter-section{padding-block:80px}
.newsletter-card{
  position:relative;text-align:center;max-width:760px;margin:0 auto;
  background:linear-gradient(135deg,rgba(13,29,60,.85),rgba(8,21,48,.85));
  border:1px solid var(--c-border);border-radius:24px;
  padding:60px 32px;overflow:hidden;
}
.newsletter-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 20%,rgba(61,169,252,.12),transparent 60%),
             radial-gradient(circle at 80% 80%,rgba(91,192,235,.12),transparent 60%);
  pointer-events:none;
}
.newsletter-orbit{position:absolute;inset:0;pointer-events:none}
.newsletter-orbit span{
  position:absolute;border-radius:50%;border:1px dashed rgba(124,196,255,.18);
  animation:orbit-spin 30s linear infinite;
}
.newsletter-orbit span:nth-child(1){inset:8%;animation-duration:40s}
.newsletter-orbit span:nth-child(2){inset:16%;animation-duration:32s;animation-direction:reverse}
.newsletter-orbit span:nth-child(3){inset:26%;animation-duration:24s}
@keyframes orbit-spin{to{transform:rotate(360deg)}}
.newsletter-form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:22px;position:relative}
.newsletter-form input{
  flex:1 1 280px;max-width:340px;padding:14px 18px;border-radius:50px;
  background:rgba(255,255,255,.04);border:1px solid var(--c-border);
  color:var(--c-text);font-family:inherit;font-size:14px;outline:none;
  transition:border-color .35s var(--ease),background .35s var(--ease);
}
.newsletter-form input:focus{border-color:var(--c-blue);background:rgba(61,169,252,.08)}
.newsletter-form input::placeholder{color:rgba(234,242,255,.45)}

/* --- Vlog grid (matches trip card hover language) ------------------ */
.vlog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:48px}

/* --- Reveal-words helper (h2 word-by-word fade) -------------------- */
.reveal-words .word{display:inline-block;opacity:0;transform:translateY(40%);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal-words.is-revealed .word{opacity:1;transform:none}

/* --- RTL adjustments ---------------------------------------------- */
body.rtl .btn .arrow{transform:scaleX(-1)}
body.rtl .btn:hover .arrow{transform:scaleX(-1) translateX(6px)}

/* --- Responsive ---------------------------------------------------- */
@media (max-width:760px){
  .how-grid::before{display:none}
  .hero-stats-glass{padding:14px 16px;gap:18px}
  .dest-card{height:220px}
  .dest-content h3{font-size:26px}
  .social-card{padding:28px 20px}
  .newsletter-card{padding:48px 22px}
}

@media (prefers-reduced-motion:reduce){
  .aurora-text,.shimmer-line::after,.kenburns img,.dot-pulse,
  .hero-aurora .aurora,.svc-flip-front .ico,.newsletter-orbit span{
    animation:none !important;
  }
  .svc-flip:hover .svc-flip-inner{transform:none}
}


/* =====================================================================
   v5 — Gallery, 3D destinations, deep cinematic motion
   ===================================================================== */

/* --- Page hero (used by Gallery and other inner pages) ------------- */
.page-hero{position:relative;padding:160px 0 80px;text-align:center;overflow:hidden;isolation:isolate}
.page-hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(ellipse at 50% 0%,rgba(61,169,252,.2),transparent 60%),
             linear-gradient(180deg,#040B1A 0%,#081530 100%);
}
.page-hero h1{font-size:clamp(56px,9vw,140px);line-height:.95;margin:.2em 0}
.page-hero .lead{max-width:680px;margin:.2em auto 0;color:var(--c-muted)}

/* --- 3D Destinations (deeper depth + parallax tilt) ---------------- */
.dest-grid-3d{perspective:1400px;transform-style:preserve-3d}
.dest-grid-3d .dest-card{
  transform:translateZ(0) rotateX(0) rotateY(0);
  transition:transform .9s var(--ease),box-shadow .9s var(--ease),border-radius .6s var(--ease);
  border-radius:20px;
}
.dest-grid-3d .dest-card:hover{
  transform:translateZ(40px) rotateX(-2deg) rotateY(2deg) scale(1.03);
  box-shadow:0 40px 80px -20px rgba(61,169,252,.45),0 0 0 1px rgba(124,196,255,.4);
  z-index:5;border-radius:14px;
}
.dest-grid-3d .dest-card::after{transition:transform .55s var(--ease-spring),background .35s var(--ease),opacity .35s var(--ease),box-shadow .35s var(--ease)}
.dest-grid-3d .dest-card:hover::after{box-shadow:0 8px 24px rgba(61,169,252,.5)}

/* Card depth shadow under image */
.dest-grid-3d .dest-card::before{
  content:"";position:absolute;left:8%;right:8%;bottom:-20px;height:30px;z-index:-2;
  background:radial-gradient(ellipse,rgba(61,169,252,.45),transparent 70%);
  filter:blur(20px);opacity:0;transition:opacity .6s var(--ease);
}
.dest-grid-3d .dest-card:hover::before{opacity:.85}

/* --- Gallery preview mosaic (home) --------------------------------- */
.gallery-mosaic{
  display:grid;gap:14px;
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:140px;
  margin-top:48px;perspective:1200px;
}
.gallery-tile{
  position:relative;display:block;overflow:hidden;border-radius:14px;
  transform:translateZ(0);
  transition:transform .8s var(--ease-spring),box-shadow .8s var(--ease),z-index 0s linear .4s;
  background:#0a1a35;
  isolation:isolate;
}
.gallery-tile img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s var(--ease),filter .6s var(--ease);
  filter:saturate(.9) brightness(.85);
}
.gallery-tile:hover{
  transform:translateZ(60px) rotateY(-3deg) scale(1.04);
  box-shadow:0 30px 60px -10px rgba(61,169,252,.5);
  z-index:5;transition-delay:0s;
}
.gallery-tile:hover img{transform:scale(1.12);filter:saturate(1.15) brightness(1)}
.gallery-tile-meta{
  position:absolute;left:0;right:0;bottom:0;padding:14px 16px;
  background:linear-gradient(180deg,transparent,rgba(4,11,26,.92));
  color:#fff;opacity:0;transform:translateY(10px);
  transition:opacity .5s var(--ease),transform .5s var(--ease);
}
.gallery-tile:hover .gallery-tile-meta{opacity:1;transform:none}
.gallery-tile-meta strong{display:block;font-family:'Cormorant Garamond',serif;font-size:18px;margin-top:4px}
/* Mosaic placement (9 tiles) */
.gallery-tile:nth-child(1){grid-column:span 2;grid-row:span 2}
.gallery-tile:nth-child(2){grid-column:span 2;grid-row:span 1}
.gallery-tile:nth-child(3){grid-column:span 2;grid-row:span 1}
.gallery-tile:nth-child(4){grid-column:span 1;grid-row:span 1}
.gallery-tile:nth-child(5){grid-column:span 1;grid-row:span 2}
.gallery-tile:nth-child(6){grid-column:span 2;grid-row:span 1}
.gallery-tile:nth-child(7){grid-column:span 2;grid-row:span 1}
.gallery-tile:nth-child(8){grid-column:span 2;grid-row:span 1}
.gallery-tile:nth-child(9){grid-column:span 2;grid-row:span 1}
@media (max-width:900px){
  .gallery-mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .gallery-tile,.gallery-tile:nth-child(n){grid-column:span 1;grid-row:span 1}
  .gallery-tile:nth-child(1){grid-column:span 2}
}

/* --- Gallery page (full grid + filter chips) ----------------------- */
.gallery-filter{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:36px}
.gallery-chip{
  background:rgba(255,255,255,.04);border:1px solid var(--c-border);
  color:var(--c-text);padding:10px 20px;border-radius:50px;
  font-family:'Outfit',sans-serif;font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  cursor:pointer;transition:all .35s var(--ease);
}
.gallery-chip:hover{border-color:var(--c-blue);color:var(--c-blue-2)}
.gallery-chip.is-active{
  background:linear-gradient(135deg,var(--c-blue),var(--c-blue-3));
  border-color:transparent;color:#fff;
  box-shadow:0 8px 24px -8px var(--c-blue-glow);
}
.gallery-masonry{
  column-count:3;column-gap:18px;margin-top:24px;
}
@media (max-width:1100px){.gallery-masonry{column-count:2}}
@media (max-width:640px){.gallery-masonry{column-count:1}}
.gallery-item{
  display:block;break-inside:avoid;margin-bottom:18px;
  position:relative;border-radius:16px;overflow:hidden;
  background:#0a1a35;isolation:isolate;
  transition:transform .7s var(--ease-spring),box-shadow .7s var(--ease),opacity .5s var(--ease);
  animation:gal-fade-in .9s var(--ease) backwards;
  animation-delay:calc(var(--i,0) * 60ms);
}
@keyframes gal-fade-in{from{opacity:0;transform:translateY(40px) scale(.96)}to{opacity:1;transform:none}}
.gallery-item.is-hidden{display:none}
.gallery-item img{width:100%;display:block;transition:transform 1.2s var(--ease),filter .5s var(--ease);filter:saturate(.95)}
.gallery-item:hover{transform:translateY(-6px) scale(1.015);box-shadow:0 30px 50px -16px rgba(61,169,252,.4)}
.gallery-item:hover img{transform:scale(1.06);filter:saturate(1.1)}
.gallery-item .gallery-meta{
  position:absolute;left:0;right:0;bottom:0;padding:18px 20px;
  background:linear-gradient(180deg,transparent,rgba(4,11,26,.95));
  color:#fff;opacity:0;transform:translateY(12px);
  transition:opacity .5s var(--ease),transform .5s var(--ease);
}
.gallery-item:hover .gallery-meta{opacity:1;transform:none}
.gallery-item .gallery-meta h3{font-size:22px;margin:6px 0 0}
.gallery-hero{padding-top:180px}

/* --- Cinematic scroll: card scroll-fade + zoom --------------------- */
.section-connect{transform:translate3d(0,0,0)}
[data-reveal].is-revealed{animation:rev-in 1s var(--ease) both}
@keyframes rev-in{from{opacity:0;transform:translateY(40px) scale(.98)}to{opacity:1;transform:none}}

/* Slow drifting background grid (deep parallax) */
body::after{
  content:"";position:fixed;inset:-10%;pointer-events:none;z-index:0;
  background:
    radial-gradient(circle at 18% 22%,rgba(61,169,252,.06),transparent 30%),
    radial-gradient(circle at 82% 78%,rgba(91,192,235,.05),transparent 30%);
  animation:drift 24s ease-in-out infinite alternate;
  mix-blend-mode:screen;
}
@keyframes drift{from{transform:translate(0,0)}to{transform:translate(-3%,2%)}}

/* Section title 3D pop on enter (uses reveal-words infrastructure) */
.section-head h2{transform-style:preserve-3d}
.section-head h2 .word{transform-origin:50% 100%}

/* Hero title micro-tilt on cursor */
.hero-title{transform-style:preserve-3d;will-change:transform;transition:transform .4s var(--ease)}

/* Footer cleaner without admin */
.footer-bottom{justify-content:center !important}

@media (prefers-reduced-motion:reduce){
  body::after{animation:none}
  .gallery-item,.gallery-tile,.dest-grid-3d .dest-card{animation:none !important;transform:none !important}
}
