/* =====================================================================
   AL TAWAKKUL PROPERTIES — Luxury Design System
   Black & Gold | Playfair Display · Cormorant Garamond · Inter
   ===================================================================== */

:root{
  --gold:#D4AF37;
  --gold-2:#E6C86E;
  --gold-deep:#B8860B;
  --black:#000000;
  --charcoal:#0F172A;
  --ink:#0A0F1A;
  --cream:#F8F6F0;
  --white:#FFFFFF;
  --line:rgba(212,175,55,.22);
  --line-strong:rgba(212,175,55,.45);
  --shadow-gold:0 20px 60px -20px rgba(212,175,55,.35);
  --shadow-deep:0 30px 80px -30px rgba(0,0,0,.8);
  --font-head:'Playfair Display',Georgia,serif;
  --font-sub:'Cormorant Garamond',Georgia,serif;
  --font-body:'Inter',system-ui,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--ink);
  color:#E7E3D8;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;letter-spacing:-.01em;color:#fff;line-height:1.1}
.font-sub{font-family:var(--font-sub)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

/* ---------- gold helpers ---------- */
.text-gradient-gold{
  background:linear-gradient(100deg,#B8860B 0%,#E6C86E 35%,#FFF3C4 50%,#E6C86E 65%,#B8860B 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
}
.gold-line{height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.eyebrow{
  font-family:var(--font-sub);font-size:1.05rem;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold-2);font-weight:600;
}
.btn-gold{
  display:inline-flex;align-items:center;gap:.55rem;font-weight:600;letter-spacing:.04em;
  padding:.95rem 2.1rem;border-radius:999px;color:#1a1304;position:relative;overflow:hidden;
  background:linear-gradient(100deg,#B8860B,#E6C86E 50%,#B8860B);
  box-shadow:0 10px 30px -10px rgba(212,175,55,.6);transition:transform .35s,box-shadow .35s;
}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 18px 45px -12px rgba(212,175,55,.75)}
.btn-gold::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);transform:translateX(-120%);transition:transform .7s}
.btn-gold:hover::after{transform:translateX(120%)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:.55rem;font-weight:600;letter-spacing:.04em;
  padding:.9rem 2rem;border-radius:999px;color:var(--gold-2);border:1px solid var(--line-strong);
  background:rgba(212,175,55,.04);transition:.35s;
}
.btn-ghost:hover{background:rgba(212,175,55,.12);border-color:var(--gold);color:#fff;transform:translateY(-3px)}

/* ---------- glassmorphism ---------- */
.glass{
  background:linear-gradient(160deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border:1px solid var(--line);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-radius:20px;
}
.glass-dark{
  background:linear-gradient(160deg,rgba(15,23,42,.7),rgba(0,0,0,.55));
  border:1px solid var(--line);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}

/* ---------- Islamic geometric pattern ---------- */
.pattern-girih{
  background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23D4AF37' stroke-width='1' opacity='0.5'%3E%3Cpath d='M40 0 L80 40 L40 80 L0 40 Z'/%3E%3Cpath d='M40 12 L68 40 L40 68 L12 40 Z'/%3E%3Cpath d='M40 0 L40 80 M0 40 L80 40'/%3E%3C/g%3E%3C/svg%3E");
  background-size:64px 64px;
}
.pattern-fade{position:relative}
.pattern-fade::before{
  content:"";position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg width='120' height='120' viewBox='0 0 120 120' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23D4AF37' stroke-width='1'%3E%3Cpath d='M60 8 L112 60 L60 112 L8 60 Z'/%3E%3Cpath d='M60 28 L92 60 L60 92 L28 60 Z'/%3E%3Ccircle cx='60' cy='60' r='30'/%3E%3C/g%3E%3C/svg%3E");
  background-size:120px 120px;
}

/* radial glows */
.glow-top{position:relative}
.glow-top::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 50% at 50% 0%,rgba(212,175,55,.10),transparent 70%);}

/* ---------- header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:60;transition:.4s;}
.site-header.scrolled{background:rgba(5,8,15,.82);backdrop-filter:blur(16px);box-shadow:0 1px 0 var(--line)}
.nav-link{position:relative;font-size:.93rem;letter-spacing:.03em;color:#D8D3C4;padding:.4rem 0;transition:.3s}
.nav-link:hover{color:#fff}
.nav-link::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;background:var(--gold);transition:width .35s}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-link.active{color:var(--gold-2)}

/* mobile drawer */
.drawer{position:fixed;inset:0 0 0 auto;width:min(82%,360px);background:#05080f;z-index:80;
  transform:translateX(100%);transition:transform .45s cubic-bezier(.6,.05,.2,1);border-left:1px solid var(--line)}
.drawer.open{transform:translateX(0)}
.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:70;opacity:0;pointer-events:none;transition:.4s}
.drawer-backdrop.open{opacity:1;pointer-events:auto}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;
  animation:kenburns 22s ease-in-out infinite alternate;will-change:transform}
@keyframes kenburns{from{transform:scale(1.05)}to{transform:scale(1.18) translateY(-2%)}}
.hero-overlay{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(3,5,10,.72) 0%,rgba(3,5,10,.55) 40%,rgba(3,5,10,.9) 100%)}

/* ---------- property card ---------- */
.prop-card{position:relative;border-radius:20px;overflow:hidden;background:#0c111c;border:1px solid var(--line);
  transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s,border-color .5s}
.prop-card:hover{transform:translateY(-10px);border-color:var(--line-strong);box-shadow:var(--shadow-deep),var(--shadow-gold)}
.prop-media{position:relative;height:250px;overflow:hidden}
.prop-media img{height:100%;width:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.prop-card:hover .prop-media img{transform:scale(1.1)}
.prop-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(5,8,15,.85))}
.badge-gold{position:absolute;top:14px;left:14px;z-index:2;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:700;color:#1a1304;padding:.4rem .8rem;border-radius:999px;
  background:linear-gradient(100deg,#E6C86E,#B8860B)}
.prop-price{position:absolute;bottom:14px;left:16px;z-index:2;font-family:var(--font-head);font-size:1.35rem;color:#fff}
.spec-pill{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;color:#B9B4A6}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.1s}
.reveal[data-d="2"]{transition-delay:.2s}
.reveal[data-d="3"]{transition-delay:.3s}
.reveal[data-d="4"]{transition-delay:.4s}

/* ---------- section heads ---------- */
.section{padding:7rem 0;position:relative}
.container{width:min(1200px,92%);margin:0 auto}
.kicker-row{display:flex;align-items:center;gap:1rem;justify-content:center}
.kicker-row .dash{width:46px;height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.kicker-row .dash.r{background:linear-gradient(90deg,var(--gold),transparent)}

/* ---------- stats ---------- */
.stat-num{font-family:var(--font-head);font-size:clamp(2.6rem,5vw,3.8rem);line-height:1}

/* ---------- FAQ ---------- */
.faq-item{border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:.4s;background:rgba(255,255,255,.02)}
.faq-item.open{border-color:var(--line-strong);background:rgba(212,175,55,.04)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.35rem 1.6rem;cursor:pointer;font-family:var(--font-sub);font-size:1.3rem;color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s ease,padding .4s;padding:0 1.6rem;color:#B9B4A6}
.faq-item.open .faq-a{max-height:320px;padding:0 1.6rem 1.5rem}
.faq-icon{flex:0 0 auto;width:30px;height:30px;border-radius:50%;border:1px solid var(--line-strong);display:grid;place-items:center;color:var(--gold-2);transition:.4s}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--gold);color:#1a1304;border-color:var(--gold)}

/* ---------- testimonials ---------- */
.testi-track{display:flex;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.testi-slide{min-width:100%;padding:.5rem}
.testi-dot{width:9px;height:9px;border-radius:50%;background:var(--line-strong);transition:.3s;cursor:pointer}
.testi-dot.active{width:26px;border-radius:6px;background:var(--gold)}

/* ---------- forms ---------- */
.field{width:100%;padding:.85rem 1.1rem;border-radius:12px;background:rgba(255,255,255,.04);
  border:1px solid var(--line);color:#fff;font-family:var(--font-body);font-size:.95rem;transition:.3s}
.field::placeholder{color:#8c8779}
.field:focus{outline:none;border-color:var(--gold);background:rgba(212,175,55,.06);box-shadow:0 0 0 3px rgba(212,175,55,.12)}
label.lbl{font-size:.82rem;letter-spacing:.05em;color:#C8C3B4;margin-bottom:.4rem;display:block}
.err{color:#ff8a8a;font-size:.78rem;margin-top:.3rem;display:none}
.field.invalid{border-color:#ff8a8a}
.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(120%);z-index:120;
  background:linear-gradient(100deg,#B8860B,#E6C86E);color:#1a1304;font-weight:600;padding:.9rem 1.6rem;
  border-radius:999px;box-shadow:var(--shadow-gold);transition:transform .5s}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ---------- floating buttons ---------- */
.fab{position:fixed;right:20px;z-index:90;width:56px;height:56px;border-radius:50%;display:grid;place-items:center;
  box-shadow:0 12px 30px -8px rgba(0,0,0,.6);transition:transform .3s}
.fab:hover{transform:scale(1.08)}
.fab-wa{bottom:90px;background:#25D366;color:#fff}
.fab-call{bottom:160px;background:linear-gradient(100deg,#B8860B,#E6C86E);color:#1a1304}
.fab-wa::before{content:"";position:absolute;inset:0;border-radius:50%;background:#25D366;animation:pulse 2.2s infinite;z-index:-1}
@keyframes pulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.8);opacity:0}100%{opacity:0}}
.to-top{bottom:20px;background:rgba(15,23,42,.85);border:1px solid var(--line-strong);color:var(--gold-2);opacity:0;pointer-events:none}
.to-top.show{opacity:1;pointer-events:auto}

/* ---------- footer ---------- */
.foot-link{color:#A9A498;transition:.3s;font-size:.92rem}
.foot-link:hover{color:var(--gold-2);padding-left:4px}
.soc{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line);color:#C8C3B4;transition:.35s}
.soc:hover{border-color:var(--gold);color:#1a1304;background:var(--gold);transform:translateY(-3px)}

/* ---------- range slider (calculators) ---------- */
input[type=range]{-webkit-appearance:none;height:5px;border-radius:5px;background:rgba(212,175,55,.25);outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;
  background:linear-gradient(100deg,#E6C86E,#B8860B);cursor:pointer;box-shadow:0 0 0 4px rgba(212,175,55,.18)}

/* scrollbar */
::-webkit-scrollbar{width:11px}
::-webkit-scrollbar-track{background:#05080f}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--gold-deep),var(--gold));border-radius:6px;border:2px solid #05080f}

/* page hero (inner) */
.page-hero{position:relative;padding:11rem 0 5rem;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.4) saturate(1.05)}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(3,5,10,.6),rgba(10,15,26,.95))}
.crumb{color:#9a9588;font-size:.85rem;letter-spacing:.05em}
.crumb a:hover{color:var(--gold-2)}

@media(max-width:768px){
  .section{padding:4.5rem 0}
  .eyebrow{letter-spacing:.2em;font-size:.8rem;line-height:1.5}
  .hero{min-height:auto;justify-content:flex-start;padding-bottom:3.25rem}
  .hero .container.mt-14{margin-top:2.25rem}
}
