:root{
  --bg:#050505;
  --panel:#0b0b0b;
  --card:rgba(255,255,255,.06);
  --card2:rgba(255,255,255,.08);
  --border:rgba(255,255,255,.12);
  --fg:#ffffff;
  --muted:#a8b0bd;
  --brand:#D4AF37;
  --shadow:0 18px 60px rgba(0,0,0,.55);
  --radius:22px;
  --radius2:16px;
  --container:1180px;
}

*{ box-sizing:border-box }
html{ scroll-behavior:smooth }
body{
  background:var(--bg);
  color:var(--fg);
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  line-height:1.65;
  overflow-x:hidden;
}
html[dir="rtl"] body{
  font-family:Cairo,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}

img, video{ max-width:100%; display:block }
a{ color:inherit; text-decoration:none }
button{ font-family:inherit }

.container{
  width:min(var(--container), calc(100% - 40px));
  margin-inline:auto;
}

.anchor{ position:relative; top:-90px }

/* Skip link */
.skip-link{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px; height:1px;
  overflow:hidden;
}
.skip-link:focus{
  position:fixed;
  left:16px; top:16px;
  width:auto; height:auto;
  padding:10px 12px;
  border-radius:12px;
  background:#111;
  border:1px solid var(--border);
  z-index:9999;
}

/* Header */
.site-header{
  position:fixed;
  inset:0 0 auto 0;
  z-index:50;
  background:rgba(5,5,5,.55);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.header-inner{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  gap:14px;
  padding:14px 0;
}
.logo{ justify-self:center; display:inline-flex; align-items:center; gap:10px }
.logo-img{
  width:120px;
  height:44px;
  object-fit:contain;
}

.nav{
  display:flex;
  gap:18px;
  align-items:center;
  font-weight:800;
  font-size:12px;
  letter-spacing:.08em;
  color:rgba(255,255,255,.9);
  text-transform:uppercase;
}
.nav a{
  padding:10px 10px;
  border-radius:14px;
  transition: background .2s ease, color .2s ease;
}
.nav a:hover{ background:rgba(255,255,255,.06) }

.lang{
  background:transparent;
  color:var(--fg);
  border:1px solid rgba(255,255,255,.16);
  padding:9px 12px;
  border-radius:14px;
  font-weight:900;
  letter-spacing:.08em;
  cursor:pointer;
}
.lang:hover{ border-color:rgba(255,255,255,.26) }

/* Mobile nav */
.nav-toggle{ display:none }
.burger{
  display:none;
  justify-self:start;
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.04);
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.burger span{
  width:18px; height:2px;
  background:#fff;
  display:block;
  position:relative;
}
.burger span + span{ margin-top:6px; opacity:.85 }

.mobile-drawer{
  display:none;
  position:absolute;
  top:72px;
  left:20px;
  right:20px;
  padding:14px;
  border-radius:18px;
  background:rgba(10,10,10,.92);
  border:1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
}
.mobile-drawer a{
  display:block;
  padding:12px 12px;
  border-radius:14px;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.mobile-drawer a:hover{ background:rgba(255,255,255,.06) }
.mobile-drawer hr{
  border:0; height:1px;
  background:rgba(255,255,255,.10);
  margin:10px 0;
}
#navToggle:checked ~ .mobile-drawer{ display:block }

/* Responsive header */
@media (max-width: 980px){
  .header-inner{
    grid-template-columns: auto 1fr auto;
  }
  .nav{ display:none }
  .burger{ display:flex }
}

/* Hero */
.hero{
  min-height:92vh;
  position:relative;
  display:flex;
  align-items:center;
  padding-top:92px;
  overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0;
  background:
    radial-gradient(80% 50% at 30% 20%, rgba(212,175,55,.20), transparent 60%),
    radial-gradient(70% 40% at 70% 70%, rgba(255,255,255,.07), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.40), rgba(0,0,0,.88));
}
.hero-media{
  position:absolute; inset:0;
  z-index:0;
}
.hero-video{
  position:absolute; inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.03);
  filter:saturate(.95) contrast(1.05);
  opacity:.38;
}
.hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.85));
  z-index:1;
}
.hero-content{ position:relative; z-index:2; padding:42px 0 }
.warning{
  display:inline-block;
  padding:10px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.35);
}
.warning-top{ display:flex; align-items:center; gap:10px; margin-bottom:6px }
.warning-label{
  color:var(--brand);
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:12px;
}
.warning-line{
  flex:1;
  height:1px;
  background:rgba(212,175,55,.35);
}
.warning-text{
  margin:0;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-size:12px;
  color:rgba(255,255,255,.92);
}

.hero-title{
  margin:18px 0 0;
  font-size: clamp(32px, 4.2vw, 56px);
  line-height:1.05;
  font-weight:900;
  letter-spacing:-.02em;
  text-transform:uppercase;
}
.hero-actions{
  display:flex;
  gap:12px;
  margin-top:18px;
  flex-wrap:wrap;
}
.hero-controls{
  margin-top:22px;
  display:flex;
  align-items:center;
  gap:10px;
  color:rgba(255,255,255,.72);
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:11px;
}
.hero-controls .dot{
  width:6px; height:6px;
  border-radius:99px;
  background:var(--brand);
  box-shadow:0 0 0 4px rgba(212,175,55,.18);
}
.scroll-indicator{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:18px;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.35);
  z-index:2;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius:16px;
  font-weight:900;
  letter-spacing:.04em;
  border:1px solid transparent;
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
  cursor:pointer;
}
.btn:hover{ transform: translateY(-1px) }
.btn-primary{
  background:linear-gradient(180deg, rgba(212,175,55,1), rgba(168,126,25,1));
  color:#0b0b0b;
  border-color:rgba(212,175,55,.45);
  box-shadow:0 18px 50px rgba(212,175,55,.18);
}
.btn-ghost{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.14);
  color:#fff;
}
.btn-ghost:hover{ border-color:rgba(255,255,255,.24) }

/* Sections */
.section{ padding:76px 0 }
.section-head{ margin-bottom:24px }
.section-kicker{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(212,175,55,.28);
  background:rgba(212,175,55,.10);
  color:var(--brand);
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:11px;
  margin:0 0 12px;
}
.section-title{
  margin:0;
  font-size: clamp(26px, 3.1vw, 40px);
  line-height:1.1;
  font-weight:900;
}
.section-subtitle{
  margin:10px 0 0;
  color:var(--muted);
  font-weight:700;
}

.card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

/* Story */
.story-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:18px;
}
.story-text{ padding:22px }
.story-quote{
  margin:0 0 14px;
  padding:16px 16px;
  border-radius:18px;
  border:1px solid rgba(212,175,55,.22);
  background:rgba(212,175,55,.08);
  color:rgba(255,255,255,.92);
  font-weight:900;
}
.story-paragraph{
  margin:10px 0 0;
  color:rgba(255,255,255,.86);
  font-weight:650;
}
.story-media{
  padding:10px;
  overflow:hidden;
}
.story-photo{
  width:100%;
  height:100%;
  max-height:520px;
  object-fit:cover;
  border-radius: calc(var(--radius) - 8px);
}

/* Owner */
.owner-card{
  display:grid;
  grid-template-columns: .85fr 1.15fr;
  gap:18px;
  padding:14px;
}
.owner-media{
  border-radius: calc(var(--radius) - 8px);
  overflow:hidden;
}
.owner-photo{
  width:100%;
  height:100%;
  min-height:520px;
  object-fit:cover;
}
.owner-content{
  padding:14px 10px 14px 6px;
}
.owner-name{
  margin:4px 0 0;
  font-size:28px;
  font-weight:900;
}
.owner-role{
  margin:6px 0 10px;
  color:var(--muted);
  font-weight:800;
}
.owner-text{
  margin:10px 0 0;
  color:rgba(255,255,255,.86);
  font-weight:650;
}
.owner-quote{
  margin:16px 0 0;
  padding:14px 14px;
  border-radius:18px;
  border:1px solid rgba(212,175,55,.22);
  background:rgba(0,0,0,.28);
  color:#fff;
  font-weight:900;
}

/* Gallery */
.gallery-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
}
.gallery-item{
  position:relative;
  overflow:hidden;
  border-radius:var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  min-height:220px;
}
.gallery-item img{
  width:100%;
  height:260px;
  object-fit:cover;
  filter:saturate(.95) contrast(1.05);
  transform:scale(1.01);
}
.gallery-overlay{
  position:absolute;
  inset:auto 0 0 0;
  padding:14px;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.82));
  display:grid;
  grid-template-columns: 1fr auto;
  grid-template-rows:auto auto;
  gap:6px 10px;
}
.gallery-overlay h3{
  margin:0;
  grid-column:1;
  font-weight:900;
}
.gallery-price{
  margin:0;
  grid-column:1;
  color:rgba(255,255,255,.78);
  font-weight:800;
  font-size:12px;
}
.gallery-add{
  grid-column:2;
  grid-row:1 / span 2;
  width:42px;
  height:42px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(212,175,55,.22);
  color:#fff;
  font-weight:900;
  cursor:pointer;
}
.gallery-add:hover{ background:rgba(212,175,55,.30) }

.gallery-actions{ margin-top:16px; display:flex; justify-content:center }

/* Testimonials */
.testimonials-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
}
.testimonial-card{ padding:18px }
.stars{ color:var(--brand); font-weight:900; letter-spacing:.12em }
.testimonial-text{ margin:10px 0 0; color:rgba(255,255,255,.86); font-weight:650 }
.testimonial-author{ margin-top:12px; display:flex; flex-direction:column; gap:2px; color:var(--muted) }
.testimonial-author strong{ color:#fff }

/* Menu */
.menu-card{
  padding:20px;
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
}
.menu-note{
  width:100%;
  text-align:center;
  margin:8px 0 0;
  color:var(--muted);
  font-weight:800;
}

/* FAQ */
.faq-list{
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;
}
.faq-item{ padding:12px 14px }
.faq-question{
  cursor:pointer;
  font-weight:900;
  letter-spacing:.01em;
}
.faq-answer{
  margin:10px 0 0;
  color:rgba(255,255,255,.82);
  font-weight:650;
}

/* Contact */
.contact-tagline{ max-width:720px }
.active-branch{
  padding:18px;
}
.active-branch-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.active-branch-kicker{
  margin:0;
  color:var(--brand);
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
  font-size:11px;
}
.active-branch-title{
  margin:6px 0 0;
  font-size:20px;
  font-weight:900;
}
.active-branch-actions{
  margin-top:12px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.active-chip{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
}
.active-chip-label{
  font-weight:900;
  color:rgba(255,255,255,.75);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:11px;
}
.active-chip-value{ font-weight:900; color:#fff }
.active-branch-wa{ margin-left:auto }

.active-map{
  margin-top:14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  overflow:hidden;
  background:rgba(0,0,0,.22);
}
.map-load-btn{
  width:100%;
  padding:12px;
  background:rgba(255,255,255,.06);
  border:0;
  color:#fff;
  font-weight:900;
  cursor:pointer;
}
.map-load-btn:hover{ background:rgba(255,255,255,.08) }
.active-map-frame{
  width:100%;
  height:260px;
  border:0;
  display:block;
}

.active-branch-hint{
  margin:12px 0 0;
  color:var(--muted);
  font-weight:800;
}

/* Branch grid */
.branch-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:14px;
}
.branch-card{ padding:16px }
.branch-head{ display:flex; align-items:center; gap:10px }
.pin-ico{ color:var(--brand) }
.branch-title{ margin:0; font-size:18px; font-weight:900 }
.branch-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding-top:10px;
}
.branch-label{ color:var(--muted); font-weight:800 }
.phone-link, .map-btn{
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  font-weight:900;
}
.map-btn:hover, .phone-link:hover{ border-color:rgba(255,255,255,.22) }

.branch-select{
  margin-top:12px;
  width:100%;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(212,175,55,.28);
  background:rgba(212,175,55,.10);
  color:#fff;
  font-weight:900;
  cursor:pointer;
}
.branch-select:hover{ background:rgba(212,175,55,.16) }

/* Contact footer */
.contact-footer{
  margin-top:14px;
  padding:16px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.contact-chip{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
}
.chip-label{ font-weight:900 }
.chip-value{ color:var(--muted); font-weight:800 }

/* Floating WhatsApp */
.whatsapp-fab{
  position:fixed;
  left:18px;
  bottom:18px;
  z-index:60;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:999px;
  background:rgba(0,0,0,.55);
  border:1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
}
.whatsapp-fab:hover{ border-color:rgba(255,255,255,.26) }
.whatsapp-fab-text{ font-weight:900 }

/* Cart FAB */
.cart-fab{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:60;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.55);
  color:#fff;
  cursor:pointer;
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
}
.cart-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:26px;
  height:26px;
  padding:0 8px;
  border-radius:999px;
  background:rgba(212,175,55,.24);
  border:1px solid rgba(212,175,55,.35);
  font-weight:900;
}

/* Cart Modal */
.cart-modal{
  position:fixed;
  inset:0;
  z-index:80;
  display:none;
}
.cart-modal[aria-hidden="false"]{ display:block }
.cart-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.65);
}
.cart-panel{
  position:absolute;
  right:16px;
  top:16px;
  bottom:16px;
  width:min(520px, calc(100% - 32px));
  background:rgba(12,12,12,.94);
  border:1px solid rgba(255,255,255,.14);
  border-radius:22px;
  box-shadow: var(--shadow);
  padding:14px;
  overflow:auto;
}
html[dir="rtl"] .cart-panel{ right:auto; left:16px }

.cart-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding-bottom:8px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.cart-title{ margin:0; font-weight:900 }
.cart-close{
  width:42px; height:42px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#fff;
  cursor:pointer;
  font-size:20px;
}
.cart-close:hover{ border-color:rgba(255,255,255,.24) }

.cart-empty{ color:var(--muted); font-weight:800 }
.cart-items{ list-style:none; padding:0; margin:10px 0 0 }

.cart-note{ margin-top:10px }
.cart-note-label{ display:block; font-weight:900; margin-bottom:6px }
.cart-note-text{
  width:100%;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  color:#fff;
  padding:10px 12px;
  outline:none;
}
.cart-customer{ margin-top:12px; display:grid; gap:12px }
.cart-field-label{ display:block; font-weight:900; margin-bottom:6px }
.cart-field-input, .cart-field-textarea{
  width:100%;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  color:#fff;
  padding:10px 12px;
  outline:none;
}
.cart-summary{
  margin-top:12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 12px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
}
.cart-summary-label{ color:var(--muted); font-weight:900 }
.cart-summary-value{ font-weight:900 }

.cart-actions{
  margin-top:12px;
  display:flex;
  gap:10px;
}
.cart-actions .btn{ flex:1 }
.cart-hint{ margin:10px 0 0; color:var(--muted); font-weight:800 }

/* Toast */
.toast-container{
  position:fixed;
  inset:auto 18px 86px 18px;
  z-index:90;
  display:grid;
  gap:10px;
  pointer-events:none;
}

/* Loader */
.page-loader{
  position:fixed;
  inset:0;
  z-index:120;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.55);
}
.page-loader.show{ display:flex }
.loader-spinner{
  width:48px;
  height:48px;
  border-radius:999px;
  border:3px solid rgba(255,255,255,.16);
  border-top-color: var(--brand);
  animation:spin .85s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg) } }

/* RTL tweaks */
html[dir="rtl"] .nav{ text-transform:none; letter-spacing:0 }
html[dir="rtl"] .section-kicker{ letter-spacing:.06em }
html[dir="rtl"] .hero-title{ text-transform:none }
html[dir="rtl"] .warning-text{ text-transform:none; letter-spacing:0 }
html[dir="rtl"] .active-branch-kicker{ text-transform:none }

/* Responsive */
@media (max-width: 1100px){
  .gallery-grid{ grid-template-columns: repeat(2, 1fr) }
  .testimonials-grid{ grid-template-columns: 1fr }
}
@media (max-width: 980px){
  .story-grid{ grid-template-columns: 1fr }
  .owner-card{ grid-template-columns: 1fr; padding:12px }
  .owner-photo{ min-height:420px }
  .branch-grid{ grid-template-columns: 1fr }
  .hero{ min-height:86vh }
}
@media (max-width: 520px){
  .container{ width: min(var(--container), calc(100% - 28px)) }
  .hero-title{ font-size: 30px }
  .logo-img{ width:110px; height:40px }
  .whatsapp-fab, .cart-fab{ left:12px; right:12px }
  .whatsapp-fab{ left:12px; right:auto }
  .cart-fab{ right:12px; left:auto }
}
