/* ─── Reset & Base ─────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:18px;scroll-behavior:smooth}
body{
  font-family:'Tajawal',sans-serif;
  background:#f0f4ff;
  color:#0f172a;
  overflow-x:hidden;
  direction:rtl;
}

/* ─── CSS Variables ────────────────────────── */
:root{
  --blue:#0039b1;
  --blue-dark:#002780;
  --blue-mid:#0052cc;
  --blue-light:#d7e6fc;
  --blue-xlight:#eef4ff;
  --navy:#040e2b;
  --navy-mid:#0a1f5c;
  --gold:#f5a623;
  --green:#00b87c;
  --white:#ffffff;
  --text:#0f172a;
  --text-mid:#334155;
  --text-light:#64748b;
  --radius:20px;
  --radius-lg:32px;
  --shadow:0 8px 40px rgba(0,57,177,0.12);
  --shadow-lg:0 20px 80px rgba(0,57,177,0.18);
  --transition:all 0.35s cubic-bezier(0.4,0,0.2,1);
}

/* ─── Utilities ─────────────────────────────── */
.container{max-width:1380px;margin:0 auto;padding:0 28px}
.section{padding:100px 0}
.section-sm{padding:70px 0}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 36px;border-radius:50px;font-family:inherit;
  font-size:1rem;font-weight:700;cursor:pointer;border:none;
  transition:var(--transition);text-decoration:none;
  white-space:nowrap;
}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,57,177,.35)}
.btn-white{background:#fff;color:var(--blue)}
.btn-white:hover{background:var(--blue-light);transform:translateY(-3px)}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5)}
.btn-outline:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:#009966;transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,184,124,.35)}

.tag{
  display:inline-block;padding:5px 16px;border-radius:50px;
  font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
}
.tag-blue{background:var(--blue-light);color:var(--blue)}
.tag-gold{background:#fff3d6;color:#c57900}

/* ─── Animations ────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes shimmer{0%{background-position:200% center}100%{background-position:-200% center}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes ripple{0%{transform:scale(1);opacity:1}100%{transform:scale(2.5);opacity:0}}
@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

.anim-fadeUp{animation:fadeUp .8s ease both}
.anim-delay-1{animation-delay:.1s}
.anim-delay-2{animation-delay:.2s}
.anim-delay-3{animation-delay:.3s}
.anim-delay-4{animation-delay:.4s}
.anim-delay-5{animation-delay:.5s}

/* ─── TOP BAR ───────────────────────────────── */
.topbar{
  background:var(--navy);color:rgba(255,255,255,.75);
  font-size:.82rem;padding:10px 0;
}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.topbar-links{display:flex;gap:20px;align-items:center}
.topbar-links a{color:rgba(255,255,255,.75);text-decoration:none;transition:color .2s;display:flex;align-items:center;gap:6px}
.topbar-links a:hover{color:#fff}
.topbar-rating{display:flex;align-items:center;gap:8px;font-size:.82rem}
.stars{color:var(--gold);letter-spacing:2px;font-size:.9rem}

/* ─── HEADER ─────────────────────────────────── */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(0,57,177,.1);
  box-shadow:0 4px 30px rgba(0,57,177,.08);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:24px}
.logo{
  font-family:'Cairo',sans-serif;
  font-size:1.5rem;font-weight:900;
  color:var(--blue);text-decoration:none;
  display:flex;align-items:center;gap:12px;
  white-space:nowrap;
}
.logo-icon{
  width:46px;height:46px;background:var(--blue);border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;color:#fff;flex-shrink:0;
}
nav{display:flex;align-items:center;gap:6px}
nav a{
  padding:9px 18px;border-radius:50px;font-size:.95rem;font-weight:600;
  color:var(--text-mid);text-decoration:none;transition:var(--transition);
}
nav a:hover{background:var(--blue-xlight);color:var(--blue)}
nav a.active{background:var(--blue);color:#fff}
.header-cta{display:flex;align-items:center;gap:12px;flex-shrink:0;max-width:100%;}
.phone-btn{
  display:flex;align-items:center;gap:8px;
  padding:11px 22px;background:var(--blue-xlight);
  color:var(--blue);border-radius:50px;font-weight:700;
  text-decoration:none;font-size:.95rem;transition:var(--transition);
}
.phone-btn:hover{background:var(--blue);color:#fff}
.menu-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.menu-toggle span{display:block;width:26px;height:2px;background:var(--blue);border-radius:2px;transition:.3s}

/* ─── HERO ──────────────────────────────────── */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 40%,#0a3499 100%);
  background-size:200% 200%;
  animation:gradientShift 8s ease infinite;
  min-height:90vh;display:flex;align-items:center;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 60% at 70% 50%,rgba(0,82,204,.4) 0%,transparent 70%);
}
.hero-grid{
  display:grid;grid-template-columns:1fr 480px;
  gap:60px;align-items:center;position:relative;z-index:2;padding:80px 0;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  border-radius:50px;padding:8px 20px;margin-bottom:28px;
  backdrop-filter:blur(10px);
}
.hero-badge-dot{
  width:8px;height:8px;background:var(--green);
  border-radius:50%;animation:pulse 2s infinite;
}
.hero-badge span{color:rgba(255,255,255,.9);font-size:.85rem;font-weight:600}
h1.hero-title{
  font-family:'Cairo',sans-serif;
  font-size:clamp(2.2rem,4.5vw,3.8rem);
  font-weight:900;line-height:1.2;
  color:#fff;margin-bottom:24px;
}
h1.hero-title em{
  font-style:normal;
  background:linear-gradient(90deg,#60a5fa,var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.hero-desc{
  font-size:1.15rem;color:rgba(255,255,255,.75);
  line-height:1.8;margin-bottom:40px;max-width:560px;
}
.hero-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:50px}
.hero-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.stat-card{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);padding:20px;backdrop-filter:blur(10px);
  transition:var(--transition);
}
.stat-card:hover{background:rgba(255,255,255,.14);transform:translateY(-4px)}
.stat-num{
  font-family:'Cairo',sans-serif;font-size:2rem;font-weight:900;
  color:#fff;display:block;margin-bottom:4px;
}
.stat-label{color:rgba(255,255,255,.65);font-size:.85rem}

/* Hero Visual */
.hero-visual{position:relative}
.hero-card-main{
  background:rgba(255,255,255,.95);border-radius:var(--radius-lg);
  padding:36px;box-shadow:0 30px 100px rgba(0,0,0,.3);
  animation:float 4s ease-in-out infinite;
  backdrop-filter:blur(20px);
}
.hero-card-main h3{
  font-family:'Cairo',sans-serif;font-size:1.3rem;font-weight:700;
  color:var(--navy);margin-bottom:6px;
}
.hero-card-main p{color:var(--text-light);font-size:.9rem;margin-bottom:24px}
.form-row{display:flex;flex-direction:column;gap:14px}
.form-group{position:relative}
.form-group input,.form-group select{
  width:100%;padding:14px 18px;border:2px solid #e2e8f0;
  border-radius:14px;font-family:inherit;font-size:.95rem;
  color:var(--text);background:#fff;transition:var(--transition);
  outline:none;
}
.form-group input:focus,.form-group select:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,57,177,.1)}
.form-group input::placeholder{color:#94a3b8}
.hero-card-badge{
  position:absolute;top:-18px;left:-18px;
  background:var(--green);color:#fff;border-radius:50px;
  padding:10px 20px;font-size:.85rem;font-weight:700;
  box-shadow:0 8px 30px rgba(0,184,124,.4);
  white-space:nowrap;
}
.hero-card-rating{
  display:flex;align-items:center;gap:10px;
  background:#fffbeb;border-radius:12px;padding:12px 16px;margin-top:14px;
}
.hero-rating-text{font-size:.85rem;color:var(--text-mid)}
.hero-rating-text strong{color:var(--text);font-size:1rem}

/* Floating elements */
.float-el{
  position:absolute;border-radius:var(--radius);
  padding:14px 18px;font-size:.85rem;font-weight:700;
  backdrop-filter:blur(16px);white-space:nowrap;
  animation:float 3s ease-in-out infinite;
}
.float-el-1{
  background:#00b87c;border:none;
  color:#fff;top:-14px;left:12px;right:auto;transform:none;
  animation-delay:.5s;box-shadow:0 4px 20px rgba(0,184,124,.5);
  font-size:.82rem;font-weight:700;padding:9px 18px;
  border-radius:50px;
}
.float-el-2{
  background:rgba(0,184,124,.9);color:#fff;
  bottom:15%;right:-20px;animation-delay:1s;box-shadow:0 8px 30px rgba(0,184,124,.4);
}

/* ─── SERVICES ──────────────────────────────── */
.services{background:#fff}
.section-header{text-align:center;margin-bottom:64px}
.section-header .tag{margin-bottom:16px}
.section-header h2{
  font-family:'Cairo',sans-serif;
  font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-weight:900;color:var(--navy);margin-bottom:16px;line-height:1.2;
}
.section-header p{color:var(--text-light);font-size:1.05rem;max-width:600px;margin:0 auto;line-height:1.7}

.services-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:24px;
}
.service-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:#fff;border:1px solid #e2e8f0;
  transition:var(--transition);cursor:pointer;
  group:hover;
}
.service-card:hover{
  transform:translateY(-8px);border-color:var(--blue);
  box-shadow:var(--shadow-lg);
}
.service-card-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);
  opacity:0;transition:var(--transition);
}
.service-card:hover .service-card-bg{opacity:1}
.service-card-inner{
  position:relative;z-index:1;
  padding:36px 28px;display:flex;flex-direction:column;gap:18px;
  height:100%;
}
.service-icon{
  width:64px;height:64px;border-radius:18px;
  background:var(--blue-xlight);display:flex;align-items:center;
  justify-content:center;font-size:2rem;
  transition:var(--transition);
}
.service-card:hover .service-icon{background:rgba(255,255,255,.15)}
.service-name{
  font-family:'Cairo',sans-serif;font-size:1.2rem;font-weight:700;
  color:var(--navy);transition:var(--transition);
}
.service-card:hover .service-name{color:#fff}
.service-desc{
  color:var(--text-light);font-size:.9rem;line-height:1.7;
  flex:1;transition:var(--transition);
}
.service-card:hover .service-desc{color:rgba(255,255,255,.8)}
.service-link{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--blue);font-weight:700;font-size:.9rem;
  text-decoration:none;transition:var(--transition);
  margin-top:auto;
}
.service-card:hover .service-link{color:#fff}

/* ─── WHY US ─────────────────────────────────── */
.why-us{
  background:linear-gradient(160deg,var(--navy) 0%,#0a2a7a 50%,var(--navy-mid) 100%);
  position:relative;overflow:hidden;
}
.why-us::before{
  content:'';position:absolute;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,82,204,.3) 0%,transparent 70%);
  top:-200px;left:-200px;
}
.why-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}
.why-content h2{
  font-family:'Cairo',sans-serif;font-size:clamp(1.8rem,3vw,2.6rem);
  font-weight:900;color:#fff;margin-bottom:20px;line-height:1.2;
}
.why-content p{color:rgba(255,255,255,.7);font-size:1.05rem;line-height:1.8;margin-bottom:40px}
.why-features{display:flex;flex-direction:column;gap:20px}
.why-feature{
  display:flex;align-items:flex-start;gap:16px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);padding:20px;
  transition:var(--transition);
}
.why-feature:hover{background:rgba(255,255,255,.1);transform:translateX(-6px)}
.why-feature-icon{
  width:50px;height:50px;border-radius:14px;
  background:var(--blue);display:flex;align-items:center;
  justify-content:center;font-size:1.4rem;flex-shrink:0;
}
.why-feature-text h4{color:#fff;font-weight:700;margin-bottom:4px;font-size:1rem}
.why-feature-text p{color:rgba(255,255,255,.65);font-size:.9rem;line-height:1.5}

.guarantee-card{
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius-lg);padding:48px;backdrop-filter:blur(10px);
  text-align:center;position:relative;overflow:hidden;
}
.guarantee-card::before{
  content:'';position:absolute;top:-50px;right:-50px;
  width:200px;height:200px;border-radius:50%;
  background:rgba(0,184,124,.1);
}
.guarantee-num{
  font-family:'Cairo',sans-serif;
  font-size:5rem;font-weight:900;
  background:linear-gradient(135deg,#fff,var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  line-height:1;margin-bottom:8px;
}
.guarantee-title{color:#fff;font-size:1.4rem;font-weight:700;margin-bottom:12px}
.guarantee-desc{color:rgba(255,255,255,.65);line-height:1.7;font-size:.95rem;margin-bottom:32px}
.guarantee-badges{display:flex;flex-direction:column;gap:12px}
.g-badge{
  display:flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.08);border-radius:12px;padding:14px 18px;
}
.g-badge-icon{font-size:1.3rem}
.g-badge-text{color:rgba(255,255,255,.85);font-size:.9rem;font-weight:600}

/* ─── CITIES ─────────────────────────────────── */
.cities{background:var(--blue-xlight)}
.cities-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:20px;
}
.city-card{
  background:#fff;border-radius:var(--radius);padding:28px 20px;
  text-align:center;transition:var(--transition);
  border:2px solid transparent;cursor:pointer;
  box-shadow:0 2px 20px rgba(0,57,177,.08);
}
.city-card:hover{
  border-color:var(--blue);transform:translateY(-6px);
  box-shadow:var(--shadow);
}
.city-icon{font-size:2.5rem;margin-bottom:12px;display:block}
.city-name{
  font-family:'Cairo',sans-serif;font-size:1.1rem;font-weight:700;
  color:var(--navy);margin-bottom:6px;
}
.city-count{color:var(--text-light);font-size:.85rem}

/* ─── PROCESS ─────────────────────────────────── */
.process{background:#fff}
.process-steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  position:relative;
}
.process-steps::before{
  content:'';position:absolute;top:48px;right:12%;left:12%;
  height:2px;background:linear-gradient(90deg,var(--blue-light),var(--blue));
  z-index:0;
}
.step{text-align:center;position:relative;z-index:1;padding:0 16px}
.step-num{
  width:96px;height:96px;border-radius:50%;margin:0 auto 24px;
  background:linear-gradient(135deg,var(--blue),var(--blue-mid));
  display:flex;align-items:center;justify-content:center;
  font-family:'Cairo',sans-serif;font-size:2rem;font-weight:900;
  color:#fff;box-shadow:0 8px 30px rgba(0,57,177,.35);
  position:relative;
}
.step-num::before{
  content:'';position:absolute;inset:-6px;border-radius:50%;
  border:2px solid var(--blue-light);
}
.step h3{font-size:1.1rem;font-weight:700;color:var(--navy);margin-bottom:10px}
.step p{color:var(--text-light);font-size:.9rem;line-height:1.6}

/* ─── TESTIMONIALS ───────────────────────────── */
.testimonials{background:linear-gradient(180deg,#f0f4ff 0%,#fff 100%)}
.reviews-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:24px;
}
.review-card{
  background:#fff;border-radius:var(--radius-lg);padding:32px;
  border:1px solid #e2e8f0;transition:var(--transition);
  box-shadow:0 2px 20px rgba(0,57,177,.05);
}
.review-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.review-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.reviewer-info{display:flex;align-items:center;gap:12px}
.reviewer-avatar{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--blue-mid));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:1.2rem;
  font-family:'Cairo',sans-serif;
}
.reviewer-name{font-weight:700;color:var(--navy);font-size:.95rem}
.reviewer-city{color:var(--text-light);font-size:.82rem;margin-top:2px}
.review-stars{color:var(--gold);font-size:1rem;letter-spacing:2px}
.review-text{color:var(--text-mid);font-size:.92rem;line-height:1.75}
.review-date{color:var(--text-light);font-size:.8rem;margin-top:12px}

/* Rating Summary */
.rating-summary{
  display:grid;grid-template-columns:auto 1fr;gap:40px;
  background:var(--blue);border-radius:var(--radius-lg);padding:48px;
  margin-bottom:48px;align-items:center;
}
.rating-big{text-align:center}
.rating-score{
  font-family:'Cairo',sans-serif;font-size:5rem;font-weight:900;
  color:#fff;line-height:1;
}
.rating-stars-big{color:var(--gold);font-size:1.5rem;letter-spacing:4px;margin:8px 0}
.rating-count{color:rgba(255,255,255,.75);font-size:.9rem}
.rating-bars{display:flex;flex-direction:column;gap:10px}
.rating-bar-row{display:flex;align-items:center;gap:12px}
.rating-bar-label{color:rgba(255,255,255,.8);font-size:.85rem;min-width:50px;font-weight:600}
.rating-bar-track{flex:1;height:8px;background:rgba(255,255,255,.15);border-radius:50px}
.rating-bar-fill{height:100%;border-radius:50px;background:var(--gold)}
.rating-bar-pct{color:rgba(255,255,255,.75);font-size:.82rem;min-width:36px;text-align:left}

/* ─── FAQ ────────────────────────────────────── */
.faq{background:var(--blue-xlight)}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.faq-item{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  border:1px solid #e2e8f0;transition:var(--transition);
}
.faq-item:hover{box-shadow:var(--shadow);border-color:var(--blue-light)}
.faq-question{
  padding:24px 28px;display:flex;align-items:center;
  justify-content:space-between;cursor:pointer;gap:16px;
}
.faq-q-text{font-weight:700;color:var(--navy);font-size:1rem;line-height:1.4}
.faq-toggle{
  width:32px;height:32px;border-radius:50%;background:var(--blue-xlight);
  display:flex;align-items:center;justify-content:center;
  color:var(--blue);font-size:1.2rem;flex-shrink:0;
  transition:var(--transition);font-weight:700;
}
.faq-item.open .faq-toggle{background:var(--blue);color:#fff;transform:rotate(45deg)}
.faq-answer{
  height:0;overflow:hidden;transition:height .35s ease;
  padding:0 28px;color:var(--text-mid);font-size:.93rem;line-height:1.75;
}
.faq-item.open .faq-answer{height:auto;padding:0 28px 24px}

/* ─── CONTACT ─────────────────────────────────── */
.contact{background:#fff}
.contact-grid{
  display:grid;grid-template-columns:1fr 500px;gap:60px;align-items:start;
}
.contact-info h2{
  font-family:'Cairo',sans-serif;font-size:clamp(1.8rem,3vw,2.4rem);
  font-weight:900;color:var(--navy);margin-bottom:16px;line-height:1.2;
}
.contact-info p{color:var(--text-light);font-size:1rem;line-height:1.8;margin-bottom:36px}
.contact-methods{display:flex;flex-direction:column;gap:16px;margin-bottom:40px}
.contact-method{
  display:flex;align-items:center;gap:16px;
  background:var(--blue-xlight);border-radius:var(--radius);padding:20px;
  text-decoration:none;transition:var(--transition);
}
.contact-method:hover{background:var(--blue-light);transform:translateX(-6px)}
.contact-method-icon{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;flex-shrink:0;
}
.cm-phone .contact-method-icon{background:var(--blue);color:#fff}
.cm-whatsapp .contact-method-icon{background:var(--green);color:#fff}
.cm-email .contact-method-icon{background:#6366f1;color:#fff}
.contact-method-info{}
.contact-method-label{color:var(--text-light);font-size:.82rem;margin-bottom:3px}
.contact-method-value{color:var(--navy);font-weight:700;font-size:1rem}

.contact-form-card{
  background:#fff;border:2px solid #e2e8f0;
  border-radius:var(--radius-lg);padding:40px;
  box-shadow:var(--shadow);
  position:sticky;top:100px;
}
.contact-form-card h3{
  font-family:'Cairo',sans-serif;font-size:1.4rem;font-weight:700;
  color:var(--navy);margin-bottom:6px;
}
.contact-form-card p{color:var(--text-light);font-size:.9rem;margin-bottom:28px}
.form-field{margin-bottom:18px}
.form-field label{display:block;font-weight:600;color:var(--text);font-size:.92rem;margin-bottom:8px}
.form-field input,.form-field select,.form-field textarea{
  width:100%;padding:14px 18px;border:2px solid #e2e8f0;
  border-radius:14px;font-family:inherit;font-size:.95rem;
  color:var(--text);background:#fff;outline:none;
  transition:var(--transition);resize:vertical;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,57,177,.1);
}
.form-field textarea{height:110px}
.form-success{
  display:none;background:#f0fdf4;border:2px solid #86efac;
  border-radius:14px;padding:20px;text-align:center;margin-top:16px;
}
.form-success.show{display:block}
.form-success h4{color:#15803d;font-weight:700;margin-bottom:6px}
.form-success p{color:#166534;font-size:.9rem}

/* ─── REQUEST TYPE TABS (Multi-purpose contact form) ──── */
/* Request Type Tabs */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:480px){.form-row{grid-template-columns:1fr}}
.checkbox-field{
  display:flex;align-items:center;gap:10px;margin-bottom:18px;cursor:pointer;
  font-size:.9rem;color:var(--text-mid);font-weight:600;
}
.checkbox-field input{width:auto;accent-color:var(--blue)}
.form-error{
  display:none;background:#fef2f2;border:2px solid #fecaca;
  border-radius:14px;padding:16px 20px;text-align:center;margin-top:16px;
}
.form-error.show{display:block}
.form-error p{color:#b91c1c;font-size:.9rem;margin:0}

/* ─── CTA BANNER ─────────────────────────────── */
.cta-banner{
  background:linear-gradient(135deg,var(--blue) 0%,var(--navy) 100%);
  position:relative;overflow:hidden;padding:80px 0;
}
.cta-banner::before{
  content:'';position:absolute;top:-100px;right:-100px;
  width:400px;height:400px;border-radius:50%;
  background:rgba(255,255,255,.05);
}
.cta-banner::after{
  content:'';position:absolute;bottom:-80px;left:-60px;
  width:300px;height:300px;border-radius:50%;
  background:rgba(0,184,124,.1);
}
.cta-inner{
  text-align:center;position:relative;z-index:1;
}
.cta-inner h2{
  font-family:'Cairo',sans-serif;font-size:clamp(1.8rem,3.5vw,3rem);
  font-weight:900;color:#fff;margin-bottom:16px;
}
.cta-inner p{color:rgba(255,255,255,.75);font-size:1.1rem;margin-bottom:36px;max-width:600px;margin-inline:auto}
.cta-actions{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}

/* ─── FOOTER ─────────────────────────────────── */
footer{background:var(--navy);color:rgba(255,255,255,.7)}
.footer-main{
  display:grid;grid-template-columns:350px 1fr 1fr 1fr;
  gap:48px;padding:72px 0 48px;
}
.footer-brand p{font-size:.9rem;line-height:1.8;margin:16px 0 24px;color:rgba(255,255,255,.65)}
.footer-social{display:flex;gap:10px}
.social-btn{
  width:44px;height:44px;border-radius:12px;
  background:rgba(255,255,255,.28);border:1px solid rgba(255,255,255,.5);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;text-decoration:none;transition:var(--transition);
  color:#fff;
}
.social-btn:hover{background:var(--blue);border-color:var(--blue)}
.footer-col h4{color:#fff;font-weight:700;margin-bottom:20px;font-size:1rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul li a{
  color:rgba(255,255,255,.6);text-decoration:none;
  font-size:.9rem;transition:var(--transition);
  display:flex;align-items:center;gap:6px;
}
.footer-col ul li a:hover{color:#fff;transform:translateX(-4px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:24px 0;text-align:center;}
.footer-bottom p{font-size:.85rem;color:rgba(255,255,255,.5);margin:0}

/* ─── Floating Buttons (يسار الشاشة) ───────────── */
.fab-group{
  position:fixed;left:16px;bottom:80px;z-index:999;
  display:flex;flex-direction:column;gap:12px;align-items:flex-start;
}
.fab{
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;text-decoration:none;
  transition:var(--transition);box-shadow:0 8px 30px rgba(0,0,0,.25);
  position:relative;
}
.fab:hover{transform:scale(1.12) translateY(-3px)}
.fab-wa{background:#25d366;color:#fff}
.fab-ph{background:var(--blue);color:#fff}
.fab-label{
  position:absolute;left:68px;top:50%;transform:translateY(-50%);
  background:rgba(10,30,80,.9);color:#fff;
  padding:7px 14px;border-radius:8px;font-size:.82rem;font-weight:600;
  white-space:nowrap;opacity:0;transition:.2s;pointer-events:none;
}
.fab:hover .fab-label{opacity:1}
.fab-ripple{
  position:absolute;inset:0;border-radius:50%;
  background:inherit;animation:ripple 2s ease infinite;
  z-index:-1;
}

/* ─── Mobile Nav ─────────────────────────────── */
.mobile-nav{
  display:none;position:fixed;inset:0;z-index:200;
  background:rgba(10,30,80,.95);backdrop-filter:blur(20px);
  flex-direction:column;align-items:center;justify-content:center;gap:24px;
}
.mobile-nav.open{display:flex}
.mobile-nav a{
  font-size:1.5rem;font-weight:700;color:#fff;
  text-decoration:none;transition:.2s;
}
.mobile-nav a:hover{color:var(--gold)}
.mobile-nav-close{
  position:absolute;top:24px;left:24px;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.1);border:none;cursor:pointer;
  color:#fff;font-size:1.5rem;display:flex;align-items:center;justify-content:center;
}

/* ─── Responsive ─────────────────────────────── */
@media(max-width:1100px){
  .hero-grid{grid-template-columns:1fr;grid-template-rows:auto auto}
  .hero-visual{max-width:480px;margin:0 auto}
  .why-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .contact-form-card{position:static}
  .footer-main{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  html{font-size:16px}
  .section{padding:70px 0}
  .topbar{display:none}
  nav{display:none}
  .menu-toggle{display:flex}
  .hero-stats{grid-template-columns:1fr 1fr}
  .process-steps{grid-template-columns:1fr 1fr;gap:32px}
  .process-steps::before{display:none}
  .faq-grid{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr}
  .header-cta .btn{display:none}
  .rating-summary{grid-template-columns:1fr}
  /* إصلاح خروج القائمة خارج الشاشة */
  .container{padding:0 16px}
  .header-inner{padding:14px 0;gap:12px}
  .menu-toggle{flex-shrink:0;padding:4px;margin-left:0}
  header{overflow:hidden}
}
@media(max-width:480px){
  .hero-stats{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .cities-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:1fr}
}

/* ─── Scroll reveal ──────────────────────────── */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── Contact Page - Fixed Layout ── */
.contact-header{text-align:center;margin-bottom:48px}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:start;
}
.contact-info{display:flex;flex-direction:column;gap:24px}
.contact-hours-box{
  background:var(--blue-xlight);border-radius:var(--radius);padding:24px;
}
.contact-hours-box h4{color:var(--navy);font-weight:700;margin-bottom:16px;font-size:1rem}
.contact-hours-rows{display:flex;flex-direction:column;gap:12px}
.contact-hours-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 14px;background:#fff;border-radius:10px;
  border:1px solid rgba(0,57,177,.08);
}
.contact-hours-day{color:var(--navy);font-weight:700;font-size:.9rem}
.contact-hours-time{color:var(--blue);font-size:.9rem;font-weight:600}
.form-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:1100px){
  .contact-grid{grid-template-columns:1fr;gap:32px}
}
@media(max-width:600px){
  .form-two-col{grid-template-columns:1fr}
  .contact-form-card{padding:24px 18px}
}

/* form fields */
.form-field{margin-bottom:16px}
.form-field label{
  display:block;font-weight:700;color:var(--navy);
  font-size:.88rem;margin-bottom:6px;
}
.form-field input,
.form-field select,
.form-field textarea{
  width:100%;padding:12px 16px;
  border:2px solid #e2e8f0;border-radius:10px;
  font-family:'Cairo',sans-serif;font-size:.92rem;
  color:var(--text);background:#fafbfc;
  transition:border .2s,box-shadow .2s;outline:none;
  box-sizing:border-box;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  border-color:var(--blue);
  background:#fff;
  box-shadow:0 0 0 3px rgba(0,57,177,.08);
}
.form-field textarea{height:100px;resize:vertical}
.form-field input::placeholder,
.form-field textarea::placeholder{color:#aab4c8;font-size:.88rem}

/* submit button */
.contact-form-card .btn-primary{
  margin-top:4px;
  font-size:.95rem;font-weight:700;
  padding:14px;border-radius:12px;
}
.form-success{
  text-align:center;padding:20px;background:#f0fdf4;
  border:1px solid #86efac;border-radius:12px;margin-top:16px;
}
.form-success h4{color:#166534;margin-bottom:6px}
.form-success p{color:#166534;font-size:.88rem}
.form-error{
  text-align:center;padding:16px;background:#fef2f2;
  border:1px solid #fca5a5;border-radius:12px;margin-top:16px;
}
.form-error p{color:#991b1b;font-size:.88rem}
.checkbox-field{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;background:var(--blue-xlight);
  border-radius:10px;cursor:pointer;margin-top:4px;
}
.checkbox-field input[type=checkbox]{
  width:18px;height:18px;accent-color:var(--blue);flex-shrink:0;
}
.checkbox-field span{font-size:.88rem;font-weight:600;color:var(--navy)}
@media(max-width:480px){
  }

/* ════════════════════════════════════════════════════════
   JAHEZFIX NEW CSS - زر صعود + فورم + فوتر
   ════════════════════════════════════════════════════════ */

/* ── فوتر جديد ── */
.site-footer { background: var(--navy); color: rgba(255,255,255,.7); }
.footer-logo {
  display: flex; align-items: center; gap: 12px;
  text-decoration: none; color: #fff;
  font-family: 'Cairo', sans-serif; font-size: 1.4rem; font-weight: 900;
  margin-bottom: 14px;
}
.footer-logo-icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2);
  display: flex; align-items: center; justify-content: center; font-size: 1.3rem;
}
.footer-desc { font-size: .88rem; line-height: 1.8; color: rgba(255,255,255,.6); margin-bottom: 20px; }
.footer-social { display: flex; gap: 10px; flex-wrap: wrap; }
.soc-btn {
  width: 42px; height: 42px; border-radius: 12px;
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.3);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.85); text-decoration: none;
  transition: var(--transition);
}
.soc-btn:hover { background: var(--blue); border-color: var(--blue); color: #fff; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 22px 0;
  text-align: center;
}
.footer-bottom p {
  font-size: .84rem;
  color: rgba(255,255,255,.45);
  margin: 0;
  text-align: center;
}

/* ── فورم التواصل الجديد ── */
.efx-contact { background: #f8faff; }
.efx-contact-header { text-align: center; margin-bottom: 48px; }
.efx-contact-header h2 {
  font-family: 'Cairo', sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 900; color: var(--navy); margin: 10px 0 8px;
}
.efx-contact-header p { color: var(--text-light); font-size: .95rem; }
.efx-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 48px; align-items: start;
}

/* معلومات التواصل */
.efx-contact-info { display: flex; flex-direction: column; gap: 14px; }
.efx-method {
  display: flex; align-items: center; gap: 14px;
  background: #fff; border-radius: 14px; padding: 16px 20px;
  text-decoration: none; transition: var(--transition);
  border: 1.5px solid #e8eef8;
}
.efx-method:hover { border-color: var(--blue); transform: translateX(-4px); box-shadow: 0 4px 16px rgba(0,57,177,.1); }
.efx-method-icon { font-size: 1.6rem; flex-shrink: 0; }
.efx-method-label { font-size: .78rem; color: var(--text-light); margin-bottom: 3px; }
.efx-method-val { font-size: .95rem; font-weight: 700; color: var(--navy); }
.efx-phone .efx-method-icon { filter: hue-rotate(220deg); }
.efx-wa { border-color: #dcfce7; }
.efx-wa .efx-method-val { color: #15803d; }
.efx-hours {
  background: #fff; border-radius: 14px; padding: 20px;
  border: 1.5px solid #e8eef8; margin-top: 4px;
}
.efx-hours h4 { font-size: .9rem; font-weight: 700; color: var(--navy); margin-bottom: 14px; }
.efx-hours-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 9px 12px; border-radius: 9px; background: #f4f7ff;
  margin-bottom: 8px; font-size: .85rem;
}
.efx-hours-row span:first-child { font-weight: 700; color: var(--navy); }
.efx-hours-row span:last-child { color: var(--blue); font-weight: 600; }

/* بطاقة الفورم */
.efx-form-wrap {}
.efx-form-card {
  background: #fff;
  border-radius: 20px;
  padding: 36px;
  box-shadow: 0 8px 40px rgba(0,57,177,.1);
  border: 1.5px solid #e8eef8;
}
.efx-form-card h3 {
  font-family: 'Cairo', sans-serif;
  font-size: 1.3rem; font-weight: 800;
  color: var(--navy); margin-bottom: 6px;
}
.efx-form-card > p { color: var(--text-light); font-size: .88rem; margin-bottom: 24px; }

/* شبكة أزرار الاختيار */
.efx-type-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 28px;
}
.efx-type-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 14px 10px;
  background: #f4f7ff;
  border: 2px solid #dde6f5;
  border-radius: 16px;
  font-family: 'Cairo', sans-serif;
  font-size: .84rem;
  font-weight: 700;
  color: #3a4a6b;
  cursor: pointer;
  transition: all .2s;
  text-align: center;
  line-height: 1.3;
}
.efx-type-icon { font-size: 1.4rem; display: block; }
.efx-type-btn:hover {
  border-color: var(--blue);
  background: #eaefff;
  color: var(--blue);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,57,177,.12);
}
.efx-type-btn.active {
  background: var(--blue);
  border-color: var(--blue);
  color: #fff;
  box-shadow: 0 6px 20px rgba(0,57,177,.3);
  transform: translateY(-2px);
}
.efx-type-btn.active .efx-type-icon { filter: brightness(2); }

/* حقول الفورم */
.efx-field { margin-bottom: 16px; }
.efx-field label {
  display: block; font-size: .86rem;
  font-weight: 700; color: var(--navy); margin-bottom: 7px;
}
.efx-field .req { color: #e53e3e; }
.efx-field input,
.efx-field select,
.efx-field textarea {
  width: 100%; padding: 12px 16px;
  border: 2px solid #e2e8f0; border-radius: 12px;
  font-family: 'Cairo', sans-serif; font-size: .9rem;
  color: var(--text); background: #fafbff;
  transition: border .2s, box-shadow .2s; outline: none;
  box-sizing: border-box;
}
.efx-field input:focus,
.efx-field select:focus,
.efx-field textarea:focus {
  border-color: var(--blue);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(0,57,177,.08);
}
.efx-field textarea { height: 100px; resize: vertical; }
.efx-field input::placeholder,
.efx-field textarea::placeholder { color: #b0bcd4; font-size: .85rem; }
.efx-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.efx-check {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px; background: #f0f4ff; border-radius: 10px;
  cursor: pointer; margin-bottom: 16px;
}
.efx-check input { width: 18px; height: 18px; accent-color: var(--blue); flex-shrink: 0; }
.efx-check span { font-size: .86rem; font-weight: 600; color: var(--navy); }
.efx-submit-btn {
  width: 100%; padding: 15px;
  background: var(--blue); color: #fff;
  border: none; border-radius: 14px;
  font-family: 'Cairo', sans-serif;
  font-size: 1rem; font-weight: 800;
  cursor: pointer; transition: all .2s;
  margin-top: 8px;
}
.efx-submit-btn:hover { background: var(--navy); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(0,57,177,.3); }
.efx-submit-btn:disabled { opacity: .7; cursor: not-allowed; transform: none; }
.efx-msg { display: none; border-radius: 12px; padding: 16px 20px; margin-top: 16px; text-align: center; }
.efx-success { background: #f0fdf4; border: 1.5px solid #86efac; }
.efx-success strong { display: block; color: #15803d; font-size: 1rem; margin-bottom: 6px; }
.efx-success p { color: #166534; font-size: .86rem; margin: 0; }
.efx-error { background: #fef2f2; border: 1.5px solid #fca5a5; }
.efx-error p { color: #991b1b; font-size: .86rem; margin: 0; }

/* Responsive */
@media(max-width: 900px) {
  .efx-contact-grid { grid-template-columns: 1fr; gap: 28px; }
}
@media(max-width: 480px) {
  .efx-form-card { padding: 24px 16px; }
  .efx-type-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .efx-type-btn { padding: 12px 8px; font-size: .8rem; }
  .efx-type-icon { font-size: 1.2rem; }
  .efx-row { grid-template-columns: 1fr; }

}

/* ════════════════════════════════════════════
   MINI BOOKING FORM
   ════════════════════════════════════════════ */
.mf-section {
  background: linear-gradient(135deg, #0a1f5c 0%, #1a3a8f 50%, #0a1f5c 100%);
  padding: 60px 0;
  position: relative;
  overflow: hidden;
}
.mf-section::before {
  content: '';
  position: absolute;
  top: -80px; left: -80px;
  width: 320px; height: 320px;
  border-radius: 50%;
  background: rgba(255,255,255,.04);
}
.mf-section::after {
  content: '';
  position: absolute;
  bottom: -60px; right: -60px;
  width: 240px; height: 240px;
  border-radius: 50%;
  background: rgba(255,255,255,.04);
}
.mf-inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 48px;
  align-items: center;
}
.mf-tag {
  display: inline-block;
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
  padding: 6px 16px;
  border-radius: 50px;
  font-size: .82rem;
  font-weight: 700;
  margin-bottom: 16px;
}
.mf-title {
  font-family: 'Cairo', sans-serif;
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 900;
  color: #fff;
  margin: 0 0 10px;
  line-height: 1.2;
}
.mf-sub {
  color: rgba(255,255,255,.75);
  font-size: .9rem;
  line-height: 1.7;
  margin-bottom: 20px;
}
.mf-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.mf-trust span {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.9);
  padding: 6px 14px;
  border-radius: 50px;
  font-size: .8rem;
  font-weight: 600;
}

/* الفورم */
.mf-form {
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 20px;
  padding: 32px;
}
.mf-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 18px;
}
.mf-field label {
  display: block;
  font-size: .78rem;
  font-weight: 700;
  color: rgba(255,255,255,.8);
  margin-bottom: 6px;
}
.mf-field input,
.mf-field select {
  width: 100%;
  padding: 12px 16px;
  background: rgba(255,255,255,.12);
  border: 1.5px solid rgba(255,255,255,.2);
  border-radius: 12px;
  color: #fff;
  font-family: 'Cairo', sans-serif;
  font-size: .9rem;
  outline: none;
  transition: border .2s, background .2s;
  box-sizing: border-box;
}
.mf-field input::placeholder { color: rgba(255,255,255,.5); }
.mf-field select option { color: #333; background: #fff; }
.mf-field input:focus,
.mf-field select:focus {
  border-color: rgba(255,255,255,.6);
  background: rgba(255,255,255,.18);
}
.mf-btn {
  width: 100%;
  padding: 15px;
  background: #00b87c;
  color: #fff;
  border: none;
  border-radius: 14px;
  font-family: 'Cairo', sans-serif;
  font-size: 1rem;
  font-weight: 800;
  cursor: pointer;
  transition: all .2s;
  letter-spacing: .3px;
}
.mf-btn:hover {
  background: #009a68;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,184,124,.4);
}
.mf-btn:disabled { opacity: .7; cursor: not-allowed; transform: none; }
.mf-msg {
  display: none;
  text-align: center;
  padding: 12px 16px;
  border-radius: 10px;
  margin-top: 14px;
  font-size: .88rem;
  font-weight: 600;
}
.mf-ok {
  background: rgba(0,184,124,.2);
  border: 1px solid rgba(0,184,124,.4);
  color: #a7f3d0;
}
.mf-err {
  background: rgba(239,68,68,.2);
  border: 1px solid rgba(239,68,68,.4);
  color: #fca5a5;
}
.mf-err a { color: #fde68a; }

/* Responsive */
@media(max-width: 900px) {
  .mf-inner { grid-template-columns: 1fr; gap: 28px; }
  .mf-headline { text-align: center; }
  .mf-trust { justify-content: center; }
}
@media(max-width: 480px) {
  .mf-grid { grid-template-columns: 1fr; }
  .mf-form { padding: 20px 16px; }
  .mf-section { padding: 40px 0; }
}

/* سهم الأعلى بـ pseudo-element */

/* الظل */

/* مخفي في البداية */

/* مرئي عند التمرير */

@media (max-width: 768px) {

/* =============================================
   JTOP - زر الصعود للأعلى
   ============================================= */
#jtop {
  position: fixed;
  bottom: 28px;
  right: 22px;
  left: auto;
  z-index: 9999;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: none;
  background: var(--blue, #0039b1);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(0,57,177,.4);
  /* مخفي في البداية */
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(12px);
  transition: opacity .3s ease, visibility .3s ease, transform .3s ease, background .2s;
}
#jtop.on {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}
#jtop:hover { background: #001f7a; }
/* السهم داخل الزر */
#jtop span {
  display: block;
  width: 11px;
  height: 11px;
  border-top: 2.5px solid #fff;
  border-left: 2.5px solid #fff;
  transform: rotate(45deg) translate(2px, -2px);
  border-radius: 1px;
}
@media (max-width: 768px) {
  #jtop { width: 44px; height: 44px; bottom: 90px; right: 16px; }
}

/* =============================================
   CONTACT PAGE - NEW DESIGN (ct-*)
   ============================================= */

/* ── معلومات التواصل ── */
.ct-info-section { background: #f6f8ff; }
.ct-header { text-align: center; margin-bottom: 40px; }
.ct-header h1 {
  font-family: 'Cairo', sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 900; color: var(--navy); margin: 10px 0 8px;
}
.ct-header p { color: var(--text-light); font-size: .95rem; }

.ct-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.ct-card {
  display: flex; align-items: center; gap: 16px;
  background: #fff; border-radius: 16px; padding: 20px;
  text-decoration: none; border: 2px solid #e8eef8;
  transition: all .22s; cursor: pointer;
}
.ct-card:hover {
  border-color: var(--blue);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,57,177,.12);
}
.ct-card-icon {
  width: 52px; height: 52px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 1.4rem;
}
.ct-card-phone .ct-card-icon  { background: #eff6ff; color: var(--blue); }
.ct-card-wa .ct-card-icon     { background: #f0fdf4; color: #16a34a; }
.ct-card-email .ct-card-icon  { background: #faf5ff; color: #7c3aed; }
.ct-card-hours .ct-card-icon  { background: #fff7ed; color: #ea580c; }
.ct-card-body { flex: 1; min-width: 0; }
.ct-card-label { font-size: .78rem; color: var(--text-light); margin-bottom: 4px; }
.ct-card-val { font-size: .95rem; font-weight: 700; color: var(--navy); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ct-card-arrow { color: var(--blue); font-size: 1.1rem; font-weight: 700; margin-right: auto; }

/* ── فورم الطلب ── */
.ct-form-section { background: #fff; padding: 60px 0; }
.ct-form-wrap { max-width: 720px; margin: 0 auto; }
.ct-form-head { text-align: center; margin-bottom: 36px; }
.ct-form-head h2 {
  font-family: 'Cairo', sans-serif;
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 900; color: var(--navy); margin-bottom: 8px;
}
.ct-form-head p { color: var(--text-light); font-size: .9rem; }

/* أنواع الطلبات */
.ct-types {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  margin-bottom: 32px;
}
.ct-type {
  display: flex; flex-direction: column;
  align-items: center; gap: 6px;
  padding: 14px 8px;
  background: #f4f7ff;
  border: 2px solid #dde6f5;
  border-radius: 14px;
  font-family: 'Cairo', sans-serif;
  font-size: .78rem; font-weight: 700; color: #3a4a6b;
  cursor: pointer; transition: all .2s; text-align: center;
}
.ct-type-ico { font-size: 1.5rem; line-height: 1; }
.ct-type:hover {
  border-color: var(--blue); background: #eaefff;
  color: var(--blue); transform: translateY(-2px);
}
.ct-type.active {
  background: var(--blue); border-color: var(--blue);
  color: #fff; box-shadow: 0 4px 16px rgba(0,57,177,.3);
  transform: translateY(-2px);
}

/* حقول الفورم */
.ct-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.ct-field { margin-bottom: 16px; }
.ct-field label {
  display: block; font-size: .86rem;
  font-weight: 700; color: var(--navy); margin-bottom: 7px;
}
.ct-field em { color: #e53e3e; font-style: normal; }
.ct-field input,
.ct-field select,
.ct-field textarea {
  width: 100%; padding: 13px 16px;
  border: 2px solid #e2e8f0; border-radius: 12px;
  font-family: 'Cairo', sans-serif; font-size: .9rem;
  color: var(--text); background: #fafbff;
  transition: border .2s, box-shadow .2s; outline: none;
  box-sizing: border-box;
}
.ct-field input:focus,
.ct-field select:focus,
.ct-field textarea:focus {
  border-color: var(--blue); background: #fff;
  box-shadow: 0 0 0 3px rgba(0,57,177,.08);
}
.ct-field textarea { height: 110px; resize: vertical; }
.ct-field input::placeholder,
.ct-field textarea::placeholder { color: #b0bcd4; font-size: .85rem; }

/* زر الإرسال */
.ct-submit {
  width: 100%; padding: 16px;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  background: var(--blue); color: #fff;
  border: none; border-radius: 14px;
  font-family: 'Cairo', sans-serif;
  font-size: 1rem; font-weight: 800;
  cursor: pointer; transition: all .22s;
  margin-top: 8px; letter-spacing: .3px;
}
.ct-submit:hover { background: var(--navy); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,57,177,.3); }
.ct-submit:disabled { opacity: .7; cursor: not-allowed; transform: none; }

/* عنوان القسم */
.ct-section-title {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Cairo', sans-serif;
  font-size: .92rem; font-weight: 800; color: var(--navy);
  background: #f4f7ff; border: 2px solid #dde6f5;
  border-radius: 12px; padding: 12px 16px;
  margin-bottom: 20px;
}
.ct-section-ico { font-size: 1.2rem; }
.ct-common-fields { margin-bottom: 4px; }

/* رسائل */
.ct-ok, .ct-err {
  display: none; border-radius: 14px;
  padding: 18px 20px; margin-top: 16px; text-align: center;
}
.ct-ok { background: #f0fdf4; border: 2px solid #86efac; }
.ct-ok strong { display: block; color: #15803d; margin-bottom: 6px; font-size: .95rem; }
.ct-ok p { color: #166534; font-size: .85rem; margin: 0; }
.ct-err { background: #fef2f2; border: 2px solid #fca5a5; }
.ct-err p { color: #991b1b; font-size: .85rem; margin: 0; }
.ct-err a { color: #1d4ed8; }

/* Responsive */
@media (max-width: 900px) {
  .ct-cards { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .ct-cards { grid-template-columns: 1fr; }
  .ct-types { grid-template-columns: repeat(3, 1fr); }
  .ct-row { grid-template-columns: 1fr; }
  .ct-form-section { padding: 40px 0; }
}
@media (max-width: 380px) {
  .ct-types { grid-template-columns: repeat(2, 1fr); }
}

/* ═══════════════════════════════════════════════
   ARTICLE / PAGE LAYOUT  (art-* & sb-*)
   ═══════════════════════════════════════════════ */

/* ── Breadcrumb ── */
.art-breadcrumb {
  background: #fff;
  border-bottom: 1px solid #e8edf8;
  padding: 13px 0;
}
.art-bc-list {
  display: flex; flex-wrap: wrap; align-items: center;
  list-style: none; gap: 6px;
  font-size: .82rem; color: var(--text-light);
}
.art-bc-list li { display: flex; align-items: center; gap: 6px; }
.art-bc-list li:not(:last-child)::after {
  content: '›'; color: #c0cce8; font-size: .9rem;
}
.art-bc-list a { color: var(--blue); text-decoration: none; }
.art-bc-list a:hover { text-decoration: underline; }
.art-bc-current { color: var(--text-light); font-weight: 600; }

/* ── Layout wrapper ── */
.art-layout { background: #f0f4ff; padding: 40px 0 60px; }
.art-container {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 28px;
  align-items: start;
}

/* ── Main card ── */
.art-card {
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 4px 24px rgba(0,57,177,.07);
  overflow: hidden;
}

/* ── Header ── */
.art-header { padding: 36px 40px 0; }
.art-page-header { padding-bottom: 28px; border-bottom: 2px solid #f0f4ff; }
.art-cats { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.art-cat-badge {
  display: inline-block;
  background: var(--blue-xlight); color: var(--blue);
  border: 1px solid var(--blue-light);
  padding: 4px 14px; border-radius: 30px;
  font-size: .78rem; font-weight: 700; text-decoration: none;
  transition: .2s;
}
.art-cat-badge:hover { background: var(--blue); color: #fff; }
.art-title {
  font-family: 'Cairo', sans-serif;
  font-size: clamp(1.45rem, 2.8vw, 2rem);
  font-weight: 900; color: var(--navy);
  line-height: 1.4; margin-bottom: 18px;
}
.art-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  font-size: .82rem; color: var(--text-light);
  padding-bottom: 24px; border-bottom: 2px solid #f0f4ff;
}
.art-meta-item { display: flex; align-items: center; gap: 5px; }
.art-meta-sep { color: #c0cce8; }

/* ── Thumbnail ── */
.art-thumb { overflow: hidden; }
.art-thumb img {
  width: 100%; height: auto; display: block;
  max-height: 420px; object-fit: cover;
  object-position: center;
}

/* ── Body (محتوى المقال) ── */
.art-body {
  padding: 36px 40px 40px;
  font-family: 'Tajawal', sans-serif;
  font-size: 1.05rem; line-height: 1.95;
  color: var(--text-mid);
}
.art-body h2 {
  font-family: 'Cairo', sans-serif;
  font-size: 1.35rem; font-weight: 900; color: var(--navy);
  margin: 40px 0 16px;
  padding-right: 16px;
  border-right: 4px solid var(--blue);
}
.art-body h3 {
  font-family: 'Cairo', sans-serif;
  font-size: 1.1rem; font-weight: 800; color: var(--navy-mid);
  margin: 30px 0 12px;
}
.art-body h4 {
  font-family: 'Cairo', sans-serif;
  font-size: 1rem; font-weight: 700; color: var(--navy-mid);
  margin: 24px 0 10px;
}
.art-body p { margin-bottom: 18px; }
.art-body ul, .art-body ol {
  padding-right: 24px; margin-bottom: 20px;
}
.art-body li { margin-bottom: 8px; }
.art-body ul li::marker { color: var(--blue); }
.art-body ol li::marker { color: var(--blue); font-weight: 700; }
.art-body a { color: var(--blue); text-decoration: underline; }
.art-body a:hover { color: var(--navy); }
.art-body strong { color: var(--navy); font-weight: 700; }
.art-body blockquote {
  margin: 28px 0;
  padding: 20px 24px 20px 20px;
  border-right: 4px solid var(--blue);
  background: var(--blue-xlight);
  border-radius: 0 12px 12px 0;
  font-style: italic; color: var(--navy-mid);
}
.art-body img {
  max-width: 100%;
  width: auto;
  height: auto;
  display: block;
  border-radius: 12px;
  margin: 20px auto;
  object-fit: contain;
}
/* صور داخل p أو figure */
.art-body p img,
.art-body figure img {
  max-width: 100%;
  width: auto;
  height: auto;
  max-height: 480px;
  display: block;
  margin: 0 auto;
  border-radius: 12px;
}
.art-body figure {
  margin: 24px 0;
  text-align: center;
}
.art-body figcaption {
  font-size: .82rem;
  color: var(--text-light);
  margin-top: 8px;
  text-align: center;
}
.art-body table {
  width: 100%; border-collapse: collapse;
  margin: 24px 0; font-size: .92rem;
}
.art-body th {
  background: var(--navy); color: #fff;
  padding: 12px 16px; text-align: right;
  font-weight: 700;
}
.art-body td {
  padding: 11px 16px; border-bottom: 1px solid #e8edf8;
  color: var(--text-mid);
}
.art-body tr:nth-child(even) td { background: #f8faff; }
.art-body code {
  background: #f0f4ff; color: var(--blue);
  padding: 2px 8px; border-radius: 6px;
  font-size: .88rem;
}
.art-body pre {
  background: var(--navy); color: #e2e8f0;
  padding: 20px 24px; border-radius: 12px;
  overflow-x: auto; margin: 20px 0; font-size: .88rem;
}

/* ── Tags ── */
.art-tags {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  padding: 20px 40px 24px;
  border-top: 2px solid #f0f4ff;
  font-size: .82rem;
}
.art-tags-label { color: var(--text-light); font-weight: 700; }
.art-tag {
  background: #f0f4ff; color: var(--blue);
  padding: 4px 14px; border-radius: 30px;
  text-decoration: none; font-weight: 600;
  transition: .2s;
}
.art-tag:hover { background: var(--blue); color: #fff; }

/* ── Navigation ── */
.art-nav {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  margin-top: 24px;
}
.art-nav-item {
  display: flex; flex-direction: column; gap: 6px;
  padding: 18px 20px; border-radius: 14px;
  background: #fff; border: 2px solid #e8edf8;
  text-decoration: none; transition: .2s;
}
.art-nav-item:hover { border-color: var(--blue); box-shadow: 0 4px 16px rgba(0,57,177,.1); }
.art-nav-dir { font-size: .75rem; color: var(--blue); font-weight: 700; }
.art-nav-ttl { font-size: .88rem; color: var(--navy); font-weight: 700; line-height: 1.4; }

/* ═══ Sidebar ═══ */
.art-sidebar { display: flex; flex-direction: column; gap: 20px; position: sticky; top: 90px; }

/* ── صندوق الحجز ── */
.sb-box {
  background: #fff; border-radius: 18px;
  box-shadow: 0 4px 24px rgba(0,57,177,.07);
  overflow: hidden;
}
.sb-booking { border: 2px solid var(--blue-light); }
.sb-box-head {
  display: flex; align-items: center; gap: 14px;
  padding: 20px 20px 16px;
}
.sb-box-ico { font-size: 2rem; line-height: 1; }
.sb-box-title {
  font-family: 'Cairo', sans-serif;
  font-size: 1rem; font-weight: 900; color: var(--navy);
}
.sb-box-sub { font-size: .8rem; color: var(--text-light); margin-top: 2px; }
.sb-trust {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 0 20px 16px;
  font-size: .78rem; color: var(--text-mid);
}
.sb-trust span {
  background: #f0f4ff; padding: 4px 10px;
  border-radius: 20px; font-weight: 600;
}
.sb-btn-wa {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin: 0 20px 10px;
  padding: 13px 20px;
  background: #25d366; color: #fff;
  border-radius: 12px; font-family: 'Cairo', sans-serif;
  font-weight: 800; font-size: .9rem; text-decoration: none;
  transition: .2s;
}
.sb-btn-wa:hover { background: #1ea856; }
.sb-btn-ph {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin: 0 20px 20px;
  padding: 12px 20px;
  background: #f0f4ff; color: var(--blue);
  border-radius: 12px; font-family: 'Cairo', sans-serif;
  font-weight: 800; font-size: .88rem; text-decoration: none;
  border: 2px solid var(--blue-light); transition: .2s;
  direction: ltr;
}
.sb-btn-ph:hover { background: var(--blue); color: #fff; border-color: var(--blue); }

/* ── TOC ── */
.sb-toc { padding: 20px; }
.sb-toc-title {
  display: flex; align-items: center; gap: 8px;
  font-family: 'Cairo', sans-serif;
  font-size: .9rem; font-weight: 900; color: var(--navy);
  margin-bottom: 14px; padding-bottom: 12px;
  border-bottom: 2px solid #f0f4ff;
}
.sb-toc-list { list-style: none; padding: 0; }
.sb-toc-list li { margin-bottom: 4px; }
.sb-toc-list a {
  display: block; padding: 7px 12px;
  font-size: .82rem; color: var(--text-mid);
  text-decoration: none; border-radius: 8px;
  transition: .2s; line-height: 1.4;
  border-right: 3px solid transparent;
}
.sb-toc-list a:hover,
.sb-toc-list a.toc-active {
  background: var(--blue-xlight); color: var(--blue);
  border-right-color: var(--blue);
}
.sb-toc.toc-empty { display: none; }

/* ── Related ── */
.sb-related { padding: 20px; }
.sb-related-title {
  font-family: 'Cairo', sans-serif;
  font-size: .9rem; font-weight: 900; color: var(--navy);
  margin-bottom: 14px; padding-bottom: 12px;
  border-bottom: 2px solid #f0f4ff;
}
.sb-related-list { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.sb-related-item { display: flex; gap: 12px; align-items: flex-start; }
.sb-rel-thumb {
  flex-shrink: 0; width: 68px; height: 60px;
  border-radius: 10px; overflow: hidden; display: block;
}
.sb-rel-thumb img { width: 100%; height: 100%; object-fit: cover; }
.sb-rel-info { display: flex; flex-direction: column; gap: 4px; }
.sb-rel-ttl {
  font-size: .83rem; font-weight: 700; color: var(--navy);
  text-decoration: none; line-height: 1.4;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.sb-rel-ttl:hover { color: var(--blue); }
.sb-rel-date { font-size: .74rem; color: var(--text-light); }

/* ═══ Responsive ═══ */
@media (max-width: 1100px) {
  .art-container { grid-template-columns: 1fr 280px; }
}
@media (max-width: 860px) {
  .art-container { grid-template-columns: 1fr; }
  .art-sidebar { position: static; }
  /* نعرض السايدبار أول على موبايل — بوكس الحجز فقط */
  .art-sidebar { order: -1; }
  .sb-related, .sb-toc { display: none; }
  .art-header { padding: 24px 20px 0; }
  .art-body { padding: 24px 20px 28px; }
  .art-tags { padding: 16px 20px 20px; }
  .art-nav { grid-template-columns: 1fr; }
  .art-title { font-size: 1.35rem; }
}
@media (max-width: 600px) {
  .art-layout { padding: 20px 0 40px; }
  .art-body h2 { font-size: 1.15rem; }
  .art-body { font-size: .97rem; }
}

/* ── WordPress Image Alignment & Size Classes ── */
.art-body .aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.art-body .alignright {
  float: left;
  margin: 8px 20px 16px 0;
}
.art-body .alignleft {
  float: right;
  margin: 8px 0 16px 20px;
}
.art-body .alignnone { display: block; }
.art-body .wp-caption { max-width: 100%; }
.art-body .wp-caption img { max-width: 100%; height: auto; }
.art-body .wp-caption-text {
  font-size: .8rem; color: var(--text-light);
  text-align: center; margin-top: 6px;
}
/* إزالة overflow على موبايل */
@media (max-width: 600px) {
  .art-body .alignright,
  .art-body .alignleft { float: none; margin: 16px auto; display: block; }
  .art-body p img,
  .art-body figure img { max-height: 280px; }
}

/* ═══════════════════════════════════════════════════════════════════
   ARTICLE CONTENT UPGRADE — تحسين شامل لتنسيق المقالات والصفحات
   ═══════════════════════════════════════════════════════════════════ */

/* ── Hero Banner للمقالات (خلفية زرقاء فوق الصفحة) ── */
.art-hero-banner {
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 50%, #0a3499 100%);
  color: #fff;
  padding: 40px 0 44px;
  text-align: center;
}
.art-hero-banner .art-bc-list { justify-content: center; }
.art-hero-banner .art-bc-list a { color: rgba(255,255,255,.75); }
.art-hero-banner .art-bc-list a:hover { color: #fff; }
.art-hero-banner .art-bc-list li:not(:last-child)::after { color: rgba(255,255,255,.4); }
.art-hero-banner .art-bc-current { color: rgba(255,255,255,.9); }
.art-hero-title {
  font-family: 'Cairo', sans-serif;
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 900;
  color: #fff;
  margin: 14px 0 10px;
  line-height: 1.4;
}
.art-hero-meta {
  display: flex; justify-content: center; flex-wrap: wrap;
  gap: 14px; font-size: .82rem; color: rgba(255,255,255,.75);
  margin-top: 12px;
}
.art-hero-meta span { display: flex; align-items: center; gap: 5px; }

/* ── Layout رئيسي (أعرض قليلاً) ── */
.art-layout { background: #f0f4ff; padding: 36px 0 64px; }
.art-container {
  display: grid;
  grid-template-columns: 1fr 310px;
  gap: 30px;
  align-items: start;
}

/* ── البطاقة الرئيسية ── */
.art-card {
  background: #fff;
  border-radius: 22px;
  box-shadow: 0 4px 28px rgba(0,57,177,.08);
  overflow: hidden;
}

/* ── الصورة ── */
.art-thumb { overflow: hidden; position: relative; }
.art-thumb img {
  width: 100%; height: auto; display: block;
  max-height: 440px; object-fit: cover;
}

/* ── هيدر المقال ── */
.art-header { padding: 32px 36px 0; }
.art-page-header { padding-bottom: 26px; border-bottom: 2px solid #f0f4ff; }

.art-cats { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.art-cat-badge {
  display: inline-block;
  background: var(--blue-xlight); color: var(--blue);
  border: 1px solid var(--blue-light);
  padding: 4px 16px; border-radius: 30px;
  font-size: .78rem; font-weight: 700;
  text-decoration: none; transition: .2s;
}
.art-cat-badge:hover { background: var(--blue); color: #fff; }

.art-title {
  font-family: 'Cairo', sans-serif;
  font-size: clamp(1.45rem, 2.8vw, 2rem);
  font-weight: 900; color: var(--navy);
  line-height: 1.45; margin-bottom: 16px;
}

.art-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  font-size: .82rem; color: var(--text-light);
  padding-bottom: 22px; border-bottom: 2px solid #f0f4ff;
}
.art-meta-item { display: flex; align-items: center; gap: 5px; }
.art-meta-sep { color: #c0cce8; }

/* ══ جسم المقال — التحسين الأساسي ══ */
.art-body {
  padding: 34px 36px 38px;
  font-family: 'Tajawal', sans-serif;
  font-size: 1.06rem;
  line-height: 2;
  color: var(--text-mid);
}

/* H2 — عنوان رئيسي مع خط جانبي */
.art-body h2 {
  font-family: 'Cairo', sans-serif;
  font-size: 1.38rem; font-weight: 900; color: var(--navy);
  margin: 44px 0 18px;
  padding: 14px 20px;
  background: linear-gradient(135deg, #eef4ff 0%, #f8faff 100%);
  border-right: 5px solid var(--blue);
  border-radius: 0 12px 12px 0;
  position: relative;
}
.art-body h2:first-child { margin-top: 0; }

/* H3 — عنوان ثانوي */
.art-body h3 {
  font-family: 'Cairo', sans-serif;
  font-size: 1.15rem; font-weight: 800; color: var(--navy-mid);
  margin: 34px 0 14px;
  display: flex; align-items: center; gap: 10px;
}
.art-body h3::before {
  content: '';
  display: inline-block;
  width: 8px; height: 8px;
  background: var(--blue);
  border-radius: 50%;
  flex-shrink: 0;
}

/* H4 */
.art-body h4 {
  font-family: 'Cairo', sans-serif;
  font-size: 1.02rem; font-weight: 700; color: var(--navy-mid);
  margin: 26px 0 10px;
}

/* فقرات */
.art-body p { margin-bottom: 20px; }
.art-body > p:first-child {
  font-size: 1.1rem;
  color: var(--navy-mid);
  font-weight: 500;
}

/* قوائم */
.art-body ul, .art-body ol { padding-right: 8px; margin-bottom: 22px; }
.art-body ul { list-style: none; }
.art-body ul li {
  margin-bottom: 10px;
  padding-right: 26px;
  position: relative;
}
.art-body ul li::before {
  content: '';
  position: absolute;
  right: 0; top: .7em;
  width: 8px; height: 8px;
  background: var(--blue);
  border-radius: 50%;
}
.art-body ol { padding-right: 28px; }
.art-body ol li { margin-bottom: 10px; }
.art-body ol li::marker { color: var(--blue); font-weight: 800; font-size: 1rem; }

/* روابط */
.art-body a { color: var(--blue); text-decoration: underline; transition: .15s; }
.art-body a:hover { color: var(--navy); }
.art-body strong { color: var(--navy); font-weight: 700; }
.art-body em { color: var(--navy-mid); }

/* اقتباس */
.art-body blockquote {
  margin: 30px 0;
  padding: 22px 26px 22px 22px;
  border-right: 5px solid var(--blue);
  background: var(--blue-xlight);
  border-radius: 0 14px 14px 0;
  font-size: 1.05rem;
  color: var(--navy-mid);
  font-weight: 600;
}
.art-body blockquote p { margin-bottom: 0; }

/* صور */
.art-body img {
  max-width: 100%; width: auto; height: auto;
  display: block; border-radius: 14px;
  margin: 22px auto;
  box-shadow: 0 4px 20px rgba(0,0,0,.08);
  object-fit: contain;
}
.art-body p img,
.art-body figure img {
  max-width: 100%; width: auto; height: auto;
  max-height: 500px; display: block;
  margin: 0 auto; border-radius: 14px;
}
.art-body figure { margin: 26px 0; text-align: center; }
.art-body figcaption {
  font-size: .82rem; color: var(--text-light);
  margin-top: 8px; text-align: center;
}

/* جدول */
.art-body table {
  width: 100%; border-collapse: collapse;
  margin: 26px 0; font-size: .93rem;
  border-radius: 12px; overflow: hidden;
  box-shadow: 0 2px 12px rgba(0,57,177,.08);
}
.art-body th {
  background: var(--navy); color: #fff;
  padding: 13px 18px; text-align: right;
  font-weight: 700; font-family: 'Cairo', sans-serif;
}
.art-body td {
  padding: 12px 18px; border-bottom: 1px solid #e8edf8;
  color: var(--text-mid);
}
.art-body tr:nth-child(even) td { background: #f8faff; }
.art-body code {
  background: #f0f4ff; color: var(--blue);
  padding: 2px 9px; border-radius: 6px; font-size: .88rem;
}

/* ── Tags ── */
.art-tags {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  padding: 18px 36px 22px;
  border-top: 2px solid #f0f4ff; font-size: .82rem;
}
.art-tags-label { color: var(--text-light); font-weight: 700; }
.art-tag {
  background: #f0f4ff; color: var(--blue);
  padding: 4px 16px; border-radius: 30px;
  text-decoration: none; font-weight: 600; transition: .2s;
}
.art-tag:hover { background: var(--blue); color: #fff; }

/* ── التنقل بين المقالات ── */
.art-nav {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  margin-top: 24px;
}
.art-nav-item {
  display: flex; flex-direction: column; gap: 6px;
  padding: 18px 20px; border-radius: 14px;
  background: #fff; border: 2px solid #e8edf8;
  text-decoration: none; transition: .2s;
}
.art-nav-item:hover { border-color: var(--blue); box-shadow: 0 4px 16px rgba(0,57,177,.1); }
.art-nav-dir { font-size: .75rem; color: var(--blue); font-weight: 700; }
.art-nav-ttl { font-size: .88rem; color: var(--navy); font-weight: 700; line-height: 1.4; }

/* ══ Sidebar ══ */
.art-sidebar { display: flex; flex-direction: column; gap: 20px; position: sticky; top: 90px; }

.sb-box {
  background: #fff; border-radius: 18px;
  box-shadow: 0 4px 24px rgba(0,57,177,.07);
  overflow: hidden;
}

/* صندوق الحجز */
.sb-box-head {
  display: flex; align-items: center; gap: 14px;
  padding: 20px 20px 0;
}
.sb-box-ico { font-size: 2rem; line-height: 1; }
.sb-box-title { font-family: 'Cairo', sans-serif; font-weight: 800; color: var(--navy); font-size: 1rem; }
.sb-box-sub { font-size: .8rem; color: var(--text-light); margin-top: 2px; }
.sb-trust {
  display: flex; flex-direction: column; gap: 6px;
  padding: 16px 20px; font-size: .82rem; color: var(--text-mid);
}
.sb-trust span { display: flex; align-items: center; gap: 8px; }
.sb-btn-wa {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin: 0 20px 10px;
  background: #25d366; color: #fff;
  padding: 13px; border-radius: 12px;
  text-decoration: none; font-weight: 700; font-size: .95rem;
  transition: .2s;
}
.sb-btn-wa:hover { background: #1ea856; }
.sb-btn-ph {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin: 0 20px 20px;
  border: 2px solid var(--blue-light); color: var(--blue);
  padding: 11px; border-radius: 12px;
  text-decoration: none; font-weight: 700; font-size: .92rem;
  transition: .2s;
}
.sb-btn-ph:hover { background: var(--blue); color: #fff; border-color: var(--blue); }

/* جدول المحتويات */
.sb-toc { padding: 20px; }
.sb-toc-title {
  display: flex; align-items: center; gap: 8px;
  font-weight: 800; color: var(--navy);
  font-family: 'Cairo', sans-serif;
  margin-bottom: 14px; font-size: .95rem;
}
.sb-toc-list { list-style: none; padding: 0; }
.sb-toc-list li { margin-bottom: 4px; counter-increment: toc-counter; }
.sb-toc-list a {
  display: flex; align-items: flex-start; gap: 8px;
  text-decoration: none; color: var(--text-mid);
  font-size: .84rem; line-height: 1.5;
  padding: 5px 8px; border-radius: 8px; transition: .2s;
}
.sb-toc-list a:hover,
.sb-toc-list a.toc-active {
  background: var(--blue-xlight); color: var(--blue); font-weight: 600;
}
.sb-toc.toc-empty { display: none; }

/* مقالات ذات صلة */
.sb-related { padding: 20px; }
.sb-related-title {
  font-family: 'Cairo', sans-serif; font-weight: 800;
  color: var(--navy); margin-bottom: 16px; font-size: .95rem;
}
.sb-related-list { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.sb-related-item { display: flex; gap: 12px; align-items: flex-start; }
.sb-rel-thumb { flex-shrink: 0; width: 64px; height: 64px; border-radius: 10px; overflow: hidden; display: block; }
.sb-rel-thumb img { width: 100%; height: 100%; object-fit: cover; }
.sb-rel-info { display: flex; flex-direction: column; gap: 4px; }
.sb-rel-ttl { font-size: .85rem; font-weight: 700; color: var(--navy); text-decoration: none; line-height: 1.4; }
.sb-rel-ttl:hover { color: var(--blue); }
.sb-rel-date { font-size: .75rem; color: var(--text-light); }

/* ══ Responsive ══ */
@media (min-width: 1024px) {
  .art-container { grid-template-columns: 1fr 300px; }
}
@media (max-width: 900px) {
  .art-container { grid-template-columns: 1fr; }
  .art-sidebar { position: static; }
}
@media (max-width: 600px) {
  .art-sidebar { order: -1; }
  .sb-related, .sb-toc { display: none; }
  .art-header { padding: 22px 18px 0; }
  .art-body { padding: 22px 18px 26px; }
  .art-tags { padding: 14px 18px 18px; }
  .art-nav { grid-template-columns: 1fr; }
  .art-title { font-size: 1.3rem; }
  .art-body h2 { font-size: 1.12rem; padding: 12px 16px; }
  .art-body h3 { font-size: 1.05rem; }
  .art-body { font-size: .97rem; line-height: 1.9; }
  .art-layout { padding: 18px 0 40px; }
}
