/* ============================================================
   Rekaz Advertising — Minimal Design System
   ============================================================ */

:root{
  --navy: #2E3191;
  --navy-700: #242682;
  --navy-900: #181a5c;
  --navy-50: #EFEFFA;
  --ink: #14162B;
  --muted: #6B6E85;
  --paper: #FFFFFF;
  --mist: #F5F5FB;
  --line: #E7E7F2;
  --whatsapp: #25D366;
  --whatsapp-dark: #1DA851;
  --radius-sm: 8px;
  --radius: 14px;
  --radius-lg: 22px;
  --container: 1180px;
  --ease: cubic-bezier(.4,0,.2,1);
  --shadow: 0 1px 2px rgba(20,22,43,.04);
  --shadow-md: 0 8px 24px rgba(20,22,43,.08);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4,p{ margin:0; }
input,textarea,select{ font:inherit; }

html{
  scroll-behavior:smooth;
}

html[lang="ar"] body{ font-family:'Tajawal','Inter',sans-serif; }
html[lang="en"] body{ font-family:'Inter','Tajawal',sans-serif; }

body{
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ---------- Language visibility ---------- */
html[lang="ar"] .en{ display:none !important; }
html[lang="en"] .ar{ display:none !important; }

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important; scroll-behavior:auto !important;
  }
}

/* ---------- Layout helpers ---------- */
.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:24px;
}
.section{ padding-block:88px; }
.section-tight{ padding-block:56px; }
@media (max-width:780px){
  .section{ padding-block:56px; }
  .section-tight{ padding-block:40px; }
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--navy);
  margin-bottom:14px;
}
html[lang="ar"] .eyebrow{ letter-spacing:0; text-transform:none; }
.eyebrow::before{
  content:"";
  width:18px; height:2px;
  background:var(--navy);
  display:inline-block;
}

.section-head{
  max-width:640px;
  margin-bottom:48px;
}
.section-head.center{ margin-inline:auto; text-align:center; }

h1,.h1{ font-size:clamp(34px,5vw,56px); font-weight:700; line-height:1.15; letter-spacing:-0.01em; }
h2,.h2{ font-size:clamp(26px,3.4vw,38px); font-weight:700; line-height:1.2; letter-spacing:-0.01em; }
h3,.h3{ font-size:20px; font-weight:600; line-height:1.35; }
.lead{ font-size:18px; color:var(--muted); line-height:1.7; }
.muted{ color:var(--muted); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 26px;
  border-radius:999px;
  font-weight:600;
  font-size:15px;
  border:1px solid transparent;
  transition:transform .15s var(--ease), background .2s var(--ease), border-color .2s var(--ease), color .2s var(--ease);
  white-space:nowrap;
}
.btn:active{ transform:scale(.97); }
.btn-primary{ background:var(--navy); color:#fff; }
.btn-primary:hover{ background:var(--navy-700); }
.btn-outline{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-outline:hover{ border-color:var(--navy); color:var(--navy); }
.btn-whatsapp{ background:var(--whatsapp); color:#fff; }
.btn-whatsapp:hover{ background:var(--whatsapp-dark); }
.btn-ghost-light{ background:rgba(255,255,255,.12); color:#fff; border-color:rgba(255,255,255,.35); }
.btn-ghost-light:hover{ background:rgba(255,255,255,.2); }
.btn-block{ width:100%; }
.btn svg{ width:18px; height:18px; flex:none; }

/* ============================================================
   Header
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:78px;
  gap:24px;
}
.brand{ display:flex; align-items:center; gap:10px; flex:none; }
.brand img{ height:38px; width:auto; }
.brand-text{ display:flex; flex-direction:column; line-height:1.1; }
.brand-text strong{ font-size:15px; font-weight:700; color:var(--navy); }
.brand-text span{ font-size:11px; color:var(--muted); letter-spacing:.03em; }

.main-nav{ display:flex; align-items:center; gap:32px; }
.main-nav a{
  font-size:15px; font-weight:500; color:var(--ink);
  position:relative; padding-block:6px;
}
.main-nav a::after{
  content:""; position:absolute; inset-inline-start:0; bottom:0;
  height:2px; width:0; background:var(--navy);
  transition:width .2s var(--ease);
}
.main-nav a:hover::after, .main-nav a.active::after{ width:100%; }
.main-nav a.active{ color:var(--navy); }

.header-actions{ display:flex; align-items:center; gap:14px; flex:none; }

.lang-switch{
  display:inline-flex; align-items:center;
  border:1px solid var(--line); border-radius:999px;
  padding:4px; gap:2px; background:var(--mist);
}
.lang-switch button{
  border:none; background:transparent; border-radius:999px;
  padding:6px 14px; font-size:13px; font-weight:600; color:var(--muted);
  transition:background .2s var(--ease), color .2s var(--ease);
}
.lang-switch button.is-active{ background:var(--navy); color:#fff; }

.nav-toggle{
  display:none;
  width:42px; height:42px; border-radius:50%;
  border:1px solid var(--line); background:transparent;
  align-items:center; justify-content:center;
}
.nav-toggle svg{ width:20px; height:20px; }

@media (max-width:980px){
  .main-nav{
    position:fixed; inset-inline:0; top:78px; bottom:0;
    background:#fff; flex-direction:column; align-items:stretch;
    padding:24px; gap:6px; transform:translateY(-12px);
    opacity:0; pointer-events:none; transition:opacity .2s var(--ease), transform .2s var(--ease);
    overflow-y:auto;
  }
  .main-nav.is-open{ opacity:1; pointer-events:auto; transform:translateY(0); }
  .main-nav a{ padding:14px 6px; border-bottom:1px solid var(--line); font-size:17px; }
  .main-nav .btn{ margin-top:14px; }
  .nav-toggle{ display:flex; }
  .header-actions .btn-primary.nav-cta-desktop{ display:none; }
}

/* ============================================================
   Hero
   ============================================================ */
.hero{
  position:relative;
  background:var(--navy);
  color:#fff;
  overflow:hidden;
  isolation:isolate;
}
.hero-motif{
  position:absolute; inset-block-start:-10%; inset-inline-end:-8%;
  width:620px; height:620px;
  background:url('../img/icon_white.png') center/contain no-repeat;
  opacity:.08;
  z-index:0;
  pointer-events:none;
  animation:hero-rotate 120s linear infinite;
}
@keyframes hero-rotate{ from{ transform:rotate(0deg); } to{ transform:rotate(360deg); } }
@media (max-width:780px){ .hero-motif{ width:380px; height:380px; } }
.hero-inner{
  position:relative; z-index:1;
  padding-block:96px 100px;
  max-width:720px;
}
.hero .eyebrow{ color:#C7C9F0; }
.hero .eyebrow::before{ background:#C7C9F0; }
.hero h1{ color:#fff; margin-bottom:20px; }
.hero p.lead{ color:#D6D7F2; margin-bottom:36px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; }
@media (max-width:780px){ .hero-inner{ padding-block:64px 72px; } }

.hero-stats{
  position:relative; z-index:1;
  display:flex; gap:40px; margin-top:64px; flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.18); padding-top:28px;
}
.hero-stats div strong{ display:block; font-size:22px; font-weight:700; }
.hero-stats div span{ font-size:13px; color:#C7C9F0; }

/* ============================================================
   Category / feature grids
   ============================================================ */
.grid{ display:grid; gap:20px; }
.grid-4{ grid-template-columns:repeat(4,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-2{ grid-template-columns:repeat(2,1fr); }
@media (max-width:980px){ .grid-4{ grid-template-columns:repeat(2,1fr); } .grid-3{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .grid-4,.grid-3,.grid-2{ grid-template-columns:1fr; } }

.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:28px; transition:border-color .2s var(--ease), transform .2s var(--ease), box-shadow .2s var(--ease);
}
.card:hover{ border-color:var(--navy); transform:translateY(-3px); box-shadow:var(--shadow-md); }

.cat-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:26px 22px; display:flex; flex-direction:column; gap:14px;
  transition:border-color .2s var(--ease), transform .2s var(--ease), box-shadow .2s var(--ease);
}
.cat-card:hover{ border-color:var(--navy); transform:translateY(-3px); box-shadow:var(--shadow-md); }
.cat-card.is-highlighted{ border-color:var(--navy); box-shadow:0 0 0 4px var(--navy-50), var(--shadow-md); }
.cat-icon{
  width:52px; height:52px; border-radius:50%;
  background:var(--navy-50); color:var(--navy);
  display:flex; align-items:center; justify-content:center; flex:none;
  transition:background .25s var(--ease), color .25s var(--ease), transform .35s var(--ease);
}
.cat-icon svg{ width:26px; height:26px; }
.cat-card:hover .cat-icon, .value-card:hover .cat-icon{ background:var(--navy); color:#fff; transform:scale(1.08) rotate(-6deg); }
html[dir="rtl"] .cat-card:hover .cat-icon, html[dir="rtl"] .value-card:hover .cat-icon{ transform:scale(1.08) rotate(6deg); }

.icon-draw path, .icon-draw circle, .icon-draw rect, .icon-draw line, .icon-draw ellipse, .icon-draw polyline, .icon-draw polygon{
  transition:stroke-dashoffset 1s var(--ease);
}
.cat-card h3{ font-size:17px; }
.cat-card p{ font-size:14px; color:var(--muted); flex:1; }
.cat-card .cat-link{
  font-size:13px; font-weight:600; color:var(--navy);
  display:inline-flex; align-items:center; gap:6px;
}
.cat-card .cat-link svg{ width:14px; height:14px; transition:transform .2s var(--ease); }
html[dir="rtl"] .cat-card .cat-link svg{ transform:scaleX(-1); }
.cat-card:hover .cat-link svg{ transform:translateX(3px); }
html[dir="rtl"] .cat-card:hover .cat-link svg{ transform:scaleX(-1) translateX(3px); }

.cluster-title{
  font-size:14px; font-weight:700; text-transform:uppercase; letter-spacing:.04em;
  color:var(--navy); margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid var(--line);
}
html[lang="ar"] .cluster-title{ text-transform:none; letter-spacing:0; }
.cluster{ margin-bottom:56px; }
.cluster:last-child{ margin-bottom:0; }

/* feature list */
.feature{
  display:flex; gap:16px; align-items:flex-start;
}
.feature-icon{
  width:44px; height:44px; border-radius:12px; flex:none;
  background:var(--navy-50); color:var(--navy);
  display:flex; align-items:center; justify-content:center;
  transition:background .25s var(--ease), color .25s var(--ease), transform .35s var(--ease);
}
.feature-icon svg{ width:22px; height:22px; }
.feature:hover .feature-icon{ background:var(--navy); color:#fff; transform:scale(1.08) rotate(-6deg); }
html[dir="rtl"] .feature:hover .feature-icon{ transform:scale(1.08) rotate(6deg); }
.feature h3{ font-size:16px; margin-bottom:6px; }
.feature p{ font-size:14px; color:var(--muted); }

/* process steps */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; counter-reset:step; }
@media (max-width:900px){ .steps{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .steps{ grid-template-columns:1fr; } }
.step{ position:relative; padding-inline-start:0; }
.step-num{
  width:40px; height:40px; border-radius:50%; background:var(--navy); color:#fff;
  display:flex; align-items:center; justify-content:center; font-weight:700; margin-bottom:16px;
}
.step h3{ font-size:16px; margin-bottom:6px; }
.step p{ font-size:14px; color:var(--muted); }

/* Scroll-reveal (progressive enhancement; .js is set by an inline head script) */
.js .cat-card, .js .feature, .js .value-card, .js .step{
  opacity:0; transform:translateY(18px);
  transition:opacity .6s var(--ease), transform .6s var(--ease);
}
.js .cat-card.in-view, .js .feature.in-view, .js .value-card.in-view, .js .step.in-view{
  opacity:1; transform:translateY(0);
}

/* ============================================================
   Sections: alt background, CTA band
   ============================================================ */
.bg-mist{ background:var(--mist); }
.bg-navy{ background:var(--navy); color:#fff; }
.bg-navy .muted{ color:#C7C9F0; }

.cta-band{
  background:var(--navy); color:#fff; border-radius:var(--radius-lg);
  padding:56px; display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap;
  position:relative; overflow:hidden;
}
.cta-band h2{ color:#fff; margin-bottom:10px; }
.cta-band p{ color:#D6D7F2; }
.cta-band .actions{ display:flex; gap:12px; flex-wrap:wrap; }
@media (max-width:780px){ .cta-band{ padding:40px 28px; } }

/* ============================================================
   About page
   ============================================================ */
.about-hero{ background:var(--mist); }
.values-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media (max-width:780px){ .values-grid{ grid-template-columns:1fr; } }
.value-card{ padding:30px; border:1px solid var(--line); border-radius:var(--radius); }
.value-card .cat-icon{ margin-bottom:18px; }
.two-col{ display:grid; grid-template-columns:1.1fr .9fr; gap:64px; align-items:start; }
@media (max-width:900px){ .two-col{ grid-template-columns:1fr; gap:36px; } }
.about-art{
  aspect-ratio:1/1; border-radius:var(--radius-lg); background:var(--navy);
  display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden;
}
.about-art img{ width:46%; opacity:.95; }

.check-list{ display:flex; flex-direction:column; gap:12px; }
.check-list li{ display:flex; align-items:flex-start; gap:12px; font-size:15px; color:var(--ink); }
.check-list li::before{
  content:"\2713"; flex:none; width:22px; height:22px; border-radius:50%; margin-top:1px;
  background:var(--navy); color:#fff; font-size:12px; font-weight:700; line-height:1;
  display:flex; align-items:center; justify-content:center;
}

/* ============================================================
   Contact page
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:48px; align-items:start; }
@media (max-width:900px){ .contact-grid{ grid-template-columns:1fr; } }
.contact-info-card{ background:var(--navy); color:#fff; border-radius:var(--radius-lg); padding:40px; }
.contact-info-card h3{ color:#fff; font-size:18px; margin-bottom:24px; }
.contact-row{ display:flex; gap:14px; align-items:flex-start; margin-bottom:20px; }
.contact-row:last-child{ margin-bottom:0; }
.contact-row .ic{
  width:38px; height:38px; border-radius:10px; background:rgba(255,255,255,.12);
  display:flex; align-items:center; justify-content:center; flex:none;
}
.contact-row .ic svg{ width:18px; height:18px; }
.contact-row a, .contact-row span.val{ font-size:14.5px; color:#fff; }
.contact-row .label{ font-size:12px; color:#C7C9F0; display:block; margin-bottom:2px; }
.contact-divider{ height:1px; background:rgba(255,255,255,.18); margin:28px 0; }

.form-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:40px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:560px){ .form-row{ grid-template-columns:1fr; } }
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:13px; font-weight:600; margin-bottom:7px; color:var(--ink); }
.field input, .field select, .field textarea{
  width:100%; border:1px solid var(--line); border-radius:var(--radius-sm);
  padding:13px 14px; font-size:14.5px; color:var(--ink); background:#fff;
  transition:border-color .2s var(--ease);
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--navy);
}
.field textarea{ resize:vertical; min-height:110px; }
.form-actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:8px; }
.form-note{ font-size:13px; color:var(--muted); margin-top:14px; }

/* ============================================================
   Footer
   ============================================================ */
.site-footer{ background:var(--navy-900); color:#C7C9F0; }
.footer-top{ padding-block:64px 40px; display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; }
@media (max-width:900px){ .footer-top{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .footer-top{ grid-template-columns:1fr; } }
.footer-brand img{ height:34px; margin-bottom:16px; }
.footer-brand p{ font-size:14px; line-height:1.7; max-width:280px; color:#A9ABD6; }
.site-footer h4{ color:#fff; font-size:14px; font-weight:700; margin-bottom:18px; text-transform:uppercase; letter-spacing:.04em; }
html[lang="ar"] .site-footer h4{ text-transform:none; letter-spacing:0; }
.site-footer ul li{ margin-bottom:11px; }
.site-footer ul a{ font-size:14px; color:#A9ABD6; transition:color .2s var(--ease); }
.site-footer ul a:hover{ color:#fff; }
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  padding-block:22px; display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap;
  font-size:13px; color:#8587b9;
}

/* ============================================================
   Floating WhatsApp button
   ============================================================ */
.wa-float{
  position:fixed; inset-block-end:24px; inset-inline-end:24px; z-index:60;
  width:58px; height:58px; border-radius:50%; background:var(--whatsapp);
  display:flex; align-items:center; justify-content:center; box-shadow:0 10px 24px rgba(37,211,102,.4);
  transition:transform .2s var(--ease);
}
.wa-float:hover{ transform:scale(1.08); }
.wa-float:hover::before{ animation-play-state:paused; opacity:0; }
.wa-float svg{ width:28px; height:28px; fill:#fff; position:relative; z-index:1; }
.wa-float::before{
  content:""; position:absolute; inset:0; border-radius:50%;
  background:var(--whatsapp); z-index:-1;
  animation:wa-pulse 2.6s ease-out infinite;
}
@keyframes wa-pulse{
  0%{ transform:scale(1); opacity:.55; }
  100%{ transform:scale(1.8); opacity:0; }
}

/* ============================================================
   Utility
   ============================================================ */
.flex{ display:flex; }
.items-center{ align-items:center; }
.justify-between{ justify-content:space-between; }
.gap-8{ gap:8px; } .gap-12{ gap:12px; } .gap-16{ gap:16px; }
.text-center{ text-align:center; }
.mt-8{ margin-top:8px; } .mt-16{ margin-top:16px; } .mt-24{ margin-top:24px; } .mt-32{ margin-top:32px; }
.mb-8{ margin-bottom:8px; } .mb-16{ margin-bottom:16px; } .mb-24{ margin-bottom:24px; }

.page-header{ padding-block:64px 48px; background:var(--mist); }
.page-header .eyebrow{ }
.breadcrumb{ font-size:13px; color:var(--muted); margin-bottom:18px; }
.breadcrumb a{ color:var(--navy); font-weight:600; }
