/* ═══════════════════════════════════════════════════════════════════
   EmirateFix Pro — Premium LIGHT Theme
   Inspired by Samsung.com & LG.com — Clean, Professional, Modern
   ═══════════════════════════════════════════════════════════════════ */

/* ─── DESIGN TOKENS ─────────────────────────────────────────────── */
:root {
  /* Backgrounds */
  --bg:        #FFFFFF;
  --bg-alt:    #F2F6FE;
  --bg-card:   #FFFFFF;
  --bg-dark:   #0D1826;
  --bg-dark2:  #162036;
  --bg-blue:   #EBF2FF;

  /* Borders */
  --border:    #DAE3F5;
  --border-md: #C5D5EF;

  /* Blue Brand */
  --azure:     #0066FF;
  --azure-h:   #0052CC;
  --azure-l:   #EBF2FF;
  --spark:     #0094F0;

  /* Text */
  --text-1:    #0D1826;
  --text-2:    #3D5070;
  --text-3:    #5B708F; /* darkened for WCAG AA: 5.05:1 on white, 4.52:1 on hero bg */
  --text-inv:  #F0F6FF;
  --text-inv2: #8FA8C8;

  /* Specials */
  --gold:     #F59E0B;
  --wa:       #168745; /* darkened for WCAG AA contrast 4.58:1 with white text */
  --success:  #10B981;
  --error:    #EF4444;

  /* Shadows — critical for light theme */
  --sh-xs:   0 1px 3px rgba(0,50,150,.06);
  --sh-sm:   0 2px 8px rgba(0,50,150,.09);
  --sh-md:   0 4px 20px rgba(0,50,150,.11);
  --sh-lg:   0 8px 40px rgba(0,50,150,.13);
  --sh-blue: 0 8px 28px rgba(0,102,255,.22);

  /* Type */
  --font: var(--body-font,'Cairo','Poppins',sans-serif);

  /* Radius */
  --r-xs:4px; --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:30px; --r-full:9999px;

  /* Container */
  --cx:1280px; --cp:clamp(16px,4vw,48px);
}

/* ─── RESET ──────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text-1);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;}
a{color:var(--azure);text-decoration:none;transition:color .2s;}
a:hover{color:var(--azure-h);}
ul{list-style:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}
input,select,textarea{font-family:inherit;}

/* ─── CONTAINER ──────────────────────────────────────────────────── */
.container{max-width:var(--cx);margin:0 auto;padding:0 var(--cp);}

/* ─── SECTIONS ───────────────────────────────────────────────────── */
.section{padding:clamp(60px,8vw,100px) 0;}
.section--alt{background:var(--bg-alt);}
.section-head{text-align:center;margin-bottom:clamp(40px,5vw,64px);}
.section-head--left{text-align:start;}
.section-tag{
  display:inline-block;
  font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--azure);background:var(--azure-l);
  padding:4px 12px;border-radius:var(--r-full);margin-bottom:10px;
}
.section-title{
  font-size:clamp(1.7rem,3.5vw,2.6rem);
  font-weight:800;color:var(--text-1);line-height:1.2;margin-bottom:12px;
}
.section-sub{color:var(--text-2);font-size:1.05rem;max-width:560px;margin:0 auto;}
.section-head--left .section-sub{margin:0;}
.section-cta-row{text-align:center;margin-top:32px;}
.section-divider{
  width:48px;height:4px;background:linear-gradient(90deg,var(--azure),var(--spark));
  border-radius:var(--r-full);margin:.8rem auto 0;
}
.section-head--left .section-divider{margin:.8rem 0 0;}

/* ─── BUTTONS ────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:12px 22px;
  border-radius:var(--r-full);font-size:.95rem;font-weight:600;
  transition:all .22s ease;white-space:nowrap;border:2px solid transparent;
  text-decoration:none;cursor:pointer;
}
.btn svg{flex-shrink:0;}
.btn--primary{background:var(--azure);color:#fff;border-color:var(--azure);}
.btn--primary:hover{background:var(--azure-h);border-color:var(--azure-h);color:#fff;
  box-shadow:var(--sh-blue);transform:translateY(-1px);}
.btn--outline{background:#fff;border-color:var(--border-md);color:var(--text-1);}
.btn--outline:hover{border-color:var(--azure);color:var(--azure);box-shadow:var(--sh-sm);}
.btn--ghost{background:rgba(0,102,255,.06);color:var(--azure);border-color:transparent;}
.btn--ghost:hover{background:rgba(0,102,255,.12);}
.btn--dark{background:var(--bg-dark);color:#fff;border-color:var(--bg-dark);}
.btn--dark:hover{background:#1c2e48;color:#fff;}
.btn--white{background:#fff;color:var(--azure);border-color:#fff;}
.btn--white:hover{background:#f0f5ff;color:var(--azure-h);}
.btn--whatsapp{background:var(--wa);color:#fff!important;border-color:var(--wa);}
.btn--whatsapp:hover{background:#116332;color:#fff;
  box-shadow:0 6px 20px rgba(37,211,102,.32);transform:translateY(-1px);}
.btn--sm{padding:8px 18px;font-size:.875rem;}
.btn--lg{padding:14px 30px;font-size:1rem;}
.btn--full{width:100%;justify-content:center;}
.mt8{margin-top:8px;}

/* ─── CARD BASE ──────────────────────────────────────────────────── */
.card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--sh-xs);
  transition:box-shadow .3s,border-color .3s,transform .3s;
}
.card:hover{box-shadow:var(--sh-md);border-color:var(--border-md);}
.glass-card{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r-xl);box-shadow:var(--sh-md);overflow:hidden;
}

/* ─── HEADER BAR ─────────────────────────────────────────────────── */
.header-bar{
  background:var(--azure);
  padding:7px 0;font-size:.82rem;color:#fff;
}
.header-bar__inner{display:flex;align-items:center;gap:16px;}
.header-bar a{color:#fff;}
.header-bar a:hover{color:rgba(255,255,255,.8);}
.header-bar svg{vertical-align:middle;}
.header-bar__sep{width:1px;height:14px;background:rgba(255,255,255,.3);}

/* ─── NAVBAR ─────────────────────────────────────────────────────── */
body{padding-top:108px;}
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;}
.site-header.scrolled .navbar{
  box-shadow:0 2px 20px rgba(0,50,150,.1);
}
.navbar{
  background:#fff;
  border-bottom:1px solid var(--border);
  transition:box-shadow .3s;
}
.navbar__inner{display:flex;align-items:center;gap:20px;height:68px;}
.navbar__logo{text-decoration:none;flex-shrink:0;}
.navbar__logo img{height:44px;width:auto;}
.navbar__logo-text{
  font-size:1.4rem;font-weight:900;color:var(--azure);letter-spacing:-.02em;
}
.navbar__links{flex:1;display:flex;justify-content:center;}
.nav-menu{display:flex;align-items:center;gap:2px;}
.nav-menu li a{
  color:var(--text-2);font-size:.9rem;font-weight:500;
  padding:7px 14px;border-radius:var(--r-sm);transition:all .2s;
}
.nav-menu li a:hover{color:var(--azure);background:var(--azure-l);}
.nav-menu li.current-menu-item a{color:var(--azure);font-weight:600;background:var(--azure-l);}
.navbar__actions{display:flex;align-items:center;gap:10px;margin-inline-start:auto;}
.btn-lang{
  font-size:.85rem;font-weight:700;color:var(--azure);
  padding:6px 14px;border:1.5px solid var(--border-md);border-radius:var(--r-full);
  transition:all .2s;background:#fff;
}
.btn-lang:hover{background:var(--azure);color:#fff;border-color:var(--azure);}
.navbar__burger{display:none;color:var(--text-1);padding:4px;}
.burger-icon{display:flex;}
.close-icon{display:none;}
.navbar__burger.open .burger-icon{display:none;}
.navbar__burger.open .close-icon{display:flex;}
.navbar__mobile{
  background:#fff;border-top:1px solid var(--border);
  padding:16px 0 24px;box-shadow:0 8px 24px rgba(0,50,150,.08);
}
.mobile-nav li a{
  display:block;padding:13px 0;font-size:1rem;font-weight:600;
  color:var(--text-2);border-bottom:1px solid var(--border);
}
.mobile-nav li a:hover{color:var(--azure);}
.mobile-nav__bottom{margin-top:16px;display:flex;flex-direction:column;gap:10px;}
.d-none-mobile{}

/* ─── HERO ───────────────────────────────────────────────────────── */
.hero{
  position:relative;
  min-height:calc(100vh - 108px);
  display:flex;align-items:center;
  padding:clamp(48px,6vw,80px) 0;
  overflow:hidden;
  background:linear-gradient(135deg,#EBF3FF 0%,#F7FBFF 40%,#FFFFFF 70%);
}
.hero__bg{position:absolute;inset:0;z-index:0;overflow:hidden;}
.hero__grid-lines{
  position:absolute;inset:0;
  background-image:linear-gradient(var(--border) 1px,transparent 1px),
    linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:56px 56px;
  opacity:.45;
  mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 30%,transparent 100%);
}
.hero__glow{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none;}
.hero__glow-1{width:600px;height:600px;background:rgba(0,102,255,.08);top:-150px;right:-150px;}
.hero__glow-2{width:400px;height:400px;background:rgba(0,148,240,.06);bottom:-80px;left:5%;}
.hero__devices{position:absolute;inset:0;pointer-events:none;}
.hero__dev{position:absolute;color:var(--azure);opacity:.07;}
.hero__dev--1{top:5%;right:3%;animation:float1 8s ease-in-out infinite;}
.hero__dev--2{top:42%;right:15%;animation:float2 10s ease-in-out infinite;}
.hero__dev--3{top:8%;right:22%;animation:float3 12s ease-in-out infinite;}
@keyframes float1{0%,100%{transform:translateY(0) rotate(0);}50%{transform:translateY(-18px) rotate(3deg);}}
@keyframes float2{0%,100%{transform:translateY(0) rotate(0);}50%{transform:translateY(14px) rotate(-2deg);}}
@keyframes float3{0%,100%{transform:translateY(0) rotate(0);}50%{transform:translateY(-10px) rotate(1deg);}}
.hero__inner{
  position:relative;z-index:1;display:grid;
  grid-template-columns:1fr 440px;gap:48px;align-items:center;width:100%;
}
.hero__badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--azure-l);border:1px solid rgba(0,102,255,.35);
  color:#0047CC;padding:6px 14px;border-radius:var(--r-full);
  font-size:.82rem;font-weight:700;margin-bottom:20px;
}
.pulse-dot{
  width:8px;height:8px;background:var(--azure);border-radius:50%;
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(1.5);}}
.hero__title{
  font-size:clamp(2rem,5vw,3.3rem);font-weight:900;
  line-height:1.12;margin-bottom:18px;color:var(--text-1);
}
.hero__title-accent{
  display:block;color:var(--azure);
}
.hero__subtitle{font-size:1.05rem;color:var(--text-2);margin-bottom:28px;max-width:500px;}
.hero__stats-row{display:flex;align-items:center;gap:20px;margin-bottom:32px;flex-wrap:wrap;}
.hero__stat strong{display:block;font-size:1.6rem;font-weight:900;color:var(--azure);}
.hero__stat span{font-size:.78rem;color:var(--text-3);font-weight:500;}
.hero__stat-div{width:1px;height:36px;background:var(--border-md);}
.hero__ctas{display:flex;gap:12px;flex-wrap:wrap;}

/* Hero form card */
.hero__form-card{padding:28px;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-xl);box-shadow:var(--sh-lg);}
.form-card-header{margin-bottom:20px;}
.form-card-header h3,.form-card-title{font-size:1.15rem;font-weight:700;color:var(--text-1);margin-bottom:4px;}
.form-card-header p{font-size:.82rem;color:var(--text-3);}

/* ─── FORMS ──────────────────────────────────────────────────────── */
.elf-form{display:flex;flex-direction:column;gap:14px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.form-group{display:flex;flex-direction:column;gap:6px;}
.form-group label{font-size:.82rem;font-weight:600;color:var(--text-2);}
.form-group input,.form-group select,.form-group textarea{
  background:#fff;border:1.5px solid var(--border);border-radius:var(--r-sm);
  padding:10px 14px;color:var(--text-1);font-size:.9rem;
  transition:border-color .2s,box-shadow .2s;width:100%;
}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-3);}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--azure);box-shadow:0 0 0 3px rgba(0,102,255,.12);
}
.form-group select option{background:#fff;color:var(--text-1);}
.form-group textarea{resize:vertical;min-height:80px;}
.elf-select{appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%230066FF' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;}
.form-divider{display:flex;align-items:center;gap:12px;font-size:.8rem;color:var(--text-2);margin:4px 0;font-weight:600;}
.form-divider::before,.form-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.form-response{padding:12px 16px;border-radius:var(--r-sm);font-size:.9rem;text-align:center;}
.form-response.success{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0;}
.form-response.error{background:#fef2f2;color:#dc2626;border:1px solid #fca5a5;}
.req{color:var(--azure);}
.input-error{border-color:var(--error)!important;}
.form-actions{display:flex;gap:12px;flex-wrap:wrap;}
.form-actions .btn{flex:1;min-width:160px;justify-content:center;}

/* ─── SERVICES GRID ──────────────────────────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:12px;}
.service-card{
  background:#fff;border:1.5px solid var(--border);
  border-radius:var(--r-lg);padding:28px 22px;transition:all .3s ease;
  position:relative;overflow:hidden;
}
.service-card:hover{
  border-color:var(--azure);transform:translateY(-5px);
  box-shadow:var(--sh-blue);
}
.service-card__icon{
  color:var(--azure);margin-bottom:16px;
  width:56px;height:56px;background:var(--azure-l);
  border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;
  transition:all .3s;
}
.service-card:hover .service-card__icon{background:var(--azure);color:#fff;}
.service-card__title{font-size:1rem;font-weight:700;color:var(--text-1);margin-bottom:8px;}
.service-card__desc{font-size:.83rem;color:var(--text-2);line-height:1.55;margin-bottom:16px;}
.service-card__link{font-size:.83rem;color:var(--azure);font-weight:600;}
.service-card__link:hover{color:var(--azure-h);}

/* ─── PROCESS STEPS ──────────────────────────────────────────────── */
.process-section{background:var(--bg-dark);}
.process-section .section-title{color:var(--text-inv);}
.process-section .section-sub{color:var(--text-inv2);}
.process-section .section-tag{background:rgba(0,102,255,.2);color:var(--text-inv);}
.process-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.process-step{
  text-align:center;padding:36px 24px;
  background:var(--bg-dark2);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg);position:relative;
  transition:border-color .3s;
}
.process-step:hover{border-color:rgba(0,102,255,.4);}
.process-step__num{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--azure);color:#fff;
  font-size:.75rem;font-weight:800;padding:4px 14px;
  border-radius:var(--r-full);letter-spacing:.05em;
}
.process-step__icon{color:var(--azure);margin:8px auto 14px;}
.process-step h3{font-size:1rem;font-weight:700;color:var(--text-inv);margin-bottom:8px;}
.process-step p{font-size:.85rem;color:var(--text-inv2);}

/* ─── STATS ──────────────────────────────────────────────────────── */
.stats-section{background:var(--azure);padding:clamp(48px,6vw,72px) 0;position:relative;overflow:hidden;}
.stats-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 120% at 80% 50%,rgba(255,255,255,.08),transparent);
}
.stats-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;}
.stat-block__num{display:block;font-size:clamp(2rem,5vw,3.2rem);font-weight:900;color:#fff;line-height:1;margin-bottom:8px;}
.stat-block__label{font-size:.9rem;color:rgba(255,255,255,.85);}

/* ─── FEATURES ───────────────────────────────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.feature-card{
  background:#fff;border:1.5px solid var(--border);
  border-radius:var(--r-lg);padding:28px 24px;transition:all .3s;
}
.feature-card:hover{border-color:var(--azure);box-shadow:var(--sh-md);}
.feature-card__icon{
  width:52px;height:52px;background:var(--azure-l);border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  color:var(--azure);margin-bottom:16px;
}
.feature-card h3{font-size:1rem;font-weight:700;color:var(--text-1);margin-bottom:8px;}
.feature-card p{font-size:.85rem;color:var(--text-2);line-height:1.6;}

/* ─── BOOKING SECTION ────────────────────────────────────────────── */
.booking-section{background:var(--bg-alt);}
.booking-inner{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:start;}
.booking-form-wrap{padding:36px;}
.booking-info{display:flex;flex-direction:column;gap:16px;padding-top:8px;}
.booking-info-item{
  display:flex;gap:14px;align-items:flex-start;padding:16px;
  background:#fff;border-radius:var(--r-md);border:1.5px solid var(--border);
  box-shadow:var(--sh-xs);
}
.booking-info-item__icon{
  width:44px;height:44px;background:var(--azure-l);border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--azure);flex-shrink:0;
}
.booking-info-item strong{display:block;font-size:.9rem;color:var(--text-1);margin-bottom:4px;}
.booking-info-item p{font-size:.82rem;color:var(--text-2);}
.booking-contact-card{
  background:var(--azure);border-radius:var(--r-md);padding:22px;text-align:center;
}
.booking-contact-card p{font-size:.85rem;color:#fff;margin-bottom:14px;}

/* ─── CTA SECTION ────────────────────────────────────────────────── */
.cta-section{background:var(--bg-dark);padding:clamp(48px,6vw,80px) 0;}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;}
.cta-inner h2{font-size:clamp(1.4rem,3vw,2.1rem);font-weight:800;color:#fff;}
.cta-inner p{color:var(--text-inv2);margin-top:8px;}
.cta-btns{display:flex;gap:12px;flex-wrap:wrap;}

/* ─── PAGE HERO ──────────────────────────────────────────────────── */
.page-hero{
  padding:clamp(32px,4vw,48px) 0 clamp(20px,3vw,36px);
  background:linear-gradient(135deg,#EBF3FF 0%,#F7FBFF 60%,#FFFFFF 100%);
  text-align:left;border-bottom:1px solid var(--border);
}
.page-hero--sm{padding:28px 0 24px;}
@media(max-width:768px){
  .page-hero--sm{padding:20px 0 16px;}
}
.page-hero__title{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:900;color:var(--text-1);margin-bottom:12px;text-align:left;}
.page-hero__sub{font-size:1.05rem;color:var(--text-2);max-width:560px;margin:0;}
.page-hero__breadcrumb{font-size:.82rem;color:var(--text-3);margin-bottom:12px;}
.page-hero__breadcrumb a{color:var(--azure);}
.page-hero__breadcrumb a:hover{color:var(--azure-h);}
.page-hero__breadcrumb span{margin:0 6px;color:var(--text-3);}

/* ─── SERVICES FULL PAGE ─────────────────────────────────────────── */
.services-full-grid{display:flex;flex-direction:column;gap:20px;}
.service-full-card{
  background:#fff;border:1.5px solid var(--border);
  border-radius:var(--r-lg);padding:28px;transition:all .3s;
  box-shadow:var(--sh-xs);
}
.service-full-card:hover{border-color:var(--azure);box-shadow:var(--sh-md);}
.service-full-card__top{display:flex;gap:20px;align-items:flex-start;margin-bottom:20px;}
.service-full-card__icon{
  width:64px;height:64px;background:var(--azure-l);border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;color:var(--azure);flex-shrink:0;
}
.service-full-card__title{font-size:1.2rem;font-weight:700;color:var(--text-1);margin-bottom:6px;}
.service-full-card__top p{color:var(--text-2);font-size:.95rem;}
.service-full-card__problems h4{font-size:.85rem;color:var(--text-2);font-weight:600;margin-bottom:10px;}
.prob-list{display:flex;flex-wrap:wrap;gap:8px;}
.prob-list li{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--azure-l);border:1px solid rgba(0,102,255,.15);
  border-radius:var(--r-full);padding:4px 12px;font-size:.8rem;color:var(--text-2);
}
.check-icon{color:var(--azure);}
.service-full-card__action{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap;}
.services-form-section{background:var(--bg-alt);}
.services-form-inner{display:grid;grid-template-columns:1fr 280px;gap:40px;align-items:start;}
.services-form-wrap{padding:32px;}
.services-form-wrap h2{font-size:1.4rem;font-weight:700;color:var(--text-1);margin-bottom:6px;}
.services-form-wrap p{font-size:.85rem;color:var(--text-2);margin-bottom:20px;}
.services-contact-info{display:flex;flex-direction:column;gap:12px;}
.contact-info-card{
  background:#fff;border:1.5px solid var(--border);
  border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-xs);
}
.contact-info-item{
  display:flex;align-items:center;gap:10px;color:var(--text-2);
  font-size:.9rem;padding:8px 0;border-bottom:1px solid var(--border);
}
.contact-info-item:last-child{border-bottom:none;}
.contact-info-item svg{color:var(--azure);flex-shrink:0;}
.contact-info-item a{color:var(--text-1);}
.contact-info-item a:hover{color:var(--azure);}

/* ─── CONTACT PAGE ───────────────────────────────────────────────── */
.contact-layout{display:grid;grid-template-columns:300px 1fr;gap:40px;align-items:start;}
.contact-info-aside{display:flex;flex-direction:column;gap:10px;}
.contact-info-block{
  display:flex;gap:14px;padding:16px;background:#fff;
  border:1.5px solid var(--border);border-radius:var(--r-md);
  align-items:flex-start;box-shadow:var(--sh-xs);
  transition:border-color .2s,box-shadow .2s;
}
.contact-info-block:hover{border-color:var(--azure);box-shadow:var(--sh-sm);}
.contact-info-block__icon{
  width:40px;height:40px;background:var(--azure-l);border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;color:var(--azure);flex-shrink:0;
}
.contact-info-block strong{display:block;font-size:.78rem;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px;}
.contact-info-block a,.contact-info-block p{color:var(--text-1);font-size:.9rem;font-weight:500;}
.contact-info-block a:hover{color:var(--azure);}
.contact-cta-wa{margin-top:8px;}
.contact-form-area{background:#fff;border:1.5px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--sh-sm);overflow:hidden;}
.contact-tabs{display:flex;border-bottom:1.5px solid var(--border);background:var(--bg-alt);}
.contact-tab{
  flex:1;display:flex;align-items:center;justify-content:center;gap:6px;
  padding:14px 10px;font-size:.85rem;font-weight:600;color:var(--text-3);
  border-bottom:2.5px solid transparent;transition:all .2s;background:none;cursor:pointer;
}
.contact-tab:hover{color:var(--azure);}
.contact-tab.active{color:var(--azure);border-bottom-color:var(--azure);background:#fff;}
.contact-tab-panel{padding:28px;}
.contact-tab-panel[hidden]{display:none;}
.star-rating{display:flex;gap:6px;}
.star-btn{color:var(--border-md);transition:color .2s,transform .15s;padding:2px;}
.star-btn:hover,.star-btn.lit{color:var(--gold);transform:scale(1.15);}
.star-btn svg{pointer-events:none;}

/* ─── BLOG ───────────────────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.blog-card{
  background:#fff;border:1.5px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;transition:all .3s;
  box-shadow:var(--sh-xs);
}
.blog-card:hover{border-color:var(--azure);transform:translateY(-4px);box-shadow:var(--sh-md);}
.blog-card__img{display:block;aspect-ratio:16/9;overflow:hidden;}
.blog-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.blog-card:hover .blog-card__img img{transform:scale(1.04);}
.blog-card__img--placeholder{
  display:block;aspect-ratio:16/9;
  background:linear-gradient(135deg,var(--azure-l),#fff);border-bottom:1px solid var(--border);
}
.blog-card__body{padding:20px;}
.blog-card__cats{font-size:.75rem;color:var(--azure);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;}
.blog-card__title{font-size:1rem;font-weight:700;color:var(--text-1);margin-bottom:8px;line-height:1.4;}
.blog-card__title a{color:var(--text-1);}
.blog-card__title a:hover{color:var(--azure);}
.blog-card__excerpt{font-size:.83rem;color:var(--text-2);margin-bottom:16px;line-height:1.55;}
.pagination-wrap{margin-top:48px;display:flex;justify-content:center;}
.pagination-wrap .nav-links{display:flex;gap:8px;align-items:center;}
.pagination-wrap .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:40px;height:40px;padding:0 12px;
  background:#fff;border:1.5px solid var(--border);border-radius:var(--r-sm);
  color:var(--text-2);font-size:.9rem;transition:all .2s;text-decoration:none;
}
.pagination-wrap .page-numbers:hover,.pagination-wrap .page-numbers.current{
  background:var(--azure);border-color:var(--azure);color:#fff;
}

/* ─── SINGLE POST / PAGE ─────────────────────────────────────────── */
/* Centred article column — optimal reading width on all screens */
.single-article{max-width:820px;margin:0 auto;width:100%;overflow:hidden;}
.content-prose{line-height:1.8;font-size:1rem;color:var(--text-2);overflow:hidden;}
.content-prose h1,.content-prose h2,.content-prose h3,
.content-prose h4,.content-prose h5,.content-prose h6{
  color:var(--text-1);margin:1.5em 0 .5em;font-weight:700;
  text-align:start; /* headings always left — never justified */
  opacity:1!important;visibility:visible!important;
  transform:none!important;animation:none!important;
}
.content-prose h2{font-size:1.4rem;}
.content-prose h3{font-size:1.2rem;}
.content-prose p{margin-bottom:1em;}
.content-prose a{color:var(--azure);}
.content-prose ul,.content-prose ol{padding-inline-start:1.5em;margin-bottom:1em;}
.content-prose li{margin-bottom:.4em;}
.content-prose strong{color:var(--text-1);}

/* ─── FOOTER (Samsung-style dark footer) ─────────────────────────── */
.site-footer{border-top:1px solid var(--border-md);background:var(--bg-dark);}
.footer-main{padding:clamp(48px,6vw,72px) 0;}
.footer-main__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:40px;}
.footer-logo img{height:40px;width:auto;margin-bottom:14px;filter:brightness(0) invert(1);}
.footer-logo-text{font-size:1.3rem;font-weight:900;color:#fff;display:block;margin-bottom:12px;}
.footer-about{font-size:.85rem;color:var(--text-inv2);line-height:1.7;margin-bottom:20px;}
.footer-social{display:flex;gap:10px;}
.social-link{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);border-radius:var(--r-sm);
  color:var(--text-inv2);transition:all .2s;
}
.social-link:hover{background:var(--azure);border-color:var(--azure);color:#fff;}
.social-link--wa:hover{background:var(--wa);border-color:var(--wa);}
.footer-col__title{
  font-size:.8rem;font-weight:700;color:#fff;
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;
}
.footer-links li{margin-bottom:8px;}
.footer-links a{font-size:.85rem;color:var(--text-inv2);transition:color .2s;}
.footer-links a:hover{color:#fff;}
.footer-contact-list li{
  display:flex;gap:10px;align-items:flex-start;
  font-size:.85rem;color:var(--text-inv2);margin-bottom:10px;
}
.footer-contact-list svg{color:var(--azure);flex-shrink:0;margin-top:2px;}
.footer-contact-list a{color:var(--text-inv2);}
.footer-contact-list a:hover{color:#fff;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:16px 0;}
.footer-bottom__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.footer-bottom p{font-size:.82rem;color:var(--text-inv2);}
.footer-wa-fab{
  position:fixed;bottom:24px;inset-inline-end:24px;
  width:56px;height:56px;background:var(--wa);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 4px 20px rgba(37,211,102,.45);z-index:999;
  transition:transform .25s,box-shadow .25s;
}
.footer-wa-fab:hover{transform:scale(1.1);box-shadow:0 6px 30px rgba(37,211,102,.55);color:#fff;}

/* Floating buttons stack */
.fab-stack{
  position:fixed;bottom:80px;inset-inline-end:24px;
  display:flex;flex-direction:column;align-items:center;gap:12px;
  z-index:999;
}
.fab-stack .footer-wa-fab,
.fab-stack .footer-phone-fab{
  position:static; /* override fixed — stack handles positioning */
}
.footer-phone-fab{
  width:56px;height:56px;background:var(--azure);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 4px 20px rgba(0,102,255,.35);
  transition:transform .25s,box-shadow .25s;text-decoration:none;
}
.footer-phone-fab:hover{transform:scale(1.1);box-shadow:0 6px 30px rgba(0,102,255,.5);color:#fff;}

/* Scroll-to-top button */

/* ─── MISC ───────────────────────────────────────────────────────── */
.mt8{margin-top:8px;}

/* ─── RESPONSIVE ─────────────────────────────────────────────────── */
@media (max-width:1100px){
  .hero__inner{grid-template-columns:1fr 400px;}
  .services-grid{grid-template-columns:repeat(3,1fr);}
  .features-grid{grid-template-columns:repeat(2,1fr);}
  .footer-main__grid{grid-template-columns:1fr 1fr;gap:32px;}
  .booking-inner{grid-template-columns:1fr 300px;}
}
@media (max-width:900px){
  body{padding-top:60px;}
  .header-bar{display:none;}
  .navbar__inner{height:60px;}
  .navbar__links,.d-none-mobile{display:none!important;}
  .navbar__burger{display:flex;}
  .hero__inner{grid-template-columns:1fr;}
  .hero__form-card{max-width:560px;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .process-steps{grid-template-columns:1fr;gap:24px;}
  .features-grid{grid-template-columns:1fr 1fr;}
  .booking-inner{grid-template-columns:1fr;}
  .blog-grid{grid-template-columns:1fr 1fr;}
  .contact-layout{grid-template-columns:1fr;}
  .services-form-inner{grid-template-columns:1fr;}
  .cta-inner{flex-direction:column;text-align:center;}
  .form-row{grid-template-columns:1fr;}
}
@media (max-width:600px){
  .services-grid{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .features-grid{grid-template-columns:1fr;}
  .blog-grid{grid-template-columns:1fr;}
  .hero__ctas{flex-direction:column;}
  .contact-tabs{flex-wrap:wrap;}
  .footer-main__grid{grid-template-columns:1fr;gap:24px;}
  .fab-stack{bottom:64px;inset-inline-end:16px;gap:10px;}
  .fab-stack .footer-wa-fab,
  .fab-stack .footer-phone-fab,
  .footer-wa-fab{bottom:16px;inset-inline-end:16px;width:48px;height:48px;}
  .form-actions{flex-direction:column;}
  .form-actions .btn{min-width:unset;}
}

/* ─── ANIMATIONS ─────────────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
.animate-fade-up{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;}
.animate-fade-up.in-view{opacity:1;transform:translateY(0);}

/* ─── SCROLLBAR ──────────────────────────────────────────────────── */
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:#f0f4fb;}
::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:var(--azure);}

/* ─── LANGUAGE BUTTON (link to en.emiratefix.com) ───────────────── */
.btn-lang {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .85rem;
  font-weight: 700;
  color: var(--azure);
  padding: 6px 14px;
  border: 1.5px solid var(--border-md);
  border-radius: var(--r-full);
  transition: all .2s;
  background: #fff;
  white-space: nowrap;
  text-decoration: none;
}
.btn-lang:hover {
  background: var(--azure);
  color: #fff;
  border-color: var(--azure);
  box-shadow: var(--sh-sm);
}

/* ─── JUSTIFIED TEXT (DESKTOP ONLY) ────────────────────────────────── */
/* Headings are explicitly excluded — they use text-align:start (see above) */
p,
.content-prose p,
.blog-card__excerpt,
.footer-about,
.service-desc,
.feat-card__desc,
.section-sub,
.page-hero__sub {
  text-align: justify;
  text-align-last: left;
  hyphens: auto;
  -webkit-hyphens: auto;
  -ms-hyphens: auto;
  overflow-wrap: break-word;
  word-break: break-word;
}

/* ─── MOBILE: disable justify — narrow screens create huge word gaps ── */
@media (max-width: 768px) {
  p,
  .content-prose p,
  .blog-card__excerpt,
  .footer-about,
  .service-desc,
  .feat-card__desc,
  .section-sub,
  .page-hero__sub {
    text-align: start;
  }
}

/* ─── FEATURED IMAGE IN SINGLE POST ────────────────────────────────── */
.single-featured-img {
  width: 100%;
  margin-bottom: 2rem;
  border-radius: var(--r-md);
  overflow: hidden;
}
.single-featured-img img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  border-radius: var(--r-md);
}

/* ─── SCROLL-TO-TOP: LEFT for Arabic (RTL), RIGHT for English (LTR) ── */
/* Default (LTR / English): already at inset-inline-end:24px in .fab-stack */
/* RTL override: move stack to the right side (inline-start = right in RTL) */
html[dir="rtl"] .fab-stack {
  inset-inline-end: auto;
  inset-inline-start: 24px;
}
@media (max-width: 768px) {
  html[dir="rtl"] .fab-stack {
    inset-inline-end: auto;
    inset-inline-start: 16px;
  }
}

/* ─── EN SITE: Phone+WhatsApp LEFT, Scroll-top RIGHT ───────────────── */
/* fab-stack (phone+whatsapp) → LEFT side */
.fab-stack {
  inset-inline-end: auto !important;
  inset-inline-start: 24px;
}
/* scroll-top → RIGHT side, fixed at bottom-right (desktop / other pages) */
/* scroll-top hidden/visible controlled by JS — do NOT override display */

/* ── INLINE MODE (mobile front-page): button flows with the page above the form ── */

@media (max-width: 600px) {
  .fab-stack {
    inset-inline-start: 16px;
    inset-inline-end: auto !important;
  }
}

/* ─── MOBILE RESPONSIVE: Single post / page layout ─────────────────── */
@media (max-width: 900px) {
  .single-article {
    max-width: 100% !important;
    padding: 0 !important;
  }
  .page-hero__title {
    font-size: clamp(1.4rem, 5vw, 2rem) !important;
    word-break: break-word;
  }
  .content-prose {
    font-size: 1rem;
    line-height: 1.8;
    width: 100% !important;
  }
  .content-prose img {
    max-width: 100% !important;
    width: auto !important;
    height: auto !important;
  }
}
@media (max-width: 600px) {
  .container {
    padding-inline: 16px !important;
  }
}

/* ══════════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — Full site fix for phones (≤ 768px)
   No changes to desktop design
   ══════════════════════════════════════════════════════════════════ */

/* ── General containers ── */
@media (max-width: 768px) {
  .container {
    padding-inline: 18px !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .section { padding-block: 48px !important; }

  /* ── Typography ── */
  .page-hero__title {
    font-size: clamp(1.35rem, 5.5vw, 2rem) !important;
    line-height: 1.3;
    word-break: break-word;
  }
  .section-title { font-size: clamp(1.3rem, 5vw, 1.8rem) !important; }
  h1,h2,h3 { word-break: break-word; }

  /* ── Single post / page layout ── */
  .single-article {
    max-width: 100% !important;
  }
  .content-prose {
    font-size: 1rem !important;
    line-height: 1.85 !important;
    overflow-x: hidden;
  }
  /* Content images: constrain to container, never stretch small images */
  .content-prose img {
    max-width: 100% !important;
    width: auto !important;
    height: auto !important;
    display: block;
    border-radius: var(--r-sm);
    margin: 1em auto;
  }
  /* Featured image always fills full width (intentional) */
  .single-featured-img img {
    width: 100% !important;
    height: auto !important;
    border-radius: var(--r-md);
  }
  .content-prose table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }

  /* ── Blog grid ── */
  .blog-grid { grid-template-columns: 1fr !important; }
  .blog-card__img img { width: 100% !important; height: 200px !important; object-fit: cover; }

  /* ── Services grid ── */
  .services-grid { grid-template-columns: 1fr !important; }

  /* ── Features grid ── */
  .features-grid { grid-template-columns: 1fr !important; }

  /* ── Stats grid ── */
  .stats-grid { grid-template-columns: repeat(2,1fr) !important; }

  /* ── Hero section ── */
  .hero__inner { grid-template-columns: 1fr !important; text-align: center; }
  .hero__form-card { max-width: 100% !important; }
  .hero__ctas { flex-direction: column !important; gap: 12px !important; }
  .hero__ctas .btn { width: 100% !important; justify-content: center; }

  /* ── Booking section ── */
  .booking-inner { grid-template-columns: 1fr !important; }

  /* ── Footer ── */
  .footer-main__grid { grid-template-columns: 1fr !important; gap: 28px !important; }
  .footer-bottom__inner { flex-direction: column !important; text-align: center; gap: 8px; }

  /* ── Forms ── */
  .form-row { grid-template-columns: 1fr !important; }
  .form-actions { flex-direction: column !important; }
  .form-actions .btn { width: 100% !important; min-width: unset !important; }
  .elf-form input,
  .elf-form select,
  .elf-form textarea { font-size: 16px !important; } /* prevents iOS zoom */

  /* ── Contact page ── */
  .contact-layout { grid-template-columns: 1fr !important; }
  .contact-tabs { flex-wrap: wrap !important; }
  .contact-tab { flex: 1 1 45% !important; text-align: center; }

  /* ── Sidebar form card ── */
  .sidebar-form-card { padding: 20px 16px !important; }

  /* ── Page hero ── */
  .page-hero { padding-block: 40px 32px !important; }
  .page-hero__breadcrumb { font-size: .8rem; flex-wrap: wrap; }

  /* ── Navbar ── */
  .navbar__inner { height: 60px !important; }
  .navbar__logo img { max-height: 36px !important; }

  /* ── Process steps ── */
  .process-steps { grid-template-columns: 1fr !important; }

  /* ── Services page full card ── */
  .service-full-card { padding: 20px !important; }
  .service-full-card__top { flex-direction: column !important; gap: 12px; }

  /* ── CTA section ── */
  .cta-inner { flex-direction: column !important; text-align: center !important; gap: 16px !important; }
  .cta-inner .btn { width: 100% !important; justify-content: center; }

  /* ── FAB buttons ── */
  .fab-stack { gap: 10px !important; }
  .footer-wa-fab,
  .footer-phone-fab,

  /* ── Glass cards ── */
  .glass-card { padding: 20px 16px !important; }
}

/* ── Extra small phones (≤ 400px) ── */
@media (max-width: 400px) {
  .container { padding-inline: 12px !important; }
  .stats-grid { grid-template-columns: 1fr 1fr !important; }
  .section-title { font-size: 1.2rem !important; }
  .btn { padding: 10px 16px !important; font-size: .88rem !important; }
}

/* ─── CONTENT IMAGE RESPONSIVE SYSTEM ──────────────────────────────────────
   المبدأ: max-width:100% يضمن عدم تجاوز الحاوية بينما width:auto يحافظ
   على الحجم الطبيعي للصورة الصغيرة. الصور الكبيرة تتقلص، الصغيرة تبقى.
   صور البارزة (single-featured-img) تبقى بعرض كامل كما هو مقصود.
   ─────────────────────────────────────────────────────────────────────────── */

/* ① Base rule: all images respect their container */
img {
  max-width: 100%;
  height: auto;
}

/* ② WordPress injects width/height attrs for CLS — override only the problematic stretch */
img[width],
img[height] {
  max-width: 100%;
  height: auto;
}

/* ③ Content images (articles + pages): natural size, centred, never overflow */
.content-prose img,
.entry-content img,
.wp-block-image img,
article .content-prose img {
  max-width: 100%;
  width: auto;
  height: auto;
  display: block;
  float: none !important;    /* prevent WordPress float from breaking layout */
  clear: both;
  margin: 1.5em auto;
  border-radius: var(--r-sm);
}

/* ④ WordPress alignment overrides — wide/full images should fill the column */
.content-prose img.alignfull,
.content-prose img.alignwide,
.content-prose .wp-block-image.alignfull img,
.content-prose .wp-block-image.alignwide img,
.entry-content img.alignfull,
.entry-content img.alignwide {
  width: 100%;
  max-width: 100%;
  border-radius: var(--r-md);
}

/* ⑤ Blog card thumbnails — always fill their fixed-ratio box */
.blog-card__img img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* ⑥ Mobile: images still never overflow, small ones scale down if needed */
@media (max-width: 768px) {
  .content-prose img,
  .entry-content img,
  .wp-block-image img {
    max-width: 100%;
    width: auto;
    height: auto;
    margin: 1em auto;
  }
  /* Prevent any image from causing horizontal scroll */
  .content-prose,
  .entry-content,
  article {
    overflow-x: hidden;
  }
}


/* ─── ARTICLE INLINE BOOKING FORM ──────────────────────────────────────────── */
.article-booking-form {
  margin-top: 48px;
  padding: 28px 32px;
  border-radius: var(--r-xl);
  border: 1.5px solid var(--azure);
  background: linear-gradient(135deg, rgba(0,102,255,0.04) 0%, rgba(0,196,255,0.04) 100%);
}
.article-booking-form__header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 24px;
}
.article-booking-form__icon {
  width: 56px;
  height: 56px;
  background: var(--azure);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  flex-shrink: 0;
}
.article-booking-form__header h3 {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--text-1);
  margin: 0 0 4px;
}
.article-booking-form__header p {
  font-size: .875rem;
  color: var(--text-2);
  margin: 0;
}
.article-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr auto;
  gap: 12px;
  align-items: end;
}
.article-form-submit .btn {
  height: 46px;
  white-space: nowrap;
}
.article-form-wa {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 14px;
  flex-wrap: wrap;
}
.article-form-wa span {
  font-size: .82rem;
  color: var(--text-3);
}
.btn--sm {
  padding: 8px 16px !important;
  font-size: .82rem !important;
  height: auto !important;
}
.btn--outline {
  background: transparent;
  border: 1.5px solid var(--border-md);
  color: var(--text-1);
}
.btn--outline:hover {
  background: var(--azure);
  border-color: var(--azure);
  color: #fff;
}

/* Responsive: article form stacks on mobile */
@media (max-width: 900px) {
  .article-form-row {
    grid-template-columns: 1fr 1fr;
  }
  .article-form-submit {
    grid-column: span 2;
  }
}
@media (max-width: 600px) {
  .article-booking-form {
    padding: 20px 16px;
  }
  .article-booking-form__header {
    flex-direction: row;
    gap: 12px;
  }
  .article-booking-form__icon {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
  }
  .article-form-row {
    grid-template-columns: 1fr;
  }
  .article-form-submit {
    grid-column: span 1;
  }
  .article-form-wa {
    gap: 8px;
  }
}

/* ─── FAB BUTTONS: Phone+WhatsApp bottom-left, Scroll-top bottom-right ───── */
.fab-stack {
  bottom: 24px !important;
  gap: 10px !important;
}
/* Fixed button (desktop/other pages): bottom-right */
@media (max-width: 600px) {
  .fab-stack {
    bottom: 16px !important;
    inset-inline-start: 16px !important;
  }
}

/* ─── FEATURED IMAGE: Single Posts & Pages ─────────────────────────────────── */

/* Single post featured image — full width, natural proportions */
.single-featured-img {
  width: 100% !important;
  margin-bottom: 2rem;
  border-radius: var(--r-lg);
  overflow: hidden;
  display: block;
  background: var(--bg-2);
}
.single-featured-img img {
  width: 100% !important;
  height: auto !important;
  object-fit: cover;
  display: block;
  border-radius: var(--r-lg);
}

/* Fallback when no image is set */
.single-featured-img__fallback {
  width: 100%;
  height: 280px;
  background: linear-gradient(135deg, var(--azure), #0040cc);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  color: #fff;
  border-radius: var(--r-lg);
  font-size: 1rem;
  font-weight: 600;
}

/* Page featured image */
.page-featured-img {
  width: 100%;
  margin-bottom: 2.5rem;
  border-radius: var(--r-lg);
  overflow: hidden;
}
.page-featured-img img {
  width: 100% !important;
  height: auto !important;
  object-fit: cover;
  display: block;
  border-radius: var(--r-lg);
}

/* Mobile — reduce max-height to preserve space */
@media (max-width: 768px) {
  .single-featured-img img,
  .page-featured-img img {
    object-fit: cover !important;
    border-radius: var(--r-md) !important;
  }
  .single-featured-img__fallback {
    height: 200px;
  }
}
@media (max-width: 480px) {
  .single-featured-img img,
  .page-featured-img img {
    object-fit: cover !important;
  }
}


/* ─── WORDPRESS FLOAT ALIGNMENT FIX (MOBILE) ───────────────────────────────
   يلغي تعويم الصور (float) عند WordPress على الشاشات الصغيرة.
   يشمل الصور التي لها inline style="float:right/left" أيضاً.
   ─────────────────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .alignleft,
  .alignright,
  .aligncenter,
  .content-prose figure,
  .entry-content figure {
    float: none !important;
    display: block;
    margin: 1em auto !important;
    max-width: 100% !important;
  }
  .wp-block-image {
    max-width: 100% !important;
  }
}


/* ─── POST CATEGORY PILLS ──────────────────────────────────────────────── */
.post-cats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
  margin-bottom: 4px;
}
.post-cat-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 12px;
  background: var(--azure-l);
  border: 1px solid rgba(0,102,255,.18);
  color: var(--azure);
  font-size: .75rem;
  font-weight: 700;
  border-radius: var(--r-full);
  text-decoration: none;
  transition: background .18s, color .18s;
  white-space: nowrap;
}
.post-cat-pill:hover {
  background: var(--azure);
  color: #fff;
  border-color: var(--azure);
}
.post-cat-pill svg {
  flex-shrink: 0;
}



/* ═══════════════════════════════════════════════════════════════════════
   SCROLL-TO-TOP: DEFINITIVE FIX — always above content, slide-in from top
   Overrides all previous declarations
   ═══════════════════════════════════════════════════════════════════════ */

/* 1. Base button — fixed, high z-index, starts hidden ABOVE viewport */

/* 2. Visible state: slides DOWN into position */

/* 3. Hover: only scale, don't interfere with slide transform */

/* 4. Mobile adjustments */
@media (max-width: 600px) {
}

/* ═══════════════════════════════════════════════════════════
   SCROLL-TO-TOP BUTTON — كود جديد كامل من الصفر
   ═══════════════════════════════════════════════════════════ */

#scrollTopBtn {
  /* الموضع: ثابت أسفل اليمين */
  position: fixed;
  bottom: 88px;
  right: 24px;
  left: auto;
  top: auto;

  /* فوق كل شيء */
  z-index: 999999;

  /* الشكل */
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  background: #1a1a2e;
  color: #ffffff;

  /* توسيط الأيقونة */
  display: flex;
  align-items: center;
  justify-content: center;

  /* ظل */
  box-shadow: 0 4px 20px rgba(0,0,0,0.35);

  /* الحركة: يبدأ مخفي فوق موضعه وينزل للأسفل */
  opacity: 0;
  transform: translateY(-50px);
  pointer-events: none;
  transition: opacity 0.4s ease, transform 0.4s cubic-bezier(0.34,1.4,0.64,1);
}

/* حالة الظهور: ينزل لموضعه */
#scrollTopBtn.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* هوفر */
#scrollTopBtn:hover {
  background: #0066ff;
  transform: translateY(0) scale(1.1);
  box-shadow: 0 6px 28px rgba(0,102,255,0.45);
}

/* موبايل */
@media (max-width: 600px) {
  #scrollTopBtn {
    bottom: 72px;
    right: 16px;
    width: 46px;
    height: 46px;
  }
}
