/* =====================================================
   YNNIA — Industrial Automation
   Design tokens follow brand spec:
   Primary navy  #1B263B  — identity / headlines
   CTA orange    #E67E22  — interaction / accents
   Background    #F2F4F4  — page surface
   Midnight      #0D1B2A  — footer / dark sections
   Charcoal      #2C3E50  — body text
   Brand green   #1F8D43 / #6DBE65 — logo accents
   ===================================================== */

:root{
  --navy:#1B263B;
  --orange:#E67E22;
  --orange-2:#D86A12;
  --bg:#F2F4F4;
  --midnight:#0D1B2A;
  --charcoal:#2C3E50;
  --green:#1F8D43;
  --green-2:#6DBE65;
  --white:#ffffff;
  --line:rgba(27,38,59,.10);
  --line-dark:rgba(255,255,255,.10);
  --muted:#5C6B7A;
  --shadow-sm:0 1px 2px rgba(13,27,42,.06), 0 2px 8px rgba(13,27,42,.04);
  --shadow-md:0 10px 30px rgba(13,27,42,.08), 0 4px 12px rgba(13,27,42,.06);
  --shadow-lg:0 30px 60px rgba(13,27,42,.18), 0 10px 24px rgba(13,27,42,.10);
  --radius:14px;
  --radius-lg:22px;
  --maxw:1200px;
  --gutter:clamp(20px, 4vw, 40px);
  --display:"Space Grotesk", "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --sans:"Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  color:var(--charcoal);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.55;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a:focus-visible, button:focus-visible, .btn:focus-visible, input:focus-visible, textarea:focus-visible{
  outline:2px solid var(--orange);
  outline-offset:3px;
  border-radius:8px;
}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--midnight);color:#fff;padding:10px 14px;z-index:200}
.skip-link:focus{left:16px;top:16px}

/* ---------- Typography ---------- */
h1,h2,h3,h4,h5{font-family:var(--display);color:var(--navy);margin:0 0 .4em;letter-spacing:-.01em;line-height:1.12}
h1{font-size:clamp(2.4rem, 5.6vw, 4.4rem);font-weight:700;letter-spacing:-.025em;line-height:1.04}
h2{font-size:clamp(1.85rem, 3.6vw, 2.8rem);font-weight:700;letter-spacing:-.018em;line-height:1.1}
h3{font-size:clamp(1.15rem, 1.6vw, 1.35rem);font-weight:600}
h4{font-size:1.05rem;font-weight:600;color:var(--navy)}
h5{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--navy)}
p{margin:0 0 1em;color:var(--muted)}
.lede{font-size:clamp(1.05rem, 1.5vw, 1.2rem);color:var(--charcoal);max-width:54ch}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--navy);font-weight:600;
}
.eyebrow .dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--orange);box-shadow:0 0 0 4px rgba(230,126,34,.18);
}
.grad{
  background:linear-gradient(95deg, var(--navy) 0%, var(--green) 55%, var(--orange) 110%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;
  font-family:var(--sans);font-weight:600;font-size:.98rem;
  border:1px solid transparent;cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
  white-space:nowrap;
}
.btn span{transition:transform .18s ease}
.btn:hover span{transform:translateX(3px)}
.btn--primary{background:var(--orange);color:#fff;box-shadow:0 8px 22px rgba(230,126,34,.32)}
.btn--primary:hover{background:var(--orange-2);transform:translateY(-1px);box-shadow:0 12px 28px rgba(230,126,34,.38)}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--line);}
.btn--ghost:hover{background:#fff;border-color:rgba(27,38,59,.18)}
.btn--lg{padding:18px 28px;font-size:1.02rem}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:80;
  background:rgba(255,255,255,.78);
  backdrop-filter:saturate(180%) blur(12px);
  -webkit-backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .25s ease, background .25s ease, box-shadow .25s ease;
}
.nav.scrolled{
  border-bottom-color:var(--line);
  background:rgba(255,255,255,.92);
  box-shadow:var(--shadow-sm);
}
.nav__row{display:flex;align-items:center;gap:24px;height:88px}
.nav__brand{display:flex;align-items:center}
.nav__brand img{height:68px;width:auto}
.nav__menu{display:flex;align-items:center;gap:6px;margin-left:auto}
.nav__menu a{
  position:relative;padding:10px 14px;font-weight:500;color:var(--navy);
  border-radius:8px;font-size:.96rem;
}
.nav__menu a:hover{background:rgba(27,38,59,.06)}
.nav__menu a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;
  background:var(--orange);transform:scaleX(0);transform-origin:left;
  transition:transform .25s ease;
}
.nav__menu a:hover::after{transform:scaleX(1)}
.nav__cta{padding:10px 18px}
.nav__toggle{display:none;background:transparent;border:0;width:44px;height:44px;padding:10px;cursor:pointer}
.nav__toggle span{display:block;height:2px;background:var(--navy);margin:5px 0;transition:transform .25s, opacity .2s}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav__mobile{display:none;flex-direction:column;gap:4px;padding:14px var(--gutter) 22px;background:#fff;border-bottom:1px solid var(--line)}
.nav__mobile a{padding:14px 6px;color:var(--navy);font-weight:500;border-bottom:1px solid var(--line)}
.nav__mobile .btn{align-self:flex-start;margin-top:10px}

@media (max-width: 880px){
  .nav__menu, .nav__cta{display:none}
  .nav__toggle{display:block;margin-left:auto}
  .nav__mobile[data-open="true"]{display:flex}
}

/* ---------- Hero (cinematic full-bleed) ---------- */
.hero{
  position:relative;
  min-height:clamp(560px, 82vh, 820px);
  padding:120px 0 100px;
  overflow:hidden;
  isolation:isolate;
  color:#fff;
  background:#0D1B2A;
  display:flex;align-items:center;
}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg img{
  width:100%;height:100%;object-fit:cover;object-position:center 62%;
  transform:scale(1.04);
  filter:saturate(1.05) contrast(1.02) brightness(0.92);
  transition:transform 12s ease-out;
}
.hero:hover .hero__bg img{transform:scale(1.07)}
.hero__overlay{
  position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(95deg,
      rgba(13,27,42,0.92) 0%,
      rgba(13,27,42,0.74) 38%,
      rgba(13,27,42,0.28) 78%,
      rgba(13,27,42,0.10) 100%),
    linear-gradient(180deg, rgba(13,27,42,0) 45%, rgba(13,27,42,0.55) 100%);
}
.hero__wrap{
  display:grid;grid-template-columns:1.35fr .65fr;
  gap:48px;align-items:center;position:relative;z-index:1;width:100%;
}
.hero__copy h1{
  color:#fff;margin-top:18px;margin-bottom:.35em;
  text-shadow:0 2px 20px rgba(0,0,0,.18);
}
.hero__copy .lede{color:rgba(255,255,255,.86);max-width:58ch}
.hero__copy .eyebrow{color:#fff}
.hero__copy .eyebrow .dot{background:var(--orange);box-shadow:0 0 0 4px rgba(230,126,34,.32)}
.hero .grad{
  background:linear-gradient(95deg, #6DBE65 0%, #C8E6BA 30%, #F5C28A 70%, var(--orange) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.hero .btn--ghost{
  background:rgba(255,255,255,.10);color:#fff;
  border-color:rgba(255,255,255,.22);
  backdrop-filter:blur(8px);
}
.hero .btn--ghost:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.36)}
.hero__chips{list-style:none;padding:0;margin:36px 0 0;display:flex;flex-wrap:wrap;gap:10px}
.hero__chips li{
  font-size:.82rem;font-weight:600;letter-spacing:.04em;
  background:rgba(255,255,255,.10);color:#fff;
  border:1px solid rgba(255,255,255,.20);
  padding:8px 14px;border-radius:999px;
  backdrop-filter:blur(8px);
}

/* Floating credibility cards in the hero (top-right) */
.hero__cards{display:flex;flex-direction:column;gap:14px;align-items:stretch}
.hero__card{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  border-radius:14px;padding:16px 20px;
  display:flex;flex-direction:column;gap:2px;
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 18px 40px rgba(0,0,0,.18);
  animation:floaty 6s ease-in-out infinite;
}
.hero__card:nth-child(2){animation-delay:1.4s}
.hero__card:nth-child(3){animation-delay:2.8s}
.hero__card .hero__card-k{font-family:var(--display);font-size:1.8rem;font-weight:700;color:#fff;line-height:1}
.hero__card .hero__card-l{font-size:.82rem;color:rgba(255,255,255,.78);font-weight:500;margin-top:4px}
.hero__card--accent-green .hero__card-k{color:#A5E0A0}
.hero__card--accent-orange .hero__card-k{color:#F4B27A}
@keyframes floaty{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}

@media (max-width: 980px){
  .hero{padding:84px 0 80px;min-height:auto}
  .hero__wrap{grid-template-columns:1fr;gap:40px}
  .hero__cards{flex-direction:row;flex-wrap:wrap}
  .hero__card{flex:1 1 160px}
}
@media (max-width: 520px){
  .hero__card{padding:12px 16px}
  .hero__card .hero__card-k{font-size:1.4rem}
}

/* ---------- Brand bar ---------- */
.brandbar{
  background:#fff;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:22px 0;
}
.brandbar__row{display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between}
.brandbar__label{
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);font-weight:600;
}
.brandbar__list{
  list-style:none;display:flex;flex-wrap:wrap;gap:28px 36px;padding:0;margin:0;
}
.brandbar__list li{
  font-family:var(--display);font-weight:600;letter-spacing:.08em;
  color:var(--navy);opacity:.7;font-size:.95rem;
  transition:opacity .2s ease;
}
.brandbar__list li:hover{opacity:1}

/* ---------- Stats ---------- */
.stats{padding:90px 0}
.stats__grid{
  display:grid;grid-template-columns:repeat(4, minmax(0,1fr));
  gap:24px;
}
.stat{
  background:#fff;border-radius:var(--radius);
  padding:30px 26px;
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  position:relative;overflow:hidden;
  transition:transform .2s ease, box-shadow .25s ease;
}
.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.stat::before{
  content:"";position:absolute;left:0;top:0;height:3px;width:100%;
  background:linear-gradient(90deg, var(--green) 0%, var(--orange) 100%);
  transform:scaleX(0);transform-origin:left;
  transition:transform .5s ease;
}
.stat.is-revealed::before{transform:scaleX(1)}
.stat__k{font-family:var(--display);font-weight:700;font-size:clamp(2.4rem, 4vw, 3.2rem);color:var(--navy);line-height:1}
.stat__l{margin-top:8px;font-size:.95rem;color:var(--muted)}
@media (max-width: 880px){.stats__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 480px){.stats__grid{grid-template-columns:1fr}}

/* ---------- About ---------- */
.about{padding:90px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about__copy h2{margin-top:14px}
.about__pillars{list-style:none;padding:0;margin:22px 0 0;display:grid;gap:12px}
.about__pillars li{
  padding-left:26px;position:relative;color:var(--charcoal);
}
.about__pillars li::before{
  content:"";position:absolute;left:0;top:.55em;width:14px;height:2px;
  background:var(--orange);border-radius:2px;
}
.about__media{
  position:relative;height:min(70vh, 560px);
}
.about__photo{
  position:absolute;margin:0;border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-md);
  border:6px solid #fff;
}
.about__photo img{width:100%;height:100%;object-fit:cover}
.about__photo--a{top:0;left:0;width:62%;aspect-ratio:4/3;z-index:2}
.about__photo--b{bottom:0;right:0;width:55%;aspect-ratio:4/3;z-index:1}
.about__photo--c{top:32%;right:6%;width:38%;aspect-ratio:1/1;z-index:3;border-radius:50%;}
.about__photo--c img{border-radius:50%}

@media (max-width: 980px){
  .about__grid{grid-template-columns:1fr;gap:48px}
  .about__media{height:auto;display:grid;grid-template-columns:repeat(3, 1fr);gap:12px}
  .about__photo{position:relative;width:auto !important;aspect-ratio:4/5 !important;border-width:4px}
  .about__photo--c{border-radius:var(--radius)}
  .about__photo--c img{border-radius:0}
}

/* ---------- Sections (head) ---------- */
.section__head{max-width:740px;margin:0 auto 56px;text-align:center}
.section__head h2{margin-top:14px}
.section__head p{font-size:1.08rem;color:var(--muted)}

/* ---------- Services ---------- */
.services{padding:110px 0}
.services__grid{
  display:grid;grid-template-columns:repeat(4, minmax(0,1fr));
  gap:20px;
}
.service{
  background:#fff;padding:28px 24px;border-radius:var(--radius);
  border:1px solid var(--line);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.service::before{
  content:"";position:absolute;inset:auto 0 0 0;height:3px;
  background:linear-gradient(90deg, var(--green) 0%, var(--orange) 100%);
  transform:scaleX(0);transform-origin:left;transition:transform .35s ease;
}
.service:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(27,38,59,.16)}
.service:hover::before{transform:scaleX(1)}
.service__icon{
  width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, rgba(31,141,67,.12), rgba(230,126,34,.12));
  color:var(--navy);margin-bottom:14px;
}
.service__icon svg{width:22px;height:22px}
.service h3{margin-bottom:.35em}
.service p{font-size:.95rem;margin:0;color:var(--muted)}

@media (max-width: 1080px){.services__grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width: 800px){.services__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 480px){.services__grid{grid-template-columns:1fr}}

/* ---------- Work ---------- */
.work{padding:110px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.work__grid{display:grid;grid-template-columns:repeat(6, 1fr);gap:22px}
.card{
  grid-column:span 2;
  background:var(--bg);border-radius:var(--radius-lg);
  overflow:hidden;border:1px solid var(--line);
  display:flex;flex-direction:column;
  transition:transform .25s ease, box-shadow .25s ease;
  box-shadow:var(--shadow-sm);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.card--lg{grid-column:span 3}
.card__media{
  position:relative;aspect-ratio:16/10;overflow:hidden;background:#0D1B2A;
}
.card__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(13,27,42,.32) 100%);
}
.card__media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s ease;
}
.card:hover .card__media img{transform:scale(1.04)}
.card__body{padding:22px 24px 26px;display:flex;flex-direction:column;gap:6px}
.tag{
  display:inline-block;align-self:flex-start;
  background:rgba(31,141,67,.12);color:var(--green);
  padding:5px 10px;border-radius:999px;font-size:.74rem;
  font-weight:700;letter-spacing:.06em;text-transform:uppercase;
}
.card h3{margin:.15em 0 .25em}
.card p{font-size:.95rem;color:var(--muted);margin:0}
.card__meta{
  list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:14px 0 0;margin:0;
}
.card__meta li{
  font-size:.74rem;font-weight:600;letter-spacing:.04em;
  background:rgba(27,38,59,.06);color:var(--navy);
  padding:5px 10px;border-radius:999px;
}

@media (max-width: 1080px){.work__grid{grid-template-columns:repeat(4,1fr)}.card{grid-column:span 2}.card--lg{grid-column:span 4}}
@media (max-width: 720px){.work__grid{grid-template-columns:1fr}.card,.card--lg{grid-column:span 1}}

/* ---------- Capabilities ---------- */
.cap{padding:110px 0;background:linear-gradient(180deg, var(--bg) 0%, #ECEFF1 100%)}
.cap__grid{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start}
.cap__copy h2{margin-top:14px}
.cap__list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.cap__list li{background:#fff;padding:22px 22px}
.cap__list h4{margin:0 0 .25em;color:var(--navy)}
.cap__list p{margin:0;font-size:.92rem;color:var(--muted)}
@media (max-width: 980px){.cap__grid{grid-template-columns:1fr;gap:36px}}
@media (max-width: 520px){.cap__list{grid-template-columns:1fr}}

/* ---------- Process ---------- */
.process{padding:110px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.process__list{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(5,1fr);gap:18px;
  counter-reset:proc;
}
.process__list li{
  position:relative;padding:24px 22px 22px;
  border-radius:var(--radius);background:var(--bg);
  border:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;
  transition:transform .22s ease, box-shadow .22s ease;
}
.process__list li:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.process__n{
  display:inline-block;font-family:var(--display);font-weight:700;
  color:var(--orange);font-size:.92rem;letter-spacing:.08em;
}
.process__list h4{margin:0}
.process__list p{font-size:.94rem;margin:0;color:var(--muted)}
@media (max-width: 980px){.process__list{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 520px){.process__list{grid-template-columns:1fr}}

/* ---------- CTA band ---------- */
.ctaband{padding:80px 0}
.ctaband__row{
  display:flex;align-items:center;justify-content:space-between;gap:36px;
  background:linear-gradient(135deg, #0F2440 0%, var(--midnight) 60%, #0F2440 100%);
  color:#fff;padding:46px 44px;border-radius:var(--radius-lg);
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-md);
}
.ctaband__row::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(40% 60% at 100% 0%, rgba(230,126,34,.20) 0%, transparent 70%),
    radial-gradient(40% 60% at 0% 100%, rgba(31,141,67,.18) 0%, transparent 70%);
  pointer-events:none;
}
.ctaband__row h2{color:#fff;margin:0;line-height:1.1}
.ctaband__row p{color:rgba(255,255,255,.78);margin:.4em 0 0;max-width:56ch}
.ctaband__row .btn{position:relative;z-index:1}
@media (max-width: 720px){.ctaband__row{flex-direction:column;align-items:flex-start;padding:34px 26px}}

/* ---------- Contact ---------- */
.contact{padding:110px 0}
.contact__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:start}
.contact__copy h2{margin-top:14px}
.contact__list{list-style:none;padding:0;margin:28px 0 0;display:grid;gap:14px}
.contact__list li{
  display:flex;align-items:baseline;gap:18px;padding:14px 0;border-bottom:1px solid var(--line);
}
.contact__list span{
  min-width:96px;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);font-weight:700;
}
.contact__list a{color:var(--navy);font-weight:600}
.contact__list a:hover{color:var(--orange)}

/* WhatsApp QR card — standalone row, centered horizontally below the form */
.contact__card-row{
  display:flex;justify-content:center;
  margin-top:48px;
}
.contact__card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);
  padding:22px 26px;
  display:flex;align-items:center;gap:22px;
  max-width:520px;width:100%;
  transition:transform .2s ease, box-shadow .2s ease;
}
.contact__card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.contact__card-qr{
  flex-shrink:0;display:block;background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:8px;line-height:0;
}
.contact__card-qr img{width:140px;height:140px;display:block;border-radius:6px;background:#f6f7f8}
.contact__card-qr img:not([src]),
.contact__card-qr img[src=""]{visibility:hidden}
.contact__card-meta{display:flex;flex-direction:column;align-items:flex-start;gap:10px;min-width:0;text-align:start}
.contact__card-head{display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.contact__card-head h4{margin:0;color:var(--navy);font-size:1.1rem;line-height:1.2}
.contact__card-pill{
  display:inline-flex;align-items:center;gap:6px;
  background:#25D366;color:#fff;
  font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:5px 12px;border-radius:999px;
}
.contact__card-name{
  margin:0;font-size:.95rem;color:var(--charcoal);font-weight:600;line-height:1.4;
}
.contact__card-phone{
  font-family:var(--display);font-weight:700;letter-spacing:.02em;
  color:var(--navy);font-size:1.05rem;text-decoration:none;
}
.contact__card-phone:hover{color:#25D366}
.contact__card-cta.btn-wa{
  display:inline-flex;align-items:center;gap:8px;
  background:#25D366;color:#fff;
  padding:10px 16px;border-radius:999px;
  font-weight:600;font-size:.92rem;letter-spacing:.01em;
  box-shadow:0 6px 16px rgba(37,211,102,.25);
  transition:transform .18s ease, background .18s ease, box-shadow .18s ease;
}
.contact__card-cta.btn-wa:hover{background:#1FB759;transform:translateY(-1px);box-shadow:0 10px 22px rgba(37,211,102,.35)}
.contact__card-hint{
  margin:0;font-size:.82rem;color:var(--muted);line-height:1.45;
}

@media (max-width: 520px){
  .contact__card{flex-direction:column;align-items:flex-start;text-align:start;padding:22px}
  .contact__card-qr{align-self:center}
}

.contact__form{
  background:#fff;padding:30px;border-radius:var(--radius-lg);
  border:1px solid var(--line);box-shadow:var(--shadow-sm);
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.contact__form label{display:flex;flex-direction:column;gap:6px}
.contact__form label.full{grid-column:1 / -1}
.contact__form span{font-size:.85rem;font-weight:600;color:var(--navy)}
.contact__form input,
.contact__form textarea{
  font-family:inherit;font-size:1rem;color:var(--charcoal);
  background:#FAFBFB;border:1px solid var(--line);
  padding:13px 14px;border-radius:10px;width:100%;
  transition:border-color .2s ease, background .2s ease;
}
.contact__form input:focus,
.contact__form textarea:focus{
  outline:none;background:#fff;border-color:var(--orange);
}
.contact__form .btn{grid-column:1 / -1;justify-self:flex-start}
.contact__success{
  grid-column:1 / -1;margin:0;color:var(--green);
  background:rgba(31,141,67,.10);padding:12px 14px;border-radius:10px;font-weight:600;
}
.contact__error{
  grid-column:1 / -1;margin:0;color:#B33A3A;
  background:rgba(179,58,58,.10);padding:12px 14px;border-radius:10px;font-weight:600;
}
.contact__error a{color:inherit;text-decoration:underline}
.contact__form button[type="submit"][disabled]{opacity:.7;cursor:wait}

@media (max-width: 980px){.contact__grid{grid-template-columns:1fr;gap:40px}}
@media (max-width: 520px){.contact__form{grid-template-columns:1fr;padding:22px}}

/* ---------- Footer ---------- */
.footer{
  background:var(--midnight);color:#CBD3DC;
  padding:70px 0 28px;
}
.footer__grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:40px;padding-bottom:42px;border-bottom:1px solid var(--line-dark);
}
.footer__logo{opacity:.95;height:64px;width:auto}
.footer__tag{color:rgba(255,255,255,.72);max-width:36ch;margin-top:14px}
.footer h5{color:#fff;margin:0 0 14px}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.footer ul a{color:rgba(255,255,255,.78)}
.footer ul a:hover{color:var(--orange)}
.footer__base{
  display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;
  padding-top:22px;font-size:.88rem;color:rgba(255,255,255,.6);
}
.footer__mark{display:inline-flex;gap:10px;align-items:center}
.footer__mark .dot{
  width:7px;height:7px;border-radius:50%;background:var(--green-2);
  box-shadow:0 0 0 4px rgba(109,190,101,.18);
}
@media (max-width: 720px){.footer__grid{grid-template-columns:1fr 1fr}}
@media (max-width: 420px){.footer__grid{grid-template-columns:1fr}}

/* ---------- Reveal on scroll ---------- */
/* Default: content is visible (no JS / older browsers / fallback) */
.reveal{opacity:1;transform:none;transition:opacity .7s ease, transform .7s ease}
/* Only hide if JS is ready and will reveal on scroll */
html.js-ready .reveal{opacity:0;transform:translateY(18px)}
html.js-ready .reveal.is-revealed{opacity:1;transform:none}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{animation-duration:0.001ms !important;transition-duration:0.001ms !important;animation-iteration-count:1 !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}

/* =====================================================
   Language switcher (shared)
   ===================================================== */
.langs{
  display:inline-flex;align-items:center;gap:2px;
  margin-inline-start:6px;padding:4px;border:1px solid var(--line);
  border-radius:999px;background:#fff;
}
.langs a{
  font-size:.78rem;font-weight:700;letter-spacing:.06em;
  padding:6px 12px;border-radius:999px;color:var(--navy);
  transition:background .2s ease, color .2s ease;
  font-family:var(--display);
}
.langs a.is-active{background:var(--navy);color:#fff}
.langs a:not(.is-active):hover{background:rgba(27,38,59,.08)}
.nav__mobile .langs{margin:14px 0 0;align-self:flex-start}

/* =====================================================
   RTL (Arabic) — overrides for the Arabic page only.
   The shared design system flips automatically where it
   uses logical properties; here we fix the absolute &
   transform-based pieces.
   ===================================================== */

/* Arabic-optimised typography for the RTL page */
html[dir="rtl"]{
  --sans:"IBM Plex Sans Arabic", "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Tahoma, Arial, sans-serif;
  --display:"IBM Plex Sans Arabic", "Space Grotesk", "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Tahoma, Arial, sans-serif;
}
html[dir="rtl"] body{line-height:1.7}
/* Arabic display sizes — Arabic glyphs read larger; tighten slightly */
html[dir="rtl"] h1{letter-spacing:0;line-height:1.18}
html[dir="rtl"] h2{letter-spacing:0;line-height:1.25}
html[dir="rtl"] h3,html[dir="rtl"] h4{letter-spacing:0;line-height:1.4}
html[dir="rtl"] .eyebrow{letter-spacing:.04em}
html[dir="rtl"] h5{letter-spacing:.06em}

/* Force any inline Latin tokens (brand names, model numbers) to render LTR */
html[dir="rtl"] .ltr,
html[dir="rtl"] .brandbar__list li{
  direction:ltr;unicode-bidi:isolate;
}

/* Buttons: keep arrow on the trailing edge in RTL too — only mirror visual icons that depend on direction */
html[dir="rtl"] .btn span{display:inline-block}
html[dir="rtl"] .btn:hover span{transform:translateX(-3px)}

/* Hero — flip the background gradient direction so dark overlay sits on the leading edge */
html[dir="rtl"] .hero__overlay{
  background:
    linear-gradient(265deg,
      rgba(13,27,42,0.92) 0%,
      rgba(13,27,42,0.74) 38%,
      rgba(13,27,42,0.28) 78%,
      rgba(13,27,42,0.10) 100%),
    linear-gradient(180deg, rgba(13,27,42,0) 45%, rgba(13,27,42,0.55) 100%);
}

/* About — mirror the layered photo collage */
html[dir="rtl"] .about__photo--a{left:auto;right:0}
html[dir="rtl"] .about__photo--b{right:auto;left:0}
html[dir="rtl"] .about__photo--c{right:auto;left:6%}

/* About pillars — flip the bullet marker to the right */
html[dir="rtl"] .about__pillars li{padding-left:0;padding-right:26px}
html[dir="rtl"] .about__pillars li::before{left:auto;right:0}

/* Service cards — keep underline animation aligned to the start edge */
html[dir="rtl"] .service::before{transform-origin:right}
html[dir="rtl"] .stat::before{transform-origin:right}

/* Contact list — keep label/value spacing comfortable in RTL */
html[dir="rtl"] .contact__list span{min-width:120px}

/* Form: input alignment naturally inherits dir from <html> — nothing else needed */

/* Footer base row — mirror spacing */
html[dir="rtl"] .footer__mark .dot{box-shadow:0 0 0 4px rgba(109,190,101,.18)}

/* Nav menu underline anchor */
html[dir="rtl"] .nav__menu a::after{transform-origin:right}
html[dir="rtl"] .nav__menu a:hover::after{transform:scaleX(1)}

/* Card meta chips — already inline-flex, just stay tidy */
html[dir="rtl"] .card__meta{gap:8px}

