
html {
  scroll-behavior: smooth;
}
/* Call Button */
.call-btn {
  background: #28a745;  /* green */
  color: #fff;
  margin-top: 15px;
  display: inline-block;
}
.call-btn:hover {
  background: #218838;
}
.call-btn {
  background: #ffcc00;
  color: #111;
  margin-top: 15px;
  display: inline-block;
  text-align: center;
  padding: 12px 20px;
  border-radius: 30px;
  font-weight: bold;
}

.hero-text {
  flex: 1 1 400px;
  text-align: center;   /* center the text + button */
  display: flex;
  flex-direction: column;
  align-items: center;  /* horizontal centering */
}
.hero-text h1, 
.hero-text p {
  text-align: center;   /* ensure texts align center */
}

.hero-text .call-btn {
  display: inline-block;
  margin-top: 15px;
  padding: 12px 24px;
  border-radius: 30px;
  font-weight: bold;
  max-width: 300px;
  text-align: center;
}


/* GLOBAL */


body { margin:0; font-family: Arial, sans-serif; background:#f8f8f8; color:#333; }
h1,h2,h3 { margin:0 0 15px; font-weight:600; }
.section { padding:60px 20px; text-align:center; }
.section.alt { background:#fff; }
.btn { background:#ffcc00; color:#111; padding:12px 24px; border-radius:25px; font-weight:bold; border:none; cursor:pointer; display:inline-block; }
.btn:hover { background:#ffaa00; }
.btn.small { padding:6px 14px; font-size:0.9rem; }

/* NAVBAR */
.navbar { background:#ffcc00; padding:15px 0; position:sticky; top:0; z-index:1000; }
.container { max-width:1200px; margin:auto; display:flex; justify-content:space-between; align-items:center; width:90%; }
.logo { font-size:22px; font-weight:bold; color:#111; }
.nav-links { list-style:none; display:flex; gap:20px; margin:0; }
.nav-links li a { color:#111; text-decoration:none; }
.menu-toggle { display:none; color:#fff; font-size:24px; cursor:pointer; }
@media(max-width:768px){
  .nav-links { display:none; flex-direction:column; background:#fff; padding:20px; border-radius:8px; }
  .nav-links.open { display:flex; }
  .menu-toggle { display:block; }
}

/* HERO */
.hero .overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55); /* <-- this controls how dark it looks */
  
}

.hero { height:85vh; background:url(images/taxi-bg.jpg) center/cover no-repeat; position:relative; display:flex; align-items:center; justify-content:center; padding-top: 60px; }
.hero-inner { position:relative; z-index:1; display:flex; gap:40px; align-items:center; flex-wrap:wrap; justify-content:center; color:#fff; width:90%; max-width:1100px; }
.hero-text { flex:1 1 400px; text-align:left; }
.hero-text h1 { font-size:2.5rem;    padding-top: 120px;
    text-align: center; }
.hero-img { max-width:280px; border-radius:12px; margin-top:15px; }
.booking-box { background:#fff; color:#111; padding:25px; border-radius:12px; flex:1 1 320px; box-shadow:0 6px 14px rgba(0,0,0,0.2); }
.booking-box h2 { margin-bottom:15px; }
.booking-form { display:flex; flex-direction:column; gap:12px; }
.booking-form input { padding:12px; border:1px solid #ccc; border-radius:6px; font-size:1rem; }


/* ABOUT SECTION */
.about-container {
  display: grid;
  grid-template-columns: 1fr 1.5fr;  /* image 1, text 1.5 */
  gap: 40px;
  align-items: center;
  max-width: 1100px;
  margin: auto;
  padding: 60px 20px;
}

.about-img img {
  width: 100%;
  border-radius: 12px;
  box-shadow: 0 4px 15px rgba(0,0,0,0.15);
}

.about-content {
  text-align: left;   /* force text left */
}

.about-content h2 {
  font-size: 2rem;
  margin-bottom: 20px;
  color: #222;
}

.about-content p {
  margin-bottom: 15px;
  line-height: 1.6;
  font-size: 1rem;
  color: #444;
}

/* Responsive: stack image above text */
@media(max-width: 768px) {
  .about-container {
    grid-template-columns: 1fr;
  }
}




/* SERVICES */
.grid-3 { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:25px; max-width:1000px; margin:auto; }
.card { background:#fff; padding:25px; border-radius:10px; box-shadow:0 4px 12px rgba(0,0,0,0.08); }
.card img { width:100%; height:180px; object-fit:cover; border-radius:8px; margin-bottom:15px; }

/* WHY US */
.grid-4 { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:20px; max-width:1000px; margin:auto; }
.feature { background:#fff; padding:20px; border-radius:12px; text-align:center; font-weight:600; box-shadow:0 4px 10px rgba(0,0,0,0.08); }
.feature i { font-size:1.5rem; color:#ffcc00; display:block; margin-bottom:10px; }

/* TESTIMONIALS */
.grid-2 { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:25px; max-width:900px; margin:auto; }
.testimonial { background:#fff; padding:25px; border-radius:16px; box-shadow:0 6px 14px rgba(0,0,0,0.1); text-align:center; }
.avatar { width:70px; height:70px; border-radius:50%; border:3px solid #ffcc00; margin-bottom:15px; object-fit:cover; }
.testimonial p { font-style:italic; margin-bottom:10px; }

/* FAQ */
/* FAQ Accordion */
.faq-list { max-width:800px; margin:auto; text-align:left; }
.faq-item { margin-bottom:15px; border-radius:8px; overflow:hidden; box-shadow:0 3px 8px rgba(0,0,0,0.08); }
.faq-question {
  width:100%; background:#fff; border:none; outline:none;
  padding:15px; text-align:left; font-weight:600; font-size:1rem;
  cursor:pointer; display:flex; justify-content:space-between; align-items:center;
  /* FAQ Card Style */
.faq-grid { max-width:1000px; margin:auto; display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:25px; }
.faq-item {
  background:#fff; padding:25px; border-radius:12px;
  box-shadow:0 6px 16px rgba(0,0,0,0.08); transition:transform .2s;
}
.faq-item:hover { transform:translateY(-5px); }
.faq-item h3 { font-size:1.2rem; color:#222; margin-bottom:10px; }
.faq-item p { font-size:0.95rem; color:#555; }

}
.faq-answer {
  display:none; background:#fafafa; padding:15px; font-size:0.95rem; color:#555;
}
.faq-item.active .faq-answer { display:block; }
.faq-item.active .faq-question i { transform:rotate(180deg); }

/* CONTACT */
/* LOCATIONS */
.location-card {
  background:#fff;
  padding:25px;
  border-radius:10px;
  box-shadow:0 4px 12px rgba(0,0,0,0.08);
  text-align:center;
}
.location-card h3 {
  margin-bottom:10px;
  color:#222;
}
.location-card p {
  font-size:0.95rem;
  color:#555;
}


/* FOOTER */
.footer {
  background: #111;
  color: #fff;
  padding: 40px 20px;
}

.footer-container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 30px;
  max-width: 1100px;
  margin: auto;
}

.footer h4 {
  color: #ffcc00;
  margin-bottom: 15px;
}

.footer a {
  color: #ffcc00;
  text-decoration: none;
}

.footer a:hover {
  text-decoration: underline;
}

.map-container {
  margin-top: 10px;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 3px 10px rgba(0,0,0,0.3);
}

.footer-bottom {
  text-align: center;
  margin-top: 20px;
  font-size: 0.9rem;
  color: #aaa;
}
.footer-social a {
  display: flex;
  align-items: center;
  gap: 8px;  /* spacing between icon and text */
  color: #ffcc00;
  text-decoration: none;
  font-size: 1rem;
}

.footer-social a:hover {
  color: #fff;
}

.footer-social i {
  font-size: 1.2rem;
}
.footer-links p {
  margin-bottom: 10px;  /* space between links */
}

.footer-links a {
  color: #ffcc00;
  text-decoration: none;
  font-size: 1rem;
}

.footer-links a:hover {
  color: #fff;
}



/* BOOKING BOX */
.booking-box {
  background: #fff;
  padding: 25px;
  border-radius: 12px;
  max-width: 400px;
  margin: auto;
  box-shadow: 0 6px 16px rgba(0,0,0,0.2);
}

.booking-box h2 {
  margin-bottom: 15px;
  font-size: 1.4rem;
  text-align: left;
}

.booking-form {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.booking-form input {
  padding: 12px;
  border: 1px solid #ccc;
  border-radius: 6px;
  font-size: 1rem;
}

.booking-form input:focus {
  border-color: #ffcc00;
  outline: none;
  box-shadow: 0 0 5px rgba(255, 204, 0, 0.6);
}

.booking-form .btn {
  background: #ffcc00;
  color: #111;
  font-weight: bold;
  border: none;
  border-radius: 25px;
  padding: 12px;
  cursor: pointer;
  transition: background 0.3s;
}

.booking-form .btn:hover {
  background: #e6b800;
}
.booking-form input {
  padding: 12px;
  border: 1px solid #ccc;
  border-radius: 6px;
  font-size: 1rem;
}
.logo {
  background: #222;
  padding: 6px 12px;
  border-radius: 6px;
}

.gradient-text {
  background: linear-gradient(90deg, #ff4e50, #fff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: bold;
}
.designer-credit {
  text-align: center;
  font-size: 0.9rem;
  margin-top: 20px;
  color: #888;
}

.designer-credit a {
  color: #ffc107;
  text-decoration: none;
}

.designer-credit a:hover {
  text-decoration: underline;
}
