/* ============================================================================
   PyramidsX — Design System v2  •  "The logo, brought to life at scale"
   Display: Fraunces (semi-serif, architectural)  •  Body/UI: Poppins
   Dual theme: dark hero/CTA (gold + circuitry) ⟷ light content (navy + gold lines)
   ----------------------------------------------------------------------------
   ▼▼▼  BRAND CONFIG  ▼▼▼
   ========================================================================== */
:root {
  --brand-primary:   #D4A017;   /* PyramidsX gold */
  --brand-primary-2: #F0C24A;   /* light gold */
  --brand-gold:      #D4A017;
  --brand-gold-deep: #B8860B;

  --navy:        #0B132B;   /* deep navy */
  --navy-2:      #111827;   /* slate */
  --ink:         #0B132B;   /* primary heading on light */
  --paper:       #F6F4EC;   /* warm off-white content surface */
  --paper-2:     #FFFFFF;   /* card white */
  --gray:        #5B6473;   /* body on light */

  /* theme tokens (default = DARK) */
  --bg:          #0B132B;
  --bg-soft:     #0E1730;
  --surface:     rgba(255,255,255,0.045);
  --surface-2:   rgba(255,255,255,0.08);
  --border:      rgba(212,160,23,0.18);
  --border-2:    rgba(212,160,23,0.40);
  --text:        #EEF1F8;
  --text-dim:    #A6B0C3;
  --text-faint:  #6B7280;
  --heading:     #F4F1E8;
  --shadow:      0 24px 60px -28px rgba(0,0,0,0.7);
  --primary-soft: rgba(212,160,23,0.14);

  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body: 'Poppins', ui-sans-serif, system-ui, -apple-system, sans-serif;

  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px; --s-10:128px;
  --maxw: 1240px;
  --radius: 14px; --radius-lg: 22px; --radius-pill: 999px;
  --ease: cubic-bezier(0.22,1,0.36,1);
  --ease-out: cubic-bezier(0.16,1,0.3,1);
  --dur: 360ms;
  --nav-h: 78px;
}

/* LIGHT section: flip the theme tokens; components re-skin automatically */
.theme-light {
  --bg: var(--paper);
  --bg-soft: #EFEDE3;
  --surface: var(--paper-2);
  --surface-2: #FFFFFF;
  --border: rgba(11,19,43,0.10);
  --border-2: rgba(212,160,23,0.55);
  --text: #2A3140;
  --text-dim: #5B6473;
  --text-faint: #8A93A3;
  --heading: var(--ink);
  --shadow: 0 24px 60px -30px rgba(11,19,43,0.28);
  --primary-soft: rgba(212,160,23,0.12);
  background: var(--bg);
  color: var(--text);
}

/* ============================ RESET ============================ */
*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body {
  font-family: var(--font-body); background: var(--navy); color: var(--text);
  line-height: 1.6; font-size: 16px; -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility; overflow-x: hidden; min-height: 100dvh;
}
img,svg,canvas { display:block; max-width:100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
:focus-visible { outline: 2px solid var(--brand-primary); outline-offset: 3px; border-radius: 6px; }
::selection { background: rgba(212,160,23,0.3); color: #fff; }

/* ============================ ATMOSPHERE (dark) ============================ */
.bg-grid { position: fixed; inset:0; z-index:-3; pointer-events:none;
  background-image: linear-gradient(rgba(212,160,23,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(212,160,23,0.05) 1px,transparent 1px);
  background-size: 66px 66px; mask-image: radial-gradient(ellipse 80% 55% at 50% 0%,#000 30%,transparent 80%); -webkit-mask-image: radial-gradient(ellipse 80% 55% at 50% 0%,#000 30%,transparent 80%); }
.bg-glow { position: fixed; inset:0; z-index:-4; pointer-events:none;
  background: radial-gradient(45% 38% at 78% 6%, rgba(42,60,102,0.5), transparent 70%),
              radial-gradient(40% 36% at 16% 14%, rgba(212,160,23,0.14), transparent 70%),
              radial-gradient(45% 45% at 50% 108%, rgba(212,160,23,0.08), transparent 70%); }

/* ============================ CURSOR GLOW ============================ */
.cursor-glow { position: fixed; top:0; left:0; width: 380px; height: 380px; border-radius:50%; z-index: 5; pointer-events:none;
  transform: translate(-50%,-50%); opacity:0; transition: opacity .4s; mix-blend-mode: screen;
  background: radial-gradient(circle, rgba(212,160,23,0.16), transparent 62%); }
@media (hover:hover) and (pointer:fine){ body:hover .cursor-glow{ opacity:1; } }

/* ============================ PAGE TRANSITION ============================ */
.page-fade { position: fixed; inset:0; z-index: 9999; pointer-events:none; background: var(--navy);
  opacity:0; transition: opacity .42s var(--ease); }
.page-fade.show { opacity:1; pointer-events:all; }
.page-fade .pf-mark { position:absolute; inset:0; display:grid; place-items:center; opacity:0; transition: opacity .3s; }
.page-fade.show .pf-mark { opacity:1; }
.page-fade .pf-mark img { width: 86px; filter: drop-shadow(0 0 22px rgba(212,160,23,0.5)); animation: pfpulse 1s var(--ease) infinite; }
@keyframes pfpulse { 0%,100%{ transform: scale(1); opacity:.8 } 50%{ transform: scale(1.08); opacity:1 } }

/* ============================ LAYOUT ============================ */
.container { width:100%; max-width: var(--maxw); margin-inline:auto; padding-inline: clamp(20px,5vw,44px); }
.section { position: relative; padding-block: clamp(64px,10vw,128px); }
.section--soft { background: var(--bg-soft); }
.section--tight { padding-block: clamp(44px,7vw,80px); }
.theme-light.section, .theme-light { background: var(--paper); }
.theme-light.section--soft { background: var(--bg-soft); }

.eyebrow { display:inline-flex; align-items:center; gap: var(--s-2); font-family: var(--font-body); font-size: 12px; font-weight:600;
  letter-spacing: .26em; text-transform: uppercase; color: var(--brand-gold-deep);
  padding: 7px 14px 7px 12px; border:1px solid var(--border); border-radius: var(--radius-pill); background: var(--primary-soft); margin-bottom: var(--s-5); }
.theme-light .eyebrow { color: var(--brand-gold-deep); }
.eyebrow::before { content:""; width:6px; height:6px; border-radius:50%; background: var(--brand-primary); box-shadow:0 0 10px var(--brand-primary); }

h1,h2,h3,h4 { font-family: var(--font-display); font-optical-sizing:auto; font-weight:600; line-height:1.04; letter-spacing:-0.015em; color: var(--heading); }
.h1 { font-size: clamp(2.6rem,6.8vw,5rem); font-weight:600; }
.h2 { font-size: clamp(2rem,4.6vw,3.4rem); }
.h3 { font-size: clamp(1.3rem,2.4vw,1.7rem); font-weight:600; }
.lead { font-size: clamp(1.06rem,1.55vw,1.32rem); color: var(--text-dim); max-width: 60ch; line-height:1.6; }
.muted { color: var(--text-dim); }
.section-head { max-width: 66ch; margin-bottom: var(--s-8); }
.center { text-align:center; margin-inline:auto; }
.gold-text { color: var(--brand-primary); }
.grad-text { background: linear-gradient(100deg,var(--brand-primary),var(--brand-primary-2) 45%,#FBE2A3); -webkit-background-clip:text; background-clip:text; color:transparent; }
.serif-em { font-family: var(--font-display); font-style: italic; font-weight: 500; color: var(--brand-primary); }
.rule-gold { width: 64px; height:2px; border:0; background: linear-gradient(90deg,var(--brand-primary),transparent); margin: var(--s-5) 0; }
.center .rule-gold { margin-inline:auto; background: linear-gradient(90deg,transparent,var(--brand-primary),transparent); }

/* ============================ BUTTONS ============================ */
.btn { position:relative; display:inline-flex; align-items:center; justify-content:center; gap: var(--s-2);
  font-family: var(--font-body); font-weight:600; font-size:.92rem; letter-spacing:.01em;
  padding: 14px 26px; min-height:50px; border-radius: var(--radius-pill); border:1px solid transparent;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), background .3s, color .3s; overflow:hidden; will-change: transform; }
.btn svg { width:18px; height:18px; position:relative; z-index:1; }
.btn span,.btn { z-index:1; }
.btn--primary { color:#1a1304; background: linear-gradient(120deg,var(--brand-primary),var(--brand-primary-2));
  box-shadow: 0 10px 34px -10px rgba(212,160,23,0.6), inset 0 0 0 1px rgba(255,255,255,0.22); }
.btn--primary:hover { transform: translateY(-2px); box-shadow: 0 18px 46px -12px rgba(212,160,23,0.8); }
.btn--ghost { color: var(--text); background: var(--surface); border-color: var(--border); backdrop-filter: blur(8px); }
.btn--ghost:hover { transform: translateY(-2px); border-color: var(--border-2); background: var(--surface-2); }
.btn--lg { padding: 17px 34px; min-height:58px; font-size:1rem; }
.btn .ripple { position:absolute; border-radius:50%; transform: translate(-50%,-50%) scale(0); background: rgba(255,255,255,0.35); pointer-events:none; z-index:0; animation: ripple .6s var(--ease-out); }
@keyframes ripple { to { transform: translate(-50%,-50%) scale(7); opacity:0; } }
.link-arrow { display:inline-flex; align-items:center; gap:8px; color: var(--brand-gold-deep); font-weight:600; }
.theme-light .link-arrow{ color: var(--brand-gold-deep); }
.link-arrow svg{ width:18px;height:18px; transition: transform .35s var(--ease); }
.link-arrow:hover svg{ transform: translateX(5px); }

/* ============================ GLASS / CARD ============================ */
.glass { position:relative; background: var(--surface); border:1px solid var(--border); border-radius: var(--radius-lg); backdrop-filter: blur(14px); overflow:hidden; }
.theme-light .glass { backdrop-filter:none; box-shadow: var(--shadow); }
.glass::before { content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none; background: linear-gradient(160deg, rgba(255,255,255,0.08), transparent 42%); }
.theme-light .glass::before { background: linear-gradient(160deg, rgba(212,160,23,0.06), transparent 40%); }
.card { padding: var(--s-6); transition: transform .45s var(--ease), border-color .4s, box-shadow .4s, background .4s; }
.card:hover { transform: translateY(-6px); border-color: var(--border-2); box-shadow: 0 26px 60px -26px rgba(212,160,23,0.35); }
.card__icon { width:56px; height:56px; border-radius:15px; display:grid; place-items:center; background: var(--primary-soft); border:1px solid var(--border); color: var(--brand-primary); margin-bottom: var(--s-5); transition: transform .45s var(--ease); }
.card:hover .card__icon { transform: scale(1.08) rotate(-3deg); }
.card__icon svg { width:27px; height:27px; }
.card h3 { margin-bottom: var(--s-3); }
.card p { color: var(--text-dim); font-size:.98rem; }

.grid { display:grid; gap: var(--s-5); }
.grid-2 { grid-template-columns: repeat(2,1fr); }
.grid-3 { grid-template-columns: repeat(3,1fr); }
.grid-4 { grid-template-columns: repeat(4,1fr); }
@media (max-width:900px){ .grid-3,.grid-4{ grid-template-columns: repeat(2,1fr);} }
@media (max-width:600px){ .grid-2,.grid-3,.grid-4{ grid-template-columns: 1fr;} }

/* ============================ NAV ============================ */
.nav { position: fixed; top:0; left:0; right:0; z-index:100; height: var(--nav-h); display:flex; align-items:center; transition: background .4s, border-color .4s, backdrop-filter .4s; border-bottom:1px solid transparent; }
.nav.is-scrolled { background: rgba(11,19,43,0.78); border-bottom-color: rgba(212,160,23,0.16); backdrop-filter: blur(16px) saturate(140%); }
.nav__inner { width:100%; max-width: var(--maxw); margin-inline:auto; padding-inline: clamp(20px,5vw,44px); display:flex; align-items:center; justify-content:space-between; gap: var(--s-5); }
.brand { display:inline-flex; align-items:center; gap: var(--s-3); font-family: var(--font-display); font-weight:600; font-size:1.18rem; letter-spacing:.01em; color: var(--text); }
.brand__mark { height: 38px; width:auto; filter: drop-shadow(0 0 10px rgba(212,160,23,0.4)); }
.brand b { color: var(--brand-primary); }
.brand .tld { color: var(--text-dim); font-weight:500; font-size:.6em; align-self:flex-end; margin-left:1px; }
.nav__links { display:flex; align-items:center; gap: 2px; }
.nav__links a { font-family: var(--font-body); font-size:.95rem; font-weight:500; color: var(--text-dim); padding: 9px 13px; border-radius:10px; transition: color .3s, background .3s; }
.nav__links a:hover { color: var(--text); }
.nav__links a.is-active { color: var(--brand-primary); }
.nav__right { display:flex; align-items:center; gap: var(--s-3); }
.lang-toggle { font-family: var(--font-body); font-weight:600; font-size:.9rem; color: var(--text); background: var(--surface); border:1px solid var(--border); border-radius: var(--radius-pill); padding: 8px 14px; min-height:42px; transition: border-color .3s, background .3s; }
.lang-toggle:hover { border-color: var(--border-2); }
.nav__toggle { display:none; width:46px; height:46px; border:1px solid var(--border); border-radius:12px; background: var(--surface); color: var(--text); align-items:center; justify-content:center; }
.nav__toggle svg { width:22px; height:22px; }
.nav__drawer { position: fixed; inset: var(--nav-h) 0 auto 0; z-index:99; background: rgba(11,19,43,0.97); backdrop-filter: blur(20px); border-bottom:1px solid var(--border); padding: var(--s-5) clamp(20px,5vw,44px) var(--s-7); display:none; flex-direction:column; gap: 6px; transform: translateY(-12px); opacity:0; transition: transform .4s var(--ease), opacity .4s; }
.nav__drawer.is-open { display:flex; transform:none; opacity:1; }
.nav__drawer a { padding: 14px 12px; border-radius:12px; color: var(--text); font-size:1.05rem; border:1px solid transparent; }
.nav__drawer a:hover,.nav__drawer a.is-active { background: var(--surface); border-color: var(--border); }
.nav__drawer .btn { margin-top: var(--s-3); }
@media (max-width:980px){ .nav__links, .nav__right .btn--cta-text { display:none; } }
@media (max-width:980px){ .nav__toggle{ display:inline-flex; } }

/* ============================ HERO ============================ */
.hero { position: relative; min-height: 100svh; display:flex; align-items:center; padding-top: var(--nav-h); overflow:hidden; }
#pyramid-canvas { position: fixed; inset:0; z-index:-2; width:100%; height:100%; pointer-events:none; }
.hero__inner { position:relative; z-index:2; max-width: 66ch; padding-block: var(--s-9); }
.hero .h1 { margin-bottom: var(--s-5); }
.hero__sub { margin-bottom: var(--s-7); }
.hero__cta { display:flex; flex-wrap:wrap; gap: var(--s-4); }
.hero__scroll { position:absolute; bottom: 26px; left:50%; transform: translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap: var(--s-2); color: var(--text-faint); font-size:11px; letter-spacing:.2em; text-transform:uppercase; }
.hero__scroll .mouse { width:24px; height:38px; border:1.5px solid var(--border-2); border-radius:14px; position:relative; }
.hero__scroll .mouse::after { content:""; position:absolute; top:7px; left:50%; width:3px; height:7px; background: var(--brand-primary); border-radius:2px; transform:translateX(-50%); animation: wheel 1.8s var(--ease) infinite; }
@keyframes wheel { 0%{opacity:0;transform:translate(-50%,0)} 30%{opacity:1} 100%{opacity:0;transform:translate(-50%,12px)} }
.pyramid-lite { position: fixed; inset:0; z-index:-2; pointer-events:none; display:grid; place-items:center; overflow:hidden; }
.pyramid-lite svg { width:min(90vw,720px); opacity:.45; filter: drop-shadow(0 0 40px rgba(212,160,23,0.25)); animation: floaty 9s ease-in-out infinite; }
@keyframes floaty { 0%,100%{transform:translateY(0) rotate(0)} 50%{transform:translateY(-16px) rotate(.5deg)} }
.circuit-bg { position:absolute; inset:0; z-index:0; pointer-events:none; }
.has-circuit > *:not(.circuit-bg){ position: relative; z-index:1; }

/* ============================ STATS ============================ */
.stats { display:grid; grid-template-columns: repeat(4,1fr); gap: var(--s-5); }
@media (max-width:700px){ .stats{ grid-template-columns: repeat(2,1fr);} }
.stat { padding: var(--s-6) var(--s-5); text-align:center; }
.stat__num { font-family: var(--font-display); font-weight:600; font-size: clamp(2.1rem,4vw,3rem); line-height:1; background: linear-gradient(120deg,var(--brand-primary),var(--brand-primary-2)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat__label { color: var(--text-dim); font-size:.9rem; margin-top: var(--s-3); letter-spacing:.03em; }

.trust { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap: clamp(22px,5vw,54px); opacity:.62; }
.trust span { font-family: var(--font-display); font-weight:500; letter-spacing:.06em; color: var(--text-dim); font-size:1.05rem; }

/* ============================ SERVICES ============================ */
.services { display:grid; grid-template-columns: repeat(3,1fr); gap: var(--s-5); }
@media (max-width:900px){ .services{ grid-template-columns: repeat(2,1fr);} }
@media (max-width:600px){ .services{ grid-template-columns:1fr; } }
.svc { padding: var(--s-6); display:flex; flex-direction:column; }
.svc--featured { grid-column: span 2; grid-row: span 1; background: linear-gradient(135deg, rgba(212,160,23,0.12), var(--surface) 60%); }
.theme-light .svc--featured { background: linear-gradient(135deg, #FFF8E7, #fff 60%); }
@media (max-width:900px){ .svc--featured{ grid-column: span 2; } }
@media (max-width:600px){ .svc--featured{ grid-column: span 1; } }
.svc__tag { font-size:11px; letter-spacing:.14em; text-transform:uppercase; color: var(--brand-gold-deep); font-weight:600; margin-bottom: var(--s-3); }
.svc .link-arrow { margin-top: auto; padding-top: var(--s-5); opacity:.0; transform: translateY(6px); transition: opacity .4s, transform .4s; }
.svc:hover .link-arrow { opacity:1; transform:none; }
@media (hover:none){ .svc .link-arrow{ opacity:1; transform:none; } }

/* ============================ PORTFOLIO ============================ */
.filterbar { display:flex; flex-wrap:wrap; gap: var(--s-2); margin-bottom: var(--s-7); }
.filter-btn { font-family: var(--font-body); font-weight:500; font-size:.92rem; color: var(--text-dim); background: var(--surface); border:1px solid var(--border); border-radius: var(--radius-pill); padding: 9px 18px; transition: all .3s; }
.filter-btn:hover { color: var(--text); border-color: var(--border-2); }
.filter-btn.is-active { color:#1a1304; background: var(--brand-primary); border-color: var(--brand-primary); }
.pgrid { display:grid; grid-template-columns: repeat(3,1fr); gap: var(--s-5); }
@media (max-width:900px){ .pgrid{ grid-template-columns: repeat(2,1fr);} }
@media (max-width:600px){ .pgrid{ grid-template-columns:1fr; } }
.pcard { position:relative; border-radius: var(--radius-lg); overflow:hidden; aspect-ratio: 4/3.4; border:1px solid var(--border); transition: transform .4s var(--ease); }
.pcard__media { position:absolute; inset:0; background: linear-gradient(135deg,var(--navy-2),#1a2748); display:grid; place-items:center; }
.pcard__media svg { width: 84px; opacity:.5; }
.pcard__cat { position:absolute; top:14px; left:14px; z-index:2; font-size:11px; letter-spacing:.1em; text-transform:uppercase; padding:6px 12px; border-radius:var(--radius-pill); background: rgba(11,19,43,0.66); border:1px solid var(--border); color: var(--brand-primary); }
.pcard__overlay { position:absolute; inset:0; z-index:3; background: linear-gradient(0deg, rgba(11,19,43,0.96) 10%, rgba(11,19,43,0.5) 60%, transparent); display:flex; flex-direction:column; justify-content:flex-end; padding: var(--s-6); opacity:0; transform: translateY(10px); transition: opacity .4s, transform .4s; }
.pcard:hover .pcard__overlay { opacity:1; transform:none; }
.pcard:hover { transform: translateY(-6px); }
.pcard__overlay h3 { color:#fff; font-size:1.25rem; margin-bottom: var(--s-2); }
.pcard__overlay p { color: #cdd5e6; font-size:.92rem; margin-bottom: var(--s-4); }
@media (hover:none){ .pcard__overlay{ opacity:1; transform:none; background: linear-gradient(0deg, rgba(11,19,43,0.96) 30%, transparent); } }

/* ============================ BLOG ============================ */
.feat-post { display:grid; grid-template-columns: 1.15fr 1fr; gap: 0; border-radius: var(--radius-lg); overflow:hidden; border:1px solid var(--border); }
@media (max-width:820px){ .feat-post{ grid-template-columns:1fr; } }
.feat-post__media { min-height: 320px; background: linear-gradient(135deg,var(--navy-2),#1c2a4d); display:grid; place-items:center; }
.feat-post__media svg{ width:90px; opacity:.5; }
.feat-post__body { padding: clamp(28px,4vw,48px); display:flex; flex-direction:column; justify-content:center; background: var(--surface); }
.post-meta { display:flex; gap: var(--s-3); align-items:center; font-size:.82rem; color: var(--text-faint); margin-top: var(--s-3); }
.post-cat { font-size:11px; letter-spacing:.1em; text-transform:uppercase; color: var(--brand-gold-deep); font-weight:600; }
.bcard { overflow:hidden; }
.bcard__media { aspect-ratio:16/9; background: linear-gradient(135deg,var(--navy-2),#1a2748); display:grid; place-items:center; }
.bcard__media svg{ width:60px; opacity:.45; }
.bcard__body { padding: var(--s-5); }
.bcard__body h3 { font-size:1.15rem; margin: var(--s-2) 0; }

/* ============================ SPLIT / VALUES ============================ */
.split { display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(32px,6vw,72px); align-items:center; }
@media (max-width:860px){ .split{ grid-template-columns:1fr; } }
.checklist { list-style:none; padding:0; display:grid; gap: var(--s-4); margin-top: var(--s-6); }
.checklist li { display:flex; gap: var(--s-3); align-items:flex-start; color: var(--text-dim); }
.checklist svg { width:22px; height:22px; color: var(--brand-primary); flex:none; margin-top:2px; }
.checklist b { color: var(--text); font-weight:600; }
.steps { display:grid; gap: var(--s-5); grid-template-columns: repeat(4,1fr); }
@media (max-width:900px){ .steps{ grid-template-columns: repeat(2,1fr);} }
@media (max-width:560px){ .steps{ grid-template-columns:1fr; } }
.step { padding: var(--s-6); }
.step__n { font-family: var(--font-display); font-weight:600; font-size:1.5rem; color: var(--brand-primary); display:block; margin-bottom: var(--s-3); }
.step h3 { font-size:1.15rem; margin-bottom: var(--s-3); }
.step p { color: var(--text-dim); font-size:.95rem; }

/* ============================ CONTACT ============================ */
.channels { display:grid; gap: var(--s-4); }
.channel { display:flex; gap: var(--s-4); align-items:center; padding: var(--s-5); transition: transform .35s var(--ease), border-color .35s; }
.channel:hover { transform: translateX(4px); border-color: var(--border-2); }
.channel__ic { width:48px; height:48px; border-radius:13px; background: var(--primary-soft); border:1px solid var(--border); display:grid; place-items:center; color: var(--brand-primary); flex:none; }
.channel__ic svg{ width:22px; height:22px; }
.channel .l { font-size:.78rem; text-transform:uppercase; letter-spacing:.1em; color: var(--text-faint); }
.channel .v { color: var(--text); font-weight:500; }
.map-embed { border-radius: var(--radius-lg); overflow:hidden; border:1px solid var(--border); min-height: 320px; }
.map-embed iframe { width:100%; height:100%; min-height:320px; border:0; filter: grayscale(.3) contrast(1.05); }

/* ============================ FORM ============================ */
.form { display:grid; gap: var(--s-5); }
.field { display:grid; gap: var(--s-2); }
.field label { font-size:.9rem; font-weight:600; color: var(--text); }
.field .req { color: var(--brand-primary); }
.field input,.field textarea,.field select { font:inherit; color: var(--text); background: var(--surface); border:1px solid var(--border); border-radius:12px; padding: 14px 16px; min-height:52px; transition: border-color .3s, box-shadow .3s, background .3s; }
.theme-light .field input,.theme-light .field textarea,.theme-light .field select { background:#fff; }
.field textarea { min-height:140px; resize:vertical; }
.field input::placeholder,.field textarea::placeholder { color: var(--text-faint); }
.field input:focus,.field textarea:focus,.field select:focus { outline:none; border-color: var(--brand-primary); box-shadow: 0 0 0 3px var(--primary-soft); }
.field--row { display:grid; grid-template-columns:1fr 1fr; gap: var(--s-5); }
@media (max-width:560px){ .field--row{ grid-template-columns:1fr; } }
.field .help { font-size:.82rem; color: var(--text-faint); }
.field .error { font-size:.82rem; color:#ff8a8a; display:none; }
.field.is-invalid input,.field.is-invalid textarea,.field.is-invalid select { border-color:#ff8a8a; box-shadow:0 0 0 3px rgba(255,122,122,0.15); }
.field.is-invalid .error { display:block; }
.checks { display:grid; grid-template-columns: 1fr 1fr; gap: var(--s-3); }
@media (max-width:560px){ .checks{ grid-template-columns:1fr; } }
.check { display:flex; align-items:center; gap: var(--s-3); padding: 12px 14px; border:1px solid var(--border); border-radius:12px; cursor:pointer; transition: border-color .3s, background .3s; color: var(--text-dim); font-size:.95rem; }
.check:hover { border-color: var(--border-2); }
.check input { width:18px; height:18px; accent-color: var(--brand-primary); }
.check:has(input:checked) { border-color: var(--brand-primary); background: var(--primary-soft); color: var(--text); }
.form__status { font-size:.95rem; padding:14px 16px; border-radius:12px; display:none; }
.form__status.is-ok { display:block; background: rgba(52,211,153,0.12); border:1px solid rgba(52,211,153,0.4); color:#6ee7b7; }
.form__status.is-err { display:block; background: rgba(255,122,122,0.12); border:1px solid rgba(255,122,122,0.4); color:#ff9a9a; }
.form__status.is-err a { color:#ffc7c7; text-decoration:underline; }

/* ============================ CTA + TESTIMONIAL ============================ */
.cta-banner { position:relative; text-align:center; padding: clamp(48px,8vw,92px); border-radius: var(--radius-lg); overflow:hidden; background: var(--surface); border:1px solid var(--border); }
.cta-banner::after { content:""; position:absolute; inset:0; z-index:-1; background: radial-gradient(60% 100% at 50% 0%, var(--primary-soft), transparent 70%), radial-gradient(50% 100% at 50% 120%, rgba(212,160,23,0.1), transparent 70%); }
.cta-banner .h2 { margin-bottom: var(--s-5); }
.cta-banner .hero__cta { justify-content:center; }
.quote-box { padding: clamp(32px,6vw,64px); text-align:center; max-width: 900px; margin-inline:auto; }
.quote-box p.q { font-family: var(--font-display); font-weight:500; font-size: clamp(1.3rem,2.7vw,1.9rem); line-height:1.4; color: var(--heading); }

/* ============================ PAGE HEAD ============================ */
.page-head { position:relative; padding-top: calc(var(--nav-h) + clamp(48px,9vw,120px)); padding-bottom: clamp(40px,7vw,84px); }
.page-head .h1 { font-size: clamp(2.3rem,5.6vw,4rem); margin-bottom: var(--s-5); }
.breadcrumb { display:flex; gap: var(--s-2); align-items:center; color: var(--text-faint); font-size:.85rem; margin-bottom: var(--s-5); }
.breadcrumb a:hover { color: var(--brand-primary); }

/* ============================ FOOTER ============================ */
.footer { border-top:1px solid var(--border); background: var(--navy); color:#EEF1F8; padding-block: var(--s-8) var(--s-6); margin-top: var(--s-9); }
.footer__grid { display:grid; grid-template-columns: 1.7fr 1fr 1.2fr 1fr; gap: var(--s-6); margin-bottom: var(--s-7); }
@media (max-width:820px){ .footer__grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .footer__grid{ grid-template-columns:1fr; } }
.footer h4 { font-family: var(--font-body); font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:#7E8AA0; margin-bottom: var(--s-4); }
.footer a { display:block; color:#A6B0C3; padding:6px 0; font-size:.95rem; transition: color .3s; }
.footer a:hover { color: var(--brand-primary); }
.footer__brand img { max-width: 250px; width:100%; height:auto; }
.footer__brand p { color:#A6B0C3; max-width: 34ch; margin-top: var(--s-4); font-size:.95rem; }
.footer__bottom { display:flex; flex-wrap:wrap; justify-content:space-between; gap: var(--s-4); padding-top: var(--s-5); border-top:1px solid var(--border); color:#7E8AA0; font-size:.88rem; align-items:center; }
.footer__social { display:flex; gap: var(--s-3); }
.footer__social a { width:42px; height:42px; border:1px solid var(--border); border-radius:11px; display:grid; place-items:center; padding:0; transition: border-color .3s, background .3s, transform .3s; }
.footer__social a:hover { border-color: var(--brand-primary); background: var(--surface); transform: translateY(-3px); }
.footer__social svg { width:18px; height:18px; }

/* ============================ REVEAL ============================ */
.reveal { opacity:0; transform: translateY(30px); transition: opacity .8s var(--ease-out), transform .8s var(--ease-out); will-change: transform,opacity; }
.reveal.is-in { opacity:1; transform:none; }
.reveal-stagger > * { opacity:0; transform: translateY(26px); transition: opacity .65s var(--ease-out), transform .65s var(--ease-out); }
.reveal-stagger.is-in > * { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal,.reveal-stagger>*{ opacity:1 !important; transform:none !important; transition:none !important; }
  .pyramid-lite svg,.hero__scroll .mouse::after,.page-fade .pf-mark img{ animation:none !important; } }

/* ============================ UTIL + RTL ============================ */
.mt-4{margin-top:var(--s-4)} .mt-6{margin-top:var(--s-6)} .mt-8{margin-top:var(--s-8)}
.tag-row{ display:flex; flex-wrap:wrap; gap:var(--s-2); margin-top:var(--s-5); }
.tag{ font-size:.8rem; padding:6px 12px; border-radius:var(--radius-pill); border:1px solid var(--border); color:var(--text-dim); background:var(--surface); }
[dir="rtl"] .breadcrumb, [dir="rtl"] .hero__cta, [dir="rtl"] .channel { direction: rtl; }
[dir="rtl"] .link-arrow svg, [dir="rtl"] .btn svg { transform: scaleX(-1); }
[dir="rtl"] .link-arrow:hover svg { transform: translateX(-5px) scaleX(-1); }
[dir="rtl"] .rule-gold { background: linear-gradient(270deg,var(--brand-primary),transparent); }
[dir="rtl"] { --font-display: 'Cairo', sans-serif; --font-body: 'Cairo', ui-sans-serif, system-ui, sans-serif; }

@keyframes revealUp { from { opacity:0; transform: translateY(16px);} to { opacity:1; transform:none; } }


/* ============================ SERVICES ACCORDION ============================ */
.svc { transition: transform .45s var(--ease), border-color .4s, box-shadow .4s, background .4s; }
.svc__more { display:grid; grid-template-rows:0fr; transition: grid-template-rows .42s var(--ease); }
.svc.is-open .svc__more { grid-template-rows:1fr; }
.svc__more-in { overflow:hidden; }
.svc__more-in p { padding-top: var(--s-4); margin-top: var(--s-2); border-top:1px solid var(--border); color: var(--text-dim); font-size:.95rem; }
.svc__toggle { margin-top: auto; padding-top: var(--s-5); display:inline-flex; align-items:center; gap:8px; background:none; border:0; padding-inline:0; color: var(--brand-gold-deep); font-family: var(--font-body); font-weight:600; font-size:.92rem; cursor:pointer; align-self:flex-start; }
.theme-light .svc__toggle { color: var(--brand-gold-deep); }
.svc__toggle:hover { color: var(--brand-primary); }
.svc__chev { display:inline-flex; }
.svc__chev svg { width:18px; height:18px; transform: rotate(90deg); transition: transform .35s var(--ease); }
.svc.is-open .svc__chev svg { transform: rotate(-90deg); }
.svc__toggle .lbl-less { display:none; }
.svc.is-open .svc__toggle .lbl-more { display:none; }
.svc.is-open .svc__toggle .lbl-less { display:inline; }
[dir="rtl"] .svc__chev svg { transform: rotate(90deg) scaleX(1); }

/* ============================ POLISH v3 ============================ */
/* film grain — filmic texture across the whole site */
.grain { position: fixed; inset:0; z-index:60; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
@media (prefers-reduced-motion: reduce){ .grain{ display:none; } }

/* generative cover art fills its media tile (override old svg sizing) */
.pcard__media, .bcard__media, .feat-post__media { position:relative; overflow:hidden; }
.pcard__media .cover, .bcard__media .cover, .feat-post__media .cover { position:absolute; inset:0; width:100%; height:100%; display:block; z-index:0; }

/* skip link */
.skip-link { position:fixed; top:-60px; left:14px; z-index:10000; background:var(--brand-primary); color:#1a1304; font-weight:700; padding:10px 18px; border-radius:10px; transition: top .25s var(--ease); }
.skip-link:focus-visible { top:14px; }

/* WCAG AA contrast fixes (light sections) */
.theme-light .eyebrow { color: var(--ink); }
.theme-light .eyebrow::before { box-shadow:0 0 8px rgba(212,160,23,.7); }
.theme-light .link-arrow, .theme-light .svc__toggle, .theme-light .svc__tag, .theme-light .post-cat { color:#7a5800; }
.theme-light .link-arrow:hover, .theme-light .svc__toggle:hover { color:#6f4f00; }
:root { --text-faint:#828ea4; }
.theme-light { --text-faint:#5f6776; }

/* refined reveals — blur-in, not generic fade-up */
.reveal { opacity:0; transform:translateY(18px); filter:blur(7px); transition:opacity .85s var(--ease-out), transform .85s var(--ease-out), filter .85s var(--ease-out); }
.reveal.is-in { opacity:1; transform:none; filter:none; }
.reveal-stagger > * { opacity:0; transform:translateY(16px); filter:blur(6px); transition:opacity .7s var(--ease-out), transform .7s var(--ease-out), filter .7s var(--ease-out); }
.reveal-stagger.is-in > * { opacity:1; transform:none; filter:none; }
@media (prefers-reduced-motion: reduce){ .reveal, .reveal-stagger>*{ filter:none !important; transform:none !important; } }

/* typography tightening */
.h1 { letter-spacing:-0.025em; }
.h2 { letter-spacing:-0.02em; }
h1,h2,h3 { text-wrap:balance; }
.lead { text-wrap:pretty; }

/* ===================== MOBILE — designed, not shrunk ===================== */
@media (max-width:640px){
  :root { --nav-h:64px; }
  .h1 { font-size: clamp(2.2rem,10vw,2.9rem); line-height:1.06; }
  .hero { min-height:92svh; }
  .hero__inner { padding-block: var(--s-7); }
  .hero__cta { flex-direction:column; align-items:stretch; gap:12px; }
  .hero__cta .btn { width:100%; }
  .hero__scroll { display:none; }
  .section { padding-block: clamp(48px,14vw,72px); }
  .section-head { margin-bottom: var(--s-6); }
  .stats { grid-template-columns:1fr 1fr; gap:12px; }
  .stat { padding: var(--s-5) var(--s-3); }
  .card, .svc, .step { padding: var(--s-5); }
  .btn { min-height:52px; }
  .channel { padding: var(--s-4); }
  .cta-banner { padding: clamp(32px,9vw,48px); }
  .breadcrumb { font-size:.8rem; }
  .svc--featured { background: var(--surface); }
  .card:hover, .svc:hover, .pcard:hover { transform:none; }
}
@media (max-width:400px){ .stats { grid-template-columns:1fr; } }
@media (max-height:520px) and (orientation:landscape){
  .hero { min-height:auto; padding-block: calc(var(--nav-h) + 24px) 40px; }
  .hero__scroll { display:none; }
}

/* ============================ POLISH v4 ============================ */
/* Arabic: generous leading so dots/hamza/tashkeel never overlap between lines */
[dir="rtl"] { line-height: 1.9; }
[dir="rtl"] .h1 { line-height: 1.55; }
[dir="rtl"] .h2, [dir="rtl"] h1, [dir="rtl"] h2, [dir="rtl"] h3, [dir="rtl"] h4 { line-height: 1.5; }
[dir="rtl"] .lead, [dir="rtl"] p { line-height: 1.95; }
[dir="rtl"] .eyebrow { letter-spacing: 0; }
[dir="rtl"] .stat__label, [dir="rtl"] .svc__tag, [dir="rtl"] .post-cat { line-height: 1.7; }

/* Skip link — off-screen until keyboard focus, on-brand */
.skip-link { position:fixed; top:0; left:50%; transform:translate(-50%,-130%); z-index:10000;
  background:linear-gradient(120deg,var(--brand-primary),var(--brand-primary-2)); color:#1a1304;
  font-family:var(--font-body); font-weight:700; font-size:.9rem; padding:10px 22px; border-radius:0 0 14px 14px;
  box-shadow:0 10px 30px -8px rgba(212,160,23,.6); transition:transform .3s var(--ease); }
.skip-link:focus, .skip-link:focus-visible { transform:translate(-50%,0); outline:none; }

/* Contact channels — stack label/value, align, and shrink social to premium minis */
.channel { align-items:center; }
.channel > span:last-child { display:flex; flex-direction:column; gap:2px; min-width:0; }
.channel .l, .channel .v { display:block; }
.channels .grid.grid-3 { display:flex; gap:10px; }
.channels .grid.grid-3 .channel { flex:0 0 auto; width:48px; height:48px; padding:0 !important; border-radius:13px; justify-content:center; }
.channels .grid.grid-3 .channel svg { width:19px; height:19px; }

/* footer socials a touch smaller + refined */
.footer__social a { width:38px; height:38px; border-radius:10px; }
.footer__social svg { width:16px; height:16px; }

/* intl-tel-input integration with our fields */
.iti { display:block; width:100%; }
.iti__tel-input, .iti input[type=tel] { width:100%; }
.iti--separate-dial-code .iti__selected-dial-code { color: var(--text); }
.iti__selected-flag { border-radius:12px 0 0 12px; }
.iti__dropdown-content { color:#1a2030; font-family:var(--font-body); }
[dir="rtl"] .iti { text-align:right; }

/* Success screen — on-brand, motion-forward */
.px-success { position:fixed; inset:0; z-index:9998; display:grid; place-items:center; padding:24px;
  background:rgba(6,9,20,.74); backdrop-filter:blur(10px); opacity:0; pointer-events:none; transition:opacity .4s var(--ease); }
.px-success.show { opacity:1; pointer-events:auto; }
.px-success__card { position:relative; max-width:440px; width:100%; text-align:center; background:var(--bg-soft);
  border:1px solid var(--border); border-radius:var(--radius-lg); padding:clamp(30px,5vw,50px);
  box-shadow:0 50px 120px -30px rgba(0,0,0,.75); transform:translateY(18px) scale(.95); opacity:0;
  transition:transform .55s var(--ease), opacity .55s var(--ease); }
.px-success.show .px-success__card { transform:none; opacity:1; }
.px-success__mark { position:relative; width:98px; height:98px; margin:0 auto 22px; }
.px-success__mark > svg:first-child { width:98px; height:98px; filter:drop-shadow(0 0 22px rgba(212,160,23,.55)); animation:pfpulse 1.8s var(--ease) infinite; }
.px-check { position:absolute; inset:0; margin:auto; width:56px !important; height:56px !important; }
.px-check path { stroke-dasharray:60; stroke-dashoffset:60; animation:pxdraw .6s .35s var(--ease) forwards; }
@keyframes pxdraw { to { stroke-dashoffset:0; } }
.px-success__card h3 { color:var(--heading); margin-bottom:10px; }
.px-success__card p { color:var(--text-dim); margin-bottom:22px; }
@media (prefers-reduced-motion: reduce){ .px-success__mark>svg:first-child{ animation:none; } .px-check path{ animation:none; stroke-dashoffset:0; } }

/* ============================ POLISH v5 ============================ */
/* the [hidden] attribute must beat .field { display:grid } — fixes "Please specify" showing */
[hidden] { display: none !important; }

/* Premium CTA interaction (replaces the magnetic "juggle") — glow + subtle lift/scale */
.btn--primary { transition: transform .45s var(--ease), box-shadow .45s var(--ease), background .3s, filter .3s; }
.btn--primary:hover { transform: translateY(-2px) scale(1.025); box-shadow: 0 22px 54px -12px rgba(212,160,23,.9), inset 0 0 0 1px rgba(255,255,255,.28); filter: brightness(1.04); }
.btn--gold:hover { transform: translateY(-2px) scale(1.025); }
.btn:active { transform: translateY(0) scale(.99); }

/* success modal: room for the home CTA */
.px-success__home { min-width: 200px; }

/* ============================ THEME: article / prose ============================ */
.article-hero { border-radius: var(--radius-lg); overflow:hidden; border:1px solid var(--border); margin-bottom: var(--s-7); }
.article-hero img, .article-hero .cover { width:100%; height:auto; display:block; }
.prose { color: var(--text); font-size:1.08rem; line-height:1.85; }
.prose > * + * { margin-top: var(--s-5); }
.prose h2 { font-size: clamp(1.5rem,3vw,2rem); margin-top: var(--s-8); color: var(--heading); }
.prose h3 { font-size: clamp(1.2rem,2.2vw,1.5rem); margin-top: var(--s-7); color: var(--heading); }
.prose p, .prose li { color: var(--text-dim); }
.prose a { color:#7a5800; text-decoration: underline; text-underline-offset:3px; }
.prose ul, .prose ol { padding-inline-start: 1.4em; display:grid; gap:8px; }
.prose img { border-radius: var(--radius); border:1px solid var(--border); height:auto; }
.prose blockquote { border-inline-start:3px solid var(--brand-primary); padding-inline-start: var(--s-5); font-family: var(--font-display); font-size:1.25rem; color: var(--heading); font-style:italic; }
.prose hr { border:0; border-top:1px solid var(--border); }
.work-metrics { display:flex; flex-wrap:wrap; gap: var(--s-7); margin-bottom: var(--s-7); padding: var(--s-5) 0; border-block:1px solid var(--border); }
.wm__n { font-family: var(--font-display); font-weight:700; font-size: clamp(1.8rem,4vw,2.6rem); color:#7a5800; }
.wm__l { color: var(--text-dim); font-size:.9rem; margin-top:4px; }
.bcard { transition: transform .45s var(--ease), border-color .4s, box-shadow .4s; }
.bcard:hover { transform: translateY(-6px); border-color: var(--border-2); box-shadow: 0 26px 60px -26px rgba(212,160,23,.35); }
.pagination .page-numbers, .nav-links .page-numbers { display:inline-grid; place-items:center; min-width:44px; height:44px; padding:0 12px; border:1px solid var(--border); border-radius:12px; color: var(--text); background: var(--surface); font-weight:600; margin:2px; }
.pagination .page-numbers.current { background: var(--brand-primary); color:#1a1304; border-color: var(--brand-primary); }
[dir="rtl"] .prose { text-align: right; }
