/* =========================================================
   Caravan RMC theme — main stylesheet
   Blue primary + Yellow accent, RTL Arabic, fully responsive
   ========================================================= */

:root{
    --c-primary:#0d3b66;
    --c-accent:#f4c542;
    --c-dark:#06223f;
    --c-bg:#ffffff;
    --c-bg-alt:#f4f7fb;
    --c-text:#1c2433;
    --c-muted:#5b6677;
    --c-border:#e3e8ef;
    --c-white:#ffffff;
    --shadow-sm:0 2px 6px rgba(13,59,102,.06);
    --shadow-md:0 8px 24px rgba(13,59,102,.10);
    --shadow-lg:0 18px 50px rgba(13,59,102,.18);
    --radius-sm:8px;
    --radius:16px;
    --radius-lg:22px;
    --container:1200px;
    --gap:24px;
    --header-h:84px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
    margin:0;
    font-family:'Tajawal','Cairo',system-ui,-apple-system,'Segoe UI',Tahoma,sans-serif;
    color:var(--c-text);
    background:var(--c-bg);
    line-height:1.7;
    font-size:17px;
    overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-primary);text-decoration:none;transition:color .2s}
a:hover{color:var(--c-accent)}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4,h5,h6{font-family:'Cairo','Tajawal',sans-serif;color:var(--c-dark);line-height:1.25;margin:0 0 .5em;font-weight:800}
p{margin:0 0 1em}
ul{padding:0;margin:0;list-style:none}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 20px}
.section{padding:84px 0}
.section--alt{background:var(--c-bg-alt)}
.text-center{text-align:center}

.screen-reader-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;top:-100px;right:8px;background:var(--c-primary);color:#fff;padding:10px 16px;z-index:9999;border-radius:6px}
.skip-link:focus{top:8px}

/* ---------- Buttons ---------- */
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:14px 28px;border:2px solid transparent;border-radius:999px;
    font-weight:700;font-size:16px;line-height:1;cursor:pointer;
    transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease,border-color .2s ease;
    text-align:center;white-space:nowrap;
}
.btn--lg{padding:18px 36px;font-size:17px}
.btn--primary{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.btn--primary:hover{background:var(--c-dark);color:#fff;border-color:var(--c-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--accent{background:var(--c-accent);color:var(--c-dark);border-color:var(--c-accent)}
.btn--accent:hover{background:#ffd86b;color:var(--c-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--outline{background:transparent;color:#fff;border-color:#fff}
.btn--outline:hover{background:#fff;color:var(--c-primary)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn--ghost:hover{background:#fff;color:var(--c-primary);border-color:#fff}

/* ---------- Topbar ---------- */
.topbar{background:var(--c-dark);color:#cfd8e8;font-size:14px}
.topbar a{color:#cfd8e8}
.topbar a:hover{color:var(--c-accent)}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;min-height:44px;flex-wrap:wrap;gap:10px}
.topbar__contact{display:flex;flex-wrap:wrap;gap:18px}
.topbar__item{display:inline-flex;align-items:center;gap:6px}
.topbar__item .icon,.footer-contact .icon,.contact__list .icon{flex:0 0 auto}
.footer-contact li{align-items:center}
.contact__list .ci{display:inline-flex;align-items:center;justify-content:center;color:var(--c-accent)}
.mvv__icon .icon{color:var(--c-accent)}
.brand-mark .icon{color:var(--c-accent)}
.wa-float .icon{color:#fff}
.card__link .icon{transition:transform .2s}
.card__link:hover .icon{transform:translateX(-4px)}
.footer-social .icon{width:18px;height:18px}
.topbar__social{display:flex;gap:6px}
.topbar__social-link{
    display:inline-flex;align-items:center;justify-content:center;
    width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.06);
    font-size:12px;font-weight:700;
}
.topbar__social-link:hover{background:var(--c-accent);color:var(--c-dark)}

/* ---------- Header ---------- */
.site-header{
    position:sticky;top:0;z-index:90;
    background:#fff;
    box-shadow:0 4px 16px rgba(13,59,102,.06);
}
.site-header__inner{
    display:flex;align-items:center;gap:24px;min-height:var(--header-h);
}
.site-branding{flex:0 0 auto}
.brand-link{display:flex;align-items:center;gap:12px;color:var(--c-dark)}
.brand-link:hover{color:var(--c-primary)}
.brand-mark{
    width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,var(--c-primary),var(--c-dark));color:var(--c-accent);
    border-radius:12px;font-size:24px;
}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-text strong{font-size:18px;font-weight:900;color:var(--c-dark)}
.brand-text em{font-size:12px;color:var(--c-muted);font-style:normal}
.custom-logo{max-height:54px;width:auto}

.primary-nav{flex:1 1 auto;display:flex;justify-content:center}
.primary-menu{display:flex;gap:6px;flex-wrap:wrap}
.primary-menu li{position:relative}
.primary-menu a{
    display:inline-block;padding:10px 16px;color:var(--c-dark);font-weight:600;font-size:16px;
    border-radius:8px;transition:color .2s,background .2s;
}
.primary-menu a:hover,
.primary-menu .current-menu-item > a,
.primary-menu .current_page_item > a{color:var(--c-primary);background:rgba(13,59,102,.06)}
.primary-menu .sub-menu{
    position:absolute;top:100%;right:0;min-width:220px;background:#fff;
    box-shadow:var(--shadow-md);border-radius:12px;padding:8px;
    opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s;z-index:5;
}
.primary-menu li:hover > .sub-menu,
.primary-menu li:focus-within > .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.primary-menu .sub-menu a{display:block;padding:10px 14px}

.header-cta{flex:0 0 auto}

.nav-toggle{
    display:none;width:44px;height:44px;background:transparent;border:0;
    flex-direction:column;justify-content:center;align-items:center;gap:5px;border-radius:8px;
}
.nav-toggle__bar{width:24px;height:3px;background:var(--c-dark);border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{
    position:relative;color:#fff;
    background-size:cover;background-position:center;
    min-height:calc(100vh - var(--header-h));
    display:flex;align-items:center;padding:80px 0;
    overflow:hidden;
}
.hero::after{
    content:"";position:absolute;inset:auto -10% -40% auto;width:60%;height:80%;
    background:radial-gradient(closest-side,var(--c-accent),transparent 70%);
    opacity:.18;pointer-events:none;
}
.hero__inner{position:relative;z-index:2;max-width:780px}
.hero__eyebrow{
    display:inline-block;background:rgba(244,197,66,.18);color:var(--c-accent);
    padding:8px 16px;border-radius:999px;font-weight:700;font-size:14px;margin-bottom:18px;
    border:1px solid rgba(244,197,66,.35);
}
.hero__title{
    font-size:clamp(34px,5vw,60px);font-weight:900;color:#fff;line-height:1.15;margin:0 0 18px;
    text-shadow:0 2px 30px rgba(0,0,0,.25);
}
.hero__sub{font-size:clamp(16px,1.6vw,20px);color:rgba(255,255,255,.92);margin:0 0 32px;max-width:640px}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px}
.hero__scroll{
    position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
    width:24px;height:40px;border:2px solid rgba(255,255,255,.7);border-radius:20px;
}
.hero__scroll span{
    display:block;width:4px;height:8px;background:#fff;border-radius:2px;
    margin:8px auto;animation:scroll 1.6s ease-in-out infinite;
}
@keyframes scroll{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(10px);opacity:.4}}

/* ---------- Stats ---------- */
.stats{padding:48px 0}
.stats__grid{
    display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
    background:#fff;border-radius:var(--radius-lg);padding:30px;
    box-shadow:var(--shadow-md);margin-top:-60px;position:relative;z-index:5;
}
.stat{
    text-align:center;padding:14px;border-inline-end:1px solid var(--c-border);
}
.stat:last-child{border-inline-end:0}
.stat__num{
    display:block;font-size:clamp(32px,4vw,46px);font-weight:900;
    color:var(--c-primary);font-family:'Cairo',sans-serif;
}
.stat__label{display:block;color:var(--c-muted);font-weight:600;font-size:14px}
.stat--dark .stat__num{color:var(--c-accent)}

/* ---------- Section heads ---------- */
.section-head{text-align:center;max-width:760px;margin:0 auto 56px}
.section-head__eyebrow{
    display:inline-block;color:var(--c-primary);font-weight:700;
    text-transform:uppercase;letter-spacing:2px;font-size:13px;margin-bottom:10px;
    position:relative;padding-inline:30px;
}
.section-head__eyebrow::before,.section-head__eyebrow::after{
    content:"";position:absolute;top:50%;width:20px;height:2px;background:var(--c-accent);
}
.section-head__eyebrow::before{right:0}
.section-head__eyebrow::after{left:0}
.section-head__title{font-size:clamp(28px,3.4vw,40px);color:var(--c-dark);margin:0 0 14px}
.section-head__sub{color:var(--c-muted);font-size:17px;margin:0}

/* ---------- Cards grid ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:28px}
.cards--lg{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:32px}
.card{
    background:#fff;border-radius:var(--radius);overflow:hidden;
    box-shadow:var(--shadow-sm);transition:.3s;
    border:1px solid var(--c-border);display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card__media{display:block;overflow:hidden;aspect-ratio:3/2;position:relative}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .card__media img{transform:scale(1.07)}
.card__media::after{
    content:"";position:absolute;inset:auto 0 0 0;height:50%;
    background:linear-gradient(to top,rgba(13,59,102,.45),transparent);
}
.card__body{padding:22px 22px 26px;display:flex;flex-direction:column;gap:10px;flex:1}
.card__title{font-size:20px;margin:0}
.card__title a{color:var(--c-dark)}
.card__title a:hover{color:var(--c-primary)}
.card__desc{color:var(--c-muted);margin:0;font-size:15px;flex:1}
.card__link{
    margin-top:8px;color:var(--c-primary);font-weight:700;align-self:flex-start;
    border-bottom:2px solid transparent;padding-bottom:2px;
}
.card__link:hover{border-color:var(--c-accent);color:var(--c-dark)}

/* ---------- Why us ---------- */
.why__grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.why__head .section-head__title{margin-bottom:14px}
.why__media{margin-top:30px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);position:relative}
.why__media::before{
    content:"";position:absolute;inset:auto -20px -20px auto;width:60%;height:60%;
    background:repeating-linear-gradient(45deg,var(--c-accent) 0 2px,transparent 2px 12px);
    border-radius:var(--radius);opacity:.6;z-index:-1;
}
.why__list{display:flex;flex-direction:column;gap:22px}
.why__item{
    display:flex;gap:18px;background:#fff;padding:24px;border-radius:var(--radius);
    box-shadow:var(--shadow-sm);border:1px solid var(--c-border);transition:.25s;
}
.why__item:hover{transform:translateX(-4px);border-color:var(--c-accent);box-shadow:var(--shadow-md)}
.why__num{
    flex:0 0 auto;width:54px;height:54px;border-radius:14px;
    background:linear-gradient(135deg,var(--c-primary),var(--c-dark));
    color:var(--c-accent);font-weight:900;font-size:20px;
    display:inline-flex;align-items:center;justify-content:center;font-family:'Cairo',sans-serif;
}
.why__title{font-size:18px;margin:0 0 6px;color:var(--c-dark)}
.why__desc{color:var(--c-muted);margin:0;font-size:15px}

/* ---------- Page hero / breadcrumbs ---------- */
.page-hero{
    background:linear-gradient(135deg,var(--c-primary),var(--c-dark));
    color:#fff;padding:70px 0 60px;position:relative;overflow:hidden;
}
.page-hero::before{
    content:"";position:absolute;inset:0;
    background:radial-gradient(circle at 100% 0,rgba(244,197,66,.18),transparent 60%);
}
.page-hero__title{color:#fff;font-size:clamp(32px,4vw,46px);margin:14px 0 8px;position:relative}
.page-hero__sub{color:rgba(255,255,255,.85);font-size:18px;margin:0;max-width:760px;position:relative}
.breadcrumbs{color:rgba(255,255,255,.7);font-size:14px;position:relative}
.breadcrumbs a{color:var(--c-accent)}
.breadcrumbs .sep{margin:0 8px;color:rgba(255,255,255,.5)}

/* ---------- About ---------- */
.about-intro__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:center}
.about-intro__media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}
.about-intro__text p{font-size:17px;line-height:2;color:var(--c-text)}

.mvv__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.mvv__item{
    background:#fff;border-radius:var(--radius);padding:36px 28px;text-align:center;
    box-shadow:var(--shadow-sm);border:1px solid var(--c-border);transition:.3s;
}
.mvv__item:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--c-accent)}
.mvv__icon{
    display:inline-flex;width:72px;height:72px;align-items:center;justify-content:center;
    background:linear-gradient(135deg,var(--c-primary),var(--c-dark));color:var(--c-accent);
    border-radius:50%;font-size:32px;margin-bottom:16px;
}
.mvv__item h3{font-size:22px;color:var(--c-dark);margin:0 0 8px}
.mvv__item p{color:var(--c-muted);margin:0;font-size:15px}

/* ---------- Products (featured list) ---------- */
.featured-list__items{display:flex;flex-direction:column;gap:80px;margin-top:50px}
.featured{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.featured--rev{direction:rtl}
.featured--rev .featured__media{order:2}
.featured__media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}
.featured__num{
    display:inline-block;color:var(--c-accent);font-weight:900;font-size:64px;line-height:1;
    font-family:'Cairo',sans-serif;margin-bottom:6px;opacity:.9;
}
.featured h3{font-size:30px;color:var(--c-dark);margin:0 0 14px}
.featured p{color:var(--c-muted);font-size:17px;margin:0 0 24px;line-height:2}

/* ---------- Contact ---------- */
.contact__grid{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start}
.contact__info{
    background:linear-gradient(135deg,var(--c-primary),var(--c-dark));color:#fff;
    border-radius:var(--radius-lg);padding:36px;position:relative;overflow:hidden;
}
.contact__info::after{
    content:"";position:absolute;inset:auto -30% -40% auto;width:80%;height:80%;
    background:radial-gradient(closest-side,var(--c-accent),transparent 70%);opacity:.18;
}
.contact__info .section-head__title{color:#fff;margin-bottom:20px;position:relative}
.contact__list{display:flex;flex-direction:column;gap:18px;position:relative}
.contact__list li{display:flex;gap:14px;align-items:flex-start}
.contact__list .ci{
    flex:0 0 auto;width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.1);
    display:inline-flex;align-items:center;justify-content:center;font-size:18px;
}
.contact__list strong{display:block;color:var(--c-accent);font-size:14px;margin-bottom:2px}
.contact__list a{color:#fff;font-weight:600}
.contact__list a:hover{color:var(--c-accent)}

.contact__form-wrap{background:#fff;border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-md);border:1px solid var(--c-border)}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-form label{display:block;font-weight:700;color:var(--c-dark);margin-bottom:14px;font-size:14px}
.contact-form input,
.contact-form textarea,
.contact-form select{
    display:block;width:100%;margin-top:6px;
    padding:14px 16px;border:2px solid var(--c-border);border-radius:12px;
    font-family:inherit;font-size:16px;background:#fff;color:var(--c-text);transition:border-color .2s,box-shadow .2s;
}
.contact-form input:focus,
.contact-form textarea:focus{outline:0;border-color:var(--c-primary);box-shadow:0 0 0 4px rgba(13,59,102,.08)}
.contact-form button{margin-top:8px;width:auto}
.alert{padding:14px 18px;border-radius:12px;margin:0 0 18px;font-weight:600}
.alert--success{background:#e6f7ed;color:#0f6b34;border:1px solid #b6e3c6}
.alert--error{background:#fdecec;color:#a3251f;border:1px solid #f3c0bd}

.map-section{padding:0 0 60px}
.map-embed{
    width:100%;max-width:var(--container);margin:0 auto;
    border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);
}
.map-embed iframe{width:100%;height:420px;border:0;display:block}

/* ---------- CTA band ---------- */
.cta-band{
    background:linear-gradient(135deg,var(--c-primary),var(--c-dark));
    color:#fff;padding:60px 0;position:relative;overflow:hidden;
}
.cta-band::before{
    content:"";position:absolute;inset:0;
    background:radial-gradient(circle at 0 100%,rgba(244,197,66,.2),transparent 50%);
}
.cta-band__inner{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap;position:relative}
.cta-band__title{color:#fff;font-size:clamp(24px,3vw,34px);margin:0 0 6px}
.cta-band__sub{color:rgba(255,255,255,.85);margin:0;font-size:16px}
.cta-band__buttons{display:flex;gap:12px;flex-wrap:wrap}

/* ---------- Footer ---------- */
.site-footer{background:var(--c-dark);color:#cfd8e8;padding:64px 0 0;margin-top:0}
.site-footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px;padding-bottom:48px}
.footer-title{color:#fff;font-size:18px;margin:0 0 16px;font-weight:800}
.footer-col p{color:#a9b5c8;line-height:1.9;font-size:15px;margin:0 0 16px}
.footer-links li{margin-bottom:8px}
.footer-links a,.footer-contact a{color:#cfd8e8}
.footer-links a:hover,.footer-contact a:hover{color:var(--c-accent)}
.footer-contact li{display:flex;gap:10px;margin-bottom:10px;align-items:flex-start;color:#a9b5c8}
.footer-social{display:flex;gap:8px;margin-top:12px}
.footer-social a{
    width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.06);
    display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#fff;
}
.footer-social a:hover{background:var(--c-accent);color:var(--c-dark)}
.site-footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding:18px 0;text-align:center;font-size:14px;color:#8c98ac}
.site-footer__bottom p{margin:0}

/* ---------- WhatsApp float ---------- */
.wa-float{
    position:fixed;bottom:24px;left:24px;z-index:80;
    width:58px;height:58px;border-radius:50%;
    background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;
    font-size:28px;box-shadow:0 8px 24px rgba(37,211,102,.4);
    transition:.25s;
}
.wa-float:hover{transform:scale(1.08);color:#fff}

/* ---------- Default page / blog ---------- */
article.single-post{padding:60px 0}
a.topbar__item{direction:ltr}
.footer-contact li a{direction:ltr;text-align:right}
.single-post__inner{max-width:880px;margin:0 auto}
.single-post__media{margin-bottom:30px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.single-post__media img{width:100%;height:auto;display:block}
.single-post__footer{margin-top:36px;padding-top:24px;border-top:1px solid var(--c-border)}
.tag-pill{display:inline-block;background:var(--c-bg-alt);color:var(--c-primary);padding:4px 12px;border-radius:999px;margin-inline-end:6px;font-size:14px;font-weight:600}
.default-page{padding:60px 20px}
.archive-header{margin-bottom:30px}
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px}
.entry-content{max-width:820px;margin:0 auto;font-size:17px;line-height:2}
.entry-content h2{margin-top:1.4em}
.entry-content img{border-radius:var(--radius);margin:1.4em 0}
.pagination{margin-top:36px;text-align:center}

/* ---------- Responsive ---------- */
@media (max-width: 1024px){
    .site-header__inner{gap:14px}
    .header-cta{display:none}
    .why__grid,.about-intro__grid,.contact__grid{grid-template-columns:1fr;gap:40px}
    .featured{grid-template-columns:1fr;gap:30px}
    .featured--rev .featured__media{order:0}
    .stats__grid{grid-template-columns:repeat(2,1fr);margin-top:-40px}
    .stat{border-inline-end:0}
    .stat:nth-child(odd){border-inline-end:1px solid var(--c-border)}
    .mvv__grid{grid-template-columns:1fr;gap:20px}
}
@media (max-width: 768px){
    body{font-size:16px}
    .section{padding:60px 0}
    .topbar{display:none}
    .nav-toggle{display:inline-flex}
    .primary-nav{
        position:absolute;inset:100% 0 auto 0;background:#fff;
        max-height:0;overflow:hidden;transition:max-height .35s ease;
        box-shadow:var(--shadow-md);
    }
    .primary-nav.is-open{max-height:80vh;overflow-y:auto}
    .primary-menu{flex-direction:column;padding:14px;gap:2px}
    .primary-menu li{width:100%}
    .primary-menu a{display:block;padding:14px 16px;border-radius:8px}
    .primary-menu .sub-menu{
        position:static;opacity:1;visibility:visible;transform:none;
        box-shadow:none;background:rgba(13,59,102,.04);padding:6px;margin:6px 0;
    }
    .hero{min-height:auto;padding:90px 0 110px}
    .hero__cta .btn{flex:1 1 auto}
    .site-footer__grid{grid-template-columns:1fr 1fr;gap:30px}
    .contact-form .row{grid-template-columns:1fr}
    .cta-band__inner{text-align:center;justify-content:center;flex-direction:column}
}
@media (max-width: 540px){
    .container{padding:0 16px}
    .section{padding:48px 0}
    .stats__grid{grid-template-columns:1fr;padding:18px}
    .stat{border-inline-end:0 !important;padding:14px 0;border-bottom:1px solid var(--c-border)}
    .stat:last-child{border-bottom:0}
    .site-footer__grid{grid-template-columns:1fr;gap:28px}
    .brand-text em{display:none}
    .brand-text strong{font-size:16px}
    .wa-float{bottom:18px;left:18px;width:52px;height:52px;font-size:24px}
}

/* RTL fine-tuning */
[dir="rtl"] .why__item:hover{transform:translateX(4px)}

/* Reveal animations — only the class added by JS; everything else stays visible */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
    .reveal{opacity:1;transform:none;transition:none}
}
.site-header.is-scrolled{box-shadow:0 6px 24px rgba(13,59,102,.10)}

/* ============================================================
   v2 — Responsive/spacing fixes + portfolio gallery
   ============================================================ */

/* Center orphan rows in auto-fill card grids (5 cards in 3-col = 2 orphans) */
.cards{justify-content:center}

/* Tighter hero spacing on mobile + better title scale */
@media (max-width:768px){
    .hero{padding:64px 0 76px}
    .hero__title{font-size:clamp(26px,7vw,34px);line-height:1.25}
    .hero__sub{font-size:15px;margin-bottom:24px}
    .hero__cta{gap:10px}
    .section{padding:52px 0}
    .section-head{margin-bottom:36px}
    .section-head__title{font-size:clamp(22px,5.5vw,28px)}
    .cards{gap:20px}
}
@media (max-width:540px){
    .hero{padding:52px 0 64px}
    .hero__eyebrow{font-size:12px;padding:6px 12px}
    .hero__title{font-size:clamp(24px,7.5vw,30px)}
    .section{padding:44px 0}
    .section-head{margin-bottom:28px}
    .container{padding:0 18px}
    .card__body{padding:18px}
    .why__item{padding:18px}
    .why__num{font-size:32px}
    .cta-band{padding:48px 0}
    .cta-band__title{font-size:24px}
}

/* ---------- Portfolio gallery ---------- */
.portfolio .section-head{margin-bottom:48px}
.portfolio__grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
    gap:18px;
}
.portfolio__item{
    position:relative;
    display:block;
    overflow:hidden;
    border-radius:14px;
    aspect-ratio:4/3;
    box-shadow:0 6px 20px rgba(13,59,102,.10);
    background:#0d3b66;
    transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s;
    text-decoration:none;
}
.portfolio__item:hover,
.portfolio__item:focus-visible{
    transform:translateY(-6px);
    box-shadow:0 18px 44px rgba(13,59,102,.22);
    outline:none;
}
.portfolio__item img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:transform .6s cubic-bezier(.2,.7,.2,1), filter .4s;
}
.portfolio__item:hover img,
.portfolio__item:focus-visible img{
    transform:scale(1.08);
    filter:brightness(.92);
}
.portfolio__item::after{
    content:"";
    position:absolute;inset:0;
    background:linear-gradient(to top, rgba(13,59,102,.92) 0%, rgba(13,59,102,.30) 40%, rgba(13,59,102,0) 60%);
    opacity:0;
    transition:opacity .4s;
    pointer-events:none;
}
.portfolio__item:hover::after,
.portfolio__item:focus-visible::after{opacity:1}
.portfolio__caption{
    position:absolute;
    bottom:14px;inset-inline:18px;
    color:#fff;
    font-weight:600;
    font-size:14px;
    transform:translateY(10px);
    opacity:0;
    transition:transform .4s, opacity .4s;
    z-index:2;
    text-shadow:0 2px 8px rgba(0,0,0,.3);
}
.portfolio__item:hover .portfolio__caption,
.portfolio__item:focus-visible .portfolio__caption{
    transform:translateY(0);
    opacity:1;
}
/* Asymmetric tile sizes on wider screens for visual rhythm */
@media (min-width:1024px){
    .portfolio__grid{
        grid-template-columns:repeat(4,1fr);
        grid-auto-flow:dense;
        gap:20px;
    }
    .portfolio__item:nth-child(7n+1){grid-column:span 2;aspect-ratio:16/10}
    .portfolio__item:nth-child(11n+5){grid-row:span 2;aspect-ratio:3/4}
}
@media (max-width:768px){
    .portfolio__grid{grid-template-columns:repeat(2,1fr);gap:12px}
    .portfolio__caption{font-size:12px;bottom:10px;inset-inline:12px}
    .portfolio .section-head{margin-bottom:32px}
}
@media (max-width:420px){
    .portfolio__grid{grid-template-columns:1fr;gap:14px}
}

/* ============================================================
   Hero v2 — split layout, image stack, trust strip
   ============================================================ */
.hero--v2{
    position:relative;
    color:#fff;
    min-height:calc(100vh - var(--header-h));
    padding:90px 0 120px;
    display:flex;align-items:center;
    overflow:hidden;
    background:
        radial-gradient(80% 60% at 90% -10%, rgba(244,197,66,.18), transparent 60%),
        radial-gradient(60% 50% at -10% 100%, rgba(13,59,102,.6), transparent 60%),
        linear-gradient(135deg,#06223f 0%,#0d3b66 55%,#0a2e52 100%);
    isolation:isolate;
}
.hero--v2::after{display:none}
.hero--v2 .hero__bg{
    position:absolute;inset:0;
    background-size:cover;background-position:center;
    opacity:.18;
    mix-blend-mode:luminosity;
    z-index:-1;
}
.hero--v2::before{
    content:"";
    position:absolute;inset:0;
    background-image:
        radial-gradient(rgba(255,255,255,.07) 1px, transparent 1px);
    background-size:24px 24px;
    opacity:.5;
    z-index:-1;
    pointer-events:none;
}
.hero__shape{
    position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:-1;
}
.hero__shape--a{
    width:520px;height:520px;background:rgba(244,197,66,.22);
    top:-160px;right:-120px;
    animation:heroFloat 14s ease-in-out infinite alternate;
}
.hero__shape--b{
    width:420px;height:420px;background:rgba(56,189,248,.18);
    bottom:-140px;left:-100px;
    animation:heroFloat 18s ease-in-out infinite alternate-reverse;
}
@keyframes heroFloat{
    0%{transform:translate(0,0)}
    100%{transform:translate(30px,-20px)}
}

.hero__grid{
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:60px;
    align-items:center;
    position:relative;z-index:2;
}
.hero__text{max-width:640px}

.hero__eyebrow{
    display:inline-flex;align-items:center;gap:8px;
    background:rgba(244,197,66,.12);
    color:var(--c-accent);
    padding:9px 18px;border-radius:999px;
    font-weight:700;font-size:13px;letter-spacing:.3px;
    margin-bottom:22px;
    border:1px solid rgba(244,197,66,.32);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
}
.hero__eyebrow-dot{
    width:8px;height:8px;border-radius:50%;background:var(--c-accent);
    box-shadow:0 0 0 4px rgba(244,197,66,.25);
    animation:dotPulse 2s ease-in-out infinite;
}
@keyframes dotPulse{
    0%,100%{box-shadow:0 0 0 4px rgba(244,197,66,.25)}
    50%{box-shadow:0 0 0 8px rgba(244,197,66,.05)}
}

.hero__title{
    font-size:clamp(34px,4.6vw,58px);
    font-weight:900;
    line-height:1.18;
    margin:0 0 22px;
    color:#fff;
    text-shadow:0 4px 30px rgba(0,0,0,.3);
    letter-spacing:-.5px;
}
.hero__sub{
    font-size:clamp(16px,1.4vw,18px);
    line-height:1.75;
    color:rgba(255,255,255,.85);
    margin:0 0 32px;
    max-width:560px;
}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero__cta .btn{display:inline-flex;align-items:center;gap:10px}

.btn--ghost{
    background:rgba(255,255,255,.08);
    color:#fff;
    border:1px solid rgba(255,255,255,.25);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
}
.btn--ghost:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.4)}

.hero__trust{
    list-style:none;padding:0;margin:44px 0 0;
    display:flex;gap:36px;flex-wrap:wrap;
    padding-top:28px;
    border-top:1px solid rgba(255,255,255,.14);
}
.hero__trust li{display:flex;flex-direction:column;gap:2px}
.hero__trust strong{
    font-size:28px;font-weight:900;color:var(--c-accent);
    line-height:1;font-family:inherit;
}
.hero__trust span{font-size:13px;color:rgba(255,255,255,.7);font-weight:500}

/* ---------- Media stack (3 tilted images + badge) ---------- */
.hero__media{position:relative;height:560px;width:100%}
.hero__stack{position:relative;width:100%;height:100%;perspective:1200px}
.hero__pic{
    position:absolute;
    border-radius:18px;
    background-size:cover;background-position:center;
    box-shadow:0 28px 60px rgba(0,0,0,.45), 0 0 0 2px rgba(255,255,255,.06);
    overflow:hidden;
    transition:transform .8s cubic-bezier(.2,.8,.2,1);
    will-change:transform;
}
.hero__pic--1{
    width:62%;height:70%;
    top:8%;right:0;
    transform:rotate(4deg);
    z-index:3;
}
.hero__pic--2{
    width:54%;height:58%;
    bottom:6%;left:0;
    transform:rotate(-5deg);
    z-index:2;
}
.hero__pic--3{
    width:46%;height:46%;
    top:0;left:18%;
    transform:rotate(8deg);
    z-index:1;
    opacity:.92;
}
.hero__stack:hover .hero__pic--1{transform:rotate(2deg) translateY(-6px)}
.hero__stack:hover .hero__pic--2{transform:rotate(-3deg) translateY(-4px)}
.hero__stack:hover .hero__pic--3{transform:rotate(6deg) translateY(-3px)}

.hero__badge{
    position:absolute;
    bottom:18%;right:-8%;
    z-index:5;
    background:linear-gradient(135deg,var(--c-accent),#e0a92e);
    color:#06223f;
    border-radius:18px;
    padding:18px 22px;
    display:flex;flex-direction:column;align-items:center;
    box-shadow:0 16px 38px rgba(244,197,66,.4), 0 0 0 4px rgba(255,255,255,.95);
    transform:rotate(-4deg);
    animation:badgeFloat 6s ease-in-out infinite;
}
.hero__badge-num{font-size:36px;font-weight:900;line-height:1;letter-spacing:-1px}
.hero__badge-lbl{font-size:12px;font-weight:700;margin-top:4px;letter-spacing:.2px}
@keyframes badgeFloat{
    0%,100%{transform:rotate(-4deg) translateY(0)}
    50%{transform:rotate(-2deg) translateY(-6px)}
}

/* RTL flip for media side */
[dir="rtl"] .hero__pic--1{right:auto;left:0;transform:rotate(-4deg)}
[dir="rtl"] .hero__pic--2{left:auto;right:0;transform:rotate(5deg)}
[dir="rtl"] .hero__pic--3{left:auto;right:18%;transform:rotate(-8deg)}
[dir="rtl"] .hero__stack:hover .hero__pic--1{transform:rotate(-2deg) translateY(-6px)}
[dir="rtl"] .hero__stack:hover .hero__pic--2{transform:rotate(3deg) translateY(-4px)}
[dir="rtl"] .hero__stack:hover .hero__pic--3{transform:rotate(-6deg) translateY(-3px)}
[dir="rtl"] .hero__badge{right:auto;left:-8%;transform:rotate(4deg)}
[dir="rtl"] @keyframes badgeFloat{
    0%,100%{transform:rotate(4deg) translateY(0)}
    50%{transform:rotate(2deg) translateY(-6px)}
}

/* ---------- Hero v2 responsive ---------- */
@media (max-width:1024px){
    .hero--v2{padding:80px 0 100px;min-height:auto}
    .hero__grid{grid-template-columns:1fr;gap:48px}
    .hero__text{max-width:none;text-align:center;margin:0 auto}
    .hero__sub{margin-inline:auto}
    .hero__cta{justify-content:center}
    .hero__trust{justify-content:center;margin-top:36px}
    .hero__media{height:420px;max-width:520px;margin:0 auto}
}
@media (max-width:768px){
    .hero--v2{padding:64px 0 80px}
    .hero__title{font-size:clamp(26px,7vw,36px);line-height:1.25}
    .hero__sub{font-size:15px}
    .hero__trust{gap:24px;margin-top:32px;padding-top:22px}
    .hero__trust strong{font-size:22px}
    .hero__media{height:340px}
    .hero__badge{padding:14px 16px;bottom:14%}
    .hero__badge-num{font-size:28px}
}
@media (max-width:540px){
    .hero--v2{padding:52px 0 64px}
    .hero__title{font-size:clamp(24px,7.5vw,32px)}
    .hero__sub{margin-bottom:24px}
    .hero__trust{gap:18px}
    .hero__trust strong{font-size:20px}
    .hero__trust span{font-size:11px}
    .hero__media{height:280px;max-width:340px}
    .hero__pic{border-radius:14px}
    .hero__badge{padding:12px 14px;border-radius:14px}
    .hero__badge-num{font-size:24px}
    .hero__badge-lbl{font-size:10px}
    .hero__shape--a,.hero__shape--b{filter:blur(50px)}
    .hero__shape--a{width:300px;height:300px}
    .hero__shape--b{width:260px;height:260px}
}
@media (max-width:380px){
    .hero__cta .btn{width:100%;justify-content:center}
}

/* ---------------- Home: Company About block ---------------- */
.home-about{padding:84px 0;background:linear-gradient(180deg,#fff 0%,#f7faff 100%)}
.home-about__grid{display:grid;grid-template-columns:1fr 1.15fr;gap:56px;align-items:center}
.home-about__media{position:relative;border-radius:24px;overflow:hidden;box-shadow:0 30px 60px -25px rgba(13,59,102,.35);isolation:isolate}
.home-about__media img{display:block;width:100%;height:100%;min-height:420px;object-fit:cover;transition:transform .8s ease}
.home-about__media:hover img{transform:scale(1.04)}
.home-about__media::before{content:"";position:absolute;inset:auto -30px -30px auto;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,var(--c-accent) 0%,transparent 70%);opacity:.45;z-index:-1}
.home-about__badge{position:absolute;inset-block-start:-22px;inset-inline-start:-22px;width:138px;height:138px;border-radius:50%;background:radial-gradient(circle at 30% 25%,#ffd766 0%,var(--c-accent) 50%,#d29c14 100%);color:var(--c-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;line-height:1;box-shadow:0 18px 40px -10px rgba(13,59,102,.45),inset 0 -6px 14px rgba(0,0,0,.18),inset 0 4px 10px rgba(255,255,255,.4);font-weight:900;text-align:center;z-index:3;animation:badge-float 4s ease-in-out infinite}
.home-about__badge-ring{position:absolute;inset:6px;border-radius:50%;border:2px dashed rgba(13,59,102,.55);pointer-events:none;animation:badge-rotate 18s linear infinite}
.home-about__badge-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--c-dark)}
.home-about__badge-num{font-size:32px;letter-spacing:-1px;text-shadow:0 1px 0 rgba(255,255,255,.45);font-family:'Cairo','Tajawal',sans-serif}
.home-about__badge-lbl{font-size:10.5px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;opacity:.85}
@keyframes badge-rotate{to{transform:rotate(360deg)}}
@keyframes badge-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
[dir="rtl"] .home-about__badge{inset-inline-start:auto;inset-inline-end:-22px}
@media (max-width:900px){
    .home-about__badge{width:118px;height:118px;inset-block-start:-18px;inset-inline-start:-12px}
    [dir="rtl"] .home-about__badge{inset-inline-end:-12px}
    .home-about__badge-num{font-size:26px}
}
.home-about__text{display:flex;flex-direction:column;gap:14px}
.home-about__text .section-head__eyebrow{align-self:flex-start;background:rgba(13,59,102,.08);color:var(--c-primary);padding:6px 14px;border-radius:999px;font-weight:700;font-size:13px}
.home-about__text .section-head__title{font-size:clamp(24px,3.4vw,38px);line-height:1.25;margin:6px 0 4px;color:var(--c-dark)}
.home-about__text p{color:#445268;line-height:1.85;font-size:15.5px;margin:0}
.home-about__bullets{list-style:none;padding:0;margin:14px 0 8px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 22px}
.home-about__bullets li{display:flex;align-items:center;gap:10px;color:var(--c-dark);font-weight:700;font-size:14.5px}
.home-about__bullets li svg{flex:0 0 auto;width:18px;height:18px;padding:4px;border-radius:50%;background:var(--c-accent);color:var(--c-dark)}
.home-about__cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}
@media (max-width:900px){
    .home-about{padding:56px 0}
    .home-about__grid{grid-template-columns:1fr;gap:32px}
    .home-about__media img{min-height:280px}
    .home-about__bullets{grid-template-columns:1fr}
}

/* ---------------- 11-card services grid balance ---------------- */
.services .cards,.products .cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.services .card,.products .card{transition:transform .35s ease,box-shadow .35s ease}
.services .card:hover,.products .card:hover{transform:translateY(-6px);box-shadow:0 24px 50px -20px rgba(13,59,102,.35)}

/* RTL/LTR safety for phone digits */
.topbar__item bdi,.footer-contact bdi,.contact__list bdi{direction:ltr;unicode-bidi:isolate;display:inline-block}
.contact__list a[href^="tel:"]{direction:ltr;unicode-bidi:isolate;display:inline-block}

/* ---------------- Portfolio grid polish (balanced + zoom hint) ---------------- */
.portfolio__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}
.portfolio__item{cursor:zoom-in;border-radius:16px}
.portfolio__item::before{content:"";position:absolute;inset-block-start:12px;inset-inline-end:12px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%230d3b66' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><line x1='21' y1='21' x2='16.65' y2='16.65'/><line x1='11' y1='8' x2='11' y2='14'/><line x1='8' y1='11' x2='14' y2='11'/></svg>");background-repeat:no-repeat;background-position:center;opacity:0;transform:scale(.6);transition:opacity .35s,transform .35s;z-index:3;box-shadow:0 6px 16px rgba(0,0,0,.18);pointer-events:none}
.portfolio__item:hover::before,.portfolio__item:focus-visible::before{opacity:1;transform:scale(1)}
@media (min-width:1024px){
    .portfolio__grid{grid-template-columns:repeat(4,1fr);grid-auto-flow:dense;gap:18px}
    .portfolio__item:nth-child(8n+1){grid-column:span 2;grid-row:span 2;aspect-ratio:1/1}
    .portfolio__item:nth-child(8n+4){grid-column:span 2;aspect-ratio:16/9}
}

/* ---------------- Lightbox / image popup ---------------- */
body.lb-locked{overflow:hidden}
.lb{position:fixed;inset:0;z-index:9999;background:rgba(6,34,63,.94);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility 0s linear .25s;padding:32px}
.lb.is-open{opacity:1;visibility:visible;transition:opacity .25s ease,visibility 0s}
.lb__stage{margin:0;max-width:min(96vw,1280px);max-height:88vh;display:flex;flex-direction:column;align-items:center;gap:14px;transform:scale(.95);transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.lb.is-open .lb__stage{transform:scale(1)}
.lb__img{display:block;max-width:100%;max-height:78vh;object-fit:contain;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb__cap{color:#fff;font-weight:700;font-size:15px;text-align:center;background:rgba(255,255,255,.08);padding:8px 16px;border-radius:999px;backdrop-filter:blur(4px)}
.lb__close{position:absolute;inset-block-start:18px;inset-inline-end:22px;width:46px;height:46px;border-radius:50%;border:none;background:rgba(255,255,255,.15);color:#fff;font-size:30px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s}
.lb__close:hover{background:var(--c-accent);color:var(--c-dark);transform:rotate(90deg) scale(1.08)}
.lb__nav{position:absolute;inset-block-start:50%;transform:translateY(-50%);width:50px;height:50px;border-radius:50%;border:none;background:rgba(255,255,255,.12);color:#fff;font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s;z-index:2}
.lb__nav:hover{background:var(--c-accent);color:var(--c-dark)}
.lb__nav--prev{inset-inline-start:22px}
.lb__nav--next{inset-inline-end:22px}
.lb__count{position:absolute;inset-block-end:22px;inset-inline-start:50%;transform:translateX(-50%);color:#fff;font-size:13px;font-weight:700;background:rgba(255,255,255,.1);padding:6px 14px;border-radius:999px;letter-spacing:1px}
@media (max-width:600px){
    .lb{padding:16px}
    .lb__close{inset-block-start:10px;inset-inline-end:12px;width:38px;height:38px;font-size:24px}
    .lb__nav{width:38px;height:38px;font-size:18px}
    .lb__nav--prev{inset-inline-start:8px}
    .lb__nav--next{inset-inline-end:8px}
    .lb__img{max-height:70vh}
    .lb__cap{font-size:13px;padding:6px 12px}
}


/* ===================== Service page (v2 — redesigned) ===================== */

/* --- Service hero (split layout with media stack) --- */
.service-hero{position:relative;min-height:620px;display:flex;align-items:center;color:#fff;overflow:hidden;isolation:isolate;padding:60px 0}
.service-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:-2;transform:scale(1.04);filter:saturate(1.05)}
.service-hero__overlay{position:absolute;inset:0;background:linear-gradient(110deg,rgba(6,34,63,.94) 0%,rgba(6,34,63,.78) 40%,rgba(13,59,102,.55) 65%,rgba(13,59,102,.25) 100%);z-index:-1}
.service-hero__shape{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:-1;opacity:.6}
.service-hero__shape--a{width:520px;height:520px;background:radial-gradient(circle,rgba(244,197,66,.35) 0%,transparent 70%);top:-160px;inset-inline-end:-120px}
.service-hero__shape--b{width:420px;height:420px;background:radial-gradient(circle,rgba(13,59,102,.6) 0%,transparent 70%);bottom:-140px;inset-inline-start:-100px}

.service-hero__inner{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;width:100%}
.service-hero__content{max-width:640px}
.service-hero .breadcrumbs{margin-bottom:18px;color:rgba(255,255,255,.7)}
.service-hero .breadcrumbs a{color:rgba(255,255,255,.85)}
.service-hero__eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;letter-spacing:2.2px;font-weight:700;color:var(--c-accent);background:rgba(244,197,66,.12);border:1px solid rgba(244,197,66,.4);padding:7px 16px;border-radius:999px;margin-bottom:22px;text-transform:uppercase}
.service-hero__eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--c-accent);box-shadow:0 0 0 4px rgba(244,197,66,.2);animation:srvpulse 2s ease-in-out infinite}
@keyframes srvpulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.5}}
.service-hero__title{color:#fff;font-size:clamp(32px,4.8vw,58px);line-height:1.1;font-weight:900;margin:0 0 20px;letter-spacing:-.5px;text-shadow:0 4px 30px rgba(0,0,0,.35)}
.service-hero__sub{font-size:clamp(16px,1.5vw,19px);line-height:1.75;color:rgba(255,255,255,.92);margin:0 0 28px;max-width:560px}
.service-hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}
.service-hero__chips{display:flex;flex-wrap:wrap;gap:8px;list-style:none;padding:0;margin:0}
.service-hero__chips li{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);padding:6px 14px;border-radius:999px;backdrop-filter:blur(8px);color:rgba(255,255,255,.95)}
.service-hero__chips .icon{color:var(--c-accent)}

/* Media stack — three offset photos + badge */
.service-hero__media{position:relative;height:520px;max-width:560px;margin-inline-start:auto}
.service-hero__pic{position:absolute;background-size:cover;background-position:center;border-radius:20px;box-shadow:0 30px 80px -25px rgba(0,0,0,.7),0 0 0 4px rgba(255,255,255,.06)}
.service-hero__pic--main{width:75%;height:75%;inset-block-start:0;inset-inline-end:0;z-index:2;transform:rotate(2deg);transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.service-hero:hover .service-hero__pic--main{transform:rotate(0deg) scale(1.02)}
.service-hero__pic--a{width:48%;height:42%;inset-block-end:30px;inset-inline-start:0;z-index:3;transform:rotate(-4deg);transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.service-hero:hover .service-hero__pic--a{transform:rotate(-1deg) translateY(-6px)}
.service-hero__pic--b{width:42%;height:38%;inset-block-end:0;inset-inline-end:6%;z-index:1;transform:rotate(6deg);opacity:.85}
.service-hero__badge{position:absolute;inset-block-start:8%;inset-inline-start:-10px;z-index:4;width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--c-accent) 0%,#e3b127 100%);color:var(--c-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:900;box-shadow:0 20px 50px -15px rgba(244,197,66,.7);animation:srvfloat 5s ease-in-out infinite}
@keyframes srvfloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.service-hero__badge-num{font-size:42px;line-height:1}
.service-hero__badge-lbl{font-size:12px;letter-spacing:1px;margin-top:2px}

@media (max-width:960px){
    .service-hero{min-height:auto;padding:60px 0 40px}
    .service-hero__inner{grid-template-columns:1fr;gap:40px}
    .service-hero__media{height:380px;max-width:100%}
    .service-hero__badge{width:90px;height:90px;inset-inline-start:0}
    .service-hero__badge-num{font-size:32px}
}

/* --- Intro section --- */
.service-intro__grid{display:grid;grid-template-columns:1.15fr 1fr;gap:64px;align-items:center}
.service-intro__text p{font-size:16.5px;line-height:1.95;color:#3b4a5a;margin:14px 0 0}
.service-intro__bullets{list-style:none;padding:0;margin:26px 0 28px;display:grid;gap:14px}
.service-intro__bullets li{display:flex;align-items:flex-start;gap:12px;font-weight:600;color:var(--c-dark);font-size:15.5px}
.service-intro__bullets li .icon{flex:0 0 auto;color:#fff;background:linear-gradient(135deg,var(--c-primary),#1a5a96);width:28px;height:28px;border-radius:50%;padding:5px;margin-top:-2px;box-shadow:0 6px 16px -6px rgba(13,59,102,.4)}
.service-intro__cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}

.service-intro__media{position:relative}
.service-intro__media-frame{position:relative;border-radius:24px;overflow:hidden;box-shadow:0 40px 80px -30px rgba(13,59,102,.45);transform:rotate(-1.5deg);transition:transform .6s ease}
.service-intro__media:hover .service-intro__media-frame{transform:rotate(0deg)}
.service-intro__media-frame img{display:block;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover}
.service-intro__media-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 60%,rgba(13,59,102,.15));pointer-events:none}
.service-intro__badge{position:absolute;inset-block-end:-18px;inset-inline-start:-18px;background:#fff;border-radius:18px;padding:16px 20px;display:flex;flex-direction:column;align-items:flex-start;gap:2px;box-shadow:0 20px 50px -15px rgba(13,59,102,.4);border:4px solid var(--c-accent);min-width:140px}
.service-intro__badge-icon{color:var(--c-accent);background:rgba(244,197,66,.15);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:6px}
.service-intro__badge-num{font-size:32px;font-weight:900;color:var(--c-dark);line-height:1}
.service-intro__badge-lbl{font-size:12px;font-weight:700;color:#5a6a7c;letter-spacing:.5px}
.service-intro__chip{position:absolute;inset-block-start:20px;inset-inline-end:-14px;background:var(--c-accent);color:var(--c-dark);font-weight:800;font-size:13px;padding:8px 16px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;box-shadow:0 12px 30px -8px rgba(244,197,66,.6);transform:rotate(8deg)}

@media (max-width:860px){
    .service-intro__grid{grid-template-columns:1fr;gap:50px}
    .service-intro__media{order:-1;max-width:520px;margin-inline:auto}
    .service-intro__badge{inset-inline-start:0;inset-block-end:-12px}
}

/* --- Sub-services grid (the "أنواع الخدمة" section) --- */
.sub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:26px;max-width:1180px;margin-inline:auto}
.sub-grid:has(> .sub-card:only-child){grid-template-columns:minmax(0,640px);justify-content:center}
.sub-grid:has(> .sub-card:nth-child(2):last-child){grid-template-columns:repeat(2,minmax(0,440px));justify-content:center}
.sub-card{background:#fff;border-radius:22px;overflow:hidden;box-shadow:0 12px 40px -22px rgba(13,59,102,.3);transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease;display:flex;flex-direction:column;border:1px solid rgba(13,59,102,.05);position:relative}
.sub-card:hover{transform:translateY(-8px);box-shadow:0 30px 60px -22px rgba(13,59,102,.5)}
.sub-card__media{position:relative;aspect-ratio:16/10;overflow:hidden;background:#0d3b66}
.sub-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.sub-card:hover .sub-card__media img{transform:scale(1.08)}
.sub-card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(6,34,63,.65));pointer-events:none}
.sub-card__num{position:absolute;inset-block-start:16px;inset-inline-start:16px;background:var(--c-accent);color:var(--c-dark);font-weight:900;font-size:15px;padding:7px 14px;border-radius:999px;letter-spacing:1px;box-shadow:0 8px 22px -8px rgba(244,197,66,.7);z-index:1}
.sub-card__tag{position:absolute;inset-block-end:16px;inset-inline-start:16px;background:rgba(255,255,255,.15);color:#fff;font-weight:700;font-size:11px;letter-spacing:1.5px;padding:5px 11px;border-radius:999px;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);z-index:1}
.sub-card__body{padding:24px 26px 26px;display:flex;flex-direction:column;gap:12px;flex:1}
.sub-card__title{font-size:20px;font-weight:800;margin:0;color:var(--c-dark);line-height:1.35}
.sub-card__desc{font-size:15px;line-height:1.85;color:#4a5a6c;margin:0;flex:1}
.sub-card__link{margin-top:auto;display:inline-flex;align-items:center;gap:8px;font-weight:800;color:var(--c-primary);text-decoration:none;font-size:14.5px;border-block-start:1px solid rgba(13,59,102,.08);padding-top:16px;transition:color .2s,gap .2s}
.sub-card__link:hover{color:var(--c-accent);gap:12px}
.sub-card__link .icon{transition:transform .2s}
.is-rtl .sub-card__link .icon{transform:scaleX(-1)}

/* --- Featured list (products page) subservices chip list --- */
.featured__subs{list-style:none;padding:0;margin:16px 0 20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px 22px}
.featured__subs li{display:flex;align-items:center;gap:8px;font-size:14.5px;color:#3b4a5a;font-weight:500}
.featured__subs .icon{flex:0 0 auto;color:var(--c-accent)}
.featured__cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}

/* --- Related services grid (richer cards) --- */
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}
.related-card{position:relative;display:flex;flex-direction:column;justify-content:flex-end;min-height:300px;border-radius:20px;overflow:hidden;text-decoration:none;color:#fff;isolation:isolate;box-shadow:0 14px 40px -18px rgba(13,59,102,.4);transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease}
.related-card:hover{transform:translateY(-6px);box-shadow:0 28px 60px -22px rgba(13,59,102,.6)}
.related-card__media{position:absolute;inset:0;background-size:cover;background-position:center;background-color:#0d3b66;transition:transform .9s cubic-bezier(.2,.7,.2,1);z-index:-2}
.related-card:hover .related-card__media{transform:scale(1.08)}
.related-card__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,34,63,.1) 0%,rgba(6,34,63,.55) 55%,rgba(6,34,63,.95) 100%);z-index:-1;transition:background .35s ease}
.related-card:hover .related-card__overlay{background:linear-gradient(180deg,rgba(6,34,63,.3) 0%,rgba(6,34,63,.7) 55%,rgba(6,34,63,.97) 100%)}
.related-card__body{padding:22px 24px 24px;display:flex;flex-direction:column;gap:8px}
.related-card__count{display:inline-block;align-self:flex-start;font-size:11px;font-weight:800;letter-spacing:1.5px;color:var(--c-dark);background:var(--c-accent);padding:5px 11px;border-radius:999px;text-transform:uppercase;margin-bottom:4px}
.related-card__title{font-weight:900;font-size:20px;line-height:1.3;margin:0;color:#fff}
.related-card__short{font-size:13.5px;line-height:1.7;color:rgba(255,255,255,.85);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.related-card__cta{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:800;color:var(--c-accent);margin-top:6px;transition:gap .25s ease}
.related-card:hover .related-card__cta{gap:12px}
.related-card__arrow{display:inline-flex;align-items:center}
.is-rtl .related-card__arrow .icon{transform:scaleX(-1)}

@media (max-width:600px){
    .related-card{min-height:260px}
    .related-card__title{font-size:18px}
}

/* ===== Success Partners (شركاء النجاح) ===== */
.partners{background:#fff;padding-block:80px}
.partners .section-head{margin-bottom:40px}
.partners__grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(170px,1fr));
    gap:20px;
    align-items:center;
}
.partners__item{
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px 18px;
    background:#fafbfd;
    border:1px solid #eef0f4;
    border-radius:14px;
    min-height:120px;
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.partners__item img{
    max-width:100%;
    max-height:80px;
    width:auto;
    height:auto;
    object-fit:contain;
    filter:grayscale(100%);
    opacity:.72;
    transition:filter .25s ease, opacity .25s ease, transform .25s ease;
}
.partners__item:hover{
    transform:translateY(-4px);
    box-shadow:0 12px 30px rgba(13,59,102,.08);
    border-color:rgba(13,59,102,.18);
}
.partners__item:hover img{
    filter:grayscale(0);
    opacity:1;
    transform:scale(1.04);
}
@media (max-width:600px){
    .partners{padding-block:56px}
    .partners__grid{grid-template-columns:repeat(2,1fr);gap:14px}
    .partners__item{min-height:96px;padding:18px 12px}
    .partners__item img{max-height:60px}
}

/* ===== Service FAQs ===== */
.service-faqs{background:#fff}
.faqs{
    max-width:880px;
    margin:0 auto;
    display:flex;
    flex-direction:column;
    gap:14px;
}
.faq{
    background:#fafbfd;
    border:1px solid #e8ebf0;
    border-radius:14px;
    padding:0 24px;
    transition:border-color .25s ease, box-shadow .25s ease;
}
.faq[open]{
    border-color:rgba(13,59,102,.2);
    box-shadow:0 8px 24px rgba(13,59,102,.06);
}
.faq__q{
    list-style:none;
    cursor:pointer;
    padding:22px 0;
    font-weight:700;
    font-size:17px;
    color:var(--c-dark,#06223f);
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:16px;
}
.faq__q::-webkit-details-marker{display:none}
.faq__icon{
    flex-shrink:0;
    width:32px;
    height:32px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    background:var(--c-accent,#f4c542);
    color:var(--c-dark,#06223f);
    border-radius:50%;
    font-weight:900;
    font-size:20px;
    line-height:1;
    transition:transform .3s ease, background .3s ease;
}
.faq[open] .faq__icon{
    transform:rotate(45deg);
    background:var(--c-primary,#0d3b66);
    color:#fff;
}
.faq__a{
    padding:0 0 22px;
    color:#3d4d63;
    line-height:1.85;
    font-size:15.5px;
    border-top:1px solid #eef0f4;
    padding-top:18px;
    margin-top:-4px;
}
.faq__a p{margin:0}
@media (max-width:600px){
    .faq{padding:0 18px}
    .faq__q{font-size:15.5px;padding:18px 0}
}
