/* =========================================================
   asalah-kh.com — Redesign Stylesheet
   Brand: #E8551E orange / white / deep black
   Font: Tajawal (RTL Arabic)
   ========================================================= */

/* Omani Rial currency icon (img/RO.svg) — inline, orange */
.ryl{
  display:inline-block;
  width:1.1em;height:1.1em;
  vertical-align:-0.18em;
  background-color:#E8551E;
  -webkit-mask:url("../img/RO.svg") center/contain no-repeat;
          mask:url("../img/RO.svg") center/contain no-repeat;
  margin-inline:.2em;
}

/* ------- 0. Reset & Base ------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
#services{scroll-margin-top:90px}
body{
  font-family:'Tajawal',system-ui,-apple-system,'Segoe UI',sans-serif;
  font-weight:400;
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  direction:rtl;
  text-align:right;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img,svg,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;border:0;background:none;cursor:pointer;color:inherit}
input,textarea,select{font-family:inherit;font-size:inherit}
ul{list-style:none}

/* ------- 1. Tokens ------- */
:root{
  --orange:#E8551E;
  --orange-soft:#ff6b35;
  --orange-deep:#c8410f;
  --bg:#ffffff;
  --bg-alt:#f6f3ee;
  --ink:#0e0e0e;
  --ink-soft:#3a3a3a;
  --ink-mute:#7a7a7a;
  --line:#e6e2dc;
  --dark:#0a0a0a;
  --dark-2:#141414;
  --white:#ffffff;
  --radius:18px;
  --radius-sm:10px;
  --container:1280px;
  --gutter:clamp(16px,3vw,40px);

  --fs-mega:clamp(36px,7.5vw,104px);
  --fs-h1:clamp(34px,5vw,68px);
  --fs-h2:clamp(28px,3.8vw,48px);
  --fs-h3:clamp(22px,2.4vw,32px);
  --fs-lead:clamp(18px,1.6vw,22px);
  --fs-body:clamp(15px,1.05vw,17px);
  --fs-small:13px;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --transition:.6s var(--ease);
}

/* ------- 2. Layout helpers ------- */
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.container-wide{max-width:1480px;margin-inline:auto;padding-inline:var(--gutter)}
.section{padding:clamp(80px,10vw,160px) 0;position:relative}
.section-tight{padding:clamp(60px,7vw,110px) 0}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:13px;font-weight:600;letter-spacing:.08em;
  color:var(--ink-soft);text-transform:uppercase;
  margin-bottom:24px;
}
.eyebrow::before{
  content:'';width:32px;height:1px;background:var(--orange);
}
.headline{
  font-size:var(--fs-h1);font-weight:800;line-height:1.05;
  letter-spacing:-.02em;color:var(--ink);
}
.headline span.accent{color:var(--orange)}
.subhead{font-size:var(--fs-lead);color:var(--ink-soft);max-width:62ch;line-height:1.65;margin-top:24px}
.kicker{font-size:var(--fs-h2);font-weight:800;line-height:1.05;letter-spacing:-.02em}

/* ------- 3. Cursor (magnetic + custom dot) ------- */
@media (hover:hover) and (pointer:fine){
  .cursor{
    position:fixed;top:0;left:0;width:8px;height:8px;border-radius:50%;
    background:var(--orange);pointer-events:none;z-index:9999;
    transform:translate(-50%,-50%);mix-blend-mode:difference;
    transition:transform .25s var(--ease),width .3s var(--ease),height .3s var(--ease),opacity .3s;
  }
  .cursor.is-hover{width:54px;height:54px;background:rgba(232,85,30,.85)}
  body.cursor-on{cursor:none}
  body.cursor-on a,body.cursor-on button,body.cursor-on .magnetic{cursor:none}
}
.cursor{display:none}
@media (hover:hover) and (pointer:fine){.cursor{display:block}}

/* ------- 4. Nav ------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:90;
  padding:18px 0;
  transition:background .35s var(--ease),padding .35s var(--ease),box-shadow .35s var(--ease);
  background:rgba(255,255,255,.0);
}
.nav.is-stuck{
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(1.6) blur(14px);
  -webkit-backdrop-filter:saturate(1.6) blur(14px);
  padding:12px 0;
  box-shadow:0 1px 0 var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:20px;letter-spacing:-.02em}
.brand-mark{
  width:36px;height:36px;border-radius:10px;
  background:var(--orange);display:grid;place-items:center;color:#fff;font-weight:900;
  box-shadow:0 6px 18px rgba(232,85,30,.35);
}
.brand-mark svg{width:20px;height:20px}
.nav-menu{display:flex;align-items:center;gap:6px}
.nav-menu a{
  position:relative;padding:10px 14px;font-weight:600;font-size:15px;color:var(--ink);
  border-radius:8px;
}
.nav-menu a::after{
  content:'';position:absolute;left:14px;right:14px;bottom:6px;height:2px;background:var(--orange);
  transform:scaleX(0);transform-origin:right;transition:transform .35s var(--ease);
}
.nav-menu a:hover::after,.nav-menu a[aria-current="page"]::after{transform:scaleX(1);transform-origin:left}
.nav-cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 22px;border-radius:999px;background:var(--ink);color:#fff;font-weight:700;
  transition:transform .3s var(--ease),background .3s;
}
.nav-cta:hover{background:var(--orange)}
.nav-toggle{display:none;width:44px;height:44px;border-radius:10px;background:var(--ink);color:#fff;align-items:center;justify-content:center}

/* mobile drawer */
.drawer{
  position:fixed;inset:0;background:rgba(10,10,10,.96);color:#fff;z-index:95;
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:20px;
  transform:translateY(-100%);transition:transform .5s var(--ease),visibility .5s;
  padding:40px;visibility:hidden;
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  overflow-y:auto;
}
.drawer.open{transform:translateY(0);visibility:visible}
.drawer a{font-size:clamp(22px,5vw,32px);font-weight:700;color:#fff;padding:10px 14px;border-radius:10px}
.drawer a:hover,.drawer a:focus-visible{color:var(--orange);background:rgba(255,255,255,.04)}
.drawer-close{
  position:absolute;top:20px;left:20px;
  width:48px;height:48px;border-radius:50%;
  background:transparent;color:#fff;
  display:grid;place-items:center;cursor:pointer;
  border:1px solid rgba(255,255,255,.2);
  font-size:22px;line-height:1;
  transition:background .25s var(--ease),border-color .25s var(--ease),transform .3s var(--ease);
}
.drawer-close:hover,
.drawer-close:focus-visible{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.4);
}
.drawer-close:active{transform:scale(.94)}
.drawer-close svg{width:20px;height:20px}

/* Hide the X on desktop widths where the drawer itself is not used */
@media (min-width:961px){
  .drawer-close{display:none}
}

/* Raise nav-toggle above drawer so it can act as a close button too */
.nav-toggle{position:relative;z-index:96}

/* ------- 5. Buttons ------- */
.btn{
  --btn-bg:var(--orange);--btn-fg:#fff;
  position:relative;display:inline-flex;align-items:center;gap:12px;
  padding:18px 32px;border-radius:999px;
  background:var(--btn-bg);color:var(--btn-fg);
  font-weight:700;font-size:16px;letter-spacing:.01em;
  overflow:hidden;isolation:isolate;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),color .3s;
  box-shadow:0 10px 30px -10px rgba(232,85,30,.55);
}
.btn::before{
  content:'';position:absolute;inset:0;background:var(--ink);
  transform:translateY(101%);transition:transform .5s var(--ease);
  z-index:-1;
}
.btn:hover::before{transform:translateY(0)}
.btn:hover{box-shadow:0 16px 40px -12px rgba(0,0,0,.45)}
.btn .arr{display:inline-block;transition:transform .4s var(--ease)}
.btn:hover .arr{transform:translateX(-6px)}
.btn-ghost{
  --btn-bg:transparent;--btn-fg:var(--ink);
  border:1.5px solid var(--ink);box-shadow:none;
}
.btn-ghost:hover{color:#fff}
.btn-ghost::before{background:var(--ink)}
.btn-light{--btn-bg:#fff;--btn-fg:var(--ink);box-shadow:0 10px 30px -10px rgba(0,0,0,.2)}
.btn-light::before{background:var(--orange)}
.btn-light:hover{color:#fff}

.wa-floater{
  position:fixed;bottom:24px;left:24px;z-index:70;
  width:60px;height:60px;border-radius:50%;background:#25D366;color:#fff;
  display:grid;place-items:center;
  box-shadow:0 10px 30px rgba(37,211,102,.45);
  transition:transform .35s var(--ease);
}
.wa-floater:hover{transform:scale(1.08)}
.wa-floater svg{width:30px;height:30px}

/* ------- 6. Hero (Home) ------- */
.hero{
  position:relative;padding-top:clamp(110px,13vw,140px);padding-bottom:clamp(56px,7vw,72px);overflow:hidden;
  background:
    radial-gradient(900px 500px at 88% 10%,rgba(232,85,30,.12),transparent 60%),
    radial-gradient(700px 600px at 0% 80%,rgba(232,85,30,.08),transparent 60%),
    var(--bg);
}
.hero-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:60px;align-items:end}
.hero-mega{
  font-size:var(--fs-mega);font-weight:900;line-height:.95;letter-spacing:-.04em;
  color:var(--ink);
}
.hero-mega .word{display:inline-block;overflow:hidden;padding:0 .04em;line-height:1.44}
.hero-mega .word > span{display:inline-block;transform:translateY(110%);transition:transform .9s var(--ease-out)}
.hero-mega.is-in .word > span{transform:translateY(0)}
.hero-mega .accent{color:var(--orange)}
/* Arabic glyphs disconnect when outlined via -webkit-text-stroke, so the
   default is a solid fill. The outline style is re-enabled on desktop
   (≥1025px) only — Latin-heavy breakpoints where the effect reads cleanly. */
.hero-mega .accent-stroke{
  color:var(--orange);
  -webkit-text-stroke:0;
}
.hero-sub{margin-top:32px;max-width:48ch;font-size:var(--fs-lead);color:var(--ink-soft)}
.hero-cta-row{display:flex;flex-wrap:wrap;gap:16px;margin-top:36px}

.hero-visual{
  position:relative;aspect-ratio:1/1.05;border-radius:var(--radius);
  background:var(--bg-alt);
}
.hero-visual::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:
    conic-gradient(from 200deg at 70% 30%,var(--orange) 0deg,transparent 90deg,transparent 360deg);
  filter:blur(40px);opacity:.55;
}
.hero-visual-grid{
  position:absolute;inset:0;border-radius:inherit;overflow:hidden;
  background-image:
    linear-gradient(to right,rgba(0,0,0,.06) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(0,0,0,.06) 1px,transparent 1px);
  background-size:40px 40px;
}
.hero-visual .browser-card{
  position:absolute;inset:auto 24px 24px 24px;top:24px;
  background:#fff;border-radius:14px;box-shadow:0 30px 60px -20px rgba(0,0,0,.25),0 6px 18px rgba(0,0,0,.08);
  display:flex;flex-direction:column;overflow:hidden;
}
.browser-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;border-bottom:1px solid var(--line);background:#fafafa}
.browser-bar .dot{width:10px;height:10px;border-radius:50%;background:#e0e0e0}
.browser-bar .dot.r{background:#ff6058}.browser-bar .dot.y{background:#ffbd2e}.browser-bar .dot.g{background:#28ca42}
.browser-bar .url{margin-inline-start:auto;font-size:11px;color:var(--ink-mute);background:#fff;padding:4px 10px;border-radius:999px;border:1px solid var(--line)}
.browser-body{flex:1;padding:18px;display:flex;flex-direction:column;gap:10px;background:#fff}
.bb-row{height:10px;border-radius:6px;background:#efece7}
.bb-row.w70{width:70%}.bb-row.w50{width:50%}.bb-row.w90{width:90%}
.bb-hero{height:120px;border-radius:10px;background:linear-gradient(135deg,var(--orange),#ffb38a)}
.bb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:6px}
.bb-card{height:64px;border-radius:8px;background:#f3f0ea}
.float-badge{
  position:absolute;background:#fff;border-radius:14px;box-shadow:0 18px 40px -12px rgba(0,0,0,.18);
  padding:14px 18px;display:flex;align-items:center;gap:12px;font-weight:700;font-size:14px;
}
.float-badge .num{font-size:24px;color:var(--orange);font-weight:900}
.float-badge.b1{top:18%;right:-30px;animation:float 6s ease-in-out infinite}
.float-badge.b2{bottom:14%;left:-20px;animation:float 7s ease-in-out infinite reverse}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ------- 7. Marquee ------- */
.marquee{
  overflow:hidden;width:100%;
  background:var(--ink);color:#fff;padding:clamp(18px,2vw,26px) 0;
  border-block:1px solid #1f1f1f;
}
.marquee-track{
  display:flex;
  width:max-content;
  align-items:center;
  will-change:transform;
  backface-visibility:hidden;
  transform:translate3d(0,0,0);
}
/* CSS-animation fallback only used when JS hasn't taken over */
.marquee-track:not([data-js]){
  animation:marquee 18s linear infinite;
  animation-iteration-count:infinite;
}
.marquee-item{
  display:inline-flex;
  align-items:center;
  gap:clamp(12px,1.4vw,20px);
  white-space:nowrap;
  flex:0 0 auto;
  font-weight:700;
  font-size:clamp(16px,2.2vw,26px);
  letter-spacing:-.01em;
  color:currentColor;
  /* trailing space = part of the item so one copy tiles perfectly */
  margin-inline-end:clamp(32px,5vw,64px);
}
.marquee-item .dot{
  display:inline-block;
  width:8px;height:8px;
  background:var(--orange);
  border-radius:50%;
  flex:0 0 auto;
}
@keyframes marquee{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(var(--marquee-shift,-33.3333%),0,0)}
}
/* RTL: reverse so items enter from the RIGHT (reading direction) and exit LEFT */
[dir="rtl"] .marquee-track{animation-direction:reverse}

/* Pause on hover for readability on desktop only */
@media (hover:hover) and (pointer:fine){
  .marquee:hover .marquee-track{animation-play-state:paused}
  .marquee[data-paused] .marquee-track{/* JS pause target */}
}

/* ------- 8. Section heads ------- */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:60px;flex-wrap:wrap}
.sec-head .left{max-width:680px}
.sec-head .right{max-width:380px;color:var(--ink-soft)}

/* ------- 9. Services grid ------- */
.serv-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.serv-card{
  grid-column:span 4;background:var(--bg-alt);border-radius:var(--radius);padding:36px;
  position:relative;overflow:hidden;min-height:320px;display:flex;flex-direction:column;
  transition:transform .55s var(--ease),background .45s var(--ease),color .45s;
  border:1px solid transparent;
}
.serv-card .ico{
  width:56px;height:56px;border-radius:14px;background:var(--white);display:grid;place-items:center;
  color:var(--orange);transition:background .4s,color .4s;
}
.serv-card .ico svg{width:28px;height:28px}
.serv-card h3{margin-top:24px;font-size:24px;font-weight:800;letter-spacing:-.01em}
.serv-card p{margin-top:10px;color:var(--ink-soft);font-size:15px;flex:1}
.serv-card .more{
  margin-top:20px;display:inline-flex;align-items:center;gap:10px;font-weight:700;color:var(--orange);
}
.serv-card::after{
  content:'';position:absolute;inset:auto -30% -30% auto;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,85,30,.12),transparent 70%);
  transition:transform .6s var(--ease);
}
.serv-card:hover{transform:translateY(-6px);background:var(--ink);color:#fff;border-color:var(--ink)}
.serv-card:hover .ico{background:var(--orange);color:#fff}
.serv-card:hover p{color:rgba(255,255,255,.7)}
.serv-card:hover .more{color:var(--orange-soft)}
.serv-card.span6{grid-column:span 6}
.serv-card.span8{grid-column:span 8}
.serv-card.span4{grid-column:span 4}

/* ------- 10. Stats / proof ------- */
.proof{
  background:var(--ink);color:#fff;border-radius:32px;padding:clamp(40px,6vw,80px);
  display:grid;grid-template-columns:repeat(4,1fr);gap:40px;margin-top:40px;
}
.proof .stat .num{font-size:clamp(38px,4.8vw,64px);font-weight:900;color:var(--orange);letter-spacing:-.03em;line-height:1}
.proof .stat .lbl{margin-top:10px;color:rgba(255,255,255,.7);font-size:15px;font-weight:500}
.proof .stat .sym{font-size:.5em;vertical-align:top;color:#fff}

/* ------- 11. Process ------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:step}
.step{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px;
  position:relative;counter-increment:step;
}
.step::before{
  content:counter(step,decimal-leading-zero);
  position:absolute;top:24px;left:24px;font-size:42px;font-weight:900;color:var(--orange);letter-spacing:-.04em;
  opacity:.95;
}
.step h4{margin-top:60px;font-size:22px;font-weight:800}
.step p{margin-top:10px;color:var(--ink-soft);font-size:15px}

/* ------- 12. Testimonials ------- */
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tcard{
  background:var(--bg-alt);border-radius:var(--radius);padding:32px;
  display:flex;flex-direction:column;gap:18px;
}
.tcard .quote{font-size:18px;font-weight:600;line-height:1.7}
.tcard .who{display:flex;align-items:center;gap:12px;margin-top:auto}
.tcard .ava{width:42px;height:42px;border-radius:50%;background:var(--orange);color:#fff;font-weight:900;display:grid;place-items:center}
.tcard .name{font-weight:800}
.tcard .role{font-size:13px;color:var(--ink-mute)}

/* ------- 13. CTA banner ------- */
.cta-banner{
  background:var(--orange);color:#fff;border-radius:32px;padding:clamp(48px,7vw,96px);
  display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;
  position:relative;overflow:hidden;
}
.cta-banner::after{
  content:'';position:absolute;left:-10%;top:-50%;width:60%;height:200%;
  background:radial-gradient(circle,rgba(255,255,255,.18),transparent 60%);
  pointer-events:none;z-index:0;
}
.cta-banner > *{position:relative;z-index:1}
.cta-banner h2{font-size:var(--fs-h2);font-weight:900;line-height:1.05;letter-spacing:-.02em}
.cta-banner p{margin-top:18px;font-size:18px;opacity:.92;max-width:48ch}
.cta-banner .actions{display:flex;flex-direction:column;gap:12px;position:relative;z-index:2}
.cta-banner .actions .btn{position:relative;z-index:3}

/* ------- 14. Footer ------- */
.foot{background:var(--dark);color:#cfcfcf;padding:80px 0 40px;margin-top:60px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px}
.foot h5{color:#fff;font-size:14px;font-weight:800;margin-bottom:18px;letter-spacing:.06em;text-transform:uppercase}
.foot a{color:#bdbdbd;display:block;padding:6px 0;font-size:15px}
.foot a:hover{color:var(--orange)}
.foot .brand{color:#fff;font-size:24px}
.foot .blurb{margin-top:18px;color:#9c9c9c;max-width:38ch;line-height:1.7}
.foot-bot{margin-top:60px;padding-top:24px;border-top:1px solid #1d1d1d;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:#7d7d7d;font-size:13px}

/* ------- 15. Page banner (about/services/portfolio/contact) ------- */
.pbanner{padding:clamp(110px,13vw,140px) 0 clamp(48px,6vw,64px);background:var(--bg-alt);position:relative;overflow:hidden}
.pbanner h1{font-size:clamp(36px,5.5vw,80px);font-weight:900;letter-spacing:-.03em;line-height:1.02}
.pbanner .crumbs{display:flex;gap:8px;color:var(--ink-mute);font-size:14px;font-weight:600;margin-bottom:18px}
.pbanner .crumbs a:hover{color:var(--orange)}
.pbanner .lead{margin-top:24px;max-width:62ch;font-size:var(--fs-lead);color:var(--ink-soft)}

/* ------- 16. Reasons / Why grid (campaign) ------- */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.why{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.why:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(0,0,0,.18)}
.why .ico{
  width:52px;height:52px;border-radius:14px;background:rgba(232,85,30,.1);color:var(--orange);
  display:grid;place-items:center;margin-bottom:20px;
}
.why .ico svg{width:26px;height:26px}
.why h3{font-size:20px;font-weight:800;margin-bottom:8px}
.why p{font-size:15px;color:var(--ink-soft)}

/* ------- 17. Packages ------- */
.pkgs{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pkg{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:36px;
  display:flex;flex-direction:column;gap:18px;
  transition:transform .5s var(--ease),border-color .4s,box-shadow .5s;
}
.pkg.featured{background:var(--ink);color:#fff;border-color:var(--ink);transform:scale(1.02);box-shadow:0 30px 80px -30px rgba(0,0,0,.45)}
.pkg.featured .pkg-name{color:var(--orange-soft)}
.pkg.featured .price{color:#fff}
.pkg.featured .feat li::before{background:var(--orange)}
.pkg .pkg-name{font-size:13px;font-weight:800;color:var(--orange);letter-spacing:.08em;text-transform:uppercase}
.pkg h3{font-size:28px;font-weight:900;letter-spacing:-.01em}
.pkg .price{font-size:clamp(34px,3.5vw,42px);font-weight:900;letter-spacing:-.03em}
.pkg .price small{font-size:14px;font-weight:600;color:var(--ink-mute)}
.pkg .feat{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.pkg .feat li{position:relative;padding-inline-start:26px;font-size:15px;line-height:1.6}
.pkg .feat li::before{
  content:'';position:absolute;right:0;top:9px;width:14px;height:14px;border-radius:50%;
  background:rgba(232,85,30,.18);box-shadow:inset 0 0 0 4px var(--orange);
}
.pkg.featured .feat li{color:rgba(255,255,255,.85)}
.pkg .pkg-cta{margin-top:auto}

.ribbon{
  align-self:flex-start;background:var(--orange);color:#fff;font-size:12px;font-weight:800;
  padding:6px 12px;border-radius:999px;letter-spacing:.06em;text-transform:uppercase;
}

/* ------- 18. Before/After ------- */
.ba{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.ba-card{
  background:var(--bg-alt);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;gap:16px;
}
.ba-pair{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ba-shot{
  position:relative;aspect-ratio:4/3;border-radius:12px;overflow:hidden;
  background:repeating-linear-gradient(45deg,#e6e2dc 0 8px,#efece7 8px 16px);
}
.ba-shot.before::after,.ba-shot.after::after{
  content:attr(data-label);position:absolute;top:10px;right:10px;
  background:#fff;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
}
.ba-shot.after{background:linear-gradient(135deg,var(--orange),#ffd0b8)}
.ba-card h4{font-size:20px;font-weight:800}
.ba-card p{color:var(--ink-soft);font-size:14px}

/* ------- 19. FAQ ------- */
.faq{display:flex;flex-direction:column;gap:12px;max-width:880px;margin-inline:auto}
.faq details{
  background:var(--bg-alt);border-radius:14px;padding:22px 28px;border:1px solid var(--line);
}
.faq summary{
  list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;
  font-size:18px;font-weight:700;color:var(--ink);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .icn{width:28px;height:28px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-size:14px;transition:transform .35s var(--ease),background .3s}
.faq details[open] summary .icn{transform:rotate(45deg);background:var(--orange)}
.faq details p{margin-top:14px;color:var(--ink-soft);font-size:15.5px;line-height:1.8}

/* ------- 20. Forms ------- */
.form{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.form .full{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:13px;font-weight:700;color:var(--ink-soft)}
.field input,.field textarea,.field select{
  background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:14px 16px;
  font-size:15px;color:var(--ink);transition:border-color .3s,box-shadow .3s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--orange);box-shadow:0 0 0 4px rgba(232,85,30,.15);
}
.field textarea{min-height:140px;resize:vertical}
.form-note{font-size:13px;color:var(--ink-mute);margin-top:6px}

/* ------- 21. Reveal animation utility ------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.12s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.19s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.26s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.33s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.4s}
.reveal-stagger.in > *:nth-child(7){transition-delay:.47s}
.reveal-stagger.in > *:nth-child(8){transition-delay:.54s}

/* ------- 22. Portfolio grid ------- */
.work{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.work-item{
  grid-column:span 6;border-radius:var(--radius);overflow:hidden;background:var(--bg-alt);
  position:relative;aspect-ratio:4/3;display:flex;flex-direction:column;justify-content:flex-end;
  padding:32px;color:#fff;
}
.work-item::before{
  content:'';position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(10,10,10,0) 40%,rgba(10,10,10,.82) 100%),
    linear-gradient(135deg,rgba(232,85,30,.18),rgba(58,28,13,.22));
  opacity:1;transition:opacity .4s;
}
.work-item.alt::before{
  background:
    linear-gradient(180deg,rgba(10,10,10,0) 40%,rgba(10,10,10,.88) 100%),
    linear-gradient(135deg,rgba(26,26,26,.12),rgba(58,58,58,.15));
}
.work-item.alt2::before{
  background:
    linear-gradient(180deg,rgba(10,10,10,0) 40%,rgba(10,10,10,.85) 100%),
    linear-gradient(135deg,rgba(255,179,138,.18),rgba(232,85,30,.22));
}
.work-item:hover::before{opacity:.95}
.work-item > *{position:relative;z-index:1}
.work-item .tag{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;opacity:.9}
.work-item h3{font-size:28px;font-weight:900;margin-top:8px;letter-spacing:-.01em}
.work-item .placeholder-note{
  position:absolute;top:24px;left:24px;background:rgba(255,255,255,.18);backdrop-filter:blur(8px);
  padding:6px 12px;border-radius:999px;font-size:11px;font-weight:700;
}
.work-item.large{grid-column:span 8;aspect-ratio:16/10}
.work-item.tall{grid-column:span 4;aspect-ratio:3/4}

/* ------- 23. About specifics ------- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.value{padding:28px;border-radius:var(--radius);background:var(--bg-alt)}
.value h4{font-size:22px;font-weight:800;color:var(--orange);margin-bottom:8px}
.value p{color:var(--ink-soft);font-size:15px}

/* ------- 24. Contact details strip ------- */
.contact-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.cstrip-card{background:var(--bg-alt);border-radius:var(--radius);padding:28px;display:flex;gap:18px;align-items:flex-start}
.cstrip-card .ico{width:48px;height:48px;border-radius:12px;background:#fff;color:var(--orange);display:grid;place-items:center;flex:none}
.cstrip-card h4{font-size:18px;font-weight:800;margin-bottom:4px}
.cstrip-card p{color:var(--ink-soft);font-size:14px;line-height:1.7}

/* ------- 25. Big text headline (campaign hero) ------- */
.mega-hero{
  position:relative;padding:clamp(110px,13vw,140px) 0 clamp(56px,7vw,72px);overflow:hidden;
  background:linear-gradient(180deg,#fff 0%,#faf6ef 100%);
}
.mega-hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(900px 600px at 100% 0,rgba(232,85,30,.18),transparent 60%),
    radial-gradient(700px 500px at 0 100%,rgba(232,85,30,.10),transparent 60%);
  pointer-events:none;
}
.mega-hero .badge-line{display:flex;gap:10px;align-items:center;margin-bottom:32px;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--orange)}
.mega-hero .badge-line::before{content:'';width:42px;height:1px;background:var(--orange)}
.mega-hero h1{font-size:clamp(38px,7.4vw,96px);font-weight:900;line-height:1.2;letter-spacing:-.02em;color:var(--ink)}
.mega-hero h1 em{font-style:normal;color:var(--orange)}
.mega-hero h1 .stroke{color:var(--ink);-webkit-text-stroke:0}
.mega-hero .subline{margin-top:36px;max-width:60ch;font-size:var(--fs-lead);color:var(--ink-soft);line-height:1.7}
.mega-hero .ctas{margin-top:40px;display:flex;flex-wrap:wrap;gap:16px}
.mega-hero .stripe{
  margin-top:80px;display:flex;flex-wrap:wrap;gap:48px;align-items:center;color:var(--ink-soft);font-weight:600;
}
.mega-hero .stripe .pill{padding:10px 18px;border:1px solid var(--line);border-radius:999px;background:#fff}

/* ------- 26. Sticky scroll process (campaign) ------- */
.scrolly{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.scrolly .sticky{position:sticky;top:120px}
.scrolly .step-list{display:flex;flex-direction:column;gap:28px}
.scrolly .step-item{
  border-inline-end:2px solid var(--line);padding:24px 28px 24px 0;
  position:relative;transition:border-color .4s;
}
.scrolly .step-item.is-active{border-color:var(--orange)}
.scrolly .step-item h4{font-size:24px;font-weight:800}
.scrolly .step-item p{color:var(--ink-soft);margin-top:8px}
.scrolly .step-item .num{font-size:14px;font-weight:800;color:var(--orange);margin-bottom:6px}

/* ------- 27. Reusable two-column layout (used on contact + campaign) ------- */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.two-col-wide{grid-template-columns:1.2fr 1fr}

/* ------- 28. Responsive ------- */

/* Prevent horizontal overflow anywhere */
html,body{overflow-x:hidden;max-width:100%}
img,video,iframe{max-width:100%;height:auto}
*{min-width:0}

/* Touch / tap feedback */
a,button,.btn,.nav-cta,.nav-toggle,.more,.magnetic,summary,.wa-floater,input[type="submit"]{
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}

/* Body scroll lock while mobile drawer is open */
body.no-scroll{overflow:hidden;touch-action:none;position:fixed;inset:0;width:100%}

/* Large tablets / small desktops */
@media (max-width:1200px){
  .nav-menu a{padding:8px 10px;font-size:14px}
  .nav-menu{gap:2px}
}

/* Tablets */
@media (max-width:1024px){
  .hero{padding-top:clamp(100px,12vw,130px);padding-bottom:clamp(48px,6vw,64px)}
  .hero-grid{grid-template-columns:1fr;gap:40px;align-items:start}
  .hero-visual{max-width:560px;margin-inline:auto;width:100%}
  /* CRITICAL: remap parent grids from 12-col to 2-col so span children size correctly */
  .serv-grid{grid-template-columns:repeat(2,1fr)}
  .serv-card,
  .serv-card.span6,
  .serv-card.span8,
  .serv-card.span4{grid-column:auto}
  .work{grid-template-columns:repeat(2,1fr)}
  .work-item,.work-item.large,.work-item.tall{grid-column:auto;aspect-ratio:16/10}
  .steps,.proof,.tcards,.why-grid,.pkgs,.contact-strip,.value-grid{grid-template-columns:repeat(2,1fr)}
  .cta-banner{grid-template-columns:1fr;padding:clamp(36px,6vw,72px)}
  .foot-grid{grid-template-columns:repeat(2,1fr)}
  .scrolly{grid-template-columns:1fr}
  .scrolly .sticky{position:relative;top:0}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .sec-head{margin-bottom:40px}
  .two-col,.two-col-wide{grid-template-columns:1fr;gap:40px}
}

/* Hide nav menu earlier before overflow */
@media (max-width:960px){
  .nav-menu{display:none}
  .nav-toggle{display:inline-flex}
}

/* Small tablets / large phones */
@media (max-width:720px){
  .nav{padding:14px 0}
  .nav.is-stuck{padding:10px 0}
  .nav-cta{display:none}
  .brand{font-size:17px}
  .brand-mark{width:32px;height:32px}
  .section{padding:clamp(56px,12vw,96px) 0}
  .section-tight{padding:clamp(48px,9vw,80px) 0}
  .pbanner{padding:120px 0 56px}
  .hero{padding-top:clamp(120px,22vw,140px);padding-bottom:48px}
  .pbanner{padding-top:clamp(120px,22vw,140px)}
  .mega-hero{padding-top:clamp(120px,22vw,140px)}
  /* Extra breathing room between nav and the hero headline */
  .hero-grid > :first-child,
  .mega-hero .container > :first-child,
  .pbanner .container > :first-child{margin-top:clamp(8px,2vw,20px)}
  /* Container grids → single column on phones */
  .serv-grid,.work,.steps,.proof,.tcards,.why-grid,.pkgs,.foot-grid,.contact-strip,.value-grid,.ba,.ba-pair{grid-template-columns:1fr}
  .serv-card,.serv-card.span6,.serv-card.span8,.serv-card.span4{grid-column:auto;min-height:auto;padding:28px}
  .work-item,.work-item.large,.work-item.tall{grid-column:auto;aspect-ratio:4/3}
  .form{grid-template-columns:1fr}
  .pkg.featured{transform:none}
  .proof{padding:32px;gap:28px;border-radius:24px}
  .proof .stat .num{font-size:clamp(40px,11vw,64px)}
  .cta-banner{padding:36px 28px;border-radius:24px}
  .cta-banner .actions{flex-direction:column;align-items:stretch}
  .cta-banner .actions .btn{justify-content:center}
  .sec-head{gap:16px;margin-bottom:32px}
  .sec-head .right{max-width:100%}
  .hero-visual{max-width:460px}
  .hero-cta-row{flex-wrap:wrap}
  .hero-cta-row .btn{flex:1 1 100%;justify-content:center;min-width:0}
  .foot{padding:56px 0 32px}
  .foot-bot{flex-direction:column;align-items:flex-start}
  .faq details{padding:18px 20px}
  .faq summary{font-size:16px}
  .wa-floater{width:52px;height:52px;bottom:18px;left:18px}
  .wa-floater svg{width:26px;height:26px}
  .mega-hero{padding:120px 0 56px}
  .mega-hero .stripe{margin-top:48px;gap:24px}
  .two-col,.two-col-wide{grid-template-columns:1fr;gap:32px}
  .drawer a{font-size:26px}
  .btn{padding:15px 26px;font-size:15px}
}

/* Small phones */
@media (max-width:480px){
  .container{padding-inline:16px}
  .hero-mega{letter-spacing:-.02em;line-height:1.02}
  .hero-sub{font-size:16px}
  .hero-cta-row{flex-direction:column;align-items:stretch}
  .hero-cta-row .btn{width:100%;flex:0 0 auto}
  .mega-hero h1{line-height:1.25}
  .proof{grid-template-columns:1fr;padding:28px}
  .cta-banner{padding:32px 22px}
  .cta-banner h2{font-size:clamp(26px,7vw,38px)}
  .cta-banner p{font-size:16px}
  .tcard,.step,.why,.pkg,.value,.cstrip-card{padding:24px}
  .cstrip-card{flex-direction:column;gap:12px}
  .serv-card h3{font-size:20px}
  .step h4,.why h3{font-size:18px}
  .pkg h3{font-size:22px}
  .pkg .price{font-size:38px}
  .nav{padding:12px 0}
  .brand{font-size:16px}
  .mega-hero .stripe{flex-direction:column;align-items:flex-start;gap:12px}
  .drawer{padding:32px 24px;gap:14px}
  .drawer a{font-size:clamp(20px,5.2vw,26px)}
  .foot-grid{gap:28px}
  .pbanner{padding:110px 0 48px}
  .pbanner h1{line-height:1.02}
  .pbanner .lead{font-size:16px}
  .kicker{font-size:clamp(22px,5.5vw,32px)}
  .ribbon{font-size:11px;padding:4px 10px}
  .field input,.field textarea,.field select{padding:12px 14px;font-size:14px}
  .hero-visual{max-width:100%;aspect-ratio:1/1}
  .hero-visual .browser-card{inset:auto 16px 16px 16px;top:16px}
  .browser-body{padding:14px;gap:8px}
  .bb-hero{height:90px}
}

/* Extra small phones */
@media (max-width:360px){
  .btn{padding:13px 20px;font-size:14px}
  .hero-mega{letter-spacing:-.015em}
  .nav-cta{display:none}
  .brand{font-size:15px}
  .brand-mark{width:30px;height:30px}
  .drawer a{font-size:18px}
}

/* ------- 28. Safety guards for mobile overflow ------- */
.container,
.container-wide{
  width:100%;
  max-width:100%;
}
a,button,input,select,textarea{
  max-width:100%;
}
h1,h2,h3,h4,h5,h6,p,li,a{
  overflow-wrap:anywhere;
  word-break:break-word;
}
pre,code{
  white-space:pre-wrap;
  overflow-wrap:anywhere;
}
svg{
  max-width:100%;
  height:auto;
}

/* ------- 29. Print / reduce motion ------- */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001s !important;transition-duration:.001s !important;animation-iteration-count:1 !important}
  .marquee-track{animation:none}
}

/* ------- 29. Loader ------- */
.loader{
  position:fixed;inset:0;z-index:200;background:var(--ink);color:#fff;display:grid;place-items:center;
  transition:opacity .6s var(--ease),visibility .6s;
}
.loader.is-out{opacity:0;visibility:hidden}
.loader .lo-mark{font-size:42px;font-weight:900;letter-spacing:-.03em;color:#fff;display:flex;align-items:center;gap:14px}
.loader .lo-mark .d{width:18px;height:18px;border-radius:50%;background:var(--orange);animation:lo 1.4s ease-in-out infinite}
@keyframes lo{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.6);opacity:1}}

/* ------- 30. Misc ------- */
.divider{height:1px;background:var(--line);margin-block:48px}
.tag-pill{display:inline-block;padding:6px 14px;border-radius:999px;background:rgba(232,85,30,.12);color:var(--orange);font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
.center-text{text-align:center}
.center-text .subhead{margin-inline:auto}

/* =========================================================
   31. Responsive polish (added post-launch)
   - Protect hero word-reveal if JS stalls
   - Normalise Arabic RTL paddings
   - Mobile-safe grid fallbacks
   - Disable heavy animations on small devices
   ========================================================= */

/* Hero reveal fallback: show words even if JS never toggles `is-in`.
   CSS now reveals after 2.4s regardless, via animation. JS still layers GSAP on top. */
.hero-mega .word > span,
.mega-hero h1 .word > span{
  animation:heroWordFallback .9s 2.4s var(--ease-out) both;
}
.hero-mega.is-in .word > span,
.mega-hero h1.is-in .word > span{
  animation:none;
  transform:translateY(0);
}
@keyframes heroWordFallback{
  from{transform:translateY(110%)}
  to{transform:translateY(0)}
}
@media (prefers-reduced-motion:reduce){
  .hero-mega .word > span,
  .mega-hero h1 .word > span{animation:none;transform:translateY(0)}
}

/* Ensure inline word spans wrap naturally in Arabic RTL */
.hero-mega .word,
.mega-hero h1 .word{white-space:normal;word-break:keep-all}

/* Tablet: visual & decorative tweaks (typography handled in section 32 below) */
@media (max-width:1024px){
  .hero-visual{aspect-ratio:1/0.85}
  .proof{border-radius:24px}
  .cta-banner{border-radius:24px}
  .scrolly .step-item{padding:20px 20px 20px 0}
}

/* Scrolly RTL: make sure the step-item border sits on the correct visual side */
[dir="rtl"] .scrolly .step-item{padding:24px 0 24px 28px}
@media (max-width:1024px){
  [dir="rtl"] .scrolly .step-item{padding:20px 0 20px 20px}
}

/* Float badges: resize & re-position down the breakpoints so they stay
   visible on phones/tablets WITHOUT creating horizontal overflow. */
@media (max-width:1024px){
  .float-badge{padding:12px 16px;font-size:13px;border-radius:12px;box-shadow:0 14px 30px -12px rgba(0,0,0,.22)}
  .float-badge .num{font-size:20px}
  .float-badge.b1{right:-10px}
  .float-badge.b2{left:-6px}
}
@media (max-width:720px){
  /* ~65% scale — tablet / large phones */
  .float-badge{
    padding:9px 13px;gap:8px;font-size:11px;border-radius:10px;
    box-shadow:0 10px 24px -10px rgba(0,0,0,.20);
    white-space:nowrap;max-width:calc(100% - 16px);
  }
  .float-badge .num{font-size:16px}
  .float-badge.b1{top:8%;right:4px;animation-duration:5.5s}
  .float-badge.b2{bottom:8%;left:4px;animation-duration:6.5s}
}
@media (max-width:480px){
  /* ~50% scale — small phones. Tucked inside the visual so no clipping. */
  .float-badge{padding:7px 10px;gap:6px;font-size:10px;border-radius:8px;line-height:1.2}
  .float-badge .num{font-size:13px}
  .float-badge.b1{top:10px;right:10px;animation-duration:5s}
  .float-badge.b2{bottom:10px;left:10px;animation-duration:6s}
}
@media (max-width:360px){
  .float-badge{padding:6px 9px;font-size:9.5px}
  .float-badge .num{font-size:12px}
}

/* Two-col and about-grid safety */
@media (max-width:720px){
  .two-col,.two-col-wide,.about-grid{grid-template-columns:1fr;gap:28px}
  .proof{gap:20px}
  .serv-grid{gap:14px}
  .tcards,.why-grid,.pkgs,.steps,.value-grid,.ba,.contact-strip{gap:14px}
  .pkg.featured{transform:none;box-shadow:0 20px 60px -25px rgba(0,0,0,.45)}
  .cta-banner .actions .btn{flex:1 1 100%}
}

/* Marquee mobile polish — tighter spacing, faster loop, smaller dot */
@media (max-width:768px){
  .marquee-track{animation-duration:14s}
  .marquee-item{font-size:clamp(15px,4vw,20px);gap:clamp(10px,2.5vw,14px);margin-inline-end:clamp(24px,5vw,36px)}
  .marquee-item .dot{width:6px;height:6px}
}
@media (max-width:480px){
  .marquee-track{animation-duration:11s}
  .marquee-item{font-size:clamp(13px,4.4vw,16px)}
}

/* Tame the drawer on very tall mobile viewports */
@media (max-height:640px) and (max-width:960px){
  .drawer{justify-content:flex-start;padding-top:90px;gap:6px}
  .drawer a{font-size:20px}
}

/* Loader text must never overflow on phones */
.loader .lo-mark{font-size:clamp(28px,8vw,42px)}

/* WhatsApp floater: keep comfortably inside safe area on phones */
@supports(padding:max(0px)){
  .wa-floater{bottom:max(18px,env(safe-area-inset-bottom));left:max(18px,env(safe-area-inset-left))}
}

/* Disable GSAP parallax jank on mobile: JS also respects this */
@media (max-width:1024px){
  [data-parallax]{transform:none !important}
}

/* Nav on very short screens: reduce vertical padding so content has room */
@media (max-height:520px){
  .nav,.nav.is-stuck{padding:8px 0}
}

/* Forms: never let a wider input push the grid past the viewport */
.field input,.field textarea,.field select{max-width:100%;width:100%}

/* Prevent any absolutely-positioned decorative layer from creating
   horizontal scroll on mobile */
.cta-banner,.proof,.hero,.mega-hero,.pbanner,.marquee{max-width:100vw}

/* Keep Arabic text from breaking the layout when a very long word appears */
.hero-sub,.subline,.pbanner .lead,.tcard .quote,.why p,.serv-card p,.pkg .feat li{
  overflow-wrap:anywhere;
  word-break:break-word;
}

/* Make sticky nav safer when address bar hides on mobile */
@supports(padding-top:env(safe-area-inset-top)){
  .nav{padding-top:max(12px,env(safe-area-inset-top))}
}

/* =========================================================
   32. Typography scale lock-down (round 2 — definitive)

   Single source of truth for hero / mega-hero / page-banner titles.
   Cascade is descending (widest breakpoint first → narrowest last)
   so that narrower viewports always win at the bottom.
   ========================================================= */

/* Large desktop (>= 1280px) — keep base values from :root --fs-mega
   which is now clamp(36px, 7.5vw, 104px). At 1440px = 7.5vw=108→cap 104.
   At 1280px = 96. */

/* Small desktop / large laptop (1280px and below) */
@media (max-width:1280px){
  .hero-mega{font-size:clamp(36px,4.6vw,56px);line-height:1.22;letter-spacing:-.02em}
  .mega-hero h1{font-size:clamp(54px,7vw,84px);line-height:1.2}
  .pbanner h1{font-size:clamp(48px,6.5vw,72px)}
}

/* Tablet (1024px and below) */
@media (max-width:1024px){
  .hero-mega{font-size:clamp(32px,4.4vw,48px);line-height:1.24;letter-spacing:-.015em}
  .mega-hero h1{font-size:clamp(46px,6.4vw,70px);line-height:1.22}
  .pbanner h1{font-size:clamp(40px,5.8vw,60px)}
  .kicker{font-size:clamp(26px,3.8vw,40px)}
}

/* Mobile L (768px and below) */
@media (max-width:768px){
  .hero-mega{font-size:clamp(28px,4.2vw,40px);line-height:1.28;letter-spacing:-.01em}
  .mega-hero h1{font-size:clamp(38px,6vw,56px);line-height:1.25}
  .pbanner h1{font-size:clamp(34px,5.5vw,48px)}
  .kicker{font-size:clamp(24px,4.2vw,34px)}
  .proof .stat .num{font-size:clamp(34px,7vw,48px)}
}

/* Mobile S (480px and below) */
@media (max-width:480px){
  .hero-mega{font-size:clamp(22px,5.8vw,30px);line-height:1.3;letter-spacing:-.005em}
  .mega-hero h1{font-size:clamp(30px,8vw,42px);line-height:1.3}
  .pbanner h1{font-size:clamp(28px,8vw,38px);line-height:1.05}
  .kicker{font-size:clamp(22px,5.5vw,30px);line-height:1.15}
  .proof .stat .num{font-size:clamp(30px,9vw,40px)}
  .pkg .price{font-size:clamp(28px,8vw,36px)}
}

/* Tiny phones (360px and below) */
@media (max-width:360px){
  .hero-mega{font-size:clamp(24px,8.5vw,32px);line-height:1.3}
  .mega-hero h1{font-size:clamp(26px,9vw,34px);line-height:1.3}
  .pbanner h1{font-size:clamp(24px,8.5vw,30px)}
  .kicker{font-size:clamp(20px,6vw,26px)}
}

/* Make split-word spans flow as inline text on small screens
   (default inline-block makes long Arabic words wrap each on its own line) */
@media (max-width:480px){
  .hero-mega .word,.mega-hero h1 .word{
    display:inline;
    overflow:visible;
    padding:0;
  }
  .hero-mega .word > span,.mega-hero h1 .word > span{
    display:inline;
    transform:none !important;
    animation:none !important;
  }
}

/* Belt-and-suspenders: ensure no big headline ever creates horizontal scroll */
.hero-mega,.mega-hero h1,.pbanner h1,.kicker{
  max-width:100%;
  overflow-wrap:break-word;
  word-break:normal;
}

/* =========================================================
   33. Outlined accent (desktop only)

   `-webkit-text-stroke` makes Arabic glyphs look broken because it draws
   the outline around each glyph independently, breaking the visual
   letter-joining. Default style is a solid orange fill. The hollow outline
   effect is only re-enabled at ≥1025px, where either Latin-heavy content
   or the large font-size makes the outline read as intended.
   ========================================================= */
@media (min-width:1025px){
  .hero-mega .accent-stroke{
    color:transparent;
    -webkit-text-stroke:2px var(--orange);
  }
  .mega-hero h1 .stroke{
    color:transparent;
    -webkit-text-stroke:2px var(--ink);
  }
}

/* =========================================================
   34. Desktop hero layout — landscape browser card + aligned block

   On ≥1025px:
   - .hero-grid uses 1.2fr / 0.8fr so the text gets ~60% of the row.
   - Both columns are vertically centered with each other: the text
     column becomes a flex container that centers its own items, and
     the visual is explicitly align-self:center. This makes text+visual
     read as a single horizontally-balanced block instead of text-top /
     visual-middle.
   - .hero-visual switches from near-square (1/1.05) to landscape (4/3),
     capped at 520px wide so it never dominates the headline.
   - margin-inline-start: auto pushes the card toward the inline-end of
     its grid cell — in RTL that visually anchors it to the LEFT side.
   ========================================================= */
@media (min-width:1025px){
  .hero-grid{
    grid-template-columns:1.2fr 0.8fr;
    gap:clamp(40px,5vw,80px);
    align-items:center;
    place-items:center;
  }
  /* Text column: the first direct child <div> inside .hero-grid */
  .hero-grid > div:first-child{
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-self:stretch;
  }
  .hero-visual{
    max-width:520px;
    width:100%;
    aspect-ratio:4/3;
    /* RTL: pull the card toward the text (right side) rather than
       pinning it to the outer edge. margin-inline-end:auto absorbs
       free space on the opposite side, so the card sits at the
       inline-start of its cell — next to the text. */
    margin-inline-start:0;
    margin-inline-end:auto;
    align-self:center;
  }
  .hero-visual .browser-card{width:auto;height:auto}

  /* mega-hero (campaign.html single-column hero): also center its content
     vertically if the section's intrinsic height ever grows taller than
     its content (decorative gradient, mega h1, subline, CTAs, stripe). */
  .mega-hero{
    display:flex;
    flex-direction:column;
    justify-content:center;
  }
}

/* Larger desktops: keep the card from growing further */
@media (min-width:1440px){
  .hero-visual{max-width:480px}
}
@media (min-width:1920px){
  .hero-visual{max-width:520px}
}

/* ------- 28. Dual-pricing alt line (one-time under monthly) ------- */
.pkg .price-alt-line{
  font-size:13px;color:var(--ink-mute);font-weight:600;
  margin-top:4px;padding:10px 14px;
  background:rgba(232,85,30,.06);border-radius:10px;
  border:1px dashed rgba(232,85,30,.25);
  line-height:1.5;
}
.pkg .price-alt-line b{color:var(--orange);font-weight:800}
.pkg.featured .price-alt-line{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,179,138,.4);
  color:rgba(255,255,255,.75);
}
.pkg.featured .price-alt-line b{color:var(--orange-soft)}

/* ------- 29. Terms grid (subscription vs one-time) ------- */
.terms-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:20px;
  margin-top:36px;
}
.terms-box{
  background:var(--bg-alt);border-radius:var(--radius);
  padding:28px;border:1px solid var(--line);
}
.terms-head{
  display:flex;align-items:center;gap:12px;margin-bottom:16px;
  padding-bottom:14px;border-bottom:1px solid var(--line);
}
.terms-ico{
  font-size:24px;width:44px;height:44px;border-radius:12px;
  background:#fff;display:grid;place-items:center;flex:none;
  box-shadow:0 2px 8px -2px rgba(14,14,14,.08);
}
.terms-head h4{
  font-size:18px;font-weight:800;color:var(--ink);margin:0;
}
.terms-box ul{
  display:flex;flex-direction:column;gap:12px;
}
.terms-box ul li{
  position:relative;padding-inline-start:22px;
  font-size:14px;line-height:1.7;color:var(--ink-soft);
}
.terms-box ul li::before{
  content:'';position:absolute;top:10px;inset-inline-start:6px;
  width:6px;height:6px;border-radius:50%;background:var(--orange);
}
.terms-box ul li b{color:var(--ink);font-weight:800}
@media (max-width:720px){
  .terms-grid{grid-template-columns:1fr;gap:14px}
  .terms-box{padding:22px}
}

/* ------- 27. Inclusion strip (above packages) ------- */
.incl-strip{
  display:flex;flex-wrap:wrap;justify-content:center;gap:10px;
  margin:24px 0 36px;padding:18px 22px;
  background:linear-gradient(135deg,rgba(232,85,30,.08),rgba(232,85,30,.03));
  border:1px dashed rgba(232,85,30,.35);border-radius:var(--radius);
}
.incl-pill{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-weight:700;color:var(--ink);
  padding:8px 14px;background:#fff;border-radius:999px;
  border:1px solid var(--line);
  box-shadow:0 2px 6px -2px rgba(14,14,14,.06);
}
.incl-pill b{color:var(--orange);font-weight:800}
@media (max-width:560px){
  .incl-strip{padding:14px;gap:8px}
  .incl-pill{font-size:12px;padding:6px 11px}
}

/* ------- 26. Portfolio work-item: image support ------- */
.work-item .work-thumb{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  z-index:0;transition:transform .7s var(--ease-out);
}
.work-item:hover .work-thumb{transform:scale(1.06)}
.work-item::before{z-index:1}
.work-item > *:not(.work-thumb):not(.work-link){position:relative;z-index:2}
.work-item .work-link{
  position:absolute;inset:0;z-index:3;border-radius:inherit;
  text-indent:-9999px;overflow:hidden;
}
.work-item .work-link:focus-visible{
  outline:2px solid #fff;outline-offset:-6px;
}

/* ------- 27. Portfolio redesign: browser cards with scroll-on-hover ------- */
.pf-filters{
  display:flex;flex-wrap:wrap;gap:10px;margin-bottom:44px;
}
.pf-chip{
  border:1px solid var(--line);background:#fff;color:var(--ink);
  padding:10px 18px;border-radius:999px;font:inherit;font-size:14px;font-weight:700;
  cursor:pointer;transition:background .25s,color .25s,border-color .25s,transform .2s;
}
.pf-chip:hover{border-color:var(--orange);color:var(--orange);transform:translateY(-1px)}
.pf-chip.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}
.pf-chip .pf-count{opacity:.7;font-weight:600;margin-inline-start:4px;font-size:12px}

.pf-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:26px;
}
.pf-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .45s var(--ease-out),box-shadow .45s var(--ease-out),border-color .35s;
}
.pf-card:hover{
  transform:translateY(-6px);
  box-shadow:0 22px 44px -18px rgba(232,85,30,.22),0 6px 14px -8px rgba(10,10,10,.08);
  border-color:rgba(232,85,30,.35);
}
.pf-card.is-hidden{display:none}

.pf-browser{
  display:flex;align-items:center;gap:7px;padding:11px 16px;
  background:#f5f2ec;border-bottom:1px solid var(--line);
  direction:ltr;
}
.pf-dot{width:10px;height:10px;border-radius:50%;background:#d7d2cc;flex:none}
.pf-dot.r{background:#ff5f57}
.pf-dot.y{background:#ffbd2e}
.pf-dot.g{background:#28c840}
.pf-url{
  margin-inline:auto;min-width:0;max-width:70%;
  font-size:12px;color:#7d7870;background:#fff;padding:5px 14px;
  border-radius:999px;border:1px solid var(--line);
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;direction:ltr;
}

.pf-frame{
  position:relative;overflow:hidden;aspect-ratio:4/3;
  background:#f1ede5;
  container-type:size;
}
.pf-shot{
  position:absolute;top:0;left:0;width:100%;height:auto;display:block;
  will-change:transform;
  transition:transform 6s linear;
}
.pf-card:hover .pf-shot,
.pf-card:focus-within .pf-shot{
  transform:translateY(calc(-100% + 100cqh));
}

.pf-meta{
  padding:18px 20px 20px;display:flex;flex-direction:column;gap:12px;
}
.pf-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:10px;
}
.pf-head h3{
  font-size:17px;font-weight:800;color:var(--ink);letter-spacing:-.01em;line-height:1.3;
}
.pf-tag{
  flex:none;font-size:11px;font-weight:700;letter-spacing:.04em;
  padding:4px 10px;border-radius:999px;
  background:rgba(232,85,30,.1);color:var(--orange);white-space:nowrap;
}
.pf-foot{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding-top:12px;border-top:1px solid var(--line);
}
.pf-platform{font-size:12px;color:var(--ink-soft);font-weight:600;letter-spacing:.02em}
.pf-visit{
  font-size:13px;font-weight:800;color:var(--orange);text-decoration:none;
  transition:transform .25s;
}
.pf-visit:hover{transform:translateX(-3px)}
.pf-visit--soft{color:#F5B400;font-weight:700;cursor:default;letter-spacing:2px;font-size:15px}
.pf-visit--soft:hover{transform:none}

.pf-empty{
  text-align:center;padding:48px 0;color:var(--ink-soft);font-size:15px;
}

@media (max-width:1024px){
  .pf-grid{grid-template-columns:repeat(2,1fr);gap:22px}
}
@media (max-width:640px){
  .pf-grid{grid-template-columns:1fr;gap:18px}
  .pf-filters{margin-bottom:28px;gap:8px}
  .pf-chip{padding:8px 14px;font-size:13px}
  .pf-head h3{font-size:16px}
  .pf-url{max-width:60%}
}

@media (prefers-reduced-motion:reduce){
  .pf-shot{transition:none}
  .pf-card:hover .pf-shot,
  .pf-card:focus-within .pf-shot{transform:none}
}

/* Fallback for browsers without container-query units: still works, image uses object-fit */
@supports not (height:100cqh){
  .pf-shot{height:100%;object-fit:cover;object-position:top}
  .pf-card:hover .pf-shot,
  .pf-card:focus-within .pf-shot{transform:none}
}
