/* =========================================================
   SERVICE PAGE (Premium RTL, No frameworks)
   ========================================================= */

.service-page{ overflow-x: clip; }
@supports not (overflow: clip){ .service-page{ overflow-x: hidden; } }
.service-page *, .service-page *::before, .service-page *::after{ box-sizing: border-box; }
.service-page img, .service-page svg, .service-page iframe, .service-page video{ max-width: 100%; height: auto; }

/* HERO BG */
.service-hero{ position: relative; padding: clamp(26px, 4vw, 70px) 0; overflow: clip; }
.service-hero__bg{ position:absolute; inset:0; pointer-events:none; z-index:0; }
.service-hero__mesh, .service-hero__grid, .service-hero__noise{ position:absolute; inset:0; }
.service-hero__mesh{
  background:
    radial-gradient(900px 520px at 15% 25%, rgba(240,48,48,.16), transparent 60%),
    radial-gradient(900px 520px at 85% 30%, rgba(48,64,96,.16), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #fbfbfc 100%);
}
.service-hero__grid{
  opacity: .32;
  background:
    linear-gradient(to right, rgba(15,23,42,.06) 1px, transparent 1px) 0 0/44px 44px,
    linear-gradient(to bottom, rgba(15,23,42,.06) 1px, transparent 1px) 0 0/44px 44px;
  mask-image: radial-gradient(closest-side at 50% 36%, #000 0%, transparent 78%);
  -webkit-mask-image: radial-gradient(closest-side at 50% 36%, #000 0%, transparent 78%);
}
.service-hero__noise{
  opacity: .08;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
  background-size: 180px 180px;
  mix-blend-mode: multiply;
}

.service-hero__inner{
  position:relative;
  z-index:1;
  direction: rtl;
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: clamp(14px, 2.4vw, 28px);
  align-items:start;
}

/* Breadcrumb */
.crumbs{ grid-column: 1 / -1; }
.crumbs__list{ margin:0; padding:0; list-style:none; display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.crumbs__item{ display:flex; align-items:center; gap:10px; }
.crumbs__item:not(:last-child)::after{ content:"/"; opacity:.45; }
.crumbs__link{ font-weight: 900; color: rgba(15,23,42,.70); }
.crumbs__link:hover{ color:#0f172a; text-decoration: underline; }
.crumbs__current{ font-weight: 1000; color:#0f172a; }

.kicker{
  margin: 0 0 10px;
  font-weight: 1000;
  color: #304060;
  display:inline-flex; align-items:center; gap:10px;
}
.kicker::before{
  content:"";
  width: 10px; height: 10px;
  border-radius: 999px;
  background: #F03030;
  box-shadow: 0 0 0 7px rgba(240,48,48,.10);
}
.title{
  margin:0 0 10px;
  font-size: clamp(22px, 2.6vw, 40px);
  line-height:1.15;
  color:#0f172a;
  font-weight:1000;
}
.subtitle{
  margin:0 0 14px;
  color: rgba(15,23,42,.74);
  font-weight: 750;
  line-height: 1.95;
  max-width: 90ch;
}

.actions{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom: 12px; }
.btn__sub{ display:block; font-size:12px; font-weight:900; opacity:.85; }

.area-chips{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom: 12px; }
.chip{
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(48,64,96,.05);
  font-weight: 1000;
  color:#0f172a;
}
.chip:hover{ background: rgba(240,48,48,.06); border-color: rgba(240,48,48,.20); }

.hero-points{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.point{
  border-radius: 22px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 54px rgba(15,23,42,.08);
  padding: 12px;
}
.point__h{ display:block; font-weight:1000; color:#0f172a; margin-bottom:6px; }
.point__p{ display:block; font-weight:750; color: rgba(15,23,42,.70); line-height:1.85; font-size:13.5px; }

/* Slider */
.hero-slider{
  border-radius: 26px;
  overflow: hidden;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(48,64,96,.06);
  box-shadow: 0 18px 54px rgba(15,23,42,.10);
}
.hero-slider__track{
  display:flex;
  width:100%;
  transform: translateX(0);
  transition: transform 520ms cubic-bezier(.2,.8,.2,1);
  will-change: transform;
}
.hero-slide{ flex: 0 0 100%; margin:0; }
.hero-slide img{ width:100%; height:100%; display:block; aspect-ratio: 16/11; }

.hero-slider__ui{
  display:flex;
  justify-content: space-between;
  gap:10px;
  align-items:center;
  padding: 12px;
  background: rgba(255,255,255,.70);
  border-top: 1px solid rgba(15,23,42,.10);
}
.hs-btn{
  height: 44px;
  padding: 0 14px;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.75);
  font-weight: 1000;
  cursor: pointer;
}
.hs-btn:hover{ background: rgba(240,48,48,.06); border-color: rgba(240,48,48,.18); }

.hs-dots{ display:flex; gap: 8px; align-items:center; }
.hs-dot{
  width: 10px; height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.18);
  background: rgba(15,23,42,.08);
  cursor: pointer;
}
.hs-dot.is-active{
  background: rgba(240,48,48,.88);
  border-color: rgba(240,48,48,.28);
  box-shadow: 0 0 0 6px rgba(240,48,48,.10);
}

/* Shared section styles */
.section-head{ direction: rtl; margin-bottom: 14px; }
.section-kicker{
  margin:0 0 10px;
  font-weight:1000;
  color:#304060;
  display:inline-flex; gap:10px; align-items:center;
}
.section-kicker::before{
  content:"";
  width: 10px; height: 10px; border-radius: 999px;
  background:#F03030; box-shadow: 0 0 0 7px rgba(240,48,48,.10);
}
.section-title{
  margin:0 0 10px;
  font-size: clamp(20px, 2.2vw, 32px);
  color:#0f172a;
  line-height: 1.2;
}
.section-subtitle{
  margin:0;
  color: rgba(15,23,42,.72);
  font-weight: 750;
  line-height: 1.9;
  max-width: 90ch;
}

/* Benefits */
.service-benefits{ padding: clamp(28px, 4vw, 80px) 0; }
.benefits-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.benefit{
  border-radius: 22px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 54px rgba(15,23,42,.08);
  padding: 14px;
}
.benefit h3{ margin:0 0 8px; font-weight:1000; color:#0f172a; font-size: 15px; }
.benefit p{ margin:0; font-weight:750; color: rgba(15,23,42,.70); line-height:1.85; }

/* Details + sticky sidebar */
.service-details{ padding: 0 0 clamp(28px, 4vw, 80px); }
.service-details__inner{
  display:grid;
  grid-template-columns: 1fr 360px;
  gap: clamp(14px, 2.4vw, 28px);
  align-items:start;
  direction: rtl;
}
.rich-content{
  border-radius: 26px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 54px rgba(15,23,42,.08);
  padding: 16px;
}
.rich-content h2, .rich-content h3{ margin-top: 18px; font-weight:1000; color:#0f172a; line-height:1.3; }
.rich-content p, .rich-content li{ font-weight:750; color: rgba(15,23,42,.74); line-height:2.0; font-size:16px; }
.rich-content a{ font-weight:1000; color:#304060; text-decoration: underline; }
.rich-content a:hover{ color:#0f172a; }

.details-side{ position: sticky; top: 16px; align-self:start; }
.side-card{
  border-radius: 22px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 54px rgba(15,23,42,.08);
  padding: 14px;
}
.side-card--cta{ border-color: rgba(240,48,48,.20); background: rgba(240,48,48,.04); }
.side-title{ margin:0 0 10px; font-weight:1000; color:#0f172a; font-size: 14.5px; }
.side-text{ margin:0 0 12px; font-weight:750; color: rgba(15,23,42,.70); line-height:1.85; }
.side-actions{ display:flex; flex-wrap:wrap; gap:10px; }
.side-mini{ display:flex; flex-wrap:wrap; gap:10px; margin-top: 12px; }
.mini{
  padding: 9px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.70);
  font-weight: 1000;
  color: rgba(15,23,42,.75);
  font-size: 12.5px;
}

/* Process */
.service-process{ padding: clamp(28px, 4vw, 80px) 0; }
.steps{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  direction: rtl;
}
.step{
  border-radius: 22px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 54px rgba(15,23,42,.08);
  padding: 14px;
}
.step__n{ display:block; font-weight:1000; color:#F03030; direction:ltr; }
.step__h{ margin: 6px 0 8px; font-weight:1000; color:#0f172a; font-size: 14.5px; }
.step__p{ margin:0; font-weight:750; color: rgba(15,23,42,.70); line-height:1.85; }

/* Packages */
.service-packages{ padding: clamp(28px, 4vw, 80px) 0; }
.packages-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  direction: rtl;
}
.pkg{
  border-radius: 22px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 54px rgba(15,23,42,.08);
  padding: 14px;
}
.pkg__h{ margin:0 0 8px; font-weight:1000; color:#0f172a; }
.pkg__p{ margin:0 0 12px; font-weight:750; color: rgba(15,23,42,.70); line-height:1.85; }
.pkg__cta{
  display:inline-flex;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(48,64,96,.05);
  font-weight: 1000;
  color:#0f172a;
}
.pkg__cta:hover{ background: rgba(240,48,48,.06); border-color: rgba(240,48,48,.18); }

/* FAQ */
.service-faq{ padding: clamp(28px, 4vw, 80px) 0; }
.faq{
  border-radius: 26px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 54px rgba(15,23,42,.08);
  padding: 10px;
  direction: rtl;
}
.faq-item{
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,.08);
  background: rgba(255,255,255,.70);
  padding: 12px;
  margin: 10px 0;
}
.faq-q{ cursor:pointer; font-weight:1000; color:#0f172a; }
.faq-a{ margin-top: 10px; color: rgba(15,23,42,.72); font-weight:750; line-height:1.9; }

/* Related */
.service-related{ padding: clamp(28px, 4vw, 80px) 0; }
.related-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  direction: rtl;
}
.rel{
  border-radius: 22px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 18px 54px rgba(15,23,42,.08);
  padding: 14px;
  display:flex;
  justify-content: space-between;
  align-items:center;
}
.rel__t{ font-weight:1000; color:#0f172a; }
.rel__m{ font-weight:900; color: rgba(15,23,42,.62); }

/* Final */
.service-final{ padding: 0 0 clamp(28px, 4vw, 80px); }
.final-card{
  border-radius: 26px;
  border: 1px solid rgba(240,48,48,.22);
  background: rgba(240,48,48,.06);
  box-shadow: 0 18px 54px rgba(15,23,42,.08);
  padding: 16px;
  direction: rtl;
  display:flex;
  justify-content: space-between;
  gap: 12px;
  align-items:center;
}
.final-card__txt h2{ margin:0 0 6px; font-weight:1000; color:#0f172a; }
.final-card__txt p{ margin:0; font-weight:750; color: rgba(15,23,42,.72); line-height:1.9; }
.final-card__actions{ display:flex; flex-wrap:wrap; gap: 10px; }

/* Sticky bottom (mobile) */
.service-sticky{
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: 12px;
  z-index: 9990;
  display:none;
  gap: 10px;
  border-radius: 18px;
  padding: 10px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.86);
  backdrop-filter: blur(10px);
}
.service-sticky__btn{
  flex: 1 1 auto;
  text-align:center;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(48,64,96,.05);
  font-weight: 1000;
  color:#0f172a;
}
.service-sticky__btn--wa{
  border-color: rgba(240,48,48,.20);
  background: rgba(240,48,48,.08);
}

/* Reveal */
[data-reveal]{ opacity:0; transform: translateY(10px); transition: opacity 260ms cubic-bezier(.2,.8,.2,1), transform 260ms cubic-bezier(.2,.8,.2,1); }
.is-revealed{ opacity:1; transform: translateY(0); }

/* Responsive */
@media (max-width: 1100px){
  .service-hero__inner{ grid-template-columns: 1fr; }
  .service-details__inner{ grid-template-columns: 1fr; }
  .details-side{ position: static; }
  .benefits-grid{ grid-template-columns: 1fr; }
  .steps{ grid-template-columns: 1fr; }
  .packages-grid{ grid-template-columns: 1fr; }
  .related-grid{ grid-template-columns: 1fr; }
  .hero-points{ grid-template-columns: 1fr; }
  .final-card{ flex-direction: column; align-items:flex-start; }
  .service-sticky{ display:flex; }
}
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ transition:none; transform:none; opacity:1; }
}
