/* ==========================================================
   TechGen Arabia — v2 (dark-navy-first, editorial)
   ========================================================== */

:root {
  /* navy palette — primary canvas */
  --navy:          #0F2440;   /* deepest base */
  --navy-1:        #122A4A;   /* surface */
  --navy-2:        #16304F;   /* elevated */
  --navy-3:        #1B3A5E;   /* hover */
  --navy-line:     #1F3D62;   /* hairline on navy */
  --navy-line-2:   #28507F;   /* brighter hairline */
  --navy-ink:      #B8C4D6;   /* muted text on navy */
  --navy-ink-soft: #7E8FA8;   /* deep muted */

  /* gold */
  --gold:          #C5A157;
  --gold-soft:     #D4B370;
  --gold-deep:     #A88840;

  /* light surfaces (used SPARINGLY now) */
  --cream:         #F5EFE0;
  --paper:         #FFFFFF;

  /* ink for any light surface */
  --ink:           #1A2438;
  --slate:         #5A6478;

  /* type */
  --font-display: 'Instrument Serif', 'Cormorant Garamond', Georgia, serif;
  --font-sans:    'Geist', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;

  --r-sharp: 2px;
  --container: 1320px;
  --gutter: 32px;
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:96px}
body{
  font-family:var(--font-sans);
  font-size:15px;
  line-height:1.6;
  color:var(--navy-ink);
  background:var(--navy);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:var(--navy)}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.container-narrow{max-width:920px;margin:0 auto;padding:0 var(--gutter)}
.container-wide{max-width:1480px;margin:0 auto;padding:0 var(--gutter)}

/* ---------- type ---------- */
h1,h2,h3,h4{margin:0;color:#fff;font-weight:400}
.display-xxl{font-family:var(--font-display);font-weight:400;font-size:clamp(56px,8.5vw,128px);line-height:0.95;letter-spacing:-3px;color:#fff}
.display-xl {font-family:var(--font-display);font-weight:400;font-size:clamp(48px,6.5vw,96px);line-height:1;letter-spacing:-2px;color:#fff}
.display-l  {font-family:var(--font-display);font-weight:400;font-size:clamp(36px,4.5vw,72px);line-height:1.05;letter-spacing:-1.5px;color:#fff}
.display-m  {font-family:var(--font-display);font-weight:400;font-size:clamp(28px,3.2vw,48px);line-height:1.1;letter-spacing:-1px;color:#fff}
.h-sans-xl  {font-family:var(--font-sans);font-weight:600;font-size:clamp(28px,3vw,40px);line-height:1.15;letter-spacing:-0.6px;color:#fff}

/* italics in display look great for a Saudi-editorial vibe */
.display-xxl em, .display-xl em, .display-l em, .display-m em {
  font-style:italic;
  color:var(--gold);
  font-weight:400;
}

p{margin:0}
.lede{font-size:19px;line-height:1.55;color:var(--navy-ink);max-width:60ch}
.body-lg{font-size:17px;line-height:1.7;color:var(--navy-ink)}

.eyebrow{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:2.6px;text-transform:uppercase;color:var(--gold);
  display:inline-block;
}
.eyebrow-num{
  font-family:var(--font-mono);font-size:11px;letter-spacing:2px;
  color:var(--gold);text-transform:uppercase;font-weight:500;
}
.mono{font-family:var(--font-mono)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-sans);font-weight:500;font-size:14px;
  letter-spacing:0.2px;padding:14px 22px;border-radius:var(--r-sharp);
  border:1px solid transparent;transition:all .18s ease;
  white-space:nowrap;cursor:pointer;
}
.btn-arrow{transition:transform .25s ease}
.btn:hover .btn-arrow{transform:translateX(4px)}

.btn-primary{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.btn-primary:hover{background:var(--gold-soft);border-color:var(--gold-soft)}

.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,0.25)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,0.04)}

.btn-light{background:#fff;color:var(--navy);border-color:#fff}
.btn-light:hover{background:var(--cream)}

.btn-lg{padding:18px 28px;font-size:15px}

/* ---------- header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(15,36,64,0.78);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid transparent;
  transition:border-color .25s, background .25s;
}
.site-header.scrolled{
  background:rgba(15,36,64,0.94);
  border-bottom-color:var(--navy-line);
}
.header-inner{
  max-width:1480px;margin:0 auto;padding:18px 32px;
  display:flex;align-items:center;gap:48px;
}
.header-brand{display:flex;align-items:center;gap:14px;text-decoration:none;flex-shrink:0}
.header-mark{width:44px;height:44px;flex-shrink:0;filter:drop-shadow(0 2px 8px rgba(0,0,0,0.25))}
.header-name{
  font-family:var(--font-sans);
  font-weight:700;font-size:19px;color:#fff;
  letter-spacing:-0.4px;line-height:1;
  display:flex;flex-direction:column;gap:3px;
}
.header-name-sub{
  font-family:var(--font-mono);font-size:9px;font-weight:500;
  letter-spacing:2.4px;color:var(--gold);text-transform:uppercase;
}
.nav-links{
  list-style:none;display:flex;gap:4px;margin:0;padding:0;
  margin-left:auto;
}
.nav-links a{
  position:relative;display:inline-flex;align-items:center;
  padding:10px 14px;font-size:14px;font-weight:500;
  color:var(--navy-ink);transition:color .15s;
}
.nav-links a:hover{color:#fff}
.nav-links a.active{color:#fff}
.nav-links a.active::after{
  content:"";position:absolute;left:14px;right:14px;bottom:2px;
  height:1px;background:var(--gold);
}
.header-cta{margin-left:8px}
.hamburger{
  display:none;background:transparent;border:1px solid rgba(255,255,255,0.18);
  color:#fff;padding:10px;border-radius:2px;
}
.mobile-menu{display:none;background:var(--navy-1);border-top:1px solid var(--navy-line)}
.mobile-menu.open{display:block}
.mobile-menu ul{list-style:none;margin:0;padding:8px 24px}
.mobile-menu a{display:block;padding:14px 0;color:var(--navy-ink);border-bottom:1px solid var(--navy-line);font-size:15px}
.mobile-menu a.active{color:#fff}

@media(max-width:1024px){
  .nav-links,.header-cta{display:none}
  .hamburger{display:inline-flex;margin-left:auto}
}

/* ---------- hero (home) ---------- */
.hero{
  position:relative;min-height:100vh;
  background:var(--navy);
  overflow:hidden;
  padding:160px 0 80px;
  display:flex;align-items:center;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 80% 20%, rgba(197,161,87,0.12), transparent 60%),
    radial-gradient(ellipse 60% 50% at 10% 90%, rgba(40,80,127,0.4), transparent 60%);
  pointer-events:none;
}
.hero .chevron-field{position:absolute;inset:0;z-index:0;opacity:0.7}
.hero-content{position:relative;z-index:2;width:100%}
.hero-grid{display:grid;grid-template-columns:1fr 320px;gap:64px;align-items:end}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr;gap:48px}}

.hero-headline{
  display:block;
}
.hero-headline .line{display:block}
.hero-meta{
  font-family:var(--font-mono);font-size:11px;letter-spacing:2.4px;
  color:var(--gold);text-transform:uppercase;
  display:flex;align-items:center;gap:14px;margin-bottom:32px;
}
.hero-meta::before{content:"";width:36px;height:1px;background:var(--gold)}
.hero-sub{margin-top:32px;max-width:54ch;font-size:18px;line-height:1.55;color:var(--navy-ink)}
.hero-actions{display:flex;gap:14px;margin-top:48px;flex-wrap:wrap}

/* hero side index */
.hero-side{
  border-left:1px solid var(--navy-line-2);
  padding-left:32px;
  display:flex;flex-direction:column;gap:24px;
}
.hero-side-label{
  font-family:var(--font-mono);font-size:10px;letter-spacing:2.4px;
  color:var(--gold);text-transform:uppercase;
}
.hero-side-item{
  display:flex;flex-direction:column;gap:4px;
  padding-bottom:18px;border-bottom:1px solid var(--navy-line);
}
.hero-side-item:last-child{border-bottom:0;padding-bottom:0}
.hero-side-num{font-family:var(--font-mono);font-size:11px;color:var(--gold)}
.hero-side-title{font-size:17px;font-weight:600;color:#fff;letter-spacing:-0.2px}
.hero-side-desc{font-size:13px;color:var(--navy-ink-soft);line-height:1.5}

@media(max-width:880px){
  .hero{min-height:auto;padding:140px 0 80px}
  .hero-side{border-left:0;border-top:1px solid var(--navy-line-2);padding-left:0;padding-top:32px}
}

/* ---------- generic page hero (interior pages) ---------- */
.page-hero{
  position:relative;
  padding:160px 0 72px;
  background:var(--navy);
  border-bottom:1px solid var(--navy-line);
  overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 50% at 80% 30%, rgba(197,161,87,0.1), transparent 65%);
}
.page-hero .chevron-field{position:absolute;inset:0;opacity:0.45}
.page-hero-inner{position:relative;z-index:2}
.breadcrumbs{
  font-family:var(--font-mono);font-size:11px;letter-spacing:2px;
  text-transform:uppercase;color:var(--navy-ink-soft);margin-bottom:28px;
}
.breadcrumbs a{color:var(--navy-ink-soft);transition:color .15s}
.breadcrumbs a:hover{color:var(--gold)}
.breadcrumbs .separator{margin:0 12px;color:var(--navy-line-2)}
.breadcrumbs .current{color:var(--gold)}
.page-hero h1{margin-top:18px;max-width:24ch}
.page-sub{margin-top:28px;font-size:18px;line-height:1.55;color:var(--navy-ink);max-width:60ch}

/* ---------- sections ---------- */
.section{padding:64px 0;position:relative}
.section-tight{padding:40px 0}
.section-loose{padding:96px 0}
.section-navy{background:var(--navy)}
.section-navy-1{background:var(--navy-1)}
.section-navy-2{background:var(--navy-2)}
.section-cream{background:var(--cream);color:var(--ink)}
.section-cream h1,.section-cream h2,.section-cream h3,.section-cream h4{color:var(--navy)}
.section-cream .eyebrow{color:var(--gold-deep)}
.section-cream .display-xxl em,.section-cream .display-xl em,.section-cream .display-l em,.section-cream .display-m em{color:var(--gold-deep)}
.section-paper{background:var(--paper);color:var(--ink)}
.section-paper h1,.section-paper h2,.section-paper h3,.section-paper h4{color:var(--navy)}

.section-head{margin-bottom:40px;max-width:780px}
.section-head .eyebrow{margin-bottom:18px}
.section-head h2{margin-bottom:0}

/* ---------- editorial primitives ---------- */
.gold-rule{height:2px;width:48px;background:var(--gold);margin-bottom:24px}
.hairline{height:1px;background:var(--navy-line);width:100%}
.hairline-light{height:1px;background:rgba(0,0,0,0.08)}

.section-number{
  font-family:var(--font-mono);font-size:10px;letter-spacing:3px;
  color:var(--gold);text-transform:uppercase;
}

/* ---------- departments (home) — editorial 3-up split layout ---------- */
.depts{padding:0;background:var(--navy)}
.dept-row{
  display:grid;grid-template-columns:200px 1fr 1fr;
  border-top:1px solid var(--navy-line);
  padding:64px 32px;align-items:start;
  gap:48px;transition:background .3s;
  position:relative;
}
.dept-row:last-child{border-bottom:1px solid var(--navy-line)}
.dept-row:hover{background:var(--navy-1)}
.dept-row::after{
  content:"→";position:absolute;right:32px;top:64px;
  font-size:24px;color:var(--navy-line-2);
  transition:color .25s, transform .25s;
}
.dept-row:hover::after{color:var(--gold);transform:translateX(8px)}
.dept-num{
  font-family:var(--font-display);font-size:64px;line-height:1;
  color:var(--gold);font-style:italic;font-weight:400;
}
.dept-num-sub{
  font-family:var(--font-mono);font-size:10px;letter-spacing:2px;
  color:var(--navy-ink-soft);text-transform:uppercase;margin-top:8px;
}
.dept-title{
  font-family:var(--font-display);font-size:48px;line-height:1.05;
  color:#fff;letter-spacing:-1.5px;margin-bottom:24px;font-weight:400;
}
.dept-tagline{
  font-size:16px;line-height:1.6;color:var(--navy-ink);max-width:36ch;
}
.dept-list{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;
}
.dept-list li{
  font-size:13.5px;color:var(--navy-ink);
  padding-left:14px;position:relative;line-height:1.6;
}
.dept-list li::before{
  content:"";position:absolute;left:0;top:9px;
  width:6px;height:1px;background:var(--gold);
}
@media(max-width:900px){
  .dept-row{grid-template-columns:1fr;padding:48px 0;gap:24px}
  .dept-row::after{display:none}
  .dept-list{grid-template-columns:1fr}
}

/* ---------- big manifesto ---------- */
.manifesto{padding:88px 0}
.manifesto-quote{
  font-family:var(--font-display);font-style:italic;font-weight:400;
  font-size:clamp(36px,5vw,72px);line-height:1.15;letter-spacing:-1.5px;
  color:#fff;max-width:22ch;
}
.manifesto-quote em{color:var(--gold);font-style:italic}
.manifesto-attr{
  margin-top:48px;display:flex;align-items:center;gap:16px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:2px;
  text-transform:uppercase;color:var(--navy-ink-soft);
}
.manifesto-attr::before{content:"";width:48px;height:1px;background:var(--gold)}

/* ---------- index list (used for capabilities, services) ---------- */
.idx-list{list-style:none;padding:0;margin:0}
.idx-row{
  display:grid;grid-template-columns:60px 1fr 2fr;
  gap:32px;align-items:center;
  padding:28px 0;border-top:1px solid var(--navy-line);
  transition:background .25s, padding-left .25s;
  cursor:pointer;
}
.idx-row:last-child{border-bottom:1px solid var(--navy-line)}
.idx-row:hover{background:rgba(255,255,255,0.02);padding-left:12px}
.idx-num{font-family:var(--font-mono);font-size:11px;color:var(--gold);letter-spacing:1px}
.idx-title{font-family:var(--font-sans);font-size:22px;color:#fff;font-weight:500;letter-spacing:-0.4px}
.idx-desc{font-size:14px;color:var(--navy-ink);line-height:1.55}
.idx-arrow{display:none}
.idx-row.cream{border-color:rgba(0,0,0,0.1)}
.section-cream .idx-row .idx-title{color:var(--navy)}
.section-cream .idx-row .idx-desc{color:var(--ink)}
.section-cream .idx-row{border-color:rgba(0,0,0,0.1)}
.section-cream .idx-row:hover{background:rgba(15,36,64,0.03)}


@media(max-width:900px){
  .idx-row{grid-template-columns:40px 1fr;gap:16px}
  .idx-desc{display:none}
}

/* ---------- pull quote ---------- */
.pull-quote{
  font-family:var(--font-display);font-style:italic;
  font-size:clamp(28px,3.5vw,52px);line-height:1.2;
  color:#fff;max-width:24ch;letter-spacing:-1px;
}

/* ---------- stat strip ---------- */
.stat-strip{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--navy-line);
  border-bottom:1px solid var(--navy-line);
}
.stat-cell{
  padding:48px 32px;border-right:1px solid var(--navy-line);
  display:flex;flex-direction:column;gap:8px;
}
.stat-cell:last-child{border-right:0}
.stat-num{
  font-family:var(--font-display);font-size:64px;line-height:1;
  color:#fff;letter-spacing:-2px;font-weight:400;
}
.stat-num em{color:var(--gold);font-style:italic}
.stat-label{
  font-family:var(--font-mono);font-size:10px;letter-spacing:2.4px;
  color:var(--navy-ink-soft);text-transform:uppercase;
}
@media(max-width:900px){
  .stat-strip{grid-template-columns:repeat(2,1fr)}
  .stat-cell:nth-child(2){border-right:0}
  .stat-cell:nth-child(1),.stat-cell:nth-child(2){border-bottom:1px solid var(--navy-line)}
}

/* ---------- vendor strip ---------- */
.vendors{
  padding:48px 0;border-top:1px solid var(--navy-line);
  border-bottom:1px solid var(--navy-line);
  background:var(--navy);
}
.vendor-label{
  font-family:var(--font-mono);font-size:10px;letter-spacing:2.4px;
  text-transform:uppercase;color:var(--gold);text-align:center;margin-bottom:24px;
}
.vendor-row{
  display:flex;justify-content:center;align-items:center;
  flex-wrap:wrap;gap:48px;
}
.vendor-row span{
  font-family:var(--font-sans);font-weight:500;font-size:13px;
  letter-spacing:3px;text-transform:uppercase;color:var(--navy-ink-soft);
  transition:color .2s;
}
.vendor-row span:hover{color:#fff}

/* marquee */
.vendor-marquee{
  position:relative;width:100%;overflow:hidden;
  -webkit-mask-image:linear-gradient(to right,transparent 0,#000 8%,#000 92%,transparent 100%);
          mask-image:linear-gradient(to right,transparent 0,#000 8%,#000 92%,transparent 100%);
}
.vendor-track{
  display:flex;width:max-content;gap:64px;
  animation:vendor-scroll 40s linear infinite;
  will-change:transform;
}
.vendor-track span{
  font-family:var(--font-sans);font-weight:500;font-size:13px;
  letter-spacing:3px;text-transform:uppercase;color:var(--navy-ink-soft);
  white-space:nowrap;flex-shrink:0;
}
@keyframes vendor-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.vendor-marquee:hover .vendor-track{animation-play-state:paused}
@media (prefers-reduced-motion: reduce){
  .vendor-track{animation:none}
}

/* ---------- service cluster (infrastructure) ---------- */
.cluster{
  display:grid;grid-template-columns:1fr 1.4fr;gap:64px;
  padding:64px 0;border-top:1px solid var(--navy-line);
  align-items:start;
}
.cluster:first-child{border-top:0;padding-top:0}
.cluster-side{position:sticky;top:120px}
.cluster-side .gold-rule{margin-bottom:18px}
.cluster-num{
  font-family:var(--font-display);font-style:italic;font-size:14px;
  color:var(--gold);margin-bottom:8px;font-weight:400;
}
.cluster-title{
  font-family:var(--font-display);font-size:48px;line-height:1.05;
  color:#fff;letter-spacing:-1.5px;font-weight:400;margin-bottom:20px;
}
.cluster-lede{font-size:15.5px;color:var(--navy-ink);line-height:1.65;max-width:38ch}
.cluster-items{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--navy-line)}
.cluster-item{
  background:var(--navy);padding:28px;
  display:flex;flex-direction:column;gap:8px;
  transition:background .2s;
}
.cluster-item:hover{background:var(--navy-1)}
.cluster-item-title{font-size:15px;font-weight:600;color:#fff;letter-spacing:-0.2px}
.cluster-item-desc{font-size:13px;color:var(--navy-ink-soft);line-height:1.55}
.cluster-vendors{
  margin-top:32px;padding-top:24px;border-top:1px solid var(--navy-line);
  display:flex;flex-wrap:wrap;gap:8px;
}
.vendor-pill{
  font-family:var(--font-mono);font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--gold);
  border:1px solid var(--navy-line-2);padding:5px 10px;border-radius:2px;
}
@media(max-width:1000px){
  .cluster{grid-template-columns:1fr;gap:32px}
  .cluster-side{position:static}
  .cluster-items{grid-template-columns:1fr}
}

/* ---------- pill nav (sticky anchor) ---------- */
.pill-nav-wrap{
  position:sticky;top:78px;z-index:30;
  background:rgba(15,36,64,0.92);backdrop-filter:blur(12px);
  border-top:1px solid var(--navy-line);
  border-bottom:1px solid var(--navy-line);
}
.pill-nav{
  display:flex;gap:0;overflow-x:auto;padding:14px 0;
  scrollbar-width:none;
}
.pill-nav::-webkit-scrollbar{display:none}
.pill-nav a{
  flex-shrink:0;padding:8px 18px;font-size:13px;font-weight:500;
  color:var(--navy-ink);transition:all .2s;
  font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1.5px;font-size:11px;
  border-right:1px solid var(--navy-line);
}
.pill-nav a:first-child{padding-left:0}
.pill-nav a:last-child{border-right:0}
.pill-nav a:hover{color:#fff}
.pill-nav a.active{color:var(--gold)}

/* ---------- agent / product cards (apps & ai) ---------- */
.agent-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--navy-line)}
.agent{
  background:var(--navy-1);padding:36px 32px;min-height:280px;
  display:flex;flex-direction:column;gap:18px;
  transition:background .25s;position:relative;
}
.agent:hover{background:var(--navy-2)}
.agent-glyph{
  width:44px;height:44px;border:1px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);font-family:var(--font-display);font-size:22px;
  font-style:italic;border-radius:2px;
}
.agent-name{font-family:var(--font-display);font-size:28px;font-weight:400;color:#fff;letter-spacing:-0.5px;line-height:1.1}
.agent-domain{font-family:var(--font-mono);font-size:10px;letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-top:-12px}
.agent-desc{font-size:14px;color:var(--navy-ink);line-height:1.6;margin-top:auto}
.agent-tag{
  display:inline-block;font-family:var(--font-mono);font-size:9.5px;
  letter-spacing:1.5px;color:var(--navy-ink-soft);text-transform:uppercase;
  padding-top:14px;border-top:1px solid var(--navy-line);
}
@media(max-width:900px){.agent-grid{grid-template-columns:1fr}}

/* ---------- contact form ---------- */
.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:80px}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:48px}}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.form-group{display:flex;flex-direction:column;gap:8px}
.form-group.full{grid-column:1/-1}
.form-label{
  font-family:var(--font-mono);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:var(--gold);font-weight:500;
}
.input{
  background:transparent;border:0;border-bottom:1px solid var(--navy-line-2);
  color:#fff;font-family:var(--font-sans);font-size:15px;
  padding:10px 0;transition:border-color .15s;
}
.input::placeholder{color:var(--navy-ink-soft)}
.input:focus{outline:0;border-bottom-color:var(--gold)}
textarea.input{min-height:120px;border:1px solid var(--navy-line-2);padding:14px;border-radius:2px;resize:vertical}
textarea.input:focus{border-color:var(--gold)}
select.input{border:1px solid var(--navy-line-2);padding:12px 14px;border-radius:2px;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--gold) 50%),linear-gradient(135deg,var(--gold) 50%,transparent 50%);background-position:calc(100% - 16px) center,calc(100% - 11px) center;background-size:5px 5px,5px 5px;background-repeat:no-repeat}
select.input option,select.input optgroup{background:var(--navy-1);color:#fff}
.form-helper{font-size:12px;color:var(--navy-ink-soft)}
.check-row{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--navy-ink)}
.check-row input{accent-color:var(--gold)}

.alert{display:flex;gap:14px;padding:20px 24px;border:1px solid;border-radius:2px}
.alert-success{background:rgba(46,125,50,0.12);border-color:rgba(46,125,50,0.5);color:#A5D6A7}
.alert-success .alert-title{font-weight:600;color:#fff;font-size:15px}
.alert-success .alert-body{color:var(--navy-ink);font-size:13.5px;margin-top:4px;line-height:1.6}
.alert-icon{width:20px;height:20px;flex-shrink:0;margin-top:2px;color:#A5D6A7}

/* ---------- footer ---------- */
.site-footer{
  background:var(--navy-deeper, #0A1A30);background:#0A1A30;
  color:var(--navy-ink);
  border-top:1px solid var(--navy-line);
  padding:64px 0 32px;
}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:64px}
@media(max-width:900px){.footer-top{grid-template-columns:1fr 1fr;gap:32px}}
.footer-brand-block{display:flex;flex-direction:column;gap:18px;max-width:32ch}
.footer-logo{display:flex;align-items:center;gap:14px}
.footer-logo svg{width:48px;height:48px}
.footer-logo span{font-weight:700;color:#fff;font-size:20px;letter-spacing:-0.4px}
.footer-tag{font-size:14px;color:var(--navy-ink);line-height:1.6}
.footer-addr{font-family:var(--font-mono);font-size:10px;letter-spacing:2.4px;color:var(--gold);text-transform:uppercase}
.footer-col-title{
  font-family:var(--font-mono);font-size:10px;letter-spacing:2.4px;
  text-transform:uppercase;color:var(--gold);margin-bottom:18px;
}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.footer-col a{font-size:14px;color:var(--navy-ink);transition:color .15s}
.footer-col a:hover{color:#fff}

.footer-affil{
  display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap;
  border-top:1px solid var(--navy-line);padding-top:32px;
}
.footer-affil-block{display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.footer-affil-row{display:flex;align-items:center;gap:14px}
.footer-affil-logo{height:44px;width:auto;display:block;background:transparent;padding:0;object-fit:contain;flex-shrink:0}
.footer-affil-label{font-family:var(--font-mono);font-size:10px;letter-spacing:2px;color:var(--navy-ink-soft);text-transform:uppercase}
.footer-affil-name{font-family:var(--font-display);font-size:22px;color:#fff;font-weight:400;letter-spacing:-0.5px;white-space:nowrap}
.footer-affil-sub{font-size:12px;color:var(--navy-ink-soft)}

.footer-bottom{
  margin-top:32px;padding-top:24px;border-top:1px solid var(--navy-line);
  font-size:12px;color:var(--navy-ink-soft);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
}
.footer-bottom-right{display:inline-flex;align-items:center;gap:18px}
.footer-social{display:inline-flex;align-items:center;gap:8px;color:var(--navy-ink-soft);text-decoration:none;transition:color .2s}
.footer-social:hover{color:var(--gold)}
.footer-social svg{display:block}
.footer-social-label{font-size:12px;letter-spacing:.2px}

/* ---------- CTA full-bleed ---------- */
.cta-section{
  position:relative;padding:96px 0;
  background:var(--navy-1);
  border-top:1px solid var(--navy-line);
  border-bottom:1px solid var(--navy-line);
  overflow:hidden;
  text-align:center;
}
.cta-section .chevron-field{position:absolute;inset:0;opacity:0.3}
.cta-section .container{position:relative;z-index:2}
.cta-section h2{font-family:var(--font-display);font-size:clamp(40px,5vw,72px);line-height:1.05;letter-spacing:-1.5px;color:#fff;font-weight:400;max-width:18ch;margin:0 auto 24px}
.cta-section h2 em{color:var(--gold);font-style:italic}
.cta-section p{font-size:17px;color:var(--navy-ink);max-width:50ch;margin:0 auto 40px;line-height:1.55}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation:none !important}
}

/* ---------- hero variant tweak ---------- */
[data-hero-variant="solid"] .hero .chevron-field,
[data-hero-variant="placeholder"] .hero .chevron-field{display:none}
[data-hero-variant="placeholder"] .hero::after{
  content:"PHOTO PLACEHOLDER · Saudi industrial / corporate imagery";
  position:absolute;right:32px;bottom:32px;z-index:4;
  font-family:var(--font-mono);font-size:10px;letter-spacing:2px;
  color:rgba(197,161,87,0.7);text-transform:uppercase;
  border:1px dashed rgba(197,161,87,0.35);padding:8px 14px;
}

/* ---------- accent strength tweak ---------- */
[data-accent="bold"]{--gold:#D6B05F}
[data-accent="subtle"]{--gold:#B59852}

/* ---------- density tweak ---------- */
[data-density="compact"] .section{padding:44px 0}
[data-density="compact"] .section-loose{padding:64px 0}
[data-density="generous"] .section{padding:104px 0}
[data-density="generous"] .section-loose{padding:140px 0}

/* ---------- focus ---------- */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
