/* =================================================================
   تليد ونماء لحلول الأعمال — Taleed & Namaa Business Solutions
   Minimalist B2B foundation · single stylesheet · logical properties
   ================================================================= */

/* ----------------------------- Fonts ----------------------------- */
@font-face {
  font-family: "Lama Sans";
  src: url("assets/fonts/LamaSans-Light.ttf") format("truetype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Lama Sans";
  src: url("assets/fonts/LamaSans-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Lama Sans";
  src: url("assets/fonts/LamaSans-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Lama Sans";
  src: url("assets/fonts/LamaSans-SemiBold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Lama Sans";
  src: url("assets/fonts/LamaSans-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ----------------------- Rotating beam token --------------------- */
@property --beam {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}

/* ----------------------------- Tokens ---------------------------- */
:root {
  /* Brand palette */
  --navy:        #05172f;  /* dominant canvas */
  --navy-2:      #0a2440;  /* gradient mid */
  --navy-deep:   #030f21;  /* gradient edges */
  --navy-glass:  rgba(6, 22, 45, 0.72);

  --gold:        #e0c58f;  /* primary accent */
  --gold-bright: #f4e3bd;  /* highlight / beam crest */
  --gold-deep:   #c9a86a;  /* pressed / borders */
  --gold-line:   rgba(224, 197, 143, 0.28);

  --cream:       #f1e8d6;  /* body text — warm, never grey */
  --cream-dim:   #d7c9ac;  /* secondary text — warm */
  --soft-white:  #f8f9fa;  /* crisp white for drawer menu items */

  /* Type */
  --font-body:    "Lama Sans", "Segoe UI", system-ui, sans-serif;
  --font-heading: "Lama Sans", "Segoe UI", system-ui, sans-serif;
  --w-light: 300;
  --w-reg:   400;
  --w-med:   500;
  --w-semi:  600;

  /* Geometry */
  --radius:    14px;
  --radius-sm: 10px;
  --radius-pill: 999px;
  --shell-pad: clamp(1.15rem, 4vw, 3rem);
  --header-h: 88px;

  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);

  /* divider fade direction (logical) + reusable tapered, fading line */
  --grad-dir: left;
  --fade-line: linear-gradient(to var(--grad-dir), rgba(224, 197, 143, 0.6), rgba(224, 197, 143, 0) 92%);
  /* gleaming metallic gold fill for masked logos */
  --metal-gold: linear-gradient(108deg,
      #a9803f 0%, #cda85f 13%, #efd79c 29%, #fff7e4 43%, #f0dcab 52%,
      #d4af6b 64%, #ecd49a 77%, #c39d59 90%, #a9803f 100%);

  color-scheme: dark;
}
[dir="rtl"] { --grad-dir: left; }
[dir="ltr"] { --grad-dir: right; }

/* ----------------------------- Reset ----------------------------- */
*, *::before, *::after { box-sizing: border-box; }

* { margin: 0; padding: 0; }

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  min-block-size: 100svh;
  font-family: var(--font-body);
  font-weight: var(--w-light);
  line-height: 1.7;
  color: var(--cream);
  background-color: var(--navy);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, svg { display: block; max-inline-size: 100%; }

button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }

a { color: inherit; text-decoration: none; }

:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
  border-radius: 4px;
}

::selection { background: rgba(224, 197, 143, 0.85); color: var(--navy); }

/* Shared content rail */
.shell {
  inline-size: min(100%, 1180px);
  margin-inline: auto;
  padding-inline: var(--shell-pad);
}

/* Inline SVG icon defaults (stroked) */
svg[viewBox] {
  inline-size: 1.35rem;
  block-size: 1.35rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}
svg.ico-fill { fill: currentColor; stroke: none; }

/* =================================================================
   HEADER
   ================================================================= */
.site-header {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: 60;
  block-size: var(--header-h);
  display: flex;
  align-items: center;
  transition: background-color 0.4s var(--ease), backdrop-filter 0.4s var(--ease);
}
.site-header.is-stuck {
  background: var(--navy-glass);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}
/* tapered, pulsing bottom divider — appears once the header is stuck */
.site-header::after {
  content: "";
  position: absolute;
  inset-inline: 0;
  inset-block-end: 0;
  block-size: 1px;
  background: var(--fade-line);
  opacity: 0;
  transition: opacity 0.4s var(--ease);
}
.site-header.is-stuck::after { opacity: 1; animation: divider-pulse 6s ease-in-out infinite; }

.header-inner {
  inline-size: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.header-start, .header-end { display: flex; align-items: center; gap: 0.7rem; }

/* Prominent header logo — masked vector filled with gleaming metallic gold */
.brand-logo {
  display: block;
  block-size: clamp(34px, 5vw, 52px);
  inline-size: auto;
  aspect-ratio: 908 / 191;
  -webkit-mask: url("assets/logo/wordmark-gold.svg") center / contain no-repeat;
          mask: url("assets/logo/wordmark-gold.svg") center / contain no-repeat;
  background-image: var(--metal-gold);
  background-size: 240% 100%;
  background-repeat: no-repeat;
  background-position: 0% 50%;
  filter: drop-shadow(0 3px 16px rgba(224, 197, 143, 0.3));
  animation: logo-gleam 6s ease-in-out infinite;
}

/* Generic icon button */
.icon-btn {
  position: relative;
  isolation: isolate;
  display: grid;
  place-items: center;
  inline-size: 46px;
  block-size: 46px;
  border-radius: var(--radius-pill);
  color: var(--gold);
  border: 1px solid transparent;
  transition: color 0.25s var(--ease), background-color 0.25s var(--ease),
              transform 0.25s var(--ease);
}
.icon-btn:hover { color: var(--gold-bright); background: rgba(224, 197, 143, 0.08); }
.icon-btn:active { transform: scale(0.94); }
.icon-btn svg { inline-size: 1.45rem; block-size: 1.45rem; }

/* glowing, rotating interactive outline on every functional icon (hover / focus) */
.icon-btn::before, .icon-btn::after {
  content: "";
  position: absolute;
  border-radius: inherit;
  background: conic-gradient(from var(--beam),
              transparent 0deg, transparent 80deg,
              var(--gold) 118deg, var(--gold-bright) 140deg, var(--gold) 162deg,
              transparent 205deg, transparent 360deg);
  opacity: 0;
  z-index: -1;
  transition: opacity 0.35s var(--ease);
  pointer-events: none;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
}
.icon-btn::before { inset: -2px; padding: 2px; }
.icon-btn::after  { inset: -5px; padding: 5px; filter: blur(7px); }
.icon-btn:hover::before, .icon-btn:focus-visible::before {
  opacity: 1; animation: beam-spin 2.8s linear infinite;
}
.icon-btn:hover::after, .icon-btn:focus-visible::after {
  opacity: 0.6; animation: beam-spin 2.8s linear infinite;
}

/* header utility links a touch larger for visibility / clickability */
.comm--header .icon-btn { inline-size: 48px; block-size: 48px; }
.comm--header .icon-btn svg { inline-size: 1.55rem; block-size: 1.55rem; }

.menu-btn svg { inline-size: 1.55rem; block-size: 1.55rem; }

.comm--header { display: flex; align-items: center; gap: 0.3rem; }

/* Location badge (typographic) */
.loc-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding-block: 0.5rem;
  padding-inline: 1rem;
  border: 1px solid var(--gold-line);
  border-radius: var(--radius-pill);
  color: var(--cream-dim);
  font-size: 0.88rem;
  font-weight: var(--w-reg);
  letter-spacing: 0.01em;
  white-space: nowrap;
}
.loc-badge .ico-pin { inline-size: 1.15rem; block-size: 1.15rem; color: var(--gold); flex: none; }
.loc-badge--block {
  inline-size: 100%;
  justify-content: center;
  padding-block: 0.6rem;
}

/* Animated language switch (sliding toggle) */
.lang-switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 4px;
  border: 1px solid var(--gold-line);
  border-radius: var(--radius-pill);
  background: rgba(8, 26, 50, 0.5);
  isolation: isolate;
  user-select: none;
  transition: border-color 0.25s var(--ease);
}
.lang-switch:hover { border-color: var(--gold); }
.lang-opt {
  position: relative;
  z-index: 1;
  inline-size: 2.15rem;
  text-align: center;
  font-family: var(--font-heading);
  font-weight: var(--w-med);
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  padding-block: 0.32rem;
  color: var(--cream-dim);
  transition: color 0.3s var(--ease);
}
/* default state = Arabic active */
.lang-opt[data-lang="ar"] { color: var(--navy); }
.lang-switch.is-en .lang-opt[data-lang="ar"] { color: var(--cream-dim); }
.lang-switch.is-en .lang-opt[data-lang="en"] { color: var(--navy); }
/* sliding knob sits under the active option */
.lang-switch__knob {
  position: absolute;
  z-index: 0;
  inset-block: 4px;
  inset-inline-start: 4px;
  inline-size: 2.15rem;
  border-radius: var(--radius-pill);
  background: linear-gradient(160deg, var(--gold-bright), var(--gold) 60%, var(--gold-deep));
  box-shadow: 0 2px 10px -2px rgba(224, 197, 143, 0.6);
  transition: inset-inline-start 0.38s var(--ease);
}
.lang-switch.is-en .lang-switch__knob { inset-inline-start: calc(4px + 2.15rem); }

/* =================================================================
   HERO
   ================================================================= */
.hero {
  position: relative;
  min-block-size: 100svh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding-block: calc(var(--header-h) + 2rem) 3rem;
  padding-inline: var(--shell-pad);
  overflow: hidden;
  isolation: isolate;
  /* Solid Royal Navy canvas, locked to #05172f, with the deep dark pushed
     heavily inward so the centre stage (slogan + CTAs) sits profoundly dark
     and high-contrast, while the faint pattern lives only at the edges. */
  background-color: var(--navy);
  background-image:
    radial-gradient(125% 105% at 50% 46%,
      rgba(0, 0, 0, 0.62) 0%, rgba(0, 0, 0, 0.28) 42%, rgba(0, 0, 0, 0) 76%);
}

/* Subtle dark geometric arc pattern (business-card motif) over the navy canvas.
   Faded toward the centre so it never competes with the logo or copy. */
/* Official brand pattern — identical technique to the main website:
   pattern.svg is used as an alpha MASK over a solid gold tint, intersected
   with a corner radial gradient so the woven quarter-arc "N" glows in the
   leading-top corner and fades to full transparency before the centre copy. */
.hero-pattern {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-color: rgba(224, 197, 143, 0.03);
  -webkit-mask-image: url("assets/pattern.svg"), radial-gradient(160% 145% at 100% 0%, #000 0%, rgba(0, 0, 0, 0.45) 34%, transparent 70%);
  -webkit-mask-repeat: repeat, no-repeat;
  -webkit-mask-size: 150px 111px, 100% 100%;
  -webkit-mask-position: 0 0, 0 0;
  -webkit-mask-composite: source-in;
          mask-image: url("assets/pattern.svg"), radial-gradient(160% 145% at 100% 0%, #000 0%, rgba(0, 0, 0, 0.45) 34%, transparent 70%);
          mask-repeat: repeat, no-repeat;
          mask-size: 150px 111px, 100% 100%;
          mask-position: 0 0, 0 0;
          mask-composite: intersect;
}
/* RTL flips the radial to the top-leading (right→left) corner */
[dir="rtl"] .hero-pattern {
  -webkit-mask-image: url("assets/pattern.svg"), radial-gradient(160% 145% at 0% 0%, #000 0%, rgba(0, 0, 0, 0.45) 34%, transparent 70%);
          mask-image: url("assets/pattern.svg"), radial-gradient(160% 145% at 0% 0%, #000 0%, rgba(0, 0, 0, 0.45) 34%, transparent 70%);
}

/* Warm gold light wash in the leading-top corner (flips with dir) */
.hero-wash {
  position: absolute;
  inset-block-start: -20%;
  inset-inline-start: -12%;
  inline-size: 60vmax;
  block-size: 60vmax;
  z-index: -1;
  pointer-events: none;
  background: radial-gradient(circle at center,
              rgba(224, 197, 143, 0.08) 0%,
              rgba(224, 197, 143, 0.03) 32%,
              transparent 62%);
  filter: blur(8px);
}
/* second, fainter wash on the opposite far corner for depth */
.hero::after {
  content: "";
  position: absolute;
  inset-block-end: -25%;
  inset-inline-end: -15%;
  inline-size: 55vmax;
  block-size: 55vmax;
  z-index: -1;
  pointer-events: none;
  background: radial-gradient(circle at center,
              rgba(0, 0, 0, 0.5) 0%, transparent 62%);
}

.hero-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(1.5rem, 3.5vw, 2.5rem);
  max-inline-size: 50rem;
  animation: rise 0.9s var(--ease) both;
}

.hero-headline {
  font-family: var(--font-heading);
  font-weight: var(--w-med);
  font-size: clamp(1.9rem, 5.2vw, 3.5rem);
  line-height: 1.22;
  letter-spacing: -0.01em;
  color: var(--gold);
  text-wrap: balance;
}

.hero-tagline {
  font-weight: var(--w-light);
  font-size: clamp(1rem, 2.1vw, 1.3rem);
  line-height: 1.75;
  color: var(--cream);
  max-inline-size: 38rem;
  text-wrap: balance;
}

/* ----------------------------- CTAs ------------------------------ */
.hero-cta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-block-start: 0.5rem;
}

.cta {
  position: relative;
  isolation: isolate;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-inline-size: 13.5rem;
  padding-block: 1rem;
  padding-inline: 2rem;
  border-radius: var(--radius-pill);
  font-family: var(--font-heading);
  font-weight: var(--w-med);
  font-size: clamp(1rem, 1.7vw, 1.12rem);
  letter-spacing: 0.01em;
  /* default = clean secondary outline (ghost) */
  background: rgba(8, 26, 50, 0.55);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  color: var(--gold);
  border: 1.5px solid var(--gold-line);
  transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease),
              border-color 0.3s var(--ease), background-color 0.3s var(--ease),
              color 0.3s var(--ease);
}
.cta:hover { transform: translateY(-2px); color: var(--gold-bright); border-color: var(--gold); }
.cta:active { transform: translateY(0) scale(0.985); }

/* active = solid gold fill + rotating beam; siblings revert to ghost instantly */
.cta.is-active {
  background: linear-gradient(160deg, var(--gold-bright), var(--gold) 55%, var(--gold-deep));
  color: var(--navy);
  border-color: transparent;
  font-weight: var(--w-semi);
  box-shadow: 0 10px 30px -12px rgba(224, 197, 143, 0.55);
}
.cta.is-active:hover { color: var(--navy); box-shadow: 0 16px 38px -10px rgba(224, 197, 143, 0.7); }

/* Rotating glowing golden beam — sharp ring (::before) + soft glow ring (::after).
   Both are masked to a border band so the button interior is never washed. */
.cta::before,
.cta::after {
  content: "";
  position: absolute;
  border-radius: inherit;
  background: conic-gradient(from var(--beam),
              transparent 0deg, transparent 78deg,
              var(--gold) 116deg, var(--gold-bright) 138deg, var(--gold) 160deg,
              transparent 200deg, transparent 360deg);
  opacity: 0;
  z-index: -1;
  transition: opacity 0.45s var(--ease);
  pointer-events: none;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
}
/* sharp ring band */
.cta::before { inset: -2px; padding: 2px; }
/* soft, blurred outer glow ring */
.cta::after { inset: -8px; padding: 8px; filter: blur(11px); }
/* beam lives on the active button (and a hint on keyboard focus) */
.cta.is-active::before, .cta:focus-visible::before {
  opacity: 1;
  animation: beam-spin 2.8s linear infinite;
}
.cta.is-active::after, .cta:focus-visible::after {
  opacity: 0.55;
  animation: beam-spin 2.8s linear infinite;
}

@keyframes beam-spin { to { --beam: 360deg; } }

/* "استكشف" — standalone corner anchor.
   inset-inline-end pins it to the bottom-left in RTL, bottom-right in LTR. */
.scroll-hint {
  position: absolute;
  inset-block-end: 1.5rem;
  inset-inline-end: clamp(1.15rem, 4vw, 3rem);
  inline-size: max-content;
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  color: var(--cream-dim);
  font-size: 1rem;
  font-weight: var(--w-reg);
  letter-spacing: 0.14em;
  opacity: 0.85;
  transition: color 0.25s var(--ease), opacity 0.25s var(--ease);
  animation: rise 1.2s var(--ease) 0.4s both;
}
/* a short tapered accent line that fades away from the text */
.scroll-hint::after {
  content: "";
  inline-size: clamp(2rem, 6vw, 3.4rem);
  block-size: 1px;
  background: var(--fade-line);
  animation: divider-pulse 6s ease-in-out infinite;
}
.scroll-hint:hover { color: var(--gold); opacity: 1; }

/* =================================================================
   DRAWER
   ================================================================= */
.drawer-scrim {
  position: fixed;
  inset: 0;
  z-index: 80;
  background: rgba(2, 9, 20, 0.62);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  opacity: 0;
  transition: opacity 0.4s var(--ease);
}
.drawer-scrim.is-open { opacity: 1; }

.drawer {
  position: fixed;
  inset-block: 0;
  inset-inline-start: 0;
  z-index: 90;
  inline-size: min(420px, 88vw);
  display: flex;
  flex-direction: column;
  background: linear-gradient(180deg, #061a35, var(--navy) 60%, var(--navy-deep));
  border-inline-end: 1px solid var(--gold-line);
  box-shadow: 0 0 60px rgba(0, 0, 0, 0.5);
  transform: translateX(-104%);
  transition: transform 0.5s var(--ease);
  overscroll-behavior: contain;
}
[dir="rtl"] .drawer { transform: translateX(104%); }
.drawer.is-open { transform: translateX(0); }

.drawer-head {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-inline: 1.4rem;
  padding-block: 1.1rem;
  flex: none;
}
.drawer-head::after {
  content: "";
  position: absolute;
  inset-inline: 1.4rem;
  inset-block-end: 0;
  block-size: 1px;
  background: var(--fade-line);
  animation: divider-pulse 6s ease-in-out infinite;
}
.drawer-logo { block-size: 30px; inline-size: auto; }
.drawer-close { color: var(--gold); }

.drawer-body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding-inline: 0.7rem;
  padding-block: 0.5rem 1rem;
  scrollbar-width: thin;
  scrollbar-color: var(--gold-deep) transparent;
}
.drawer-body::-webkit-scrollbar { inline-size: 7px; }
.drawer-body::-webkit-scrollbar-thumb { background: var(--gold-deep); border-radius: 4px; }

/* Accordion */
.acc { position: relative; }
.acc::after {
  content: "";
  position: absolute;
  inset-inline: 0.85rem;
  inset-block-end: 0;
  block-size: 1px;
  background: var(--fade-line);
  animation: divider-pulse 6s ease-in-out infinite;
}
.acc-trigger {
  inline-size: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-block: 1.05rem;
  padding-inline: 0.85rem;
  text-align: start;
  color: var(--gold);
  font-family: var(--font-heading);
  font-weight: var(--w-med);
  font-size: 1.06rem;
  border-radius: var(--radius-sm);
  transition: color 0.25s var(--ease), background-color 0.25s var(--ease);
}
.acc-trigger:hover { color: var(--gold-bright); background: rgba(224, 197, 143, 0.06); }
.acc[data-open] > .acc-trigger { color: var(--gold-bright); }   /* active header highlight */
.acc-chevron {
  inline-size: 1.15rem; block-size: 1.15rem;
  color: var(--gold);
  flex: none;
  transition: transform 0.35s var(--ease);
}
.acc[data-open] .acc-chevron { transform: rotate(180deg); }

.acc-panel {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.45s var(--ease);
  padding-inline: 0.85rem;
}
.acc[data-open] .acc-panel { grid-template-rows: 1fr; }
.acc-panel-inner {
  overflow: hidden;
  min-block-size: 0;
  /* no padding/border here — keeps closed height at an absolute zero */
  visibility: hidden;
  transition: visibility 0s linear 0.45s;
}
.acc[data-open] .acc-panel-inner {
  visibility: visible;
  transition-delay: 0s;
}
/* bottom breathing room as a clipped child spacer (collapses to 0 when closed) */
.acc-panel-inner::after { content: ""; display: block; block-size: 0.85rem; }

.acc-panel p {
  color: var(--cream);
  font-weight: var(--w-light);
  font-size: 0.95rem;
  line-height: 1.85;
  padding-block-end: 0.85rem;
}
.acc-panel p.acc-sub { color: var(--cream-dim); font-size: 0.9rem; }

.mini-h {
  color: var(--soft-white);
  font-weight: var(--w-semi);
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding-block: 0.2rem 0.35rem;
}
[dir="rtl"] .mini-h { text-transform: none; letter-spacing: 0; font-size: 0.95rem; }

/* Definition lists (services, values, pillars) */
.deflist { padding-block-end: 0.6rem; }
.deflist dt {
  color: var(--soft-white);
  font-weight: var(--w-med);
  font-size: 0.96rem;
  padding-block-start: 0.7rem;
}
.deflist dd {
  color: var(--cream);
  font-weight: var(--w-light);
  font-size: 0.9rem;
  line-height: 1.75;
  padding-block-start: 0.2rem;
  margin-inline-start: 0;
}
.deflist dt::before {
  content: "";
  display: inline-block;
  inline-size: 0.42rem;
  block-size: 0.42rem;
  margin-inline-end: 0.55rem;
  border-radius: 50%;
  background: var(--gold);
  vertical-align: middle;
}
.deflist--tight dd { padding-block-end: 0.2rem; }

/* Methodology steps */
.steps { list-style: none; counter-reset: s; padding-block-end: 0.6rem; }
.steps li {
  counter-increment: s;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.2rem 0.85rem;
  align-items: baseline;
  padding-block: 0.55rem;
}
.steps li::before {
  content: counter(s);
  grid-row: span 2;
  align-self: start;
  display: grid;
  place-items: center;
  inline-size: 2rem;
  block-size: 2rem;
  border: 1px solid var(--gold-line);
  border-radius: 50%;
  color: var(--gold);
  font-weight: var(--w-semi);
  font-size: 0.9rem;
}
.step-name { color: var(--soft-white); font-weight: var(--w-med); font-size: 0.96rem; }
.step-desc { grid-column: 2; color: var(--cream); font-weight: var(--w-light); font-size: 0.88rem; line-height: 1.7; }

.drawer-foot {
  position: relative;
  flex: none;
  padding-inline: 1.4rem;
  padding-block: 1.1rem 1.4rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.drawer-foot::before {
  content: "";
  position: absolute;
  inset-inline: 1.4rem;
  inset-block-start: 0;
  block-size: 1px;
  background: var(--fade-line);
  animation: divider-pulse 6s ease-in-out infinite;
}
.comm--drawer { display: flex; flex-direction: column; gap: 0.2rem; }
.comm-row {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding-block: 0.6rem;
  padding-inline: 0.5rem;
  border-radius: var(--radius-sm);
  color: var(--cream);
  font-size: 0.92rem;
  font-weight: var(--w-reg);
  text-align: start;
  transition: color 0.2s var(--ease), background-color 0.2s var(--ease);
}
.comm-row svg { inline-size: 1.15rem; block-size: 1.15rem; color: var(--gold); flex: none; }
.comm-row:hover { color: var(--gold-bright); background: rgba(224, 197, 143, 0.07); }

/* =================================================================
   FOOTER (structured · multi-column)
   ================================================================= */
.site-footer {
  position: relative;
  background: linear-gradient(180deg, var(--navy), var(--navy-deep));
  padding-block: clamp(2.6rem, 5vw, 3.8rem) 0;
}
.site-footer::before {
  content: "";
  position: absolute;
  inset-inline: 0;
  inset-block-start: 0;
  block-size: 1px;
  background: var(--fade-line);
  animation: divider-pulse 6s ease-in-out infinite;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.7fr 1fr 1fr 1.5fr;
  gap: clamp(1.6rem, 4vw, 3.2rem);
  align-items: start;
}

.footer-about { display: flex; flex-direction: column; align-items: flex-start; gap: 1rem; }
.brand-logo--footer { block-size: 40px; animation-duration: 7s; }
.footer-blurb {
  color: var(--cream-dim);
  font-size: 0.9rem;
  font-weight: var(--w-light);
  line-height: 1.75;
  max-inline-size: 22rem;
}
.footer-socials { display: flex; align-items: center; gap: 0.35rem; }

.footer-col { min-inline-size: 0; }
.footer-h {
  position: relative;
  color: var(--gold);
  font-family: var(--font-heading);
  font-weight: var(--w-semi);
  font-size: 0.98rem;
  letter-spacing: 0.02em;
  padding-block-end: 0.7rem;
  margin-block-end: 0.9rem;
}
.footer-h::after {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  inset-block-end: 0;
  inline-size: 2.6rem;
  block-size: 1px;
  background: var(--fade-line);
  animation: divider-pulse 6s ease-in-out infinite;
}

.footer-links { list-style: none; display: flex; flex-direction: column; gap: 0.15rem; }
.footer-link {
  display: inline-block;
  color: var(--cream-dim);
  font-size: 0.92rem;
  font-weight: var(--w-light);
  padding-block: 0.4rem;
  text-align: start;
  transition: color 0.2s var(--ease), padding-inline-start 0.2s var(--ease);
}
.footer-link:hover { color: var(--soft-white); padding-inline-start: 0.35rem; }

.footer-contact-list { list-style: none; display: flex; flex-direction: column; gap: 0.85rem; }
.footer-contact-row {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  inline-size: 100%;
  color: var(--cream);
  text-align: start;
  transition: color 0.2s var(--ease);
}
.footer-contact-row svg { inline-size: 1.35rem; block-size: 1.35rem; color: var(--gold); flex: none; }
.footer-contact-row:not(.footer-contact-row--static):hover { color: var(--gold-bright); }
.footer-contact-row--static { cursor: default; }
.fc-text { display: flex; flex-direction: column; align-items: flex-start; line-height: 1.35; }
.fc-label { font-size: 0.76rem; color: var(--cream-dim); }
.fc-val { font-size: 0.92rem; font-weight: var(--w-reg); letter-spacing: 0.01em; }

/* footer bottom bar */
.footer-bar {
  position: relative;
  margin-block-start: clamp(2rem, 4vw, 3rem);
  padding-block: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.4rem 1.5rem;
}
.footer-bar::before {
  content: "";
  position: absolute;
  inset-inline: 0;
  inset-block-start: 0;
  block-size: 1px;
  background: var(--fade-line);
  animation: divider-pulse 6s ease-in-out infinite;
}
.footer-legal { color: var(--cream-dim); font-size: 0.8rem; opacity: 0.82; }
.footer-made { color: var(--cream-dim); font-size: 0.8rem; opacity: 0.6; letter-spacing: 0.02em; }

/* =================================================================
   TOAST
   ================================================================= */
.toast {
  position: fixed;
  inset-block-end: 1.6rem;
  inset-inline: 0;
  margin-inline: auto;
  inline-size: max-content;
  max-inline-size: 90vw;
  z-index: 120;
  padding-block: 0.75rem;
  padding-inline: 1.4rem;
  background: var(--gold);
  color: var(--navy);
  font-weight: var(--w-med);
  font-size: 0.9rem;
  border-radius: var(--radius-pill);
  box-shadow: 0 14px 40px -10px rgba(0, 0, 0, 0.6);
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
  transition: opacity 0.35s var(--ease), transform 0.35s var(--ease);
}
.toast.is-on { opacity: 1; transform: translateY(0); }

/* =================================================================
   KEYFRAMES
   ================================================================= */
@keyframes rise {
  from { opacity: 0; transform: translateY(22px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes nudge {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(4px); }
}
@keyframes logo-gleam {
  0%, 100% { background-position: 0% 50%; }
  50%      { background-position: 100% 50%; }
}
@keyframes divider-pulse {
  0%, 100% { opacity: 0.4; }
  50%      { opacity: 0.95; }
}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width: 980px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem 2.4rem; }
  .footer-about { grid-column: 1 / -1; }
}
@media (max-width: 860px) {
  .comm--header .email-btn { display: none; }
}
@media (max-width: 560px) {
  :root { --header-h: 70px; }
  .comm--header { display: none; }
  .cta { min-inline-size: min(78vw, 20rem); }
  .hero-headline { font-size: clamp(1.7rem, 7.4vw, 2.5rem); }
  .footer-grid { grid-template-columns: 1fr; gap: 1.8rem; }
  .footer-about { align-items: center; text-align: center; }
  .footer-bar { justify-content: center; text-align: center; }
}

/* =================================================================
   MOTION / NO-JS
   ================================================================= */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .cta::before, .cta::after,
  .icon-btn::before, .icon-btn::after,
  .brand-logo,
  .acc::after, .drawer-head::after, .drawer-foot::before,
  .site-footer::before, .footer-h::after, .footer-bar::before,
  .site-header::after, .scroll-hint::after,
  .u-divider, .page-header::after, .path-card--premium::before,
  .pillar.is-open, .token-bar, .chip::before, .chip::after { animation: none !important; }
}

/* =================================================================
   INTERACTIVE JOURNEY PAGES — services.html · consulting.html
   Arabic-only (RTL). Depth via surfaces, gold only for primary
   actions / active states / the faint pattern motif.
   ================================================================= */
:root {
  --surf-1: #0a1f39;                       /* card surface */
  --surf-2: #102a49;                       /* raised / input */
  --surf-3: #18375d;                       /* active / interactive choice */
  --surf-line: rgba(248, 249, 250, 0.09);
  --gold-tint: rgba(224, 197, 143, 0.12);
  --danger: #f0b4b4;
}

.page { min-block-size: 100svh; display: flex; flex-direction: column; background: var(--navy); }
.page-main { flex: 1 1 auto; padding-block: calc(var(--header-h) + 1.4rem) 4rem; padding-inline: var(--shell-pad); }
.wrap { inline-size: min(100%, 940px); margin-inline: auto; }
.wrap--wide { inline-size: min(100%, 1120px); }

/* ---- slim page header ---- */
.page-header {
  position: fixed; inset-block-start: 0; inset-inline: 0; z-index: 60;
  block-size: var(--header-h); display: flex; align-items: center;
  background: var(--navy-glass);
  -webkit-backdrop-filter: blur(14px) saturate(140%); backdrop-filter: blur(14px) saturate(140%);
}
.page-header::after {
  content: ""; position: absolute; inset-inline: 0; inset-block-end: 0; block-size: 1px;
  background: var(--fade-line); animation: divider-pulse 6s ease-in-out infinite;
}
.page-header .shell { display: flex; align-items: center; justify-content: space-between; inline-size: 100%; }
.back-home { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--cream-dim); font-size: 0.92rem; transition: color 0.2s var(--ease); }
.back-home:hover { color: var(--gold); }
.back-home svg { inline-size: 1.05rem; block-size: 1.05rem; }

/* ---- page hero (title + faint pattern motif) ---- */
.page-hero { position: relative; text-align: center; padding-block: 0.5rem 2rem; isolation: isolate; }
.page-pattern {
  position: absolute; inset: -2.5rem -2rem auto -2rem; block-size: 22rem; z-index: -1; pointer-events: none;
  background-color: rgba(224, 197, 143, 0.05);
  -webkit-mask-image: url("assets/pattern.svg"), radial-gradient(130% 120% at 50% 0%, #000 0%, rgba(0,0,0,0.4) 40%, transparent 72%);
          mask-image: url("assets/pattern.svg"), radial-gradient(130% 120% at 50% 0%, #000 0%, rgba(0,0,0,0.4) 40%, transparent 72%);
  -webkit-mask-repeat: repeat, no-repeat; mask-repeat: repeat, no-repeat;
  -webkit-mask-size: 150px 111px, 100% 100%; mask-size: 150px 111px, 100% 100%;
  -webkit-mask-composite: source-in; mask-composite: intersect;
}
.page-eyebrow { color: var(--gold); font-weight: var(--w-semi); font-size: clamp(1rem, 2.4vw, 1.18rem); letter-spacing: 0.06em; }
.page-title { font-family: var(--font-heading); font-weight: var(--w-med); font-size: clamp(1.95rem, 5vw, 3rem); color: var(--soft-white); line-height: 1.2; margin-block: 0.55rem 0.7rem; }
.page-title .t-gold { color: var(--gold); }
.page-sub { color: var(--soft-white); font-weight: var(--w-light); font-size: clamp(0.92rem, 1.7vw, 1.02rem); line-height: 1.7; max-inline-size: 40rem; margin-inline: auto; }

/* ---- surfaces / dividers ---- */
.card { background: var(--surf-1); border-radius: var(--radius); padding: clamp(1.1rem, 3vw, 1.9rem); }
.u-divider { block-size: 1px; background: var(--fade-line); animation: divider-pulse 6s ease-in-out infinite; margin-block: 1.3rem; }

/* ---- buttons ---- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  padding-block: 0.85rem; padding-inline: 1.7rem; border-radius: var(--radius-pill);
  font-family: var(--font-heading); font-weight: var(--w-med); font-size: 1rem; cursor: pointer;
  border: 1px solid transparent;
  transition: transform 0.25s var(--ease), box-shadow 0.25s var(--ease),
              background-color 0.25s var(--ease), color 0.25s var(--ease), border-color 0.25s var(--ease);
}
.btn svg { inline-size: 1.1rem; block-size: 1.1rem; }
.btn-primary { background: linear-gradient(160deg, var(--gold-bright), var(--gold) 55%, var(--gold-deep)); color: var(--navy); font-weight: var(--w-semi); box-shadow: 0 10px 30px -12px rgba(224,197,143,0.5); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 16px 38px -10px rgba(224,197,143,0.65); }
.btn-ghost { background: var(--surf-2); color: var(--soft-white); border-color: var(--surf-line); }
.btn-ghost:hover { background: var(--surf-3); border-color: var(--gold-line); }
.btn-text { background: none; color: var(--cream-dim); padding-inline: 0.6rem; }
.btn-text:hover { color: var(--gold); }
.btn:disabled { opacity: 0.4; cursor: not-allowed; transform: none; box-shadow: none; }

/* ---- form fields ---- */
.field { display: flex; flex-direction: column; gap: 0.45rem; }
.field-label { color: var(--soft-white); font-size: 0.95rem; font-weight: var(--w-med); }
.field-label .req { color: var(--gold); margin-inline-start: 0.2rem; }
.field-hint { color: var(--cream-dim); font-size: 0.8rem; font-weight: var(--w-light); }
.input, .select, .textarea {
  inline-size: 100%; padding-block: 0.78rem; padding-inline: 0.95rem;
  background: var(--surf-2); color: var(--soft-white);
  border: 1px solid transparent; border-radius: var(--radius-sm);
  font-family: var(--font-body); font-size: 0.98rem; font-weight: var(--w-light);
  transition: background-color 0.2s var(--ease), border-color 0.2s var(--ease), box-shadow 0.2s var(--ease);
}
.input::placeholder, .textarea::placeholder { color: rgba(215, 201, 172, 0.5); }
.input:focus, .select:focus, .textarea:focus { outline: none; background: var(--surf-3); border-color: var(--gold-line); box-shadow: 0 0 0 3px rgba(224,197,143,0.12); }
.textarea { resize: vertical; min-block-size: 7rem; line-height: 1.7; }
.textarea--lg { min-block-size: 9.5rem; }
.select {
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e0c58f' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");
  background-repeat: no-repeat; background-position: left 0.9rem center; background-size: 1.05rem;
  padding-inline-end: 2.4rem;
}
.field.is-invalid .input, .field.is-invalid .select, .field.is-invalid .textarea { border-color: var(--danger); box-shadow: 0 0 0 3px rgba(240,180,180,0.12); }
.field-error { color: var(--danger); font-size: 0.8rem; display: none; }
.field.is-invalid .field-error { display: block; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.1rem; }

/* ---- multi-select chips ---- */
.chips { display: flex; flex-wrap: wrap; gap: 0.9rem; }
/* category chips: unified, equal-width, architectural pills */
#catChips .chip { flex: 1 1 200px; }
.chip {
  position: relative; isolation: isolate;
  display: inline-flex; align-items: center; justify-content: center;
  padding-block: 1rem; padding-inline: 1.6rem; line-height: 1;
  background: var(--surf-1); color: var(--soft-white);
  border: 1.5px solid var(--surf-line); border-radius: var(--radius-pill);
  font-family: var(--font-heading); font-weight: var(--w-med); font-size: 1.05rem;
  cursor: pointer; user-select: none; text-align: center;
  transition: background 0.25s var(--ease), color 0.25s var(--ease), border-color 0.25s var(--ease),
              box-shadow 0.25s var(--ease), transform 0.15s var(--ease);
}
.chip:hover { background: var(--surf-2); border-color: var(--gold-line); }
.chip:active { transform: scale(0.98); }
/* active = luminous metallic gold surface + navy text (no checkmark icon) */
.chip[aria-pressed="true"] {
  background: linear-gradient(155deg, var(--gold-bright), var(--gold) 52%, var(--gold-deep));
  color: var(--navy); border-color: transparent; font-weight: var(--w-semi);
  box-shadow: 0 10px 28px -10px rgba(224, 197, 143, 0.55);
}
/* rotating glowing outline ring on the active chip (shared icon-ring language) */
.chip::before, .chip::after {
  content: ""; position: absolute; border-radius: inherit; z-index: -1; pointer-events: none;
  background: conic-gradient(from var(--beam),
              transparent 0deg, transparent 80deg,
              var(--gold) 116deg, var(--gold-bright) 140deg, var(--gold) 164deg,
              transparent 205deg, transparent 360deg);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: 0; transition: opacity 0.35s var(--ease);
}
.chip::before { inset: -2px; padding: 2px; }
.chip::after  { inset: -7px; padding: 7px; filter: blur(8px); }
.chip[aria-pressed="true"]::before { opacity: 1; animation: beam-spin 3s linear infinite; }
.chip[aria-pressed="true"]::after  { opacity: 0.6; animation: beam-spin 3s linear infinite; }
.chip-check { display: none; }   /* checkmark removed — active state is colour only */
.chips--sub .chip { flex: 0 1 auto; font-size: 0.96rem; padding-block: 0.7rem; padding-inline: 1.2rem; }

/* ---- range sliders ---- */
.range-row { display: flex; align-items: center; gap: 1rem; }
.range-row .range-val { min-inline-size: 6.5rem; text-align: start; color: var(--gold); font-weight: var(--w-med); font-size: 0.95rem; }
input[type="range"] { flex: 1; inline-size: 100%; block-size: 1.6rem; appearance: none; -webkit-appearance: none; background: transparent; cursor: pointer; }
input[type="range"]::-webkit-slider-runnable-track { block-size: 6px; border-radius: 3px; background: linear-gradient(to left, var(--gold-deep), var(--gold) var(--fill, 50%), var(--surf-3) var(--fill, 50%)); }
input[type="range"]::-moz-range-track { block-size: 6px; border-radius: 3px; background: var(--surf-3); }
input[type="range"]::-moz-range-progress { block-size: 6px; border-radius: 3px; background: linear-gradient(90deg, var(--gold-deep), var(--gold)); }
input[type="range"]::-webkit-slider-thumb { appearance: none; -webkit-appearance: none; margin-block-start: -7px; inline-size: 20px; block-size: 20px; border-radius: 50%; background: linear-gradient(160deg, var(--gold-bright), var(--gold-deep)); box-shadow: 0 2px 8px -1px rgba(224,197,143,0.6); }
input[type="range"]::-moz-range-thumb { inline-size: 20px; block-size: 20px; border: none; border-radius: 50%; background: linear-gradient(160deg, var(--gold-bright), var(--gold-deep)); box-shadow: 0 2px 8px -1px rgba(224,197,143,0.6); }
input[type="range"]:focus-visible::-webkit-slider-thumb { outline: 2px solid var(--gold); outline-offset: 2px; }

/* ---- radio / checkbox pills ---- */
.opt-row { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.opt { position: relative; }
.opt input { position: absolute; opacity: 0; inset: 0; cursor: pointer; }
.opt span {
  display: inline-flex; align-items: center; gap: 0.45rem; padding-block: 0.55rem; padding-inline: 1rem;
  background: var(--surf-2); color: var(--cream); border: 1px solid var(--surf-line); border-radius: var(--radius-pill);
  font-size: 0.92rem; transition: background-color 0.2s var(--ease), color 0.2s var(--ease), border-color 0.2s var(--ease);
}
.opt input:checked + span { background: var(--surf-3); color: var(--soft-white); border-color: var(--gold); }
.opt input:focus-visible + span { outline: 2px solid var(--gold); outline-offset: 2px; }

/* =================================================================
   WIZARD (services.html)
   ================================================================= */
.wiz-top { display: flex; align-items: center; justify-content: space-between; gap: 1rem 1.5rem; flex-wrap: wrap; margin-block-end: 1.4rem; }
.wiz-meta { display: flex; align-items: center; gap: 0.8rem; flex-wrap: wrap; }
.wiz-est { display: inline-flex; align-items: center; gap: 0.4rem; color: var(--gold); font-size: 0.82rem; background: var(--gold-tint); padding-block: 0.32rem; padding-inline: 0.75rem; border-radius: var(--radius-pill); }
.wiz-est svg { inline-size: 0.95rem; block-size: 0.95rem; }
.wiz-progress { inline-size: 100%; }
.wiz-progress-head { display: flex; justify-content: space-between; color: var(--cream-dim); font-size: 0.85rem; margin-block-end: 0.5rem; }
.wiz-progress-head b { color: var(--soft-white); font-weight: var(--w-med); }
.wiz-progress-bar { block-size: 7px; background: var(--surf-2); border-radius: 4px; overflow: hidden; }
.wiz-progress-fill { block-size: 100%; inline-size: 0; border-radius: 4px; background: linear-gradient(90deg, var(--gold-deep), var(--gold-bright)); transition: inline-size 0.45s var(--ease); }

.wiz-step { display: none; }
.wiz-step.is-current { display: block; animation: rise 0.4s var(--ease) both; }
.step-head { margin-block-end: 1.3rem; }
.step-eyebrow { color: var(--gold); font-size: 0.8rem; font-weight: var(--w-med); letter-spacing: 0.04em; }
.step-title { color: var(--soft-white); font-size: clamp(1.2rem, 3vw, 1.45rem); font-weight: var(--w-med); margin-block-start: 0.2rem; }
.step-desc { color: var(--cream-dim); font-size: 0.9rem; font-weight: var(--w-light); margin-block-start: 0.3rem; }
.stack { display: flex; flex-direction: column; gap: 1.2rem; }
.cond-block { display: none; }
.cond-block.is-on { display: block; }
.cond-title { color: var(--gold); font-weight: var(--w-med); font-size: 1rem; margin-block-end: 0.9rem; display: flex; align-items: center; gap: 0.5rem; }
.wiz-nav { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-block-start: 1.7rem; }

/* file input */
.filedrop { display: flex; align-items: center; gap: 0.8rem; padding: 1rem; background: var(--surf-2); border: 1px dashed var(--gold-line); border-radius: var(--radius-sm); color: var(--cream-dim); font-size: 0.9rem; cursor: pointer; transition: background-color 0.2s var(--ease); }
.filedrop:hover { background: var(--surf-3); }
.filedrop svg { inline-size: 1.4rem; block-size: 1.4rem; color: var(--gold); flex: none; }
.filedrop input { display: none; }
.filelist { display: flex; flex-direction: column; gap: 0.4rem; margin-block-start: 0.6rem; }
.filelist li { display: flex; align-items: center; justify-content: space-between; gap: 0.6rem; color: var(--cream); font-size: 0.85rem; background: var(--surf-2); padding-block: 0.4rem; padding-inline: 0.7rem; border-radius: var(--radius-sm); }
.filelist button { color: var(--danger); font-size: 1.1rem; line-height: 1; }

/* review summary */
.summary { display: flex; flex-direction: column; gap: 0.2rem; }
.summary-row { display: grid; grid-template-columns: 11rem 1fr; gap: 0.6rem 1rem; padding-block: 0.7rem; align-items: baseline; }
.summary-row + .summary-row { border-block-start: 1px solid var(--surf-line); }
.summary-row dt { color: var(--cream-dim); font-size: 0.88rem; }
.summary-row dd { color: var(--soft-white); font-size: 0.95rem; font-weight: var(--w-reg); }

/* =================================================================
   CONSULTING (consulting.html)
   ================================================================= */
.gateway { display: grid; grid-template-columns: 55fr 45fr; gap: 1.4rem; align-items: stretch; }
.path-card { position: relative; display: flex; flex-direction: column; gap: 0.9rem; padding: clamp(1.5rem, 3.2vw, 2.4rem); border-radius: var(--radius); background: var(--surf-1); isolation: isolate; border: 1px solid var(--surf-line); }
.path-tag { color: var(--cream-dim); font-size: 0.8rem; font-weight: var(--w-med); letter-spacing: 0.04em; }
.path-title { color: var(--soft-white); font-family: var(--font-heading); font-weight: var(--w-med); font-size: clamp(1.3rem, 3vw, 1.75rem); }
.path-desc { color: var(--cream); font-weight: var(--w-light); font-size: 0.98rem; line-height: 1.8; flex: 1; }
.path-card .btn { align-self: flex-start; }
.path-card--premium { border: 1.5px solid var(--gold); background: linear-gradient(165deg, #0d2748, #0a1f39 70%); box-shadow: 0 24px 60px -28px rgba(224,197,143,0.45); }
.path-card--premium .path-tag { color: var(--gold); }
.path-card--premium::before {
  content: ""; position: absolute; inset: -1.5px; border-radius: inherit; z-index: -1; pointer-events: none;
  padding: 1.5px;
  background: conic-gradient(from var(--beam), transparent 0deg, transparent 80deg, var(--gold) 120deg, var(--gold-bright) 145deg, var(--gold) 170deg, transparent 210deg, transparent 360deg);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: 0.85; animation: beam-spin 4s linear infinite;
}
.path-badge { position: absolute; inset-block-start: 1.1rem; inset-inline-end: 1.1rem; background: var(--gold); color: var(--navy); font-size: 0.72rem; font-weight: var(--w-semi); padding-block: 0.25rem; padding-inline: 0.6rem; border-radius: var(--radius-pill); }

.view { display: none; }
.view.is-active { display: block; animation: rise 0.4s var(--ease) both; }
.view-back { display: inline-flex; align-items: center; gap: 0.45rem; color: var(--cream-dim); font-size: 0.9rem; margin-block-end: 1.1rem; }
.view-back:hover { color: var(--gold); }
.view-back svg { inline-size: 1rem; block-size: 1rem; }

/* ---- AI chat ---- */
.chat { display: flex; flex-direction: column; block-size: min(72vh, 600px); background: var(--surf-1); border-radius: var(--radius); overflow: hidden; border: 1px solid var(--surf-line); }
.chat-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 0.9rem 1.1rem; position: relative; flex-wrap: wrap; }
.chat-head::after { content: ""; position: absolute; inset-inline: 1.1rem; inset-block-end: 0; block-size: 1px; background: var(--fade-line); animation: divider-pulse 6s ease-in-out infinite; }
.chat-id { display: flex; align-items: center; gap: 0.6rem; }
.chat-id .dot { inline-size: 0.55rem; block-size: 0.55rem; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 4px var(--gold-tint); }
.chat-id b { color: var(--soft-white); font-size: 0.95rem; font-weight: var(--w-med); }
.chat-id span { color: var(--cream-dim); font-size: 0.78rem; display: block; }
.token-meter { display: flex; flex-direction: column; gap: 0.3rem; min-inline-size: 11rem; }
.token-meter .tm-head { display: flex; justify-content: space-between; color: var(--cream-dim); font-size: 0.76rem; }
.token-meter .tm-head b { color: var(--gold); font-weight: var(--w-med); }
.token-track { block-size: 5px; background: var(--surf-3); border-radius: 3px; overflow: hidden; }
.token-bar { block-size: 100%; inline-size: 100%; border-radius: 3px; background: linear-gradient(90deg, var(--gold-deep), var(--gold-bright)); transition: inline-size 0.4s var(--ease), background 0.4s var(--ease); }
.token-meter.is-low .token-bar { background: linear-gradient(90deg, #b5762f, #e8a23c); }
.token-meter.is-low .tm-head b { color: #e8a23c; }
.chat-log { flex: 1; overflow-y: auto; padding: 1.1rem; display: flex; flex-direction: column; gap: 0.75rem; scrollbar-width: thin; scrollbar-color: var(--gold-deep) transparent; }
.chat-log::-webkit-scrollbar { inline-size: 7px; }
.chat-log::-webkit-scrollbar-thumb { background: var(--gold-deep); border-radius: 4px; }
.msg { max-inline-size: 82%; padding-block: 0.7rem; padding-inline: 1rem; border-radius: 1.1rem; font-size: 0.95rem; line-height: 1.75; font-weight: var(--w-light); white-space: pre-wrap; }
.msg.bot { align-self: flex-start; background: var(--surf-2); color: var(--soft-white); border-start-start-radius: 0.3rem; }
.msg.user { align-self: flex-end; background: linear-gradient(160deg, var(--gold-bright), var(--gold)); color: var(--navy); border-start-end-radius: 0.3rem; font-weight: var(--w-reg); }
.msg.sys { align-self: center; background: var(--gold-tint); color: var(--cream); font-size: 0.82rem; text-align: center; max-inline-size: 92%; }
.typing { align-self: flex-start; display: inline-flex; gap: 0.25rem; padding: 0.8rem 1rem; }
.typing i { inline-size: 0.45rem; block-size: 0.45rem; border-radius: 50%; background: var(--cream-dim); animation: blink 1.2s infinite; }
.typing i:nth-child(2) { animation-delay: 0.2s; } .typing i:nth-child(3) { animation-delay: 0.4s; }
@keyframes blink { 0%, 60%, 100% { opacity: 0.25; } 30% { opacity: 1; } }
.chat-foot { padding: 0.8rem; position: relative; }
.chat-foot::before { content: ""; position: absolute; inset-inline: 0.8rem; inset-block-start: 0; block-size: 1px; background: var(--fade-line); }
.chat-form { display: flex; gap: 0.6rem; align-items: flex-end; }
.chat-input { flex: 1; resize: none; min-block-size: 2.8rem; max-block-size: 7rem; padding-block: 0.7rem; }
.chat-send { flex: none; inline-size: 3rem; block-size: 3rem; padding: 0; border-radius: 50%; }
.chat-handoff { display: none; margin-block-start: 0.8rem; }
.chat-handoff.is-on { display: block; }

/* ---- premium pillars ---- */
.pillars { display: flex; flex-direction: column; gap: 0.9rem; }
.pillar { background: var(--surf-1); border: 1px solid var(--surf-line); border-radius: var(--radius); overflow: hidden; transition: background-color 0.3s var(--ease); }
.pillar.is-open { background: var(--surf-2); }
.pillar-head { inline-size: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.1rem 1.3rem; text-align: start; cursor: pointer; }
.pillar-head .ph-main { display: flex; align-items: center; gap: 0.9rem; }
.pillar-num { inline-size: 2.1rem; block-size: 2.1rem; flex: none; display: grid; place-items: center; border-radius: 50%; border: 1px solid var(--gold-line); color: var(--gold); font-weight: var(--w-semi); font-size: 0.95rem; }
.pillar.is-open .pillar-num { background: var(--gold); color: var(--navy); border-color: transparent; }
.pillar-name { color: var(--soft-white); font-family: var(--font-heading); font-weight: var(--w-med); font-size: 1.08rem; }
.pillar-name small { display: block; color: var(--cream-dim); font-size: 0.8rem; font-weight: var(--w-light); margin-block-start: 0.1rem; }
.pillar-chev { inline-size: 1.2rem; block-size: 1.2rem; color: var(--gold); flex: none; transition: transform 0.35s var(--ease); }
.pillar.is-open .pillar-chev { transform: rotate(180deg); }
.pillar-sub { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 0.4s var(--ease); }
.pillar.is-open .pillar-sub { grid-template-rows: 1fr; }
.pillar-sub-inner { overflow: hidden; min-block-size: 0; visibility: hidden; transition: visibility 0s linear 0.4s; }
.pillar.is-open .pillar-sub-inner { visibility: visible; transition-delay: 0s; }
.pillar-sub-pad { padding: 0 1.3rem 1.3rem; }
.sub-lead { color: var(--cream-dim); font-size: 0.85rem; margin-block-end: 0.8rem; }

/* ---- reassurance lock ---- */
.reassure { display: flex; align-items: flex-start; gap: 0.75rem; background: var(--gold-tint); border: 1px solid var(--gold-line); border-radius: var(--radius-sm); padding: 0.95rem 1.1rem; }
.reassure svg { inline-size: 1.4rem; block-size: 1.4rem; color: var(--gold); flex: none; margin-block-start: 0.1rem; }
.reassure b { color: var(--soft-white); font-weight: var(--w-med); font-size: 0.95rem; display: block; }
.reassure p { color: var(--cream-dim); font-size: 0.85rem; font-weight: var(--w-light); margin-block-start: 0.15rem; }
.submit-row { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; margin-block-start: 1.3rem; }

/* ---- responsive ---- */
@media (max-width: 760px) {
  .gateway { grid-template-columns: 1fr; }
  .grid-2 { grid-template-columns: 1fr; }
  .summary-row { grid-template-columns: 1fr; gap: 0.15rem; }
  .wiz-nav .btn, .submit-row .btn { flex: 1; }
}

/* =================================================================
   LIVE PREVIEW LINKS BAR (dev aid — fixed, dismissible)
   ================================================================= */
.preview-links {
  position: fixed; inset-block-end: 0; inset-inline: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center; flex-wrap: wrap;
  gap: 0.55rem 1rem; padding-block: 0.65rem; padding-inline: 1rem;
  background: rgba(6, 22, 45, 0.95);
  -webkit-backdrop-filter: blur(14px) saturate(140%); backdrop-filter: blur(14px) saturate(140%);
  font-family: var(--font-body); font-size: 0.85rem;
}
.preview-links::before {
  content: ""; position: absolute; inset-inline: 0; inset-block-start: 0; block-size: 1px;
  background: var(--fade-line); animation: divider-pulse 6s ease-in-out infinite;
}
.preview-links.is-hidden { display: none; }
.pl-label { color: var(--gold); font-weight: var(--w-semi); display: inline-flex; align-items: center; gap: 0.4rem; }
.pl-label svg { inline-size: 1.05rem; block-size: 1.05rem; }
.preview-link {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding-block: 0.42rem; padding-inline: 0.85rem;
  background: var(--surf-2, #102a49); border: 1px solid var(--gold-line); border-radius: var(--radius-pill);
}
.preview-link .pl-tag { color: var(--cream-dim); font-size: 0.76rem; white-space: nowrap; }
.preview-link a { color: var(--gold-bright); font-weight: var(--w-med); font-size: 0.86rem; direction: ltr; }
.preview-link a:hover { text-decoration: underline; }
.pl-copy { display: inline-grid; place-items: center; inline-size: 1.7rem; block-size: 1.7rem; color: var(--cream-dim); border-radius: 50%; flex: none; }
.pl-copy svg { inline-size: 0.95rem; block-size: 0.95rem; }
.pl-copy:hover { color: var(--gold); background: rgba(224, 197, 143, 0.12); }
.preview-close { color: var(--cream-dim); font-size: 1.35rem; line-height: 1; padding: 0.1rem 0.55rem; border-radius: 50%; }
.preview-close:hover { color: var(--gold); background: rgba(224, 197, 143, 0.1); }
@media (max-width: 620px) {
  .preview-links { gap: 0.35rem 0.5rem; font-size: 0.78rem; padding-block: 0.5rem; }
  .pl-label { inline-size: 100%; justify-content: center; }
  .preview-link { padding-inline: 0.6rem; gap: 0.35rem; }
  .preview-link a { font-size: 0.74rem; }
}

/* ---- AI session countdown timer ---- */
.session-timer { display: inline-flex; align-items: center; gap: 0.45rem; padding-block: 0.42rem; padding-inline: 0.85rem; background: var(--surf-2); border: 1px solid var(--gold-line); border-radius: var(--radius-pill); }
.session-timer svg { inline-size: 1.05rem; block-size: 1.05rem; color: var(--gold); }
.session-timer .st-time { font-weight: var(--w-semi); color: var(--gold); font-variant-numeric: tabular-nums; min-inline-size: 3rem; text-align: center; font-size: 0.98rem; direction: ltr; }
.session-timer .st-label { color: var(--cream-dim); font-size: 0.76rem; }
.session-timer.is-low { border-color: #e8a23c; background: rgba(232, 162, 60, 0.12); }
.session-timer.is-low svg, .session-timer.is-low .st-time { color: #e8a23c; }

/* ---- chat quick-start suggestions ---- */
.chat-suggest { display: flex; flex-wrap: wrap; gap: 0.5rem; align-self: flex-start; max-inline-size: 92%; }
.chat-suggest button {
  padding-block: 0.5rem; padding-inline: 0.95rem; border-radius: var(--radius-pill);
  background: var(--surf-2); color: var(--soft-white); border: 1px solid var(--gold-line);
  font-family: var(--font-heading); font-weight: var(--w-med); font-size: 0.85rem; cursor: pointer;
  transition: background-color 0.2s var(--ease), color 0.2s var(--ease), border-color 0.2s var(--ease);
}
.chat-suggest button:hover { background: var(--gold); color: var(--navy); border-color: transparent; }

/* =================================================================
   PREMIUM BOOKING ENGINE (consulting.html)
   ================================================================= */
.book-phase { margin-block-end: 1.8rem; }
.phase-h { display: flex; align-items: center; gap: 0.7rem; color: var(--soft-white); font-family: var(--font-heading); font-weight: var(--w-med); font-size: 1.12rem; margin-block-end: 1rem; }
.phase-num { inline-size: 1.95rem; block-size: 1.95rem; flex: none; display: grid; place-items: center; border-radius: 50%; background: var(--gold); color: var(--navy); font-weight: var(--w-semi); font-size: 0.9rem; }

/* calendar */
.cal { background: var(--surf-1); border-radius: var(--radius); padding: 1rem 1.1rem; }
.cal-head { display: flex; align-items: center; justify-content: space-between; margin-block-end: 0.9rem; }
.cal-title { color: var(--soft-white); font-weight: var(--w-med); font-size: 1rem; }
.cal-nav { inline-size: 2.2rem; block-size: 2.2rem; display: grid; place-items: center; border-radius: 50%; color: var(--gold); background: var(--surf-2); transition: background-color 0.2s var(--ease); }
.cal-nav:hover { background: var(--surf-3); }
.cal-nav:disabled { opacity: 0.35; cursor: not-allowed; }
.cal-nav svg { inline-size: 1.1rem; block-size: 1.1rem; }
.cal-dow { display: grid; grid-template-columns: repeat(7, 1fr); gap: 0.3rem; margin-block-end: 0.4rem; }
.cal-dow span { text-align: center; color: var(--cream-dim); font-size: 0.72rem; }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 0.3rem; }
.cal-cell { aspect-ratio: 1; display: grid; place-items: center; border-radius: var(--radius-sm); color: var(--soft-white); font-size: 0.92rem; background: transparent; border: 1px solid transparent; cursor: pointer; transition: background-color 0.15s var(--ease), color 0.15s var(--ease); }
.cal-cell.is-empty { background: none; cursor: default; }
.cal-cell:not(.is-off):not(.is-empty):hover { background: var(--surf-2); }
.cal-cell.is-off { color: rgba(215, 201, 172, 0.22); cursor: not-allowed; }
.cal-cell.is-sel { background: var(--gold); color: var(--navy); font-weight: var(--w-semi); }

/* time slots */
.slots { display: grid; grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); gap: 0.6rem; }
.slot { padding-block: 0.65rem; border-radius: var(--radius-pill); background: var(--surf-2); color: var(--soft-white); border: 1px solid var(--surf-line); font-family: var(--font-heading); font-weight: var(--w-med); font-size: 0.88rem; cursor: pointer; text-align: center; transition: background-color 0.15s var(--ease), color 0.15s var(--ease), border-color 0.15s var(--ease); }
.slot:hover:not(:disabled) { background: var(--surf-3); border-color: var(--gold-line); }
.slot.is-sel { background: var(--gold); color: var(--navy); border-color: transparent; font-weight: var(--w-semi); }
.slot:disabled { opacity: 0.3; cursor: not-allowed; }
.slots-empty { color: var(--cream-dim); font-size: 0.9rem; padding-block: 0.5rem; }

/* duration price */
.price-box { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 0.95rem 1.3rem; margin-block-start: 1rem; background: var(--gold-tint); border: 1px solid var(--gold-line); border-radius: var(--radius); }
.price-box > span { color: var(--cream); font-size: 0.95rem; }
.price-box b { color: var(--gold-bright); font-size: 1.45rem; font-weight: var(--w-semi); }
.price-box b span { font-variant-numeric: tabular-nums; }

/* contract hand-off */
.contract-box { margin-block-start: 1rem; padding: 1.3rem; border-radius: var(--radius); background: linear-gradient(160deg, #0d2748, #0a1f39 70%); border: 1.5px solid var(--gold); }
.contract-box h4 { color: var(--gold); font-family: var(--font-heading); font-weight: var(--w-semi); font-size: 1.05rem; margin-block-end: 0.5rem; }
.contract-box p { color: var(--cream); font-size: 0.92rem; line-height: 1.85; font-weight: var(--w-light); }
.contract-box p b { color: var(--gold-bright); font-weight: var(--w-semi); }

/* bank transfer details */
.bank-box { background: var(--surf-1); border-radius: var(--radius); padding: 0.4rem 1.2rem; }
.bank-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding-block: 0.7rem; }
.bank-row + .bank-row { border-block-start: 1px solid var(--surf-line); }
.bank-row dt { color: var(--cream-dim); font-size: 0.85rem; }
.bank-row dd { color: var(--soft-white); font-weight: var(--w-med); font-size: 0.9rem; direction: ltr; text-align: start; }

/* lock / SLA notice */
.lock-notice { display: flex; align-items: flex-start; gap: 0.75rem; padding: 1rem 1.2rem; border-radius: var(--radius-sm); background: rgba(232, 162, 60, 0.1); border: 1px solid rgba(232, 162, 60, 0.4); }
.lock-notice svg { inline-size: 1.4rem; block-size: 1.4rem; color: #e8a23c; flex: none; margin-block-start: 0.1rem; }
.lock-notice b { color: var(--soft-white); font-weight: var(--w-med); display: block; }
.lock-notice p { color: var(--cream-dim); font-size: 0.85rem; font-weight: var(--w-light); margin-block-start: 0.2rem; line-height: 1.75; }
