/* ============================================================
   AYT INDUSTRIAL — shared design system
   Bright-blue, airy, industrial. Bilingual EN / AR (RTL).
   ============================================================ */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Saira+Condensed:wght@500;600;700;800&family=Archivo:wght@400;500;600;700;800&family=Cairo:wght@400;600;700;800;900&family=Tajawal:wght@400;500;700;800&display=swap');

/* ---------- Tokens ---------- */
:root{
  --blue:        #1391CE;
  --blue-bright: #28ABE8;
  --blue-mid:    #0E7BB3;
  --blue-dark:   #0A5C88;
  --blue-deep:   #073A57;
  --blue-ink:    #0B2A3C;   /* dark text — replaces black */
  --red:         #E63329;
  --red-dark:    #C0231A;
  --ink:         #14242F;
  --muted:       #5E7280;
  --muted-2:     #8597A2;
  --line:        #E3EAEF;
  --line-2:      #D2DEE6;
  --bg:          #FFFFFF;
  --bg-soft:     #F4F8FB;
  --bg-tint:     #E9F4FB;
  --bg-blue:     #0B2A3C;

  --shadow-sm: 0 2px 8px rgba(11,42,60,.06);
  --shadow:    0 14px 40px -18px rgba(11,42,60,.30);
  --shadow-lg: 0 30px 70px -28px rgba(11,42,60,.42);

  --maxw: 1240px;
  --r:   14px;
  --r-lg: 22px;

  --font-display: 'Saira Condensed', 'Cairo', sans-serif;
  --font-body:    'Archivo', 'Tajawal', sans-serif;
  --tracking: .01em;
}

/* Arabic typography swap */
html[data-lang="ar"]{
  --font-display: 'Cairo', sans-serif;
  --font-body:    'Tajawal', sans-serif;
  --tracking: 0;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; scroll-padding-top:92px; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-body);
  font-size:17px; line-height:1.62; letter-spacing:var(--tracking);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ margin:0; line-height:1.04; }
p{ margin:0; }
::selection{ background:var(--blue); color:#fff; }

/* ---------- Display headings ---------- */
.display{
  font-family:var(--font-display); font-weight:700;
  text-transform:uppercase; letter-spacing:.005em; line-height:.96;
}
html[data-lang="ar"] .display{ text-transform:none; font-weight:800; line-height:1.18; }
.serif-x{ font-style:normal; }

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,44px); }
.section{ padding-block:clamp(64px,8vw,116px); position:relative; }
.section--tint{ background:var(--bg-soft); }
.section--blue{ background:var(--bg-blue); color:#EaF3F8; }
.lead{ font-size:clamp(17px,1.5vw,20px); color:var(--muted); line-height:1.7; }
.section--blue .lead{ color:#A9C6D6; }

/* eyebrow / kicker */
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  letter-spacing:.18em; font-size:13px; color:var(--blue);
}
html[data-lang="ar"] .kicker{ text-transform:none; letter-spacing:.02em; font-weight:700; }
.kicker::before{ content:""; width:30px; height:3px; background:var(--red); border-radius:2px; }

.section-head{ max-width:720px; margin-bottom:clamp(36px,5vw,60px); }
.section-head h2{
  font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  font-size:clamp(34px,5vw,58px); letter-spacing:.005em; margin-top:18px; color:var(--blue-ink);
}
html[data-lang="ar"] .section-head h2{ text-transform:none; font-weight:800; line-height:1.2; }
.section--blue .section-head h2{ color:#fff; }
.section-head p{ margin-top:18px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-weight:600; text-transform:uppercase;
  letter-spacing:.06em; font-size:15px;
  padding:15px 26px; border-radius:10px; border:1.5px solid transparent;
  transition:transform .25s, background .25s, color .25s, box-shadow .25s, border-color .25s;
  white-space:nowrap;
}
html[data-lang="ar"] .btn{ text-transform:none; letter-spacing:0; font-weight:700; }
.btn svg{ width:18px; height:18px; }
.btn--primary{ background:var(--blue); color:#fff; box-shadow:0 12px 26px -12px rgba(19,145,206,.8); }
.btn--primary:hover{ background:var(--blue-mid); transform:translateY(-2px); box-shadow:0 18px 34px -12px rgba(19,145,206,.9); }
.btn--red{ background:var(--red); color:#fff; box-shadow:0 12px 26px -12px rgba(230,51,41,.7); }
.btn--red:hover{ background:var(--red-dark); transform:translateY(-2px); }
.btn--ghost{ border-color:rgba(255,255,255,.45); color:#fff; }
.btn--ghost:hover{ background:rgba(255,255,255,.12); border-color:#fff; transform:translateY(-2px); }
.btn--outline{ border-color:var(--line-2); color:var(--blue-ink); background:#fff; }
.btn--outline:hover{ border-color:var(--blue); color:var(--blue); transform:translateY(-2px); }

/* ============================================================
   LOGO (CSS/SVG bracket mark)
   ============================================================ */
.logo{ display:inline-flex; align-items:center; gap:0; }
.logo-mark{ position:relative; display:inline-block; }
.logo-mark svg{ display:block; overflow:visible; }
.logo-mark .lm-text{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  gap:.06em; pointer-events:none;
}
.logo-mark .lm-ayt{
  font-family:'Archivo', sans-serif; font-weight:800; color:var(--blue-ink);
  letter-spacing:-.02em; line-height:1;
}
.logo-mark .lm-ind{
  font-family:'Times New Roman', Georgia, serif; font-weight:600; color:var(--blue-ink);
  letter-spacing:.02em; align-self:flex-end; }
/* animated bracket draw (hero) */
.logo-mark .br{ fill:none; stroke-linecap:square; stroke-linejoin:miter; stroke-width:8; }
.logo-mark svg{ width:100%; height:auto; }
.nav__brand .logo-mark{ width:106px; }
.nav__brand .lm-ayt{ font-size:25px; }
.nav__brand .lm-ind{ font-size:7px; margin-bottom:3px; }
.logo-mark--hero .lm-ayt{ font-size:clamp(34px,4.8vw,56px); }
.logo-mark--hero .lm-ind{ font-size:clamp(11px,1.3vw,15px); margin-bottom:6px; }
.footer .logo-mark .lm-ayt, .footer .logo-mark .lm-ind{ color:#fff; }
.footer .logo-mark{ width:128px; }
.footer .lm-ayt{ font-size:30px; } .footer .lm-ind{ font-size:9px; margin-bottom:4px; }
.logo-mark .br--blue{ stroke:var(--blue); }
.logo-mark .br--red{ stroke:var(--red); }
.logo-mark--hero .br{ stroke-dasharray:var(--len,700); stroke-dashoffset:var(--len,700); }
.hero.is-in .logo-mark--hero .br--blue{ animation:draw 1.1s cubic-bezier(.6,.05,.2,1) .15s forwards; }
.hero.is-in .logo-mark--hero .br--red{ animation:draw 1.1s cubic-bezier(.6,.05,.2,1) .42s forwards; }
.logo-mark--hero .lm-text{ opacity:0; transform:translateY(8px); }
.hero.is-in .logo-mark--hero .lm-text{ animation:logotext .8s cubic-bezier(.2,.7,.2,1) .9s forwards; }
@keyframes draw{ to{ stroke-dashoffset:0; } }
@keyframes logotext{ to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion:reduce){
  .logo-mark--hero .br{ stroke-dashoffset:0 !important; }
  .logo-mark--hero .lm-text{ opacity:1 !important; transform:none !important; }
}

/* ============================================================
   ORDER NOW — floating tab + modal
   ============================================================ */
.order-tab{
  position:fixed; right:0; left:auto; bottom:34px;
  z-index:70; display:flex; align-items:center; gap:9px;
  background:var(--red); color:#fff; border:0;
  font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  font-size:13.5px; padding:14px 12px;
  writing-mode:vertical-rl; border-radius:12px 0 0 12px;
  box-shadow:-8px 10px 26px -10px rgba(230,51,41,.65); transition:.28s;
}
html[data-lang="ar"] .order-tab{ text-transform:none; letter-spacing:0; }
.order-tab:hover{ background:var(--red-dark); padding-right:18px; }
.order-tab svg{ width:18px; height:18px; transform:rotate(90deg); }
@media (max-width:600px){ .order-tab{ font-size:12px; } }

.modal{ position:fixed; inset:0; z-index:120; display:grid; place-items:center; padding:20px;
  opacity:0; pointer-events:none; transition:opacity .3s; }
.modal.open{ opacity:1; pointer-events:auto; }
.modal__bd{ position:absolute; inset:0; background:rgba(7,33,49,.66); backdrop-filter:blur(4px); }
.modal__card{ position:relative; width:min(620px,100%); max-height:92dvh; overflow:auto;
  background:#fff; border-radius:var(--r-lg); box-shadow:var(--shadow-lg);
  transform:translateY(18px) scale(.98); transition:transform .35s cubic-bezier(.2,.7,.2,1); }
.modal.open .modal__card{ transform:none; }
.modal__head{ background:linear-gradient(120deg,var(--blue-mid),var(--blue-dark)); color:#fff;
  padding:26px 30px; position:relative; }
.modal__head h3{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; font-size:26px; }
html[data-lang="ar"] .modal__head h3{ text-transform:none; font-weight:800; }
.modal__head p{ color:#cfe2ec; font-size:14.5px; margin-top:6px; }
.modal__x{ position:absolute; inset-block-start:18px; inset-inline-end:18px; width:38px; height:38px;
  border-radius:10px; background:rgba(255,255,255,.16); border:0; color:#fff; font-size:20px;
  display:grid; place-items:center; transition:.2s; }
.modal__x:hover{ background:rgba(255,255,255,.3); }
.modal__body{ padding:26px 30px 30px; }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:520px){ .form-grid{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:7px; }
.field--full{ grid-column:1/-1; }
.field label{ font-family:var(--font-display); font-weight:600; text-transform:uppercase; letter-spacing:.05em;
  font-size:11.5px; color:var(--muted); }
html[data-lang="ar"] .field label{ text-transform:none; letter-spacing:0; }
.field input,.field select,.field textarea{
  font-family:var(--font-body); font-size:15.5px; color:var(--ink);
  padding:12px 14px; border:1.5px solid var(--line-2); border-radius:10px; background:#fff;
  transition:.2s; width:100%; }
.field textarea{ resize:vertical; min-height:90px; }
.field input:focus,.field select:focus,.field textarea:focus{
  outline:0; border-color:var(--blue); box-shadow:0 0 0 4px rgba(19,145,206,.14); }
.form-actions{ margin-top:20px; display:flex; gap:12px; align-items:center; flex-wrap:wrap; }
.form-alt{ margin-top:18px; padding-top:18px; border-top:1px solid var(--line);
  display:flex; gap:18px; flex-wrap:wrap; font-size:14px; color:var(--muted); }
.form-alt a{ display:inline-flex; align-items:center; gap:8px; color:var(--blue); font-weight:600; }
.form-alt a svg{ width:16px; height:16px; }
.form-success{ text-align:center; padding:30px 10px; }
.form-success .sc{ width:72px; height:72px; border-radius:50%; background:var(--bg-tint); color:var(--blue);
  display:grid; place-items:center; margin:0 auto 18px; }
.form-success .sc svg{ width:38px; height:38px; }
.form-success h4{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; font-size:24px; color:var(--blue-ink); }
html[data-lang="ar"] .form-success h4{ text-transform:none; font-weight:800; }
.form-success p{ color:var(--muted); margin-top:8px; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; inset-block-start:0; inset-inline:0; z-index:80;
  display:flex; align-items:center; gap:24px;
  padding:14px clamp(20px,5vw,44px);
  transition:background .35s, box-shadow .35s, padding .35s, border-color .35s;
  border-bottom:1px solid transparent;
}
.nav--solid{
  background:rgba(255,255,255,.88); backdrop-filter:blur(14px) saturate(1.4);
  border-color:var(--line); box-shadow:0 6px 24px -18px rgba(11,42,60,.5);
}
.nav__brand{ display:flex; align-items:center; position:relative; flex:0 0 auto; }
.nav__logo{ height:52px; width:auto; display:block; flex:0 0 auto; transition:opacity .35s; }
.nav__logo--dark{ position:absolute; inset-block-start:0; inset-inline-start:0; opacity:0; }
.nav--solid .nav__logo--light{ opacity:0; }
.nav--solid .nav__logo--dark{ opacity:1; }
@media (max-width:1080px){ .nav__logo{ height:42px; } }
.footer__logo{ height:62px; width:auto; display:block; }
.nav__brand .lm-ayt, .nav__brand .lm-ind{ color:#fff; transition:color .35s; }
.nav--solid .nav__brand .lm-ayt, .nav--solid .nav__brand .lm-ind{ color:var(--blue-ink); }
.nav__links{ display:flex; align-items:center; gap:4px; margin-inline-start:auto; flex-wrap:wrap; justify-content:flex-end; }
.nav__link{
  font-family:var(--font-display); font-weight:600; text-transform:uppercase;
  letter-spacing:.05em; font-size:14.5px; color:#fff; opacity:.92;
  padding:9px 14px; border-radius:8px; transition:.2s; white-space:nowrap;
}
html[data-lang="ar"] .nav__link{ text-transform:none; letter-spacing:0; font-weight:700; font-size:16px; }
.nav--solid .nav__link{ color:var(--blue-ink); }
.nav__link:hover{ color:var(--blue-bright); }
.nav--solid .nav__link:hover{ color:var(--blue); background:var(--bg-tint); }
.nav__tools{ display:flex; align-items:center; gap:10px; }

.lang-toggle{
  display:inline-flex; align-items:center; border:1.5px solid rgba(255,255,255,.5);
  border-radius:9px; overflow:hidden; font-family:var(--font-display); font-weight:700;
}
.nav--solid .lang-toggle{ border-color:var(--line-2); }
.lang-toggle button{
  background:transparent; border:0; color:#fff; padding:7px 12px; font-size:13.5px;
  letter-spacing:.06em; transition:.2s; line-height:1;
}
.nav--solid .lang-toggle button{ color:var(--blue-ink); }
.lang-toggle button.is-active{ background:var(--blue); color:#fff; }
.nav__cta{ display:inline-flex; }
.nav__burger{ display:none; }

/* mobile nav */
@media (max-width:1080px){
  .nav__links{ position:fixed; inset-block-start:0; inset-inline-end:0; height:100dvh; width:min(82vw,340px);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:6px; flex-wrap:nowrap;
    background:rgba(11,42,60,.97); backdrop-filter:blur(8px); padding:40px 34px;
    transform:translateX(120%); transition:transform .4s cubic-bezier(.6,.05,.2,1); margin:0; }
  html[dir="rtl"] .nav__links{ transform:translateX(-120%); }
  .nav__links.open{ transform:translateX(0); }
  .nav__link{ color:#fff; font-size:20px; }
  .nav--solid .nav__link{ color:#fff; }
  .nav__cta{ display:none; }
  .nav__burger{ display:inline-flex; flex-direction:column; gap:5px; width:42px; height:42px;
    align-items:center; justify-content:center; background:transparent; border:0; z-index:90; }
  .nav__burger span{ width:24px; height:2.5px; background:#fff; border-radius:2px; transition:.3s; }
  .nav--solid .nav__burger span{ background:var(--blue-ink); }
  .nav__burger.open span{ background:#fff; }
  .nav__burger.open span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
  .nav__burger.open span:nth-child(2){ opacity:0; }
  .nav__burger.open span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }
}

/* ============================================================
   HERO
   ============================================================ */
.hero-stage{ position:relative; height:185vh; }
.hero{ position:sticky; top:0; height:100svh; display:flex; align-items:center; align-items:safe center;
  overflow:hidden; color:#fff; isolation:isolate; }
.hero__bg{ position:absolute; inset:-20% -3%; z-index:-3; will-change:transform; }
.hero__bg picture{ display:block; width:100%; height:100%; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; }
.hero__veil{ position:absolute; inset:0; z-index:-1; opacity:0; will-change:opacity;
  background:radial-gradient(125% 95% at 50% 32%, transparent 26%, rgba(5,26,40,.92) 100%); }
.hero__scrim{ position:absolute; inset:0; z-index:-2;
  background:
    linear-gradient(180deg, rgba(7,40,60,.55) 0%, rgba(7,40,60,.12) 30%, rgba(7,40,60,.55) 72%, rgba(6,33,49,.94) 100%),
    linear-gradient(75deg, rgba(10,60,92,.62) 0%, rgba(10,60,92,0) 55%); }
.hero__grid{ position:absolute; inset:0; z-index:-1; opacity:.10; will-change:transform,opacity;
  background-image:linear-gradient(rgba(255,255,255,.6) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.6) 1px,transparent 1px);
  background-size:64px 64px; mask-image:radial-gradient(120% 90% at 50% 10%,#000 30%,transparent 78%); }

.hero__inner{ width:100%; max-width:var(--maxw); margin-inline:auto; will-change:transform, opacity;
  display:flex; flex-direction:column; align-items:center; text-align:center;
  padding-inline:clamp(20px,5vw,44px); padding-block:clamp(104px,14vh,150px) clamp(44px,7vh,80px); }
.hero__logo{ margin-bottom:clamp(26px,4vh,46px); }
.hero h1{ font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  font-size:clamp(34px,6.0vw,100px); line-height:.96; letter-spacing:.004em;
  max-width:18ch; margin-inline:auto; text-shadow:0 4px 40px rgba(0,0,0,.3); }
html[data-lang="ar"] .hero h1{ text-transform:none; font-weight:800; line-height:1.12; max-width:20ch; }
.hero h1 .hl{ color:var(--blue-bright); }
.hero__sub{ margin-top:22px; max-width:56ch; margin-inline:auto; font-size:clamp(17px,1.7vw,21px);
  color:#D7E7F0; line-height:1.6; }
.hero__cta{ margin-top:34px; display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }
.hero__stats{ margin-top:clamp(40px,6vh,64px); display:flex; flex-wrap:wrap; gap:clamp(28px,5vw,64px); justify-content:center;
  padding-top:30px; border-top:1px solid rgba(255,255,255,.18); }
.hstat__n{ font-family:var(--font-display); font-weight:700; font-size:clamp(30px,3.6vw,48px);
  line-height:1; color:#fff; }
.hstat__n .u{ color:var(--blue-bright); }
.hstat__l{ margin-top:8px; font-size:13.5px; letter-spacing:.04em; color:#A9C6D6; text-transform:uppercase; }
html[data-lang="ar"] .hstat__l{ text-transform:none; }

.hero__scroll{ position:absolute; inset-block-end:22px; inset-inline-start:50%; transform:translateX(-50%);
  z-index:2; display:flex; flex-direction:column; align-items:center; gap:8px; color:#cfe2ec;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase; }
.hero__scroll .mouse{ width:24px; height:38px; border:2px solid rgba(255,255,255,.6); border-radius:13px; position:relative; }
.hero__scroll .mouse::after{ content:""; position:absolute; inset-block-start:7px; inset-inline-start:50%;
  width:3px; height:7px; background:#fff; border-radius:2px; transform:translateX(-50%); animation:wheel 1.6s infinite; }
@keyframes wheel{ 0%{opacity:0;transform:translate(-50%,0)} 30%{opacity:1} 100%{opacity:0;transform:translate(-50%,12px)} }

/* hero scroll-scrubbed layers */
.hero__title{ display:flex; flex-direction:column; align-items:center; margin:0; }
.hl-line{ display:block; white-space:nowrap; will-change:transform,opacity,filter; }
.hl-accent{ color:var(--blue-bright); }
.hero__kicker{ will-change:transform,opacity; }
.hero__logo,.hero__sub,.hero__cta,.hero__stats{ will-change:transform,opacity; }
.hero__sweep{ display:block; height:5px; width:min(420px,58%); border-radius:3px;
  background:linear-gradient(90deg,var(--red),var(--red-dark)); margin:10px auto 22px;
  transform-origin:50% 50%; transform:scaleX(.22); box-shadow:0 6px 18px -8px rgba(230,51,41,.75);
  will-change:transform; }
html[dir="rtl"] .hero__sweep{ transform-origin:50% 50%; }
.hero__progress{ position:absolute; inset-inline:0; inset-block-end:0; height:3px; z-index:3;
  background:rgba(255,255,255,.12); }
.hero__progress::after{ content:""; position:absolute; inset:0; background:var(--red);
  transform-origin:0 50%; transform:scaleX(var(--hp,0)); }
html[dir="rtl"] .hero__progress::after{ transform-origin:100% 50%; }

/* short viewports — keep hero content clear of the nav and within the fold */
@media (max-height:760px){
  .hero__inner{ padding-block:92px 28px; }
  .hero h1{ font-size:clamp(30px,4.6vw,60px); }
  .hero__sub{ font-size:16px; margin-top:14px; max-width:60ch; }
  .hero__cta{ margin-top:22px; }
  .hero__stats{ margin-top:26px; padding-top:18px; gap:clamp(22px,4vw,48px); }
  .hero__scroll{ display:none; }
}
@media (max-height:620px){
  .hero__stats{ display:none; }
}

/* phones — hero polish with portrait background */
@media (max-width:600px){
  .hero-stage{ height:150vh; }
  .hero__inner{ padding-block:88px 30px; }
  .hero h1{ font-size:clamp(29px,8.4vw,46px); line-height:1.0; }
  .hero__sub{ font-size:15.5px; margin-top:16px; }
  .hero__cta{ margin-top:26px; width:100%; }
  .hero__cta .btn{ flex:1 1 auto; justify-content:center; }
  .hero__stats{ gap:20px 34px; margin-top:30px; }
  .hstat__n{ font-size:28px; }
  .order-tab{ writing-mode:horizontal-tb; flex-direction:row; gap:7px;
    inset-block-end:16px; right:14px; left:auto; padding:11px 15px;
    border-radius:999px; font-size:12px; letter-spacing:.06em; height:auto;
    box-shadow:0 10px 24px -8px rgba(230,51,41,.7); }
  .order-tab svg{ width:16px; height:16px; transform:none; }
}
@media (max-width:380px){
  .hero h1{ font-size:26px; }
  .hero__sweep{ margin-block:8px 16px; }
}

/* hero entrance animation states (set by JS via .is-in) */
[data-rise]{ opacity:0; }
.hero.is-in [data-rise]{ animation:rise .95s cubic-bezier(.2,.7,.2,1) calc(var(--d,0) * 1ms) both; }
@keyframes rise{ from{ opacity:0; transform:translateY(28px); } to{ opacity:1; transform:none; } }

/* ============================================================
   WHY / OVERVIEW
   ============================================================ */
.why-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
@media (max-width:920px){ .why-grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:540px){ .why-grid{ grid-template-columns:1fr;} }
.why-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:30px 26px; transition:.3s; position:relative; overflow:hidden; }
.why-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:transparent; }
.why-card__ic{ width:54px; height:54px; border-radius:14px; display:grid; place-items:center;
  background:var(--bg-tint); color:var(--blue); margin-bottom:20px; }
.why-card:nth-child(even) .why-card__ic{ background:#FDEAE8; color:var(--red); }
.why-card__ic svg{ width:28px; height:28px; }
.why-card h3{ font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  font-size:21px; letter-spacing:.01em; color:var(--blue-ink); }
html[data-lang="ar"] .why-card h3{ text-transform:none; font-weight:700; }
.why-card p{ margin-top:10px; color:var(--muted); font-size:15.5px; }

/* ============================================================
   TECHNICAL APPLICATIONS
   ============================================================ */
.apps-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:820px){ .apps-grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:480px){ .apps-grid{ grid-template-columns:1fr;} }
.app-tile{ display:flex; align-items:center; gap:18px; background:#fff; border:1px solid var(--line);
  border-radius:var(--r-lg); padding:22px 24px; transition:.3s; }
.app-tile:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:transparent; }
.app-tile__ic{ flex:0 0 auto; width:58px; height:58px; border-radius:15px; display:grid; place-items:center;
  background:var(--bg-tint); color:var(--blue); }
.app-tile:nth-child(even) .app-tile__ic{ background:#FDEAE8; color:var(--red); }
.app-tile__ic svg{ width:29px; height:29px; }
.app-tile h3{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; font-size:19px;
  letter-spacing:.01em; color:var(--blue-ink); line-height:1.12; }
html[data-lang="ar"] .app-tile h3{ text-transform:none; font-weight:700; font-size:20px; }

/* ============================================================
   PRODUCTS GRID
   ============================================================ */
.prod-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:980px){ .prod-grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:600px){ .prod-grid{ grid-template-columns:1fr;} }
.prod-card{ position:relative; display:flex; flex-direction:column; background:#fff;
  border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; transition:.35s; }
.prod-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:transparent; }
.prod-card__media{ position:relative; aspect-ratio:16/11; overflow:hidden; }
.prod-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .7s cubic-bezier(.2,.7,.2,1); }
.prod-card:hover .prod-card__media img{ transform:scale(1.07); }
.prod-card__media::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(11,42,60,0) 40%,rgba(11,42,60,.5)); opacity:0; transition:.35s; }
.prod-card:hover .prod-card__media::after{ opacity:1; }
.prod-badge{ position:absolute; inset-block-start:14px; inset-inline-start:14px; z-index:2;
  font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  font-size:11px; padding:7px 12px; border-radius:7px; background:var(--blue); color:#fff; }
.prod-badge--360{ background:var(--red); display:inline-flex; align-items:center; gap:6px; }
.prod-badge--soon{ background:rgba(11,42,60,.86); }
html[data-lang="ar"] .prod-badge{ text-transform:none; letter-spacing:0; }
.prod-card__body{ padding:24px 24px 26px; display:flex; flex-direction:column; flex:1; }
.prod-card__cat{ font-family:var(--font-display); font-weight:600; text-transform:uppercase;
  letter-spacing:.12em; font-size:11.5px; color:var(--blue); }
html[data-lang="ar"] .prod-card__cat{ text-transform:none; letter-spacing:0; }
.prod-card h3{ margin-top:9px; font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  font-size:24px; letter-spacing:.005em; color:var(--blue-ink); }
html[data-lang="ar"] .prod-card h3{ text-transform:none; font-weight:800; line-height:1.3; }
.prod-card p{ margin-top:11px; color:var(--muted); font-size:15px; flex:1; }
.prod-card__link{ margin-top:18px; display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-display); font-weight:600; text-transform:uppercase; letter-spacing:.05em;
  font-size:14px; color:var(--blue); }
html[data-lang="ar"] .prod-card__link{ text-transform:none; letter-spacing:0; font-weight:700; }
.prod-card__link svg{ width:17px; height:17px; transition:transform .3s; }
.prod-card:hover .prod-card__link svg{ transform:translateX(4px); }
html[dir="rtl"] .prod-card__link svg{ transform:scaleX(-1); }
html[dir="rtl"] .prod-card:hover .prod-card__link svg{ transform:scaleX(-1) translateX(4px); }
.prod-card--soon{ opacity:.96; }
.prod-card--soon .prod-card__media img{ filter:grayscale(.5) brightness(.92); }
.prod-card--soon .prod-card__link{ color:var(--muted-2); }

/* ============================================================
   FEATURED PROJECTS
   ============================================================ */
.proj-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media (max-width:920px){ .proj-grid{ grid-template-columns:1fr 1fr;} }
@media (max-width:600px){ .proj-grid{ grid-template-columns:1fr;} }
.proj-card{ position:relative; border-radius:var(--r-lg); overflow:hidden; min-height:340px;
  display:flex; align-items:flex-end; color:#fff; isolation:isolate; }
.proj-card img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2;
  transition:transform .7s; }
.proj-card:hover img{ transform:scale(1.06); }
.proj-card::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg,rgba(8,40,60,.05) 30%,rgba(7,33,49,.9)); }
.proj-card__in{ padding:26px; width:100%; }
.proj-card__client{ font-family:var(--font-display); font-weight:600; text-transform:uppercase;
  letter-spacing:.14em; font-size:12px; color:var(--blue-bright); }
html[data-lang="ar"] .proj-card__client{ text-transform:none; letter-spacing:0; }
.proj-card h3{ margin-top:8px; font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  font-size:25px; }
html[data-lang="ar"] .proj-card h3{ text-transform:none; font-weight:800; }
.proj-card p{ margin-top:7px; font-size:14px; color:#cde0ea; }

/* ============================================================
   STRATEGY (mission / vision)
   ============================================================ */
.mv-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:14px; }
@media (max-width:760px){ .mv-grid{ grid-template-columns:1fr;} }
.mv-card{ background:#fff; border-radius:var(--r-lg); padding:38px 34px; position:relative;
  border:1px solid rgba(255,255,255,.08); }
.section--blue .mv-card{ background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.10); }
.mv-card__tag{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font-display);
  font-weight:700; text-transform:uppercase; letter-spacing:.1em; font-size:13px; color:var(--blue-bright); }
html[data-lang="ar"] .mv-card__tag{ text-transform:none; letter-spacing:0; }
.mv-card h3{ margin-top:14px; font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  font-size:30px; color:#fff; }
html[data-lang="ar"] .mv-card h3{ text-transform:none; font-weight:800; }
.mv-card ul{ margin:18px 0 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:14px; }
.mv-card li{ position:relative; padding-inline-start:26px; color:#BCD4E1; font-size:15.5px; }
.mv-card li::before{ content:""; position:absolute; inset-inline-start:0; inset-block-start:10px;
  width:9px; height:9px; background:var(--red); border-radius:2px; transform:rotate(45deg); }
.mv-card p{ margin-top:16px; color:#BCD4E1; }

/* ============================================================
   QUALITY band (split media)
   ============================================================ */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,68px); align-items:center; }
@media (max-width:860px){ .split{ grid-template-columns:1fr; } }
.split__media{ border-radius:var(--r-lg); overflow:hidden; position:relative; box-shadow:var(--shadow);
  aspect-ratio:4/3; }
.split__media img{ width:100%; height:100%; object-fit:cover; }
.split__media .tag-chip{ position:absolute; inset-block-end:18px; inset-inline-start:18px;
  background:var(--red); color:#fff; font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  letter-spacing:.06em; font-size:12px; padding:9px 14px; border-radius:8px; }
html[data-lang="ar"] .split__media .tag-chip{ text-transform:none; letter-spacing:0; }
.feat-list{ list-style:none; margin:24px 0 0; padding:0; display:flex; flex-direction:column; gap:16px; }
.feat-list li{ display:flex; gap:14px; align-items:flex-start; }
.feat-list .fi{ flex:0 0 auto; width:30px; height:30px; border-radius:8px; background:var(--bg-tint);
  color:var(--blue); display:grid; place-items:center; margin-top:2px; }
.feat-list .fi svg{ width:17px; height:17px; }
.feat-list b{ color:var(--blue-ink); font-weight:700; }
.feat-list span{ color:var(--muted); }

/* ============================================================
   SAFETY / ISO
   ============================================================ */
.iso-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:30px; }
@media (max-width:680px){ .iso-row{ grid-template-columns:1fr; } }
.iso-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:24px 22px;
  display:flex; gap:16px; align-items:center; transition:.3s; }
.iso-card:hover{ box-shadow:var(--shadow); transform:translateY(-3px); }
.iso-card__seal{ flex:0 0 auto; width:58px; height:58px; border-radius:12px; display:grid; place-items:center;
  background:var(--blue-ink); color:#fff; font-family:var(--font-display); font-weight:800; font-size:13px; text-align:center; line-height:1; }
.iso-card__seal small{ display:block; font-size:9px; font-weight:600; opacity:.7; margin-top:3px; }
.iso-card h4{ font-family:var(--font-display); font-weight:700; font-size:19px; color:var(--blue-ink); }
.iso-card p{ font-size:13.5px; color:var(--muted); margin-top:3px; }

/* ============================================================
   CONTACT / FOOTER
   ============================================================ */
.footer{ background:var(--blue-ink); color:#cfe0ea; padding-block:clamp(64px,8vw,96px) 0; }
.footer__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:44px; }
@media (max-width:860px){ .footer__top{ grid-template-columns:1fr; gap:38px; } }
.footer h3{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; font-size:30px; color:#fff; }
html[data-lang="ar"] .footer h3{ text-transform:none; font-weight:800; }
.footer__cta-row{ margin-top:22px; display:flex; flex-wrap:wrap; gap:12px; }
.footer__colh{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  font-size:13px; color:var(--blue-bright); margin-bottom:16px; }
html[data-lang="ar"] .footer__colh{ text-transform:none; letter-spacing:0; }
.footer__list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.footer__list a{ color:#aec8d6; font-size:15px; transition:.2s; }
.footer__list a:hover{ color:#fff; }
.contact-line{ display:flex; gap:13px; align-items:flex-start; margin-bottom:14px; font-size:14.5px; color:#bcd4e1; }
.contact-line .ci{ flex:0 0 auto; width:34px; height:34px; border-radius:9px; background:var(--blue);
  display:grid; place-items:center; color:#fff; }
.contact-line .ci svg{ width:16px; height:16px; }
.footer__bar{ margin-top:clamp(46px,6vw,72px); border-top:1px solid rgba(255,255,255,.12);
  padding-block:26px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  font-size:13px; color:#8fb0c0; }

/* ============================================================
   REVEAL on scroll
   ============================================================ */
.reveal{ opacity:0; transform:translateY(30px); }
.reveal.in{ opacity:1; transform:none; transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal[data-d="1"].in{ transition-delay:.08s; }
.reveal[data-d="2"].in{ transition-delay:.16s; }
.reveal[data-d="3"].in{ transition-delay:.24s; }
.reveal[data-d="4"].in{ transition-delay:.32s; }
.reveal[data-d="5"].in{ transition-delay:.40s; }
@media (prefers-reduced-motion:reduce){
  .reveal,[data-rise]{ opacity:1!important; transform:none!important; }
  .hero{ opacity:1 !important; }
  .hero__bg img{ animation:none; }
}
/* safety net: if the rendering timeline never advances, never hide content */
html.motion-off [data-rise],
html.motion-off .reveal{ opacity:1 !important; transform:none !important; animation:none !important; }
html.motion-off .hero{ opacity:1 !important; }
html.motion-off .hero.is-in .logo-mark--hero .br{ stroke-dashoffset:0 !important; animation:none !important; }
html.motion-off .hero.is-in .logo-mark--hero .lm-text{ opacity:1 !important; transform:none !important; animation:none !important; }

/* ============================================================
   PRODUCT DETAIL PAGE
   ============================================================ */
.phero{ position:relative; min-height:62svh; display:flex; align-items:flex-end; color:#fff;
  overflow:hidden; isolation:isolate; }
.phero img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2;
  animation:kenburns 20s ease-out forwards; }
.phero::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg,rgba(7,40,60,.55) 0%,rgba(7,40,60,.18) 40%,rgba(6,33,49,.92) 100%),
             linear-gradient(75deg,rgba(10,60,92,.6),rgba(10,60,92,0) 60%); }
.phero__in{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,44px);
  padding-block:clamp(120px,16vh,160px) clamp(40px,6vh,64px); }
.pcrumb{ display:flex; gap:9px; align-items:center; font-family:var(--font-display); font-weight:600;
  text-transform:uppercase; letter-spacing:.08em; font-size:12.5px; color:#bcd4e1; margin-bottom:18px; }
html[data-lang="ar"] .pcrumb{ text-transform:none; letter-spacing:0; }
.pcrumb a:hover{ color:#fff; }
.pcrumb .sep{ opacity:.5; }
html[dir="rtl"] .pcrumb .sep{ transform:scaleX(-1); }
.phero h1{ font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  font-size:clamp(38px,6vw,80px); line-height:.96; max-width:18ch; }
html[data-lang="ar"] .phero h1{ text-transform:none; font-weight:800; line-height:1.14; }
.pcat-chip{ display:inline-flex; align-items:center; gap:8px; background:var(--blue); color:#fff;
  font-family:var(--font-display); font-weight:600; text-transform:uppercase; letter-spacing:.08em;
  font-size:12px; padding:8px 14px; border-radius:8px; margin-bottom:18px; }
html[data-lang="ar"] .pcat-chip{ text-transform:none; letter-spacing:0; }
.pcat-chip--soon{ background:var(--red); }

/* product layout: TOC + content */
.player{ display:grid; grid-template-columns:240px 1fr; gap:clamp(34px,5vw,72px); align-items:start; }
@media (max-width:900px){ .player{ grid-template-columns:1fr; } }

.toc{ position:sticky; inset-block-start:96px; }
@media (max-width:900px){ .toc{ position:relative; inset-block-start:0; margin-bottom:8px;
  border:1px solid var(--line); border-radius:var(--r); padding:18px 20px; background:var(--bg-soft); } }
.toc__title{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; letter-spacing:.1em;
  font-size:12px; color:var(--muted-2); margin-bottom:16px; padding-bottom:14px; border-bottom:1px solid var(--line); }
html[data-lang="ar"] .toc__title{ text-transform:none; letter-spacing:0; }
.toc__list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:2px; }
.toc__list a{ display:flex; align-items:center; gap:11px; padding:9px 12px; border-radius:9px;
  font-size:14.5px; color:var(--muted); transition:.2s; font-weight:500;
  border-inline-start:2px solid transparent; }
.toc__list a .n{ font-family:var(--font-display); font-weight:700; font-size:12px; color:var(--blue);
  width:20px; }
.toc__list a:hover{ background:var(--bg-tint); color:var(--blue-ink); }
.toc__list a.active{ background:var(--bg-tint); color:var(--blue-ink); font-weight:600;
  border-inline-start-color:var(--blue); }

.pblock{ scroll-margin-top:96px; margin-bottom:clamp(44px,6vw,72px); }
.pblock:last-child{ margin-bottom:0; }
.pblock__h{ font-family:var(--font-display); font-weight:700; text-transform:uppercase;
  font-size:clamp(26px,3.4vw,40px); color:var(--blue-ink); letter-spacing:.005em; margin-bottom:18px;
  display:flex; align-items:baseline; gap:14px; }
html[data-lang="ar"] .pblock__h{ text-transform:none; font-weight:800; }
.pblock__h .hn{ font-size:.55em; color:var(--blue); -webkit-text-stroke:0; opacity:.8; }
.pblock p{ color:var(--muted); margin-bottom:16px; font-size:16.5px; }
.pblock p:last-child{ margin-bottom:0; }
.pblock strong{ color:var(--blue-ink); }

.spec-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
@media (max-width:560px){ .spec-grid{ grid-template-columns:1fr; } }
.spec{ background:var(--bg-soft); border:1px solid var(--line); border-radius:var(--r); padding:20px 22px; }
.spec dt{ font-family:var(--font-display); font-weight:600; text-transform:uppercase; letter-spacing:.06em;
  font-size:12px; color:var(--blue); }
html[data-lang="ar"] .spec dt{ text-transform:none; letter-spacing:0; }
.spec dd{ margin:7px 0 0; font-size:18px; font-weight:600; color:var(--blue-ink); }

.bullets{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:13px; }
.bullets li{ position:relative; padding-inline-start:28px; color:var(--muted); font-size:16px; }
.bullets li::before{ content:""; position:absolute; inset-inline-start:0; inset-block-start:9px;
  width:9px; height:9px; background:var(--blue); border-radius:2px; transform:rotate(45deg); }

.pfig{ border-radius:var(--r); overflow:hidden; border:1px solid var(--line); background:#fff; }
.pfig img{ width:100%; }
.pfig figcaption{ font-size:13px; color:var(--muted-2); padding:12px 16px; border-top:1px solid var(--line); }

.embed-wrap{ position:relative; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow);
  background:#0B2A3C; aspect-ratio:16/10; }
.embed-wrap iframe,.embed-wrap video{ position:absolute; inset:0; width:100%; height:100%; border:0; object-fit:cover; background:#0B2A3C; }
.embed-note{ margin-top:12px; font-size:13px; color:var(--muted-2); display:flex; align-items:center; gap:8px; }
.embed-note svg{ width:15px; height:15px; color:var(--blue); }

.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
@media (max-width:560px){ .gallery{ grid-template-columns:repeat(2,1fr); } }
.gallery img{ width:100%; aspect-ratio:1; object-fit:cover; border-radius:var(--r); }

.soon-banner{ background:linear-gradient(120deg,var(--blue-ink),var(--blue-dark)); color:#fff;
  border-radius:var(--r-lg); padding:38px 34px; display:flex; gap:22px; align-items:center; flex-wrap:wrap; }
.soon-banner__ic{ width:64px; height:64px; border-radius:16px; background:rgba(255,255,255,.12);
  display:grid; place-items:center; }
.soon-banner__ic svg{ width:32px; height:32px; }
.soon-banner h3{ font-family:var(--font-display); font-weight:700; text-transform:uppercase; font-size:26px; }
html[data-lang="ar"] .soon-banner h3{ text-transform:none; font-weight:800; }
.soon-banner p{ color:#bcd4e1; margin-top:6px; max-width:52ch; }

/* related products strip */
.related-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:780px){ .related-grid{ grid-template-columns:1fr; } }

/* prev/next product footer nav */
.pnext{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top:8px; }
.pnext a{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:600;
  text-transform:uppercase; letter-spacing:.05em; font-size:14px; color:var(--blue); }
html[data-lang="ar"] .pnext a{ text-transform:none; letter-spacing:0; font-weight:700; }
.pnext svg{ width:18px; height:18px; }
html[dir="rtl"] .pnext svg{ transform:scaleX(-1); }

/* product detail dimensions table */
.dim-table{ width:100%; border-collapse:collapse; font-size:15px; min-width:440px; }
.dim-table th{ background:var(--blue-ink); color:#fff; font-family:var(--font-display); font-weight:600;
  text-transform:uppercase; letter-spacing:.05em; font-size:12.5px; padding:13px 16px; text-align:start; }
html[data-lang="ar"] .dim-table th{ text-transform:none; letter-spacing:0; }
.dim-table td{ padding:12px 16px; border-top:1px solid var(--line); color:var(--ink); }
.dim-table tbody tr:nth-child(even){ background:var(--bg-soft); }
.dim-table td:first-child{ font-family:var(--font-display); font-weight:700; color:var(--blue); }

/* certifications grid */
.cert-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:6px; }
@media (max-width:560px){ .cert-grid{ grid-template-columns:1fr; } }
.cert-card{ background:var(--bg-soft); border:1px solid var(--line); border-radius:var(--r); padding:20px 22px;
  display:flex; flex-direction:column; gap:6px; transition:.3s; }
.cert-card:hover{ box-shadow:var(--shadow); transform:translateY(-3px); border-color:transparent; }
.cert-card__ic{ width:42px; height:42px; border-radius:11px; background:var(--bg-tint); color:var(--blue);
  display:grid; place-items:center; margin-bottom:6px; }
.cert-card__ic svg{ width:22px; height:22px; }
.cert-card b{ font-family:var(--font-display); font-weight:700; font-size:18px; color:var(--blue-ink); }
.cert-card span{ font-size:14px; color:var(--muted); }

/* certificate document cards (with scan thumbnail) */
.cert-doc{ display:flex; flex-direction:column; border:1px solid var(--line); border-radius:var(--r);
  overflow:hidden; background:#fff; transition:.3s; }
.cert-doc:hover{ box-shadow:var(--shadow); transform:translateY(-3px); border-color:transparent; }
.cert-doc__img{ position:relative; aspect-ratio:4/3.2; overflow:hidden; background:var(--bg-soft);
  border-bottom:1px solid var(--line); }
.cert-doc__img img{ width:100%; height:100%; object-fit:cover; object-position:top center; transition:transform .5s; }
.cert-doc:hover .cert-doc__img img{ transform:scale(1.04); }
.cert-doc__tag{ position:absolute; inset-block-start:10px; inset-inline-end:10px; z-index:2;
  background:rgba(11,42,60,.72); color:#fff; backdrop-filter:blur(4px); border-radius:7px;
  padding:6px 9px; display:flex; align-items:center; gap:6px; font-size:11.5px; font-weight:600; }
.cert-doc__tag svg{ width:13px; height:13px; }
.cert-doc__cap{ display:flex; align-items:center; gap:10px; padding:15px 17px; }
.cert-doc__cap b{ font-family:var(--font-display); font-weight:700; font-size:17px; color:var(--blue-ink); }
.cert-doc__cap span{ font-size:13px; color:var(--muted); flex:1; }

/* utility */
.center{ text-align:center; }
.mt-cta{ margin-top:38px; display:flex; gap:14px; flex-wrap:wrap; }
.center .mt-cta{ justify-content:center; }
.hide{ display:none !important; }
[hidden]{ display:none !important; }
