@import url('https://fonts.googleapis.com/css2?family=Tajawal:wght@400;500;700;800;900&display=swap');

/* ============ Reset & Base ============ */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Tajawal',Tahoma,Arial,sans-serif;
  background:#faf6ec;
  color:#1a2e24;
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit}

/* ============ Decorative dagger signature (خنجر الشعار) ============ */
.section-title{position:relative;text-align:center;margin-bottom:48px;padding-top:6px}
.section-title:before{
  content:"";
  display:block;
  width:64px;height:24px;
  margin:0 auto 14px;
  background-image:url("/img/dagger-icon.png");
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  opacity:.92;
}
.section-title span{
  display:inline-block;
  color:#b9852a;
  font-weight:800;
  font-size:14px;
  letter-spacing:.5px;
}
.section-title h2{
  font-size:clamp(28px,4vw,42px);
  color:#0c3d2e;
  margin-top:8px;
  font-weight:900;
}

/* ============ Header / Topbar ============ */
.topbar{
  position:fixed;
  top:0;right:0;left:0;
  z-index:50;
  background:rgba(6,35,26,.94);
  color:#fff;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:14px 40px;
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(212,169,66,.3);
  gap:16px;
}
.brand{display:flex;gap:14px;align-items:center;flex-shrink:0}
.logo{
  width:50px;height:50px;
  border-radius:50%;
  overflow:hidden;
  background:linear-gradient(135deg,#d4a942,#f7d36f);
  color:#06231a;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;font-weight:900;
  flex-shrink:0;
}
.logo img{width:100%;height:100%;object-fit:cover}
.brand h1{font-size:21px;font-weight:800;color:#fff;white-space:nowrap}
.brand p{font-size:12.5px;color:#d9c896;margin-top:2px;white-space:nowrap}

/* النافيجيشن بسطر واحد دائمًا: بدون التواء (wrap)، وقابل للتمرير الأفقي
   فقط إذا ضاقت الشاشة جدًا بحيث لا تتسع الروابط، بدل أن تنكسر لسطر ثاني */
nav{
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  gap:2px;
  overflow-x:auto;
  scrollbar-width:none;
  -ms-overflow-style:none;
  max-width:100%;
  position:relative;
}
nav::-webkit-scrollbar{display:none}
/* تلميح بصري خفيف (تظليل) عند يسار النافيجيشن يلمح بوجود روابط إضافية قابلة للتمرير على الشاشات الضيقة */
.topbar{position:fixed;top:0;right:0;left:0;z-index:50}
.topbar nav{mask-image:linear-gradient(to left, transparent 0, #000 18px, #000 calc(100% - 18px), transparent 100%);}
nav a{
  color:#eef2ee;
  text-decoration:none;
  margin:0 4px;
  padding:8px 14px;
  font-weight:700;
  font-size:14.5px;
  border-radius:30px;
  transition:.25s;
  white-space:nowrap;
  flex-shrink:0;
}
nav a:hover{
  color:#06231a;
  background:#d4a942;
}

/* ============ Hero ============ */
.hero{
  min-height:100vh;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#fff;
  overflow:hidden;
  padding:140px 20px 70px;
  background:
    linear-gradient(180deg,rgba(6,28,21,.55),rgba(5,20,15,.88)),
    linear-gradient(135deg,#0c3d2e,#06231a);
  background-size:cover;
  background-position:center;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero:before{
  content:"";
  position:absolute;inset:-30%;
  background:radial-gradient(circle,rgba(212,169,66,.16),transparent 60%);
  animation:wave 9s ease-in-out infinite alternate;
  z-index:0;
  pointer-events:none;
}
.hero-content{
  position:relative;
  z-index:1;
  max-width:880px;
  animation:fadeUp 1.2s ease forwards;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#f7d36f;
  border:1px solid rgba(247,211,111,.55);
  padding:9px 24px;
  border-radius:30px;
  margin-bottom:22px;
  font-size:14.5px;
  font-weight:700;
  background:rgba(247,211,111,.06);
}
.hero h2{
  font-size:clamp(36px,6.5vw,66px);
  font-weight:900;
  color:#fff;
  text-shadow:0 10px 30px rgba(0,0,0,.5);
  margin-bottom:10px;
  letter-spacing:-.5px;
}
.hero h3{
  font-size:clamp(19px,2.6vw,30px);
  color:#f7d36f;
  font-weight:700;
  margin-bottom:22px;
}
.hero p{
  font-size:clamp(15px,1.6vw,19px);
  line-height:2;
  max-width:740px;
  margin:0 auto;
  color:#ecf3ee;
}
.actions{margin-top:34px;display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:16px 36px;
  border-radius:50px;
  text-decoration:none;
  font-weight:800;
  font-size:15.5px;
  transition:.3s;
}
.btn.primary{
  background:linear-gradient(135deg,#d4a942,#f7d36f);
  color:#06231a;
  box-shadow:0 12px 30px rgba(212,169,66,.35);
}
.btn.primary:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(212,169,66,.45)}
.btn.secondary{
  background:rgba(255,255,255,.08);
  color:#fff;
  border:1.5px solid rgba(255,255,255,.5);
}
.btn.secondary:hover{background:#fff;color:#06231a}

/* ============ Generic Section ============ */
.section{padding:96px 32px}

/* ============ About ============ */
.about{
  max-width:880px;
  margin:0 auto;
  text-align:center;
}
.about p{
  font-size:clamp(16px,1.8vw,19px);
  line-height:2.1;
  color:#2c3f33;
}

/* ============ Services ============ */
.services{
  background:linear-gradient(160deg,#06231a,#0c3d2e);
  color:#fff;
}
.services .section-title h2{color:#fff}
.services .section-title span{color:#f7d36f}
.service-grid{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:24px;
}
.service-card{
  background:rgba(255,255,255,.04);
  color:#fff;
  border-radius:22px;
  padding:36px 24px;
  text-align:center;
  border:1px solid rgba(212,169,66,.28);
  transition:.35s;
}
.service-card:hover{
  transform:translateY(-8px);
  background:rgba(255,255,255,.07);
  border-color:rgba(212,169,66,.55);
}
.service-card .icon{
  width:64px;height:64px;
  background:linear-gradient(135deg,#d4a942,#f7d36f);
  color:#06231a;
  border-radius:50%;
  margin:0 auto 18px;
  display:flex;align-items:center;justify-content:center;
  font-size:30px;
}
.service-card h3{font-size:21px;margin-bottom:10px;font-weight:800;color:#f7d36f}
.service-card p{line-height:1.8;color:#cfe0d6;font-size:14.5px}

/* ============ Gallery ============ */
.gallery-section{background:#faf6ec}
.gallery{
  max-width:1240px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(290px,1fr));
  gap:26px;
  align-items:start;
}
.empty-gallery{
  grid-column:1/-1;
  text-align:center;
  padding:48px;
  background:#fff;
  border-radius:20px;
  color:#8a8276;
  border:1px dashed #d9c8a0;
}

/* slider */
.pro-slider{
  grid-column:1/-1;
  position:relative;
  height:460px;
  border-radius:26px;
  overflow:hidden;
  isolation:isolate;
  margin-bottom:6px;
  background:#06231a;
  box-shadow:0 20px 48px rgba(6,35,26,.25);
}
.pro-slider .slide{
  position:absolute;inset:0;
  opacity:0;
  pointer-events:none;
  z-index:0;
  transition:opacity .8s ease;
}
.pro-slider .slide.active{opacity:1;pointer-events:auto;z-index:1}
.pro-slider .slide img{
  position:relative;
  width:100%;height:100%;
  object-fit:cover;
  z-index:0;
}
.pro-slider .slide::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(6,35,26,.85),rgba(6,35,26,.4),rgba(0,0,0,.1));
  pointer-events:none;
  z-index:1;
}
.pro-slider .slide-caption{
  position:absolute;
  right:32px;bottom:55px;
  max-width:520px;
  background:rgba(6,35,26,.7);
  color:#fff;
  padding:24px;
  border-radius:18px;
  border:1px solid rgba(212,169,66,.4);
  z-index:3;
  backdrop-filter:blur(4px);
}
.pro-slider .slide-caption span{
  display:inline-block;
  margin-bottom:8px;
  color:#f7d36f;
  font-weight:800;
  font-size:14px;
}
.pro-slider .slide-caption h3{margin:0 0 8px;color:#f7d36f;font-size:26px;font-weight:800}
.pro-slider .slide-caption p{margin:0;line-height:1.8;color:#fff;font-size:15px}

.slider-arrow{
  position:absolute;top:50%;
  transform:translateY(-50%);
  z-index:3;
  width:44px;height:44px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.4);
  background:rgba(6,35,26,.55);
  color:#fff;
  font-size:30px;
  line-height:1;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:.25s;
}
.slider-arrow:hover{background:#d4a942;color:#06231a;border-color:#d4a942}
.slider-arrow.prev{right:18px}
.slider-arrow.next{left:18px}
.slider-dots{
  position:absolute;left:0;right:0;bottom:18px;
  z-index:3;
  display:flex;justify-content:center;gap:8px;
}
.slider-dots button{
  width:9px;height:9px;
  border-radius:50%;
  border:0;
  background:rgba(255,255,255,.4);
  cursor:pointer;
  transition:.25s;
}
.slider-dots button.active{width:26px;border-radius:20px;background:#f7d36f}

/* photo cards */
.photo-card{
  height:auto;
  background:#0c1f17;
  border:1px solid rgba(212,169,66,.22);
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 16px 36px rgba(6,35,26,.18);
  transition:.3s;
}
.photo-card:hover{transform:translateY(-6px)}
.photo-card img{
  width:100%;
  height:230px;
  object-fit:cover;
  transition:.5s;
}
.photo-card:hover img{transform:scale(1.06)}
.photo-info{padding:22px 24px 26px;text-align:right;background:#0c1f17}
.photo-info h3{margin:0 0 10px;color:#f0b24a;font-size:21px;font-weight:800}
.photo-info p{margin:0;color:#d9c8a0;font-size:14.5px;line-height:1.85}

/* ============ Booking ============ */
.booking{
  background:linear-gradient(160deg,#f4ecd6,#faf6ec);
  padding:90px 32px;
}
.booking-form{
  max-width:680px;
  margin:0 auto;
  display:grid;
  gap:16px;
  background:#fff;
  padding:34px;
  border-radius:26px;
  box-shadow:0 22px 50px rgba(6,35,26,.1);
  border:1px solid #eadfbe;
}
.booking-form input,
.booking-form select,
.booking-form textarea{
  width:100%;
  height:50px;
  padding:0 16px;
  border:1px solid #dccfa6;
  border-radius:13px;
  font-size:15px;
  font-family:'Tajawal',Tahoma,sans-serif;
  background:#fdfbf4;
  transition:.2s;
}
.booking-form input:focus,
.booking-form select:focus,
.booking-form textarea:focus{
  outline:none;
  border-color:#d4a942;
  background:#fff;
  box-shadow:0 0 0 3px rgba(212,169,66,.15);
}
.booking-form textarea{height:110px;padding-top:14px;resize:vertical}
.booking-form select{
  direction:rtl;
  text-align:right;
  text-align-last:right;
  padding-left:40px;
  appearance:auto;
  cursor:pointer;
}
.booking-form button{
  background:linear-gradient(135deg,#0c3d2e,#06231a);
  color:#fff;
  border:0;
  height:54px;
  border-radius:13px;
  font-size:17px;
  font-weight:800;
  font-family:'Tajawal',Tahoma,sans-serif;
  cursor:pointer;
  transition:.25s;
}
.booking-form button:hover{
  background:linear-gradient(135deg,#0f5742,#0c3d2e);
  transform:translateY(-1px);
}

.event-types{
  border:1px solid #e0d3a8;
  border-radius:16px;
  padding:18px 20px;
  background:#fdfbf4;
}
.event-title{
  display:block;
  margin-bottom:12px;
  color:#0c3d2e;
  font-weight:800;
  font-size:15.5px;
}
.event-title span{color:#b5302f}
.event-types label:not(.event-title){
  display:flex;
  align-items:center;
  gap:10px;
  margin:10px 0;
  font-size:15.5px;
  color:#2c3f33;
  cursor:pointer;
}
.event-types input[type="radio"]{
  width:18px;height:18px;
  accent-color:#d4a942;
  cursor:pointer;
}

.event-day-name{
  margin:-4px 4px 2px;
  color:#0c3d2e;
  font-weight:800;
  font-size:14.5px;
}
.date-booking-status{
  margin:-4px 4px 2px;
  font-weight:800;
  font-size:14.5px;
}
.date-booking-status.busy{color:#b42318}
.date-booking-status.pending{color:#b7791f}

/* ============ Footer ============ */
footer{
  background:#06231a;
  color:#fff;
  text-align:center;
  padding:44px 20px 36px;
  position:relative;
}
footer:before{
  content:"";
  display:block;
  width:58px;height:22px;
  margin:0 auto 20px;
  background-image:url("/img/dagger-icon.png");
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  opacity:1;
}
footer h3{font-size:25px;margin-bottom:10px;color:#f7d36f;font-weight:800}
footer p{color:#cfe0d6;font-size:14.5px}

/* صف روابط التواصل الاجتماعي (واتساب + سناب شات + تيك توك) */
footer .social-links{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:18px;
}
footer .social-links a{
  color:#f7d36f;
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-top:0;
  text-decoration:none;
  font-weight:800;
  font-size:14.5px;
  padding:10px 22px;
  border:1px solid rgba(247,211,111,.4);
  border-radius:30px;
  transition:.25s;
}
footer .social-links a:hover{background:#f7d36f;color:#06231a}

/* ============ Animations ============ */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(40px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes wave{
  from{transform:translateY(-15px) rotate(0deg)}
  to{transform:translateY(15px) rotate(5deg)}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important}
}

/* ============ Responsive: Tablet ============ */
@media(max-width:900px){
  .topbar{padding:12px 20px}
  nav a{font-size:13.5px;padding:7px 10px}
  .section{padding:70px 24px}
}

/* ============ Responsive: Mobile ============ */
@media(max-width:700px){
  .topbar{
    flex-wrap:nowrap;
    gap:6px;
    padding:10px 10px;
  }
  .brand h1{font-size:12.5px}
  .brand p{display:none}
  .brand{gap:5px}
  .logo{width:30px;height:30px;font-size:14px;flex-shrink:0}

  /* على الموبايل: نخفي النص الفرعي لتحرير مساحة كافية تتسع لكل روابط النافيجيشن بسطر واحد دون قطع */
  nav{gap:0;justify-content:flex-start}
  nav a{margin:0;padding:6px 3px;font-size:10.5px}

  .hero{min-height:92vh;padding:150px 18px 60px}
  .hero h2{font-size:34px}
  .hero h3{font-size:18px}
  .hero p{font-size:15px}
  .actions{flex-direction:column;align-items:center;width:100%}
  .btn{width:100%;max-width:300px;justify-content:center}

  .section{padding:56px 18px}
  .section-title h2{font-size:26px}

  .service-grid{grid-template-columns:1fr 1fr;gap:14px}
  .service-card{padding:24px 14px}
  .service-card .icon{width:54px;height:54px;font-size:24px}
  .service-card h3{font-size:17px}
  .service-card p{font-size:13px}

  .gallery{grid-template-columns:1fr;gap:18px}
  .pro-slider{height:300px;border-radius:18px}
  .pro-slider .slide-caption{right:14px;left:14px;bottom:44px;padding:16px}
  .pro-slider .slide-caption h3{font-size:19px}
  .pro-slider .slide-caption p{font-size:13.5px}
  .slider-arrow{width:36px;height:36px;font-size:24px}
  .photo-card img{height:200px}

  .booking{padding:56px 16px}
  .booking-form{padding:22px;border-radius:20px}
  .booking-form button{height:50px;font-size:15.5px}

  footer h3{font-size:21px}
  footer .social-links{gap:8px}
  footer .social-links a{padding:9px 16px;font-size:13px}
}

@media(max-width:380px){
  .service-grid{grid-template-columns:1fr}
  .brand h1{font-size:11px}
  .logo{width:24px;height:24px;font-size:12px}
  nav a{padding:5px 1px;font-size:9px;margin:0}
}
