/* ===== RESET & BASE ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --gold:#1ba098;--gold-dark:#158b88;--gold-light:#1ba098;
  --navy:#0D1F2D;--navy2:#1A3A4A;
  --cream:transparent;--white:#FFFFFF;
  --text:#2C3E50;--muted:#6C7A89;
  --shadow:0 10px 40px rgba(0,0,0,.12);
  --shadow-lg:0 20px 60px rgba(0,0,0,.2);
  --r:16px;--ease:all .3s cubic-bezier(.4,0,.2,1)
}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--text);background:var(--cream);overflow-x:hidden}

/* ===== NAVBAR ===== */
.navbar{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:20px 5px;transition:var(--ease);background:transparent}
.navbar.scrolled{background:rgba(13,31,45,.97);backdrop-filter:blur(20px);padding:12px 5px;box-shadow:0 4px 30px rgba(0,0,0,.3)}
.nav-container{max-width:1200px;margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:10px;cursor:pointer;text-decoration:none}
.logo-icon{font-size:28px}
.logo-text{font-family:'Montserrat',sans-serif;font-size:1.5rem;font-weight:700;color:#fff;}
.logo-accent{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:8px;list-style:none}
.nav-links a{color:rgba(255,255,255,.85);text-decoration:none;font-size:14px;font-weight:500;padding:8px 16px;border-radius:8px;transition:var(--ease)}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.1)}
.lang-btn{background:var(--gold);color:#fff;border:none;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:var(--ease)}
.lang-btn:hover{background:var(--gold-dark);transform:translateY(-1px)}

/* ===== HAMBURGER ===== */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border-radius:8px;transition:var(--ease);z-index:1001}
.hamburger span{display:block;width:25px;height:2.5px;background:#fff;border-radius:3px;transition:var(--ease)}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ===== MOBILE MENU ===== */
.mobile-menu{position:fixed;inset:0;background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;transform:translateX(100%);transition:transform .5s cubic-bezier(.77,0,.175,1);padding:40px}
.mobile-menu.open{transform:translateX(0)}
.mobile-close{position:absolute;top:24px;right:24px;background:rgba(255,255,255,.1);border:none;color:#fff;font-size:24px;width:48px;height:48px;border-radius:50%;cursor:pointer;transition:var(--ease);display:flex;align-items:center;justify-content:center}
.mobile-close:hover{background:var(--gold);transform:rotate(90deg)}
.mobile-logo{font-family:'Playfair Display',serif;font-size:28px;color:#fff;margin-bottom:50px;opacity:.9}
.mobile-nav-links{list-style:none;text-align:center;width:100%;max-width:300px}
.mobile-nav-links li{margin-bottom:8px;opacity:0;transform:translateY(20px);transition:opacity .4s ease,transform .4s ease}
.mobile-menu.open .mobile-nav-links li{opacity:1;transform:translateY(0)}
.mobile-menu.open .mobile-nav-links li:nth-child(1){transition-delay:.1s}
.mobile-menu.open .mobile-nav-links li:nth-child(2){transition-delay:.15s}
.mobile-menu.open .mobile-nav-links li:nth-child(3){transition-delay:.2s}
.mobile-menu.open .mobile-nav-links li:nth-child(4){transition-delay:.25s}
.mobile-menu.open .mobile-nav-links li:nth-child(5){transition-delay:.3s}
.mobile-nav-links a{display:block;color:#fff;text-decoration:none;font-size:28px;font-family:'Playfair Display',serif;font-weight:700;padding:8px 24px;border-radius:12px;transition:var(--ease)}
.mobile-nav-links a:hover{color:var(--gold);background:rgba(230,253,249,.1);transform:translateX(8px)}
.mobile-lang-btn{margin-top:40px;background:var(--gold);color:#fff;border:none;padding:14px 32px;border-radius:50px;font-size:16px;font-weight:600;cursor:pointer;transition:var(--ease)}
.mobile-lang-btn:hover{background:var(--gold-dark);transform:translateY(-2px)}
.mobile-menu-footer{position:absolute;bottom:40px;text-align:center}
.mobile-menu-footer p{color:rgba(255,255,255,.4);font-size:13px;letter-spacing:2px;text-transform:uppercase}

/* ===== HERO ===== */
.hero{position:relative;height:100vh;min-height:600px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.hero-carousel{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.2s ease-in-out}
.hero-slide.active{opacity:1;animation:kenBurns 8s ease-in-out forwards}
@keyframes kenBurns{from{transform:scale(1.05)}to{transform:scale(1)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(13,31,45,.3) 0%,rgba(13,31,45,.5) 50%,rgba(13,31,45,.75) 100%);z-index:1}
.hero-content{position:relative;z-index:2;text-align:center;color:#fff;max-width:800px;padding:0 24px}
.hero-subtitle{font-size:13px;font-weight:700;letter-spacing:4px;color:#ffffff;margin-bottom:20px;text-transform:uppercase}
.hero-content h1{font-family:'Playfair Display',serif;font-size:clamp(40px,7vw,80px);font-weight:700;line-height:1.1;margin-bottom:24px;text-shadow:0 4px 20px rgba(0,0,0,.3)}
.hero-content h1 span{color:var(--gold)}
.hero-desc{font-size:18px;color:rgba(255,255,255,.85);margin-bottom:40px;line-height:1.6;font-weight:300}
.cta-btn{display:inline-flex;align-items:center;gap:12px;background:var(--gold);color:#fff;text-decoration:none;padding:18px 40px;border-radius:50px;font-size:16px;font-weight:600;transition:var(--ease);box-shadow:0 8px 30px rgba(27,160,152,.4)}
.cta-btn:hover{background:var(--gold-dark);transform:translateY(-3px);box-shadow:0 15px 40px rgba(27,160,152,.6)}
.cta-btn i{animation:bounce 2s infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}
.hero-controls{position:absolute;bottom:80px;left:50%;transform:translateX(-50%);z-index:3;display:flex;align-items:center;gap:20px}
.hero-arrow{background:rgba(255,255,255,.15);border:2px solid rgba(255,255,255,.3);color:#fff;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:var(--ease);backdrop-filter:blur(10px)}
.hero-arrow:hover{background:var(--gold);border-color:var(--gold);transform:scale(1.1)}
.hero-dots{display:flex;gap:8px;align-items:center}
.hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:var(--ease);border:none;padding:0}
.hero-dot.active{background:var(--gold);width:24px;border-radius:4px}
.scroll-line{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:3;width:2px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.6),transparent);animation:scrollAnim 2s infinite}
@keyframes scrollAnim{0%{opacity:1;transform:translateX(-50%) scaleY(1)}100%{opacity:0;transform:translateX(-50%) scaleY(.3)}}

/* ===== SECTIONS ===== */
.section{padding:100px 0}
.section-alt{background:var(--white)}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section-header{text-align:center;margin-bottom:60px}
.section-tag{display:inline-block;background:transparent;color:var(--gold);font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;padding:8px 20px;border-radius:50px;margin-bottom:16px}
.section-header h2{font-family:'Playfair Display',serif;font-size:clamp(28px,4vw,44px);font-weight:700;color:var(--navy);margin-bottom:16px;line-height:1.2}
.section-header p{font-size:17px;color:var(--muted);max-width:600px;margin:0 auto;line-height:1.6}

/* ===== CAROUSEL ===== */
.carousel-outer{position:relative;display:flex;align-items:center;gap:0}
.carousel-track-wrap{overflow:hidden;width:100%;border-radius:var(--r)}
.carousel-track{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1);will-change:transform}
.carousel-item{min-width:100%;padding:4px;height:483px}

.c-arrow{flex-shrink:0;width:48px;height:48px;border-radius:50%;border:2px solid var(--gold);background:var(--white);color:var(--gold);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--ease);box-shadow:var(--shadow);z-index:2;position:absolute;top:50%;transform:translateY(-50%)}
.c-arrow.left{left:-24px}
.c-arrow.right{right:-24px}
.c-arrow:hover{background:var(--gold);color:#fff;transform:translateY(-50%) scale(1.1)}

.c-dots{display:flex;justify-content:center;gap:8px;margin-top:28px}
.c-dot{width:8px;height:8px;border-radius:50%;background:var(--gold-light);cursor:pointer;transition:var(--ease);border:none;padding:0}
.c-dot.active{background:var(--gold);width:24px;border-radius:4px}

/* ===== CARDS ===== */
.card{background:var(--white);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:var(--ease);height:100%;display:flex;flex-direction:column}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.card-img{height:280px;background-size:cover;background-position:center;position:relative;overflow:hidden;flex-shrink:0}
.card-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.35) 0%,transparent 60%)}
.badge{position:absolute;top:16px;right:16px;z-index:1;padding:6px 14px;border-radius:50px;font-size:12px;font-weight:700;letter-spacing:.5px}
.badge-gold{background:var(--gold);color:#fff}
.badge-luxury{background:linear-gradient(135deg,#FFD700,#FFA500);color:var(--navy)}
.badge-star{background:var(--navy2);color:#fff}
.badge-ok{background:#2ECC71;color:#fff}

/* ===== CARD-BODY FIX ===== */
/* Suppression de height:calc() qui cassait l'affichage quand il n'y a pas de .card-img */
.card-body{
  padding: 20px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.card-body h3{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--navy);margin-bottom:12px}
.card-body p{color:var(--muted);font-size:15px;line-height:1.7;margin-bottom:24px;flex-grow:1}
.stars{font-size:18px;margin-bottom:12px;letter-spacing:2px}
blockquote{font-style:italic;color:var(--muted);font-size:14px;line-height:1.6;margin-bottom:20px;padding-left:16px;border-left:3px solid var(--gold)}
.tags{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.tags span{font-size:13px;color:var(--muted)}

/* ===== BUTTONS ===== */
.btn-gold{display:inline-block;background:var(--gold);color:#fff;text-decoration:none;padding:12px 28px;border-radius:8px;font-size:14px;font-weight:600;transition:var(--ease);text-align:center}
.btn-gold:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 5px 15px rgba(27,160,152,.3)}
.btn-outline{display:inline-block;background:transparent;color:var(--gold);text-decoration:none;padding:12px 28px;border-radius:8px;font-size:14px;font-weight:600;transition:var(--ease);border:2px solid var(--gold);text-align:center;margin-top:auto}
.btn-outline:hover{background:var(--gold);color:#fff;transform:translateY(-2px)}

/* ===== TIPS ===== */
.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}
.tip-card{background:var(--white);border-radius:var(--r);padding:36px 28px;text-align:center;box-shadow:var(--shadow);transition:var(--ease);border-top:4px solid var(--gold)}
.tip-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.tip-icon{font-size:48px;margin-bottom:20px;display:block}
.tip-card h3{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:var(--navy);margin-bottom:12px}
.tip-card p{color:var(--muted);font-size:15px;line-height:1.6}

/* ===== FOOTER ===== */
.footer{background:var(--navy);color:#fff;padding:60px 0 30px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand{display:flex;flex-direction:column;gap:16px}
.footer-brand p{color:rgba(255,255,255,.5);font-size:14px;line-height:1.7;max-width:300px}
.footer-col h4{font-family:'Playfair Display',serif;font-size:18px;margin-bottom:20px;color:var(--gold)}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:rgba(255,255,255,.6);text-decoration:none;font-size:14px;transition:var(--ease)}
.footer-col a:hover{color:var(--gold);padding-left:8px}
.social-row{display:flex;gap:12px}
.social-row a{width:40px;height:40px;background:rgba(255,255,255,.08);border-radius:10px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);text-decoration:none;font-size:16px;transition:var(--ease)}
.social-row a:hover{background:var(--gold);color:#fff;transform:translateY(-3px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;text-align:center}
.footer-bottom p{color:rgba(255,255,255,.4);font-size:13px}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .c-arrow.left{left:-12px}
  .c-arrow.right{right:-12px}
  .carousel-item{height: 483px}
}
@media(max-width:768px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .section{padding:70px 0}
  .card-img{height:220px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .tips-grid{grid-template-columns:1fr 1fr}
  .c-arrow{width:36px;height:36px;font-size:13px}
  .c-arrow.left{left:-8px}
  .c-arrow.right{right:-8px}
  .hero-desc{font-size:16px}
  .carousel-item{height: 483px}
}
@media(max-width:480px){
  .hero-content h1{font-size:30px}
  .cta-btn{padding:14px 28px;font-size:14px}
  .tips-grid{grid-template-columns:1fr}
  .card-body{padding:20px}
  .section-header{margin-bottom:40px}
  .c-arrow{display:none}
  .carousel-item{height: 1139px}
}

/* ===== EXCURSIONS SECTION ===== */
.excursion-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.excursion-card {
  background: var(--white);
  border-radius: var(--r);
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: var(--ease);
  display: flex;
  flex-direction: column;
  position: relative;
  height: 355px;
}
.excursion-card:hover {
  transform: translateY(-10px);
  box-shadow: var(--shadow-lg);
}
.excursion-card:hover .excursion-img::after {
  opacity: 1;
}
.excursion-img {
  height: 240px;
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
}
.excursion-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
  display: block;
}
.excursion-card:hover .excursion-img img {
  transform: scale(1.06);
}
.excursion-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(13,31,45,.55) 0%, transparent 55%);
  opacity: .7;
  transition: opacity .3s ease;
}
.excursion-distance {
  position: absolute;
  bottom: 14px;
  left: 16px;
  z-index: 2;
  background: var(--gold);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  padding: 5px 12px;
  border-radius: 50px;
  letter-spacing: .5px;
}
.excursion-body {
  padding: 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.excursion-body h3 {
  font-family: 'Playfair Display', serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 10px;
}
.excursion-body p {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.7;
  margin-bottom: 18px;
  flex-grow: 1;
}
.excursion-meta {
  display: flex;
  gap: 16px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.excursion-meta span {
  font-size: 12px;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 5px;
}
.excursion-meta i {
  color: var(--gold);
  font-size: 13px;
}

/* ===== GALLERY SECTION ===== */
.gallery-section {
  padding: 100px 0;
  background: var(--navy);
}
.gallery-section .section-tag { color: #1ba098; }
.gallery-section .section-header h2 { color: #fff; }
.gallery-section .section-header p  { color: rgba(255,255,255,.6); }

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: 280px 220px;
  gap: 10px;
  margin-top: 48px;
}

/* Row 1 layout */
.gallery-item:nth-child(1) { grid-column: 1 / 6;  grid-row: 1; } /* Hassan Tower — wide */
.gallery-item:nth-child(2) { grid-column: 6 / 10; grid-row: 1; } /* Mausoleum */
.gallery-item:nth-child(3) { grid-column: 10/ 13; grid-row: 1; } /* Kasbah blue */

/* Row 2 layout */
.gallery-item:nth-child(4) { grid-column: 1 / 4;  grid-row: 2; } /* Chellah */
.gallery-item:nth-child(5) { grid-column: 4 / 7;  grid-row: 2; } /* Museum */
.gallery-item:nth-child(6) { grid-column: 7 / 10; grid-row: 2; } /* Medina souk */
.gallery-item:nth-child(7) { grid-column: 10/ 13; grid-row: 2; } /* Bouregreg */

.gallery-item {
  overflow: hidden;
  border-radius: 12px;
  position: relative;
  cursor: pointer;
}
.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
}
.gallery-item:hover img {
  transform: scale(1.08);
}
.gallery-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(13,31,45,.75) 0%, transparent 60%);
  opacity: 0;
  transition: opacity .35s ease;
  display: flex;
  align-items: flex-end;
  padding: 20px;
  border-radius: 12px;
}
.gallery-item:hover .gallery-overlay {
  opacity: 1;
}
.gallery-caption {
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  font-family: 'Playfair Display', serif;
  transform: translateY(8px);
  transition: transform .35s ease;
}
.gallery-item:hover .gallery-caption {
  transform: translateY(0);
}
.gallery-zoom {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 36px;
  height: 36px;
  background: rgba(255,255,255,.2);
  backdrop-filter: blur(8px);
  border: none;
  border-radius: 8px;
  color: #fff;
  font-size: 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .3s ease, background .3s ease;
}
.gallery-item:hover .gallery-zoom {
  opacity: 1;
}
.gallery-zoom:hover {
  background: var(--gold);
}

/* Lightbox */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.93);
  z-index: 2000;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: fadeIn .2s ease;
}
.lightbox.open { display: flex; }
@keyframes fadeIn { from { opacity: 0 } to { opacity: 1 } }
.lightbox-inner {
  position: relative;
  max-width: 90vw;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.lightbox-inner img {
  max-width: 100%;
  max-height: 80vh;
  object-fit: contain;
  border-radius: 12px;
  box-shadow: 0 30px 80px rgba(0,0,0,.6);
}
.lightbox-caption {
  color: rgba(255,255,255,.8);
  font-size: 15px;
  font-family: 'Playfair Display', serif;
  text-align: center;
}
.lightbox-close {
  position: absolute;
  top: -52px;
  right: 0;
  width: 44px; height: 44px;
  background: rgba(255,255,255,.1);
  border: none;
  border-radius: 50%;
  color: #fff;
  font-size: 20px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s;
}
.lightbox-close:hover { background: var(--gold); }
.lightbox-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px; height: 48px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 50%;
  color: #fff;
  font-size: 18px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s;
}
.lightbox-arrow:hover { background: var(--gold); border-color: var(--gold); }
.lightbox-prev { left: -70px; }
.lightbox-next { right: -70px; }

/* Responsive gallery */
@media (max-width: 1024px) {
  .excursion-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
    gap: 8px;
  }
  .gallery-item:nth-child(n) {
    grid-column: auto;
    grid-row: auto;
  }
  .gallery-item:nth-child(1) { grid-column: 1 / 3; }
}
@media (max-width: 768px) {
  .excursion-grid { grid-template-columns: 1fr; }
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 160px 160px 160px 160px;
  }
  .gallery-item:nth-child(1) { grid-column: 1 / 3; }
  .gallery-item:nth-child(n+2) { grid-column: auto; }
  .lightbox-prev { left: -16px; }
  .lightbox-next { right: -16px; }
}
.excursion-card {
  height: 470px;
}
@media (max-width: 480px) {
  .gallery-grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: repeat(4, 140px);
  }
  .gallery-section { padding: 60px 0; }
}
.excursion-card {
  height: 350px;
}
