/* ============================================================
   SAFRI TRAVELS & TOURS — Design tokens & styles
   Palette sampled from logo:
   orange #F04800 (primary) · teal #186060 · sky #00A8F0
   ============================================================ */
:root{
  /* Brand — exact logo hex */
  --orange:        #F04800;
  --orange-deep:   #D84800;
  --orange-glow:   #FF6A24;
  --teal:          #186060;
  --teal-deep:     #0E3F3F;
  --teal-glow:     #1FB7AE;
  --sky:           #00A8F0;
  --sky-glow:      #38C6FF;
  --cream:         #FFF0D8;

  /* Surfaces */
  --bg:            #FBFCFD;
  --bg-2:          #F2F5F7;
  --ink:           #0C1A1A;
  --ink-soft:      #34504F;
  --line:          rgba(12,26,26,.10);
  --glass:         rgba(255,255,255,.62);
  --glass-brd:     rgba(255,255,255,.85);

  --shadow-sm: 0 2px 10px rgba(12,26,26,.06);
  --shadow-md: 0 16px 50px -20px rgba(12,26,26,.22);
  --shadow-lg: 0 40px 90px -40px rgba(14,63,63,.35);
  --glow-orange: 0 0 0 1px rgba(240,72,0,.35), 0 8px 36px -8px rgba(240,72,0,.55);

  --r-sm: 12px;
  --r-md: 18px;
  --r-lg: 28px;
  --r-pill: 999px;

  --maxw: 1160px;
  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-body: "Manrope", system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--orange);color:#fff}

/* WebGL canvas pinned behind everything */
#bg-canvas{
  position:fixed; inset:0; width:100vw; height:100vh;
  z-index:0; pointer-events:none;
}
/* soft light vignette so neon points read on white */
#bg-vignette{
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(0,168,240,.07), transparent 55%),
    radial-gradient(100% 80% at 8% 110%, rgba(240,72,0,.06), transparent 55%);
}
#app{position:relative; z-index:2}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--font-display); font-weight:700; line-height:1.02; letter-spacing:-.02em}
.eyebrow{
  font-family:var(--font-display);
  font-size:.72rem; font-weight:600; letter-spacing:.32em; text-transform:uppercase;
  color:var(--orange); display:inline-flex; align-items:center; gap:.6em;
}
.eyebrow::before{content:""; width:26px; height:2px; background:var(--orange); border-radius:2px}
.muted{color:var(--ink-soft)}
.grad-ink{background:linear-gradient(120deg,var(--teal-deep),var(--teal)); -webkit-background-clip:text; background-clip:text; color:transparent}
.grad-orange{background:linear-gradient(110deg,var(--orange),var(--orange-glow)); -webkit-background-clip:text; background-clip:text; color:transparent}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px}
section{position:relative; z-index:2}
.section-pad{padding:120px 0}

/* ---------- Oval nav ---------- */
.nav{
  position:fixed; top:22px; left:50%; transform:translateX(-50%);
  z-index:50; display:flex; align-items:center; gap:6px;
  padding:8px 8px 8px 18px;
  background:var(--glass);
  border:1px solid var(--glass-brd);
  border-radius:var(--r-pill);
  box-shadow:var(--shadow-md);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  transition:box-shadow .4s, transform .4s;
  max-width:calc(100vw - 28px);
}
.nav-brand{display:flex; align-items:center; gap:10px; padding-right:14px; margin-right:4px; border-right:1px solid var(--line)}
.nav-mark{width:30px;height:30px;border-radius:50%; display:grid;place-items:center; flex:0 0 auto}
.nav-brand-text{display:flex; flex-direction:column; line-height:1}
.nav-brand-text b{font-family:var(--font-display); font-size:1rem; letter-spacing:-.01em; white-space:nowrap}
.nav-brand-text i{font-style:normal; font-family:var(--font-display); font-size:.55rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); white-space:nowrap; margin-top:3px}
.nav-links{display:flex; align-items:center; gap:2px}
.nav-links a{
  font-size:.85rem; font-weight:600; color:var(--ink-soft);
  padding:9px 14px; border-radius:var(--r-pill); transition:.25s; white-space:nowrap;
}
.nav-links a:hover{color:var(--ink); background:rgba(12,26,26,.05)}
.nav-cta{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-display); font-weight:600; font-size:.85rem;
  color:#fff; background:linear-gradient(120deg,var(--orange),var(--orange-deep));
  padding:11px 18px; border-radius:var(--r-pill); white-space:nowrap;
  box-shadow:var(--glow-orange); transition:.25s;
}
.nav-cta:hover{transform:translateY(-1px); filter:brightness(1.05)}
.nav-burger{display:none; background:none;border:0;cursor:pointer; padding:10px; border-radius:var(--r-pill)}
.nav-burger span{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;margin:4px 0;transition:.3s}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:9px; cursor:pointer;
  font-family:var(--font-display); font-weight:600; font-size:.95rem;
  padding:15px 26px; border-radius:var(--r-pill); border:0; transition:.25s;
  white-space:nowrap;
}
.btn-primary{color:#fff; background:linear-gradient(120deg,var(--orange),var(--orange-deep)); box-shadow:var(--glow-orange)}
.btn-primary:hover{transform:translateY(-2px); filter:brightness(1.06)}
.btn-ghost{color:var(--ink); background:var(--glass); border:1px solid var(--line); backdrop-filter:blur(10px)}
.btn-ghost:hover{border-color:var(--teal); color:var(--teal)}
.btn-wa{color:#fff; background:linear-gradient(120deg,#25D366,#12a150)}
.btn-wa:hover{transform:translateY(-2px); filter:brightness(1.05)}

/* ---------- Hero ---------- */
.hero{min-height:100vh; display:flex; align-items:center; padding-top:120px; padding-bottom:60px}
.hero-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:48px; align-items:center; width:100%}
.hero h1{font-size:clamp(2.7rem,6vw,5rem); margin:18px 0 22px}
.hero h1 .line{display:block; overflow:hidden}
.hero-sub{font-size:1.18rem; max-width:30ch; margin-bottom:34px}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap; align-items:center}
.hero-stats{display:flex; gap:34px; margin-top:46px; flex-wrap:wrap}
.hero-stats .stat b{font-family:var(--font-display); font-size:1.8rem; display:block; line-height:1}
.hero-stats .stat span{font-size:.82rem; color:var(--ink-soft); letter-spacing:.02em}

/* ---------- Booking widget ---------- */
.widget{
  background:var(--glass);
  border:1px solid var(--glass-brd);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);
  backdrop-filter:blur(26px) saturate(1.4);
  -webkit-backdrop-filter:blur(26px) saturate(1.4);
  padding:10px; position:relative; overflow:hidden;
}
.widget::before{content:""; position:absolute; inset:0; border-radius:var(--r-lg); padding:1px;
  background:linear-gradient(140deg,rgba(240,72,0,.5),rgba(0,168,240,.35),transparent 60%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none}
.widget-tabs{display:grid; grid-template-columns:repeat(3,1fr); gap:6px; background:rgba(12,26,26,.05); border-radius:var(--r-md); padding:5px; position:relative}
.widget-tabs button{
  position:relative; z-index:2; border:0; background:none; cursor:pointer;
  font-family:var(--font-display); font-weight:600; font-size:.86rem; color:var(--ink-soft);
  padding:12px 6px; border-radius:13px; transition:color .3s; display:flex;flex-direction:column;align-items:center;gap:5px;
}
.widget-tabs button.active{color:#fff}
.tab-ind{position:absolute; z-index:1; top:5px; bottom:5px; border-radius:13px; transition:transform .4s cubic-bezier(.6,.2,0,1), background .4s;
  width:calc((100% - 10px - 12px)/3); left:5px}
.widget-body{padding:20px 16px 16px}
.field{margin-bottom:14px}
.field label{display:block; font-size:.74rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:7px}
.field .control{
  width:100%; font-family:var(--font-body); font-size:.95rem; color:var(--ink);
  background:rgba(255,255,255,.7); border:1px solid var(--line); border-radius:var(--r-sm);
  padding:12px 14px; transition:.2s; appearance:none;
}
.field .control:focus{outline:0; border-color:var(--orange); box-shadow:0 0 0 3px rgba(240,72,0,.14); background:#fff}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.stepper{display:flex; align-items:center; justify-content:space-between; background:rgba(255,255,255,.7); border:1px solid var(--line); border-radius:var(--r-sm); padding:6px 8px}
.stepper button{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:1.2rem;color:var(--teal);display:grid;place-items:center;transition:.2s;line-height:1}
.stepper button:hover{border-color:var(--orange);color:var(--orange)}
.stepper .val{font-family:var(--font-display);font-weight:700;font-size:1.05rem}
.chip-row{display:flex;gap:8px;flex-wrap:wrap}
.chip{font-size:.8rem;font-weight:600;padding:8px 13px;border-radius:var(--r-pill);border:1px solid var(--line);background:rgba(255,255,255,.6);cursor:pointer;transition:.2s;color:var(--ink-soft)}
.chip.active{background:var(--teal);color:#fff;border-color:var(--teal)}
.chip:hover{border-color:var(--teal)}
.widget-foot{margin-top:6px}
.widget-foot .btn{width:100%; justify-content:center; font-size:1rem; padding:16px}
.widget-note{text-align:center;font-size:.76rem;color:var(--ink-soft);margin-top:11px;display:flex;align-items:center;justify-content:center;gap:6px}
.est{display:flex;justify-content:space-between;align-items:baseline;padding:13px 4px 4px;font-size:.85rem}
.est b{font-family:var(--font-display);font-size:1.35rem;color:var(--teal)}

/* ---------- Section header ---------- */
.sec-head{max-width:680px; margin-bottom:56px}
.sec-head h2{font-size:clamp(2rem,4.2vw,3.2rem); margin:16px 0 18px}
.sec-head p{font-size:1.1rem}

/* ---------- Service feature blocks ---------- */
.service{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; padding:70px 0; position:relative}
.service.flip .service-media{order:2}
.service-media{position:relative; min-height:420px; border-radius:var(--r-lg); overflow:hidden;
  border:1px solid var(--line); background:rgba(255,255,255,.45); backdrop-filter:blur(8px); box-shadow:var(--shadow-md);
  display:flex;flex-direction:column;justify-content:flex-end;padding:26px}
.service-num{position:absolute; top:18px; left:24px; font-family:var(--font-display); font-weight:700; font-size:5.5rem; line-height:.8; color:transparent; -webkit-text-stroke:1.5px rgba(12,26,26,.10)}
.service h3{font-size:clamp(1.8rem,3.4vw,2.6rem); margin:14px 0 16px}
.service-tag{font-family:var(--font-display);font-weight:600;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase}
.feat-list{list-style:none; margin:22px 0 28px; display:grid; gap:13px}
.feat-list li{display:flex; gap:12px; align-items:flex-start; font-size:1rem}
.feat-list svg{flex:0 0 auto;margin-top:3px}
.price-pill{display:inline-flex;align-items:baseline;gap:8px;background:rgba(255,255,255,.7);border:1px solid var(--line);border-radius:var(--r-pill);padding:9px 18px;margin-bottom:24px;box-shadow:var(--shadow-sm)}
.price-pill .from{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.price-pill b{font-family:var(--font-display);font-size:1.35rem}

/* media inner: stylised neon cards (no photos) */
.media-badges{display:flex;gap:10px;flex-wrap:wrap}
.media-badge{background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--r-pill);padding:9px 15px;font-size:.82rem;font-weight:600;box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;gap:8px}
.media-headline{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--ink);margin-bottom:14px;max-width:16ch}

/* ---------- Package cards (Umrah) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pkg{background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--r-lg);padding:30px 26px;position:relative;transition:.3s;box-shadow:var(--shadow-sm);backdrop-filter:blur(12px)}
.pkg:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.pkg.feature{border-color:rgba(240,72,0,.4);box-shadow:var(--glow-orange)}
.pkg-flag{position:absolute;top:-12px;left:26px;background:linear-gradient(120deg,var(--orange),var(--orange-deep));color:#fff;font-family:var(--font-display);font-weight:600;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;padding:6px 13px;border-radius:var(--r-pill);box-shadow:var(--glow-orange)}
.pkg h4{font-size:1.3rem;margin-bottom:4px}
.pkg .ptier{font-size:.82rem;color:var(--ink-soft);margin-bottom:18px}
.pkg .pprice{font-family:var(--font-display);font-weight:700;font-size:2rem;margin-bottom:2px}
.pkg .pprice small{font-size:.8rem;font-weight:500;color:var(--ink-soft)}
.pkg .pnote{font-size:.78rem;color:var(--ink-soft);margin-bottom:20px}
.pkg ul{list-style:none;display:grid;gap:11px;margin-bottom:26px}
.pkg ul li{display:flex;gap:10px;font-size:.9rem;align-items:flex-start}
.pkg ul svg{flex:0 0 auto;margin-top:3px}
.pkg .btn{width:100%;justify-content:center}

/* ---------- Tours grid ---------- */
.tour-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.tour{background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--r-md);padding:20px;transition:.3s;cursor:pointer;position:relative;overflow:hidden;backdrop-filter:blur(10px);box-shadow:var(--shadow-sm)}
.tour:hover{transform:translateY(-4px);border-color:var(--teal)}
.tour .tdot{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;margin-bottom:30px}
.tour h4{font-size:1.12rem;margin-bottom:4px}
.tour .tmeta{font-size:.82rem;color:var(--ink-soft)}
.tour .tprice{margin-top:14px;font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--teal)}
.tour .tprice small{font-weight:500;color:var(--ink-soft);font-size:.74rem}

/* ---------- Why / stats ---------- */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.why{padding:30px 26px;border-radius:var(--r-lg);border:1px solid var(--line);background:rgba(255,255,255,.5);backdrop-filter:blur(8px);transition:.3s}
.why:hover{background:rgba(255,255,255,.8);box-shadow:var(--shadow-md)}
.why .wicon{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;margin-bottom:18px}
.why h4{font-size:1.18rem;margin-bottom:8px}
.why p{font-size:.94rem}

.bigstats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:70px;padding:46px 40px;border-radius:var(--r-lg);
  background:linear-gradient(120deg,var(--teal-deep),var(--teal));color:#fff;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.bigstats .bs b{font-family:var(--font-display);font-size:2.8rem;display:block;line-height:1;background:linear-gradient(120deg,#fff,var(--cream));-webkit-background-clip:text;background-clip:text;color:transparent}
.bigstats .bs span{font-size:.86rem;opacity:.82}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:s}
.step{padding:26px 22px;border-radius:var(--r-md);border:1px solid var(--line);background:rgba(255,255,255,.5);position:relative}
.step::before{counter-increment:s;content:"0" counter(s);font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--orange);display:block;margin-bottom:14px}
.step h4{font-size:1.08rem;margin-bottom:7px}
.step p{font-size:.9rem}

/* ---------- CTA band ---------- */
.cta-band{border-radius:var(--r-lg);padding:64px 56px;text-align:center;position:relative;overflow:hidden;
  background:linear-gradient(125deg,var(--orange),var(--orange-deep));color:#fff;box-shadow:var(--glow-orange)}
.cta-band h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:16px;color:#fff}
.cta-band p{font-size:1.1rem;opacity:.92;max-width:46ch;margin:0 auto 30px}
.cta-band .btn-wa{background:#fff;color:var(--orange)}
.cta-band .glow{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5}

/* ---------- Footer ---------- */
.footer{padding:80px 0 40px;border-top:1px solid var(--line);margin-top:40px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:50px}
.foot-brand b{font-family:var(--font-display);font-size:1.3rem;display:block;margin-bottom:12px}
.foot-col h5{font-family:var(--font-display);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:18px}
.foot-col a{display:block;font-size:.92rem;color:var(--ink-soft);padding:6px 0;transition:.2s}
.foot-col a:hover{color:var(--orange)}
.foot-contact div{display:flex;gap:11px;font-size:.9rem;margin-bottom:14px;color:var(--ink-soft);align-items:flex-start}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;border-top:1px solid var(--line);font-size:.82rem;color:var(--ink-soft);flex-wrap:wrap;gap:14px}
.foot-badges{display:flex;gap:10px;flex-wrap:wrap}
.foot-badge{font-size:.72rem;font-weight:600;padding:6px 12px;border-radius:var(--r-pill);border:1px solid var(--line);color:var(--ink-soft)}

/* ---------- Reveal animation — CSS scroll-driven (content always visible if unsupported) ---------- */
.reveal{opacity:1;transform:none}
@keyframes revealIn{from{opacity:0;transform:translateY(34px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:no-preference){
  @supports (animation-timeline:view()){
    .reveal{animation:revealIn linear both;animation-timeline:view();animation-range:entry 2% cover 26%}
  }
}

/* WhatsApp float */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:40;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(120deg,#25D366,#12a150);display:grid;place-items:center;box-shadow:0 12px 30px -8px rgba(18,161,80,.7);cursor:pointer;transition:.25s;border:0}
.wa-float:hover{transform:scale(1.08)}
.wa-float::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(37,211,102,.5);animation:pulse 2.4s infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.5);opacity:0}}

/* scroll progress story labels */
.story-rail{position:fixed;right:26px;top:50%;transform:translateY(-50%);z-index:30;display:flex;flex-direction:column;gap:14px}
.story-rail .dot{width:9px;height:9px;border-radius:50%;background:rgba(12,26,26,.18);transition:.3s;cursor:pointer;position:relative}
.story-rail .dot.active{background:var(--orange);box-shadow:0 0 0 4px rgba(240,72,0,.18)}
.story-rail .dot span{position:absolute;right:18px;top:50%;transform:translateY(-50%);font-size:.7rem;font-weight:600;white-space:nowrap;color:var(--ink-soft);opacity:0;transition:.3s;pointer-events:none}
.story-rail .dot:hover span{opacity:1}

/* ---------- Nav logo ---------- */
.nav-logo{height:30px;width:auto;display:block}

/* ---------- Widget head + scroll hint ---------- */
.widget-head{display:flex;align-items:center;gap:9px;padding:13px 16px 4px;font-size:.77rem;font-weight:700;color:var(--ink-soft);font-family:var(--font-display);letter-spacing:.01em}
.wh-dot{width:8px;height:8px;border-radius:50%;background:#25D366;box-shadow:0 0 0 3px rgba(37,211,102,.22);flex:0 0 auto}
.scroll-hint{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:9px;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);font-family:var(--font-display);font-weight:600}
.sh-mouse{width:22px;height:34px;border:1.5px solid var(--ink-soft);border-radius:12px;display:flex;justify-content:center;padding-top:6px}
.sh-mouse span{width:3px;height:7px;border-radius:2px;background:var(--orange);animation:shScroll 1.6s infinite}
@keyframes shScroll{0%{opacity:0;transform:translateY(-3px)}40%{opacity:1}100%{opacity:0;transform:translateY(9px)}}

/* ---------- Tour link ---------- */
.tour .tlink{margin-top:14px;display:inline-flex;align-items:center;gap:6px;font-family:var(--font-display);font-weight:600;font-size:.85rem;color:var(--teal);transition:.2s}
.tour:hover .tlink{color:var(--orange)}
.tour .tlink svg{transition:transform .25s}
.tour:hover .tlink svg{transform:translateX(3px)}

/* ---------- Centered section head ---------- */
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}

/* ---------- Footer logo ---------- */
.foot-logo{height:54px;width:auto;display:block}

/* ---------- Reviews carousel ---------- */
.rev-stage{position:relative;max-width:800px;margin:0 auto;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);background:var(--glass);border:1px solid var(--glass-brd);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);overflow:hidden}
.rev-track{display:flex;transition:transform .6s cubic-bezier(.6,.1,0,1)}
.rev-card{flex:0 0 100%;padding:48px 60px;position:relative}
.rev-card>svg:first-child{position:absolute;top:22px;left:34px}
.rev-stars{display:flex;gap:4px;margin-bottom:18px;position:relative}
.rev-text{font-family:var(--font-display);font-weight:500;font-size:1.3rem;line-height:1.45;letter-spacing:-.01em;margin-bottom:26px;color:var(--ink);text-wrap:pretty}
.rev-person{display:flex;align-items:center;gap:14px}
.rev-av{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:1.02rem;flex:0 0 auto}
.rev-person b{display:block;font-family:var(--font-display);font-size:1rem}
.rev-person span{font-size:.84rem;color:var(--ink-soft)}
.rev-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.92);cursor:pointer;display:grid;place-items:center;color:var(--teal);transition:.2s;box-shadow:var(--shadow-sm)}
.rev-arrow:hover{color:var(--orange);border-color:var(--orange)}
.rev-arrow.left{left:14px}.rev-arrow.left svg{transform:rotate(180deg)}
.rev-arrow.right{right:14px}
.rev-dots{display:flex;gap:9px;justify-content:center;margin-top:26px}
.rev-dot{width:9px;height:9px;border-radius:50%;border:0;background:rgba(12,26,26,.16);cursor:pointer;transition:.25s;padding:0}
.rev-dot.active{background:var(--orange);width:26px;border-radius:5px}

/* ---------- Decorative car driving down the page ---------- */
.roadcar{position:fixed;top:0;height:100vh;width:48px;z-index:3;pointer-events:none;display:none;
  left:calc((100vw - 1160px) / 2 - 52px)}
.roadcar-line{position:absolute;left:23px;top:0;bottom:0;width:2px;background:repeating-linear-gradient(to bottom,rgba(12,26,26,.16) 0 14px,transparent 14px 30px)}
.roadcar-line::before{content:"";position:absolute;inset:0;width:2px;background:linear-gradient(to bottom,transparent,rgba(240,72,0,.25),transparent)}
.roadcar-car{position:absolute;left:9px;top:0;filter:drop-shadow(0 7px 13px rgba(240,72,0,.45));will-change:transform}
@media(min-width:1280px){ .roadcar{display:block} }

/* ---------- Responsive ---------- */
/* large desktop breathing room */
@media(min-width:1600px){ .section-pad{padding:140px 0} .hero h1{font-size:5.4rem} }

/* small laptop */
@media(max-width:1180px){
  .tour-grid{grid-template-columns:repeat(3,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
}

/* tablet landscape — hero stacks */
@media(max-width:1024px){
  .hero{min-height:auto; padding-top:128px; padding-bottom:80px}
  .hero-grid{grid-template-columns:1fr; gap:34px}
  .hero-sub{max-width:50ch}
  .widget{max-width:540px; width:100%; margin:0 auto}
  .scroll-hint{display:none}
  .bigstats{grid-template-columns:repeat(2,1fr); gap:28px}
  .foot-grid{grid-template-columns:1.3fr 1fr 1fr; gap:30px}
}

/* tablet portrait / mobile nav */
@media(max-width:880px){
  .nav-links{display:none}
  .nav-burger{display:block}
  .nav.open .nav-links{display:flex;position:absolute;top:64px;left:0;right:0;flex-direction:column;background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-brd);border-radius:var(--r-lg);padding:10px;box-shadow:var(--shadow-md)}
  .nav.open .nav-links a{width:100%}
  .service{grid-template-columns:1fr; gap:34px}
  .service.flip .service-media{order:-1}
  .service-media{min-height:280px; order:-1}
  .tour-grid{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:1fr; gap:28px}
  .steps{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .section-pad{padding:84px 0}
  .story-rail{display:none}
  .rev-card{padding:42px 34px}
  .rev-text{font-size:1.16rem}
}

/* phones */
@media(max-width:600px){
  .wrap{padding:0 18px}
  .nav{top:14px; padding:7px 7px 7px 12px; gap:4px}
  .nav-cta{padding:10px 14px}
  .nav-brand{padding-right:11px}
  .nav-brand-text i{display:none}      /* links are in burger; "Safri" alone is unambiguous */
  .hero{padding-top:104px}
  .hero h1{margin:14px 0 18px}
  .hero-stats{gap:22px; margin-top:34px}
  .tour-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .bigstats{grid-template-columns:1fr; gap:22px; padding:34px 26px}
  .foot-grid{grid-template-columns:1fr}
  .cta-band{padding:44px 24px}
  .field-row{grid-template-columns:1fr}
  .rev-card{padding:38px 22px}
  .rev-arrow{width:34px;height:34px}
  .rev-arrow.left{left:6px}.rev-arrow.right{right:6px}
  .rev-text{font-size:1.06rem}
  .wa-float{width:52px;height:52px;right:16px;bottom:16px}
  .service-num{font-size:4rem}
}

/* mini phones */
@media(max-width:380px){
  .nav-logo{height:26px}
  .nav-brand-text b{font-size:.92rem}
  .nav-cta{font-size:.8rem; gap:5px}
  .hero h1{font-size:2.3rem}
  .hero-actions{gap:10px}
  .btn{padding:13px 18px; font-size:.9rem}
  .service-media{padding:20px}
}
