    :root{
      --deep:#093a5a;
      --aqua:#20a2c4;
      --white:#ffffff;

      --bg1:#eaf8ff;
      --bg2:#f7fdff;

      --text:#083149;

      --shadow: 0 18px 55px rgba(9,58,90,.18);
      --shadow2: 0 10px 28px rgba(9,58,90,.14);

      --font:"Bebas Neue", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

      --headerH: 66px;
      --logoSize: 88px; /* logo bigger than header */
      --logoDrop: 10px; /* how much it drops below header */
    }

    *{ box-sizing:border-box; }
    html,body{ height:100%; }
    body{
      margin:0;
      font-family:var(--font);
      color:var(--text);
      overflow-x:hidden;
      -webkit-tap-highlight-color: transparent;

      background:
        radial-gradient(1200px 700px at 20% -10%, rgba(32,162,196,.22), transparent 55%),
        radial-gradient(900px 600px at 90% 10%, rgba(9,58,90,.18), transparent 55%),
        linear-gradient(180deg, var(--bg1), var(--bg2));
    }

    a{ color:inherit; text-decoration:none; }
    button{ font-family:var(--font); }

    /* ✅ Footer placement fix */
    .app{
      min-height:100dvh;
      display:flex;
      flex-direction:column;
    }
    main{ flex:1; }

    /* =========================
       HEADER (NEW SHAPE + CLEAN LOGO)
       ========================= */
    .header{
      position:sticky;
      top:0;
      z-index:50;
      padding-top: env(safe-area-inset-top);
    }

    /* the curved header background shape */
    .header-shape{
      position:absolute;
      left:0; right:0;
      top:0;
      height: calc(var(--headerH) + env(safe-area-inset-top) + 26px); /* extra to allow curve */
      pointer-events:none;
      z-index:0;
      filter: drop-shadow(0 10px 26px rgba(9,58,90,.10));
    }
    .header-shape svg{
      width:100%;
      height:100%;
      display:block;
    }

    .header-inner{
      position:relative;
      z-index:2;
      height: var(--headerH);
      display:flex;
      align-items:center;
      justify-content:space-between;
      padding: 0 14px;
    }

    .icon-btn{
      width:44px;height:44px;
      border-radius:14px;
      border:1px solid rgba(9,58,90,.14);
      background: rgba(255,255,255,.92);
      box-shadow: var(--shadow2);
      display:grid;
      place-items:center;
      cursor:pointer;
      color: var(--deep);
    }
    .icon-btn:active{ transform: scale(.98); }

    .cta{
      display:flex;
      align-items:center;
      gap:10px;
      padding: 10px 14px;
      border-radius:16px;
      border:1px solid rgba(32,162,196,.28);
      background: linear-gradient(135deg, rgba(32,162,196,.18), rgba(255,255,255,.95));
      box-shadow: var(--shadow2);
      cursor:pointer;
      letter-spacing:.14em;
      font-size:15px;
      color: var(--deep);
      white-space:nowrap;
    }
    .cta i{ color: var(--aqua); }
    .cta:active{ transform: scale(.99); }

    /* CLEAN LOGO CENTER (no effects) */
    .logo-slot{
      position:absolute;
      left:50%;
      top: calc(env(safe-area-inset-top) + (var(--headerH) / 2));
      transform: translate(-50%, -50%) translateY(var(--logoDrop));
      width: var(--logoSize);
      height: var(--logoSize);
      z-index:3;
      pointer-events:none;
      display:grid;
      place-items:center;
    }
    .logo{
      width:100%;
      height:100%;
      border-radius:999px;
      overflow:hidden;
      background: transparent;           /* ✅ no background effect */
      border: 0;                         /* ✅ no border effect */
      box-shadow: none;                  /* ✅ no shadow effect */
    }
    .logo img{
      width:100%;
      height:100%;
      object-fit: contain;               /* ✅ keeps logo clear */
      display:block;
    }

    /* =========================
       MENU (same as before)
       ========================= */
    .menu{
      position:fixed; inset:0;
      z-index:100;
      display:none;
    }
    .menu.is-open{ display:block; }
    .menu-backdrop{
      position:absolute; inset:0;
      background: rgba(9,58,90,.18);
      backdrop-filter: blur(16px);
      -webkit-backdrop-filter: blur(16px);
    }
    .menu-panel{
      position:absolute;
      left:12px; right:12px;
      top: calc(env(safe-area-inset-top) + 12px);
      border-radius: 26px;
      background: rgba(255,255,255,.90);
      border: 1px solid rgba(9,58,90,.10);
      box-shadow: var(--shadow);
      overflow:hidden;
      color: var(--deep);
    }
    .menu-head{
      display:flex;align-items:center;justify-content:space-between;
      padding: 14px;
      border-bottom: 1px solid rgba(9,58,90,.10);
    }
    .menu-title{
      display:flex;align-items:center;gap:10px;
      letter-spacing:.14em;
      font-size:18px;
      color: var(--deep);
    }
    .menu-title i{ color: var(--aqua); }
    .menu-close{
      width:44px;height:44px;border-radius:14px;
      border:1px solid rgba(9,58,90,.12);
      background: rgba(255,255,255,.92);
      display:grid;place-items:center;
      cursor:pointer;
      color: var(--deep);
    }
    .menu-links{
      padding: 14px;
      display:grid;
      gap: 10px;
    }
    .menu-link{
      display:flex;align-items:center;justify-content:space-between;
      padding: 14px 14px;
      border-radius: 18px;
      border:1px solid rgba(9,58,90,.10);
      background: rgba(255,255,255,.95);
      letter-spacing:.12em;
      font-size:18px;
      color: var(--deep);
    }
    .menu-link .left{display:flex;align-items:center;gap:12px}
    .menu-link i{ width:18px; text-align:center; color: var(--aqua); }
    .menu-link .chev{ opacity:.55; color: var(--deep); }
    .menu-link:active{ transform: scale(.99); }
    .menu-foot{
      padding: 14px;
      border-top: 1px solid rgba(9,58,90,.10);
    }
    .menu-cta{
      width:100%;
      padding: 14px 14px;
      border-radius: 18px;
      border:1px solid rgba(32,162,196,.28);
      background: linear-gradient(135deg, rgba(32,162,196,.22), rgba(255,255,255,.96));
      letter-spacing:.14em;
      font-size:18px;
      display:flex;align-items:center;justify-content:center;gap:10px;
      cursor:pointer;
      color: var(--deep);
      box-shadow: var(--shadow2);
    }

    /* =========================
       HERO VIDEO
       ========================= */
    .hero{
      position:relative;
      width:100%;
      height: clamp(360px, 58vh, 540px);
      overflow:hidden;
      background:#000;
      margin-top:-1px;
    }
    .hero video{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
      filter: saturate(1.12) contrast(1.06);
    }
    .hero::after{
      content:"";
      position:absolute; inset:0;
      background:
        linear-gradient(to bottom, rgba(255,255,255,.00), rgba(9,58,90,.22)),
        radial-gradient(900px 520px at 50% 25%, rgba(32,162,196,.22), transparent 60%);
      pointer-events:none;
    }
    .hero-overlay{
      position:absolute; inset:0;
      display:flex;
      align-items:flex-end;
      padding: 18px 16px 22px;
    }
    .cinema-card{
      width:100%;
      border-radius: 24px;
      border: 1px solid rgba(255,255,255,.28);
      background: rgba(255,255,255,.84);
      backdrop-filter: blur(14px);
      -webkit-backdrop-filter: blur(14px);
      box-shadow: 0 22px 55px rgba(9,58,90,.18);
      padding: 16px 16px 14px;
      color: var(--deep);
    }
    .cinema-card .big{
      margin:0;
      font-size: clamp(34px, 7vw, 56px);
      letter-spacing:.18em;
      line-height:.95;
      text-transform:uppercase;
      background: linear-gradient(90deg, var(--deep), var(--aqua), var(--deep));
      -webkit-background-clip:text;
      background-clip:text;
      color:transparent;
    }
    .cinema-card .sub{
      margin: 8px 0 0;
      font-size: 15px;
      letter-spacing:.10em;
      color: rgba(8,49,73,.78);
    }

    /* =========================
       CONTENT + PROMO
       ========================= */
    .content{
      padding: 16px;
      display:flex;
      flex-direction:column;
      gap: 18px;
    }
    .promo{
      border-radius: 26px;
      overflow:hidden;
      position:relative;
      min-height: 165px;
      border: 1px solid rgba(9,58,90,.10);
      box-shadow: var(--shadow2);
      background: rgba(255,255,255,.65);
    }
    .promo img{
      width:100%; height:100%;
      object-fit:cover;
      display:block;
      transform: scale(1.02);
    }
    .promo::after{
      content:"";
      position:absolute; inset:0;
      background: linear-gradient(90deg, rgba(0,0,0,0) 36%, rgba(0,0,0,.50) 100%);
      pointer-events:none;
    }
    .promo-text{
      position:absolute;
      right: 14px;
      top: 50%;
      transform: translateY(-50%);
      text-align:right;
      max-width: 74%;
      color:#fff;
    }
    .promo-text .kicker{
      margin:0;
      font-size: 15px;
      letter-spacing:.14em;
      opacity:.92;
    }
    .promo-text .headline{
      margin: 6px 0 0;
      font-size: clamp(30px, 6.5vw, 46px);
      letter-spacing:.10em;
      line-height:.95;
      text-transform:uppercase;
    }

    /* =========================
       FOOTER
       ========================= */
    footer{
      padding: 18px 16px calc(18px + env(safe-area-inset-bottom));
    }
    .footer-card{
      border-radius: 26px;
      background: rgba(255,255,255,.86);
      border: 1px solid rgba(9,58,90,.10);
      box-shadow: var(--shadow);
      padding: 16px;
      color: var(--deep);
    }
    .footer-title{
      margin:0 0 10px;
      letter-spacing:.16em;
      font-size:20px;
      display:flex;align-items:center;gap:10px;
    }
    .footer-title i{ color: var(--aqua); }
    .footer-info{
      display:grid;
      gap:10px;
      font-size:16px;
      letter-spacing:.06em;
      color: rgba(9,58,90,.82);
    }
    .footer-info .row{display:flex;gap:10px;align-items:flex-start}
    .footer-info i{margin-top:2px;width:18px;text-align:center;color: var(--aqua);}
    .footer-links{
      margin-top: 14px;
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap: 10px;
    }
    .footer-link{
      padding: 12px 12px;
      border-radius: 18px;
      border:1px solid rgba(9,58,90,.10);
      background: rgba(255,255,255,.95);
      letter-spacing:.12em;
      font-size:16px;
      display:flex;align-items:center;justify-content:space-between;
      color: var(--deep);
    }
    .footer-link .chev{opacity:.55}
    .copyright{
      margin-top: 14px;
      text-align:center;
      font-size: 14px;
      letter-spacing:.10em;
      color: rgba(9,58,90,.70);
    }

    /* ===== CREATIVE DIVE INTRO + STATS (SECTION CSS) ===== */
:root{
  /* لو المتغيرات موجودة عندك أصلاً سيبها — دي fallback فقط */
  --deep: #093a5a;
  --aqua: #20a2c4;
  --white: #ffffff;
}

/* Section wrapper */
.dive-intro{
  padding: 16px;
}

/* Premium glass card */
.dive-intro__card{
  position: relative;
  border-radius: 26px;
  overflow: hidden;
  border: 1px solid rgba(9,58,90,.10);
  background: rgba(255,255,255,.82);
  box-shadow: 0 18px 55px rgba(9,58,90,.14);
}

/* Creative background: soft waves + light glow (no darkness) */
.dive-intro__bg{
  position:absolute;
  inset:-2px;
  pointer-events:none;
  background:
    radial-gradient(700px 340px at 20% 0%, rgba(32,162,196,.18), transparent 60%),
    radial-gradient(650px 320px at 95% 30%, rgba(9,58,90,.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.70));
}
.dive-intro__bg::after{
  content:"";
  position:absolute;
  left:-10%;
  right:-10%;
  top: 44%;
  height: 140px;
  background:
    radial-gradient(closest-side, rgba(32,162,196,.12), transparent 70%) 0 0/120px 100% repeat-x;
  opacity:.9;
  filter: blur(0.2px);
}

/* Content */
.dive-intro__content{
  position: relative;
  padding: 18px 16px 14px;
}

.dive-intro__eyebrow{
  margin:0 0 10px;
  display:flex;
  align-items:center;
  gap:10px;
  color: rgba(9,58,90,.78);
  letter-spacing: .14em;
  font-size: 14px;
}
.dive-intro__eyebrow i{
  color: var(--aqua);
  font-size: 16px;
}

.dive-intro__title{
  margin:0;
  line-height: .95;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: clamp(30px, 8.2vw, 54px);
  color: var(--deep);
}
.dive-intro__title span{
  background: linear-gradient(90deg, var(--deep), var(--aqua), var(--deep));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}

.dive-intro__desc{
  margin: 10px 0 14px;
  color: rgba(9,58,90,.72);
  letter-spacing: .08em;
  font-size: 14px;
  line-height: 1.35;
}

.dive-intro__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(32,162,196,.32);
  background: linear-gradient(135deg, rgba(32,162,196,.22), rgba(255,255,255,.96));
  color: var(--deep);
  letter-spacing: .14em;
  font-size: 16px;
  box-shadow: 0 12px 28px rgba(9,58,90,.12);
}
.dive-intro__btn i{ color: var(--aqua); }
.dive-intro__btn:active{ transform: scale(.99); }

/* ===== Stats Row (one row on mobile) ===== */
.dive-stats{
  position: relative;
  display:flex;
  gap: 10px;
  padding: 14px 12px 16px;
}

/* Stat cards */
.stat{
  flex: 1 1 0;
  min-width: 0;
  border-radius: 18px;
  border: 1px solid rgba(9,58,90,.10);
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 25px rgba(9,58,90,.10);
  padding: 12px 10px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap: 6px;
}

/* subtle “premium edge” */
.stat::before{
  content:"";
  position:absolute;
  width:0;height:0;
  opacity:0; /* kept minimal; no visual noise */
}

.stat__icon{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: rgba(32,162,196,.10);
  border: 1px solid rgba(32,162,196,.22);
}
.stat__icon i{
  font-size: 22px; /* big icons */
  color: var(--aqua);
}

.stat__value{
  display:flex;
  align-items:baseline;
  gap: 4px;
  color: var(--deep);
  letter-spacing: .10em;
  line-height: 1;
  font-size: clamp(22px, 6.3vw, 34px);
}
.stat__suffix{
  font-size: .75em;
  color: rgba(9,58,90,.60);
}

.stat__label{
  text-align:center;
  font-size: 13px;
  letter-spacing: .14em;
  color: rgba(9,58,90,.75);
  text-transform: uppercase;
  white-space: nowrap;
}

/* icon-only card */
.stat--iconOnly .stat__value{ display:none; }

/* Mobile micro-interaction (calm) */
.stat:active{
  transform: translateY(1px);
}

/* Optional: slightly larger spacing on wider phones */
@media (min-width: 420px){
  .dive-stats{ gap: 12px; padding: 16px 14px 18px; }
  .stat{ padding: 14px 12px; }
  .stat__icon{ width: 48px; height: 48px; }
  .stat__icon i{ font-size: 24px; }
}

.courses{ padding:16px; }
.courses__eyebrow{
  margin:0 0 8px; display:flex; align-items:center; gap:10px;
  letter-spacing:.14em; font-size:14px; color:rgba(9,58,90,.75);
}
.courses__eyebrow i{ color:#20a2c4; }
.courses__title{
  margin:0; letter-spacing:.18em; text-transform:uppercase; line-height:.95;
  font-size:clamp(28px,8vw,48px); color:#093a5a;
}
.courses__sub{
  margin:10px 0 14px; letter-spacing:.08em; font-size:14px; line-height:1.35;
  color:rgba(9,58,90,.70);
}

.courses__shell{
  border-radius:26px;
  border:1px solid rgba(9,58,90,.10);
  background: rgba(255,255,255,.72);
  box-shadow: 0 18px 55px rgba(9,58,90,.12);
  overflow:hidden;
}

.courses-swiper{ padding: 14px 12px 12px; }

/* ✅ App-like: slides auto width + centered + smooth */
.courses .swiper-slide{
  width: 86%;
  height: auto;
  transition: transform .35s ease, filter .35s ease, opacity .35s ease;
  opacity:.72;
  filter: blur(.2px);
}
.courses .swiper-slide-active{
  opacity:1;
  filter:none;
  transform: translateY(-2px);
}

/* Card */
.course-card{
  border-radius:22px;
  overflow:hidden;
  background: rgba(255,255,255,.95);
  border:1px solid rgba(9,58,90,.10);
  box-shadow: 0 14px 40px rgba(9,58,90,.12);
}

.course-media{
  position:relative;
  aspect-ratio: 16/10;
  background:
    radial-gradient(700px 280px at 20% 0%, rgba(32,162,196,.22), transparent 60%),
    radial-gradient(700px 280px at 90% 30%, rgba(9,58,90,.12), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78));
}
.course-media img{
  width:100%; height:100%; object-fit:cover; display:block;
  filter: saturate(1.05) contrast(1.03);
}

.badges{
  position:absolute; left:12px; top:12px;
  display:flex; gap:8px; z-index:2;
}
.badge{
  padding:8px 10px; border-radius:999px;
  letter-spacing:.12em; font-size:13px; text-transform:uppercase;
  color:#fff; border:1px solid rgba(255,255,255,.25);
  background: rgba(9,58,90,.72);
  backdrop-filter: blur(10px);
}
.badge--padi{ background: rgba(32,162,196,.78); }

.price-pill{
  position:absolute; right:12px; bottom:12px; z-index:2;
  padding:10px 12px; border-radius:999px;
  background: rgba(255,255,255,.86);
  border:1px solid rgba(255,255,255,.30);
  color:#093a5a; letter-spacing:.12em;
  display:flex; align-items:center; gap:8px;
}
.price-pill i{ color:#20a2c4; }

.course-body{ padding: 14px; }
.course-name{
  margin:0;
  color:#093a5a;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:18px;
  line-height:1.05;
}
.course-meta{
  margin-top:10px;
  display:grid; gap:8px;
  color:rgba(9,58,90,.78);
  letter-spacing:.08em;
  font-size:14px;
}
.meta-row{ display:flex; gap:10px; align-items:flex-start; line-height:1.25; }
.meta-row i{ color:#20a2c4; width:18px; text-align:center; margin-top:2px; }

/* Requirements (خفيف ومش بيطول الكارت) */
.req{
  margin-top:10px;
  border-radius:16px;
  border:1px solid rgba(9,58,90,.10);
  background: rgba(255,255,255,.92);
  overflow:hidden;
}
.req summary{
  cursor:pointer;
  padding:12px;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  letter-spacing:.12em; font-size:14px; color:#093a5a;
  list-style:none;
}
.req summary::-webkit-details-marker{ display:none; }
.req summary i{ color:#20a2c4; }
.req .req__text{
  padding: 0 12px 12px;
  color:rgba(9,58,90,.74);
  letter-spacing:.06em;
  font-size:13px;
  line-height:1.35;
}

.course-actions{
  margin-top:12px; display:flex; gap:10px;
}
.btn{
  flex:1;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(9,58,90,.12);
  background:#fff;
  color:#093a5a;
  letter-spacing:.14em;
  display:flex; align-items:center; justify-content:center; gap:10px;
}
.btn i{ color:#20a2c4; }
.btn--primary{
  border-color: rgba(32,162,196,.30);
  background: linear-gradient(135deg, rgba(32,162,196,.18), rgba(255,255,255,.98));
}

/* Controls */
.courses__bar{
  margin-top: 12px;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding: 0 2px 12px;
}
.courses__nav{
  width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(9,58,90,.12);
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 24px rgba(9,58,90,.10);
  color:#093a5a; display:grid; place-items:center;
}
.courses__nav:active{ transform: scale(.98); }
.courses__dots{ flex:1; display:flex; justify-content:center; }
.courses .swiper-pagination-bullet{ width:7px;height:7px; opacity:.25; background:#093a5a; }
.courses .swiper-pagination-bullet-active{ opacity:1; background:#20a2c4; }

/* ===== Shared (uses your existing vars if present) ===== */
:root{
  --deep:#093a5a;
  --aqua:#20a2c4;
  --white:#ffffff;
  --stroke: rgba(9,58,90,.10);
  --shadow: 0 18px 55px rgba(9,58,90,.12);
  --shadow2: 0 10px 24px rgba(9,58,90,.10);
}

.cta-sites, .tours, .reviews, .blogs{ padding:16px; }

/* ===== 1) Dive Sites CTA ===== */
.cta-sites__card{
  display:block;
  position:relative;
  border-radius:26px;
  overflow:hidden;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.72);
  box-shadow: var(--shadow);
  text-decoration:none;
}
.cta-sites__img{
  width:100%;
  height: 210px;
  object-fit:cover;
  display:block;
  transform: scale(1.02);
  filter: saturate(1.05) contrast(1.03);
}
.cta-sites__overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(0,0,0,0) 35%, rgba(0,0,0,.55) 100%),
    radial-gradient(900px 420px at 30% 20%, rgba(32,162,196,.20), transparent 60%);
}
.cta-sites__content{
  position:absolute;
  right:14px; top:50%;
  transform: translateY(-50%);
  text-align:right;
  max-width: 78%;
  color:#fff;
}
.cta-sites__eyebrow{
  margin:0 0 8px;
  letter-spacing:.14em;
  font-size:14px;
  opacity:.95;
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:flex-end;
}
.cta-sites__eyebrow i{ color: var(--aqua); }
.cta-sites__title{
  margin:0;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size: clamp(26px, 6.6vw, 42px);
  line-height:.95;
}
.cta-sites__desc{
  margin:8px 0 12px;
  letter-spacing:.06em;
  font-size:13px;
  line-height:1.35;
  opacity:.92;
}
.cta-sites__btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.28);
  background: rgba(255,255,255,.18);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  letter-spacing:.14em;
  text-transform:uppercase;
}
.cta-sites__card:active{ transform: translateY(1px); }

/* ===== Head blocks ===== */
.tours__eyebrow, .reviews__eyebrow, .blogs__eyebrow{
  margin:0 0 8px;
  display:flex; align-items:center; gap:10px;
  letter-spacing:.14em; font-size:14px;
  color: rgba(9,58,90,.75);
}
.tours__eyebrow i, .reviews__eyebrow i, .blogs__eyebrow i{ color: var(--aqua); }
.tours__title, .reviews__title, .blogs__title{
  margin:0;
  letter-spacing:.18em;
  text-transform:uppercase;
  line-height:.95;
  font-size: clamp(26px, 7.8vw, 46px);
  color: var(--deep);
}
.tours__sub, .reviews__sub, .blogs__sub{
  margin:10px 0 0;
  color: rgba(9,58,90,.70);
  letter-spacing:.08em;
  font-size:14px;
  line-height:1.35;
}

/* ===== Tabs ===== */
.tours__tabs{
  margin-top: 12px;
  display:flex;
  gap:10px;
}
.chip{
  flex:1;
  border-radius: 18px;
  padding: 12px 12px;
  border: 1px solid var(--stroke);
  background: rgba(255,255,255,.82);
  box-shadow: var(--shadow2);
  color: var(--deep);
  letter-spacing:.12em;
  text-transform:uppercase;
  display:flex; align-items:center; justify-content:center; gap:10px;
}
.chip i{ color: var(--aqua); }
.chip.is-active{
  border-color: rgba(32,162,196,.28);
  background: linear-gradient(135deg, rgba(32,162,196,.16), rgba(255,255,255,.96));
}

/* ===== Horizontal rails (smooth, premium) ===== */
.rail{
  margin-top: 12px;
}
.rail[hidden]{ display:none !important; }

.rail__bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin: 10px 2px 10px;
}
.rail__bar--tight{ margin-top: 12px; }
.rail__hint{
  display:flex; align-items:center; gap:10px;
  letter-spacing:.14em;
  color: rgba(9,58,90,.70);
  font-size: 13px;
  text-transform:uppercase;
}
.rail__hint i{ color: var(--aqua); }

.rail__nav{ display:flex; gap:10px; }
.rail__btn{
  width:44px;height:44px;
  border-radius:14px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.92);
  box-shadow: var(--shadow2);
  color: var(--deep);
  display:grid; place-items:center;
}
.rail__btn:active{ transform: scale(.98); }

.rail__track{
  display:flex;
  gap:12px;
  overflow-x:auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
  padding: 2px 2px 10px;
}
.rail__track::-webkit-scrollbar{ height: 6px; }
.rail__track::-webkit-scrollbar-thumb{
  background: rgba(9,58,90,.18);
  border-radius: 999px;
}

/* ===== Tour card (small + clean) ===== */
.tour-card{
  flex: 0 0 78%;
  scroll-snap-align: start;
  border-radius: 22px;
  overflow:hidden;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.92);
  box-shadow: 0 14px 40px rgba(9,58,90,.10);
}
.tour-media{
  position:relative;
  aspect-ratio: 16/10;
  background: rgba(255,255,255,.75);
}
.tour-media img{
  width:100%; height:100%;
  object-fit:cover; display:block;
  filter: saturate(1.05) contrast(1.03);
}
.tour-price{
  position:absolute;
  right:12px; bottom:12px;
  padding:10px 12px;
  border-radius:999px;
  background: rgba(255,255,255,.86);
  border:1px solid rgba(255,255,255,.30);
  letter-spacing:.12em;
  color: var(--deep);
  display:flex; align-items:center; gap:8px;
}
.tour-price i{ color: var(--aqua); }

.tour-body{ padding: 12px 14px 14px; }
.tour-title{
  margin:0;
  letter-spacing:.12em;
  text-transform:uppercase;
  color: var(--deep);
  font-size: 18px;
  line-height:1.05;
}
.tour-desc{
  margin:8px 0 10px;
  color: rgba(9,58,90,.72);
  letter-spacing:.06em;
  font-size: 13px;
  line-height:1.35;

  /* keep it light */
  display:-webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow:hidden;
}
.tour-points{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:6px;
}
.tour-points li{
  display:flex; gap:10px; align-items:flex-start;
  color: rgba(9,58,90,.78);
  letter-spacing:.06em;
  font-size: 13px;
  line-height:1.25;
}
.tour-points i{
  width:18px;
  text-align:center;
  margin-top:2px;
  color: var(--aqua);
}

.tour-actions{
  margin-top: 12px;
  display:flex; gap:10px;
}
.mbtn{
  flex:1;
  border-radius: 16px;
  padding: 12px 12px;
  border:1px solid rgba(9,58,90,.12);
  background:#fff;
  color: var(--deep);
  letter-spacing:.14em;
  text-transform:uppercase;
  display:flex; align-items:center; justify-content:center; gap:10px;
}
.mbtn i{ color: var(--aqua); }
.mbtn--primary{
  border-color: rgba(32,162,196,.30);
  background: linear-gradient(135deg, rgba(32,162,196,.16), rgba(255,255,255,.98));
}

/* ===== Reviews cards ===== */
.rail__track--reviews .review-card{ flex: 0 0 78%; }
.review-card{
  scroll-snap-align:start;
  border-radius: 22px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.92);
  box-shadow: 0 14px 40px rgba(9,58,90,.10);
  padding: 14px;
}
.review-top{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.avatar{
  width:42px;height:42px;border-radius:16px;
  display:grid; place-items:center;
  background: rgba(32,162,196,.10);
  border:1px solid rgba(32,162,196,.22);
  color: var(--deep);
  letter-spacing:.12em;
}
.stars{ display:flex; gap:4px; }
.stars i{ color: var(--aqua); }
.review-name{
  margin:10px 0 0;
  color: var(--deep);
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size: 16px;
}
.review-text{
  margin:8px 0 0;
  color: rgba(9,58,90,.74);
  letter-spacing:.06em;
  font-size: 13px;
  line-height:1.35;
}
.review-meta{
  margin-top: 10px;
  display:flex; align-items:center; justify-content:space-between;
  color: rgba(9,58,90,.62);
  letter-spacing:.10em;
  font-size: 12px;
  text-transform:uppercase;
}

/* ===== Blogs cards ===== */
.rail__track--blogs .blog-card{ flex: 0 0 78%; }
.blog-card{
  scroll-snap-align:start;
  border-radius: 22px;
  overflow:hidden;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.92);
  box-shadow: 0 14px 40px rgba(9,58,90,.10);
}
.blog-media{ aspect-ratio: 16/10; background: rgba(255,255,255,.75); }
.blog-media img{ width:100%; height:100%; object-fit:cover; display:block; }
.blog-body{ padding: 12px 14px 14px; }
.blog-kicker{
  margin:0;
  display:flex; align-items:center; justify-content:space-between;
  color: rgba(9,58,90,.70);
  letter-spacing:.12em;
  font-size: 12px;
  text-transform:uppercase;
}
.blog-title{
  margin:8px 0 8px;
  color: var(--deep);
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size: 17px;
  line-height:1.1;
}
.blog-excerpt{
  margin:0;
  color: rgba(9,58,90,.74);
  letter-spacing:.06em;
  font-size: 13px;
  line-height:1.35;

  display:-webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow:hidden;
}
.blog-link{
  margin-top: 12px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  border-radius: 16px;
  border:1px solid rgba(32,162,196,.28);
  background: linear-gradient(135deg, rgba(32,162,196,.14), rgba(255,255,255,.98));
  color: var(--deep);
  letter-spacing:.14em;
  text-transform:uppercase;
}

/* Wider phones */
@media (min-width: 520px){
  .tour-card, .review-card, .blog-card{ flex-basis: 58%; }
}
@media (min-width: 760px){
  .tour-card, .review-card, .blog-card{ flex-basis: 38%; }
}
