
/* MauritiusChat - Unified stylesheet */

/* Fonts */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600;700&display=swap');
*{box-sizing:border-box}
body{font-family:'Poppins',sans-serif;margin:0;background:#f4f9f8;color:#222;line-height:1.6}
header{background:linear-gradient(90deg,#00897B,#00BFA5);color:#fff;box-shadow:0 2px 12px rgba(0,0,0,0.08)}
.navbar{display:flex;justify-content:space-between;align-items:center;padding:14px 22px;max-width:1200px;margin:0 auto}
.logo{font-weight:700;color:#fff;text-decoration:none;font-size:20px}
.menu-toggle{display:none;background:none;border:none;color:#fff;font-size:26px;cursor:pointer}
.nav-links{list-style:none;display:flex;gap:18px;margin:0;padding:0}
.nav-links a{color:#fff;text-decoration:none;font-weight:600;letter-spacing:0.2px}
.content{max-width:1100px;margin:30px auto;padding:0 18px}
.hero{padding:60px 0;text-align:left;background:linear-gradient(180deg,rgba(255,255,255,0.02),transparent)}
.hero-compact .hero-inner{background:linear-gradient(180deg,#ffffff,transparent);padding:28px;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,0.04)}
.hero-inner h1{color:#00695C;margin:0 0 10px;font-size:28px}
.hero-inner p{margin:0 0 16px;color:#045254}
.hero-actions{display:flex;gap:12px}
.btn{background:#00897B;color:#fff;padding:10px 20px;border-radius:10px;text-decoration:none;font-weight:700;display:inline-block}
.btn-ghost{background:transparent;border:2px solid rgba(0,0,0,0.06);color:#00695C;padding:10px 20px;border-radius:10px}
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-top:24px}
.feature{background:#fff;padding:18px;border-radius:10px;box-shadow:0 8px 30px rgba(0,0,0,0.03)}

/* Iframe styling */
.iframe-container{width:100%;height:560px;border-radius:14px;overflow:hidden;box-shadow:0 8px 30px rgba(2,48,41,0.06);margin:0 auto 0}
.iframe-container iframe{width:100%;height:100%;border:0}
.button-center{text-align:center;margin:24px 0 36px}

/* City info card */
.city-info{max-width:900px;margin:20px auto;padding:22px;background:#fff;border-radius:12px;box-shadow:0 8px 30px rgba(2,48,41,0.04)}
.city-info h1{text-align:center;color:#00897B;margin-top:0}
.city-card{background:#fff;padding:14px;border-radius:10px;box-shadow:0 6px 24px rgba(0,0,0,0.03);margin-bottom:12px}
.cities-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:18px}
.room-list ul{list-style:disc;margin-left:20px}
.page{background:#fff;padding:22px;border-radius:12px;box-shadow:0 8px 30px rgba(0,0,0,0.03)}
.contact-form label{display:block;margin-bottom:10px}
.contact-form input,.contact-form textarea{width:100%;padding:10px;border-radius:8px;border:1px solid #e6e6e6}
footer{margin-top:40px;padding:20px;background:#00695C;color:#fff;text-align:center}
.footer-links a{color:#fff;text-decoration:none;margin:0 6px}

/* Chatrooms card grid (classy) */
.chatroom-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:30px}
.chat-card{background:#fff;border-radius:14px;box-shadow:0 8px 25px rgba(0,0,0,0.05);padding:20px;text-align:center;transition:all .3s ease}
.chat-card:hover{transform:translateY(-5px);box-shadow:0 12px 30px rgba(0,0,0,0.08)}
.chat-card h3{color:#00897B;margin-bottom:10px}
.chat-card p{color:#555;font-size:15px;margin-bottom:15px}

/* City-page darker tropical blue-green theme overrides */
body.city-page{background:#e6f5f3;color:#052f2b}
body.city-page header{background:linear-gradient(90deg,#005F56,#008B74)}
body.city-page .city-info{background:#ffffff;border-radius:12px}
body.city-page .btn{background:#007F73}
body.city-page .btn:hover{background:#00A68A}
body.city-page .iframe-container{box-shadow:0 10px 40px rgba(0,95,86,0.08)}

/* Privacy Page Banner */
.privacy-banner {
  position: relative;
  width: 100%;
  height: 260px;
  background: url("../images/privacy.jpg") center center / cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  border-radius: 0 0 18px 18px;
  overflow: hidden;
  box-shadow: 0 4px 25px rgba(0,0,0,0.2);
}

.privacy-banner .banner-overlay {
  background: rgba(0, 90, 80, 0.55);
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 20px;
}

.privacy-banner h1 {
  font-size: 32px;
  font-weight: 700;
  margin: 0;
  text-shadow: 1px 1px 6px rgba(0,0,0,0.4);
}

.privacy-banner p {
  font-size: 16px;
  margin-top: 10px;
  color: #f3f9f8;
}

/* Privacy Page Content */
.privacy-page section {
  margin-bottom: 30px;
}

.privacy-page h2 {
  color: #007F73;
  margin-bottom: 10px;
}

.privacy-page ul {
  list-style: none;
  padding: 0;
}

.privacy-page li {
  background: #f4f9f8;
  margin: 8px 0;
  padding: 8px 12px;
  border-left: 4px solid #00A68A;
  border-radius: 6px;
}


/* Responsive tweaks */
@media (max-width:900px){.iframe-container{height:420px}.hero-inner h1{font-size:22px}}
@media (max-width:720px){.nav-links{display:none;position:absolute;right:14px;top:62px;background:#00796B;padding:12px;border-radius:8px;flex-direction:column;width:200px} .menu-toggle{display:block}}
@media (max-width: 768px) {
  .nav-links {
    display: none;
    position: absolute;
    right: 14px;
    top: 62px;
    background: #00796B;
    padding: 12px;
    border-radius: 8px;
    flex-direction: column;
    width: 220px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15);
  }

  .nav-links.active {
    display: flex;
    z-index: 2000; /* ensures it's above banners */
  }

  .menu-toggle {
    display: block;
    z-index: 2001; /* ensures button is clickable */
  }
}


/* About Page Banner */
.about-banner {
  position: relative;
  width: 100%;
  height: 260px;
  background: url("../images/about.jpg") center center / cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  border-radius: 0 0 18px 18px;
  overflow: hidden;
  box-shadow: 0 4px 25px rgba(0,0,0,0.2);
}

.banner-overlay {
  background: rgba(0, 89, 76, 0.6);
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 20px;
}

.banner-overlay h1 {
  font-size: 32px;
  font-weight: 700;
  margin: 0;
  text-shadow: 1px 1px 6px rgba(0,0,0,0.4);
}

.banner-overlay p {
  font-size: 16px;
  margin-top: 10px;
  color: #f3f9f8;
}
/* Homepage Banner */
.home-banner {
  position: relative;
  width: 100%;
  height: 300px;
  background: url("../images/homepage.jpg") center center / cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  overflow: hidden;
  border-radius: 0 0 18px 18px;
  box-shadow: 0 4px 25px rgba(0,0,0,0.2);
}

.home-banner .banner-overlay {
  background: rgba(0, 90, 80, 0.55);
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 20px;
}

.home-banner h1 {
  font-size: 34px;
  font-weight: 700;
  margin: 0;
  text-shadow: 1px 1px 6px rgba(0,0,0,0.4);
}

.home-banner p {
  font-size: 16px;
  margin-top: 10px;
  color: #f3f9f8;
}
/* Chat Rooms Banner */
.chatrooms-banner {
  position: relative;
  width: 100%;
  height: 260px;
  background: url("../images/chatroom.jpg") center center / cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  border-radius: 0 0 18px 18px;
  overflow: hidden;
  box-shadow: 0 4px 25px rgba(0,0,0,0.2);
}

.chatrooms-banner .banner-overlay {
  background: rgba(0, 90, 80, 0.55);
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 20px;
}

.chatrooms-banner h1 {
  font-size: 32px;
  font-weight: 700;
  margin: 0;
  text-shadow: 1px 1px 6px rgba(0,0,0,0.4);
}

.chatrooms-banner p {
  font-size: 16px;
  margin-top: 10px;
  color: #f3f9f8;
}
/* Contact Page Banner */
.contact-banner {
  position: relative;
  width: 100%;
  height: 260px;
  background: url("../images/contact.jpg") center center / cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  border-radius: 0 0 18px 18px;
  overflow: hidden;
  box-shadow: 0 4px 25px rgba(0,0,0,0.2);
}

.contact-banner .banner-overlay {
  background: rgba(0, 90, 80, 0.55);
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 20px;
}

.contact-banner h1 {
  font-size: 32px;
  font-weight: 700;
  margin: 0;
  text-shadow: 1px 1px 6px rgba(0,0,0,0.4);
}

.contact-banner p {
  font-size: 16px;
  margin-top: 10px;
  color: #f3f9f8;
}

/* Contact Form Styling */
.contact-form-section {
  background: #ffffff;
  padding: 25px;
  border-ra
  
  /* Safety Page Banner */
.safety-banner, .terms-banner {
  position: relative;
  width: 100%;
  height: 260px;
  background: center center / cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  border-radius: 0 0 18px 18px;
  overflow: hidden;
  box-shadow: 0 4px 25px rgba(0,0,0,0.2);
}

.safety-banner {
  background-image: url("../images/mauritius-safety-banner.jpg");
}

.terms-banner {
  background-image: url("../images/mauritius-terms-banner.jpg");
}

.safety-banner .banner-overlay,
.terms-banner .banner-overlay {
  background: rgba(0, 90, 80, 0.55);
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 20px;
}

.safety-banner h1, .terms-banner h1 {
  font-size: 32px;
  font-weight: 700;
  margin: 0;
  text-shadow: 1px 1px 6px rgba(0,0,0,0.4);
}

.safety-banner p, .terms-banner p {
  font-size: 16px;
  margin-top: 10px;
  color: #f3f9f8;
}

/* Page Section Styling */
.safety-page section, .terms-page section {
  margin-bottom: 30px;
}

.safety-page ul, .terms-page ul {
  list-style: none;
  padding: 0;
}

.safety-page li, .terms-page li {
  background: #f4f9f8;
  margin: 8px 0;
  padding: 8px 12px;
  border-left: 4px solid #00A68A;
  border-radius: 6px;
}


/* --- Fix mobile menu appearing behind banner --- */
.navbar,
.nav-links {
  position: relative;
  z-index: 1001;
}
