:root{
  --gold:#c9a24d;
  --gold2:#a8832b;
  --green:#0f5132;
  --black:#0b0b0b;
  --beige:#f9f6f1;
  --muted:#6b7280;
  --card:#111113;
  --white:#ffffff;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  background:#fff;
  color:#111;
}

.gold{color:var(--gold)}

.topbar{
  background:#fff;
  border-bottom:1px solid rgba(0,0,0,.06);
}
.top-link{color:#111}
.top-link:hover{color:var(--gold)}
.btn-whatsapp{
  background:#25D366;
  color:#fff !important;
  border:none;
}
.btn-whatsapp:hover{filter:brightness(.95)}

.nav-premium{
  background:rgba(11,11,11,.75);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.navbar .nav-link{color:rgba(255,255,255,.85)}
.navbar .nav-link:hover{color:var(--gold)}
.navbar-brand .brand-name{font-weight:700}
.brand-mark{
  width:40px;height:40px;border-radius:12px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:#111;font-weight:900;
}

/* HERO */
.hero-premium{
  min-height:95vh;
  position:relative;
  display:flex;
  align-items:center;
  background:
    linear-gradient(180deg, rgba(0,0,0,.70), rgba(0,0,0,.75)),
    url('../images/hero-kaaba.jpg') center/cover no-repeat;
  padding-top:90px;
}
.hero-pattern{
  position:absolute; inset:0;
  background:url('../images/islamic-pattern.svg') repeat;
  opacity:.08;
  pointer-events:none;
}
.hero-glow{
  position:absolute; inset:-200px;
  background:
    radial-gradient(circle at 20% 30%, rgba(201,162,77,.25), transparent 45%),
    radial-gradient(circle at 80% 35%, rgba(15,81,50,.25), transparent 45%),
    radial-gradient(circle at 50% 90%, rgba(201,162,77,.16), transparent 55%);
  pointer-events:none;
}

.hero-content{position:relative; z-index:2}
.badge-premium{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  font-weight:600;
}
.hero-premium h1{
  font-family:'Cinzel',serif;
  font-size:3.6rem;
  letter-spacing:.6px;
  color:var(--gold);
}
.hero-premium .lead{max-width:900px;margin:0 auto;color:rgba(255,255,255,.88)}
.btn-gold{
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:#111;
  border:none;
  font-weight:800;
}
.btn-gold:hover{filter:brightness(.98)}
.btn-outline-gold{
  border:1px solid rgba(201,162,77,.7);
  color:var(--gold);
  font-weight:700;
}
.btn-outline-gold:hover{
  background:rgba(201,162,77,.12);
  color:var(--gold);
}

.search-card{
  max-width:980px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  border-radius:18px;
  padding:18px;
  backdrop-filter: blur(10px);
}
.search-card .form-label{color:rgba(255,255,255,.85); font-weight:600}

/* TRUST STRIP */
.trust-strip{background:#fff}
.trust-item{
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  padding:16px;
  background:linear-gradient(180deg,#fff,var(--beige));
}
.trust-item i{font-size:22px;color:var(--gold)}

/* SECTIONS */
.section-title{
  font-family:'Cinzel',serif;
  font-size:2.2rem;
  color:#111;
}
.section-subtitle{color:var(--muted); max-width:900px; margin:0 auto}
.section-pattern{
  position:relative;
  background:linear-gradient(180deg,var(--beige),#fff);
}
.section-pattern::before{
  content:"";
  position:absolute; inset:0;
  background:url('../images/islamic-pattern.svg') repeat;
  opacity:.06;
  pointer-events:none;
}

/* OFFERS */
.offer-card{
  border-radius:20px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.06);
  background:#fff;
  box-shadow:0 18px 40px rgba(0,0,0,.08);
  transition: transform .25s ease, box-shadow .25s ease;
}
.offer-card:hover{
  transform: translateY(-8px);
  box-shadow:0 22px 60px rgba(0,0,0,.12);
}
.offer-img{width:100%;height:200px;object-fit:cover}
.offer-body{padding:18px}
.price-tag{font-weight:900;color:#111;background:rgba(201,162,77,.18);padding:6px 10px;border-radius:12px}
.offer-title{font-weight:800;margin:8px 0 6px}
.offer-text{color:var(--muted);margin:0 0 10px}
.offer-list{margin:0 0 14px;padding-left:18px;color:#333}
.offer-list li{margin:4px 0}

.pill{
  font-size:12px;
  font-weight:800;
  padding:6px 10px;
  border-radius:999px;
  display:inline-block;
}
.pill-gold{background:rgba(201,162,77,.18); color:var(--gold2)}
.pill-green{background:rgba(15,81,50,.14); color:var(--green)}
.pill-dark{background:rgba(0,0,0,.12); color:#111}
.pill-light{background:rgba(107,114,128,.14); color:#374151}

/* PROGRAMS */
.tabs-premium .nav-link{
  border-radius:999px;
  font-weight:800;
  background:rgba(0,0,0,.04);
  color:#111;
}
.tabs-premium .nav-link.active{
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:#111;
}
.timeline{
  list-style:none;
  padding-left:0;
  margin:0;
}
.timeline li{
  padding:14px 14px 14px 18px;
  border-left:3px solid rgba(201,162,77,.55);
  background:rgba(255,255,255,.6);
  border-radius:14px;
  margin-bottom:10px;
}
.timeline h6{margin:0 0 6px;font-weight:900}
.timeline p{margin:0;color:var(--muted)}

.img-card{position:relative}
.img-card-badge{
  position:absolute;
  left:16px; bottom:16px;
  padding:10px 12px;
  border-radius:14px;
  background:rgba(0,0,0,.55);
  color:#fff;
  border:1px solid rgba(255,255,255,.15);
}

/* FEATURE */
.feature-card{
  border-radius:20px;
  padding:18px;
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 14px 35px rgba(0,0,0,.06);
}
.feature-card i{font-size:22px;color:var(--gold)}
.feature-card h5{font-weight:900;margin-top:10px}
.feature-card p{color:var(--muted); margin:0}

/* REVIEWS */
.review-card{
  max-width:900px;
  margin:0 auto;
  border-radius:20px;
  padding:28px;
  border:1px solid rgba(0,0,0,.06);
  background:linear-gradient(180deg,#fff,var(--beige));
  box-shadow:0 16px 40px rgba(0,0,0,.08);
  text-align:center;
}
.stars{color:var(--gold); font-weight:900; letter-spacing:2px}

/* FAQ */
.premium-accordion .accordion-item{
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.06);
  margin-bottom:10px;
}
.premium-accordion .accordion-button{font-weight:900}
.premium-accordion .accordion-button:not(.collapsed){
  background:rgba(201,162,77,.12);
  color:#111;
}

/* BLOG */
.blog-card{
  border-radius:20px;
  padding:18px;
  border:1px solid rgba(0,0,0,.06);
  background:#fff;
  box-shadow:0 14px 30px rgba(0,0,0,.06);
}
.blog-card h5{font-weight:900}
.blog-card p{color:var(--muted)}
.link-gold{color:var(--gold2); font-weight:800; text-decoration:none}
.link-gold:hover{color:var(--gold)}

/* DEVIS */
.devis-section{
  background:
    linear-gradient(180deg, rgba(0,0,0,.70), rgba(0,0,0,.80)),
    url('../images/medina.jpg') center/cover no-repeat;
  position:relative;
}
.devis-section::before{
  content:"";
  position:absolute; inset:0;
  background:url('../images/islamic-pattern.svg') repeat;
  opacity:.08;
  pointer-events:none;
}
.form-card{
  position:relative;
  background:rgba(255,255,255,.92);
  border-radius:22px;
  padding:18px;
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 20px 60px rgba(0,0,0,.18);
}
.mini-pill{
  display:inline-flex;
  align-items:center;
  padding:8px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
}

/* FOOTER */
.footer-premium{
  position:relative;
  background:linear-gradient(180deg,#0b0b0b,#050505);
  color:#fff;
  overflow:hidden;
}
.footer-pattern{
  position:absolute; inset:0;
  background:url('../images/islamic-pattern.svg') repeat;
  opacity:.08;
  pointer-events:none;
}
.footer-title{font-weight:900}
.footer-links{list-style:none;padding-left:0;margin:0}
.footer-links li{margin:8px 0}
.footer-links a{color:rgba(255,255,255,.75); text-decoration:none}
.footer-links a:hover{color:var(--gold)}
.socials a{
  width:42px;height:42px;border-radius:14px;
  display:inline-grid;place-items:center;
  border:1px solid rgba(255,255,255,.14);
  color:#fff; text-decoration:none;
  margin-right:8px;
}
.socials a:hover{border-color:rgba(201,162,77,.55); color:var(--gold)}
.footer-cta{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
}

.mobile-cta{
  position:fixed;
  left:0; right:0; bottom:0;
  display:flex;
  gap:10px;
  padding:10px;
  background:rgba(255,255,255,.92);
  border-top:1px solid rgba(0,0,0,.06);
  z-index:9999;
}

/* RESPONSIVE */
@media (max-width: 768px){
  .hero-premium h1{font-size:2.6rem}
  .search-card{padding:14px}
}
.filter-card{
  background:#fff;
  border-radius:20px;
  padding:18px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 14px 30px rgba(0,0,0,.06);
}
.filter-title{
  font-weight:900;
  margin-bottom:14px;
}
