/* ==========================================================
   Noor-e-Taiba Cab Services — stylesheet
   Palette: sand #F6EFE0 · ink #1E1A15 · deep green #0E3B2E
            gold #C89B3C · rose-sand #E7D8BE
   Type: Fraunces (display) / Inter (body) / Amiri (Arabic)
   ========================================================== */

:root{
  --sand:#F6EFE0;
  --sand-2:#EFE5CF;
  --ink:#1E1A15;
  --ink-soft:#4A443A;
  --green:#0E3B2E;
  --green-deep:#092A21;
  --gold:#C89B3C;
  --gold-light:#E4C57C;
  --rose-sand:#E7D8BE;
  --white:#FFFFFF;

  --font-display:'Fraunces', serif;
  --font-body:'Inter', sans-serif;
  --font-ar:'Amiri', serif;

  --radius:14px;
  --shadow-soft: 0 12px 30px rgba(14,59,46,0.10);
  --shadow-lift: 0 20px 44px rgba(14,59,46,0.16);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--sand);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}
h1,h2,h3{font-family:var(--font-display);margin:0;line-height:1.1;}
p{margin:0;}

.wrap{
  max-width:1160px;
  margin:0 auto;
  padding:0 28px;
}

:focus-visible{
  outline:3px solid var(--gold);
  outline-offset:3px;
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important;}
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:13px 24px;
  border-radius:999px;
  font-family:var(--font-body);
  font-weight:600;
  font-size:0.95rem;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);}
.btn-solid{background:var(--green);color:var(--white);}
.btn-solid:hover{background:var(--green-deep);}
.btn-ghost{background:transparent;color:var(--green);border-color:rgba(14,59,46,0.25);}
.btn-ghost:hover{background:rgba(14,59,46,0.06);}
.btn-gold{background:var(--gold);color:var(--green-deep);}
.btn-gold:hover{background:var(--gold-light);box-shadow:var(--shadow-soft);}
.btn-outline-light{background:transparent;color:var(--white);border-color:rgba(255,255,255,0.55);}
.btn-outline-light:hover{background:rgba(255,255,255,0.12);}
.btn-block{width:100%;}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(246,239,224,0.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(14,59,46,0.10);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 28px;
  gap:24px;
}
.brand{display:flex;align-items:center;gap:10px;}
.brand-mark{color:var(--gold);font-size:1.3rem;}
.brand-text{display:flex;flex-direction:column;line-height:1.05;}
.brand-name{font-family:var(--font-display);font-weight:600;font-size:1.15rem;color:var(--green);}
.brand-sub{font-size:0.62rem;letter-spacing:0.22em;color:var(--ink-soft);}

.main-nav{display:flex;gap:28px;}
.main-nav a{font-size:0.92rem;font-weight:500;color:var(--ink-soft);position:relative;padding:4px 0;}
.main-nav a:hover{color:var(--green);}
.main-nav a::after{
  content:'';position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--gold);transition:width .2s ease;
}
.main-nav a:hover::after{width:100%;}

.header-cta{display:flex;gap:10px;}
.header-cta .btn{padding:10px 18px;font-size:0.85rem;}

.nav-toggle{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:38px;height:38px;background:none;border:none;cursor:pointer;
}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--green);margin:0 auto;}

/* ---------- hero ---------- */
.hero{
  position:relative;
  min-height:88vh;
  display:flex;align-items:center;
  overflow:hidden;
  color:var(--white);
}
.hero-bg{position:absolute;inset:0;z-index:0;}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%;}
.hero-veil{
  position:absolute;inset:0;
  background:
    linear-gradient(100deg, rgba(9,42,33,0.94) 10%, rgba(9,42,33,0.72) 42%, rgba(9,42,33,0.35) 75%),
    linear-gradient(0deg, rgba(9,42,33,0.55), rgba(9,42,33,0.15) 40%);
}
.hero-talbiyah{
  position:absolute;
  right:-4%;
  bottom:6%;
  font-family:var(--font-ar);
  font-size:clamp(2.4rem, 9vw, 6.5rem);
  color:rgba(255,255,255,0.06);
  white-space:nowrap;
  pointer-events:none;
  z-index:1;
}
.hero-inner{position:relative;z-index:2;padding-top:60px;padding-bottom:60px;}
.eyebrow{
  font-size:0.78rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--gold-light);
  font-weight:600;
  margin-bottom:14px;
  display:block;
}
.eyebrow-dark{color:var(--gold);}
.hero-title{
  font-size:clamp(2.3rem, 4.6vw, 3.6rem);
  font-weight:600;
  max-width:14ch;
  margin-bottom:22px;
}
.hero-title em{
  font-style:italic;
  font-weight:500;
  color:var(--gold-light);
}
.hero-lede{
  font-size:1.05rem;
  line-height:1.65;
  max-width:44ch;
  color:rgba(255,255,255,0.86);
  margin-bottom:34px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:56px;}

.hero-route{
  display:flex;align-items:center;gap:14px;
  font-size:0.85rem;font-weight:600;letter-spacing:0.03em;
  color:rgba(255,255,255,0.92);
  flex-wrap:wrap;
}
.route-line{
  position:relative;
  width:64px;height:1px;
  background:rgba(255,255,255,0.4);
  display:inline-block;
}
.route-line i{
  position:absolute;top:-3px;left:0;
  width:7px;height:7px;border-radius:50%;
  background:var(--gold);
  animation:travel 3.4s ease-in-out infinite;
}
@keyframes travel{
  0%,100%{left:0;}
  50%{left:calc(100% - 7px);}
}

/* ---------- trust strip ---------- */
.strip{background:var(--green);color:var(--white);}
.strip-inner{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  padding:30px 28px;
}
.strip-item{display:flex;flex-direction:column;gap:4px;text-align:center;}
.strip-item strong{font-family:var(--font-display);font-size:1.4rem;color:var(--gold-light);}
.strip-item span{font-size:0.82rem;color:rgba(255,255,255,0.78);}

/* ---------- sections ---------- */
.section{padding:88px 0;}
.section-tint{background:var(--sand-2);}
.section-title{
  font-size:clamp(1.9rem,3.4vw,2.6rem);
  font-weight:600;
  color:var(--green);
  margin:6px 0 16px;
  max-width:18ch;
}
.section-lede{
  font-size:1.02rem;
  color:var(--ink-soft);
  max-width:56ch;
  line-height:1.65;
  margin-bottom:48px;
}

/* ---------- ticket cards (signature element) ---------- */
.ticket-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:26px;
}
.ticket{
  position:relative;
  background:var(--white);
  border-radius:var(--radius);
  padding:30px 28px 32px;
  box-shadow:var(--shadow-soft);
  border:1px solid rgba(14,59,46,0.08);
}
.ticket::before,
.ticket::after{
  content:'';
  position:absolute;
  width:22px;height:22px;
  border-radius:50%;
  background:var(--sand);
  top:50%;
  transform:translateY(-50%);
}
.ticket::before{left:-11px;}
.ticket::after{right:-11px;}
.ticket-head{
  display:flex;gap:14px;align-items:flex-start;
  padding-bottom:18px;margin-bottom:18px;
  border-bottom:1.5px dashed rgba(14,59,46,0.22);
}
.ticket-icon{font-size:1.5rem;}
.ticket-head h3{font-size:1.2rem;color:var(--green);margin-bottom:4px;}
.ticket-tag{
  font-size:0.72rem;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--gold);font-weight:700;
}
.ticket-list li{
  font-size:0.94rem;
  color:var(--ink-soft);
  padding:8px 0;
  border-bottom:1px solid rgba(14,59,46,0.07);
  display:flex;flex-direction:column;
}
.ticket-list li:last-child{border-bottom:none;padding-bottom:0;}
.ticket-list .ar{
  font-family:var(--font-ar);
  font-size:1.05rem;
  color:var(--green);
  margin-bottom:2px;
}

/* ---------- fleet ---------- */
.fleet-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:26px;
}
.fleet-card-wide{grid-column:span 2;display:grid;grid-template-columns:1.1fr 1fr;}
.fleet-card-wide .fleet-photo{height:100%;}
.fleet-card{
  background:var(--white);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  border:1px solid rgba(14,59,46,0.08);
  transition:box-shadow .25s ease, transform .25s ease;
}
.fleet-card:hover{box-shadow:var(--shadow-lift);transform:translateY(-4px);}
.fleet-photo{aspect-ratio:4/3;overflow:hidden;background:var(--sand-2);}
.fleet-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.fleet-card:hover .fleet-photo img{transform:scale(1.05);}
.fleet-body{padding:22px 24px 26px;}
.fleet-body h3{font-size:1.2rem;color:var(--green);margin-bottom:6px;}
.fleet-meta{
  font-size:0.78rem;font-weight:700;letter-spacing:0.04em;
  color:var(--gold);text-transform:uppercase;margin-bottom:10px;
}
.fleet-desc{font-size:0.92rem;color:var(--ink-soft);line-height:1.55;}

/* ---------- how it works ---------- */
.how-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:34px;
  counter-reset:step;
}
.how-step{position:relative;padding-left:2px;}
.how-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:50%;
  background:var(--green);color:var(--gold-light);
  font-family:var(--font-display);font-size:1.1rem;
  margin-bottom:18px;
}
.how-step h3{font-size:1.1rem;color:var(--green);margin-bottom:8px;}
.how-step p{font-size:0.92rem;color:var(--ink-soft);line-height:1.6;}

/* ---------- contact ---------- */
.contact-section{background:var(--green);color:var(--white);}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:start;
}
.contact-title{color:var(--white);}
.contact-lede{color:rgba(255,255,255,0.78);}
.contact-cards{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:26px;}
.contact-card{
  flex:1;min-width:210px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.18);
  border-radius:var(--radius);
  padding:20px 22px;
  display:flex;flex-direction:column;gap:6px;
  transition:background .2s ease, transform .2s ease;
}
.contact-card:hover{background:rgba(255,255,255,0.12);transform:translateY(-2px);}
.contact-label{font-size:0.74rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--gold-light);}
.contact-value{font-family:var(--font-display);font-size:1.2rem;}
.contact-manager{font-size:0.94rem;color:rgba(255,255,255,0.85);margin-bottom:6px;}
.contact-location{font-size:0.9rem;color:rgba(255,255,255,0.7);}

.contact-form{
  background:var(--white);
  color:var(--ink);
  border-radius:var(--radius);
  padding:32px;
  box-shadow:var(--shadow-lift);
}
.contact-form .eyebrow{color:var(--gold);margin-bottom:6px;}
.contact-form label{
  display:flex;flex-direction:column;gap:6px;
  font-size:0.85rem;font-weight:600;color:var(--ink-soft);
  margin-bottom:16px;
}
.contact-form input{
  font-family:var(--font-body);
  font-size:0.95rem;
  padding:11px 14px;
  border-radius:8px;
  border:1px solid rgba(14,59,46,0.2);
  background:var(--sand);
  color:var(--ink);
}
.contact-form input:focus{outline:2px solid var(--gold);border-color:transparent;}
.form-note{font-size:0.78rem;color:var(--ink-soft);margin-top:12px;text-align:center;}

/* ---------- footer ---------- */
.site-footer{background:var(--green-deep);color:rgba(255,255,255,0.75);padding:48px 0 28px;}
.footer-inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;}
.footer-brand{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:1.1rem;color:var(--white);}
.footer-brand .brand-mark{color:var(--gold);}
.footer-tag{font-size:0.88rem;max-width:46ch;color:rgba(255,255,255,0.6);}
.footer-links{display:flex;gap:20px;font-size:0.88rem;margin-top:6px;}
.footer-links a:hover{color:var(--gold-light);}
.footer-copy{font-size:0.78rem;color:rgba(255,255,255,0.4);margin-top:18px;}

/* ==========================================================
   Responsive
   ========================================================== */
@media (max-width: 980px){
  .main-nav{display:none;}
  .header-cta .btn-ghost{display:none;}
  .nav-toggle{display:flex;}
  .ticket-grid,.fleet-grid,.how-grid{grid-template-columns:1fr;}
  .fleet-card-wide{grid-column:span 1;grid-template-columns:1fr;}
  .strip-inner{grid-template-columns:repeat(2,1fr);}
  .contact-grid{grid-template-columns:1fr;}
  .hero{min-height:auto;padding-top:20px;}
}

@media (max-width: 560px){
  .wrap{padding:0 18px;}
  .header-inner{padding:14px 18px;}
  .hero-inner{padding-top:40px;padding-bottom:40px;}
  .hero-actions .btn{width:100%;}
  .strip-inner{grid-template-columns:repeat(2,1fr);gap:24px;}
  .section{padding:60px 0;}
}

/* mobile nav drawer */
.main-nav.open{
  display:flex;
  flex-direction:column;
  position:absolute;
  top:100%;left:0;right:0;
  background:var(--sand);
  padding:20px 28px 26px;
  gap:16px;
  border-bottom:1px solid rgba(14,59,46,0.1);
  box-shadow:var(--shadow-soft);
}
