*, *::before, *::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink-900);
  font-family: var(--font-body);
  font-size: var(--fs-16);
  line-height: var(--lh-body);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  min-height: 100vh;
}

body.theme-paper {
  background: var(--cream-50);
  color: var(--ink-900);
}

img, svg, video {
  max-width: 100%;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
  padding: 0;
  color: inherit;
}

input, textarea, select {
  font: inherit;
  color: inherit;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 900;
  line-height: var(--lh-display);
  letter-spacing: var(--ls-tight);
  margin: 0;
  text-transform: uppercase;
}

h1 { font-size: var(--fs-display); }
h2 { font-size: clamp(2.25rem, 5vw, 4.5rem); }
h3 { font-size: clamp(1.5rem, 2.8vw, 2.25rem); }
h4 { font-size: var(--fs-24); }

p { margin: 0 0 1em; }
p:last-child { margin-bottom: 0; }

ul, ol { margin: 0; padding: 0; list-style: none; }

::selection {
  background: var(--gold-500);
  color: var(--violet-950);
}

:focus-visible {
  outline: 3px solid var(--gold-400);
  outline-offset: 3px;
  border-radius: 2px;
}

.shell {
  width: 100%;
  max-width: var(--max-w-xl);
  margin: 0 auto;
  padding-inline: var(--gutter);
}

.shell--md { max-width: var(--max-w-md); }
.shell--lg { max-width: var(--max-w-lg); }

.section {
  position: relative;
  padding-block: clamp(3.5rem, 7vw, 6.5rem);
}

.section--tight { padding-block: clamp(2.5rem, 5vw, 4rem); }

.section + .section { padding-top: clamp(2.5rem, 5vw, 4.5rem); }

.eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-12);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  font-weight: 700;
  color: var(--gold-400);
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
}

.eyebrow::before {
  content: "";
  width: 32px;
  height: 2px;
  background: var(--gold-500);
  display: inline-block;
}

/* Old "gold-fill text with violet drop shadow" was the signature
   on dark backgrounds. On editorial-white, we invert: brand-purple
   text with a soft gold drop-stamp behind it — same editorial
   stamping motif, legible on white. */
.headline-gold {
  color: var(--violet-900);
  text-shadow:
    3px 3px 0 var(--gold-300),
    6px 6px 0 rgba(242, 201, 64, 0.35);
}

.headline-stroke {
  -webkit-text-stroke: 2px var(--gold-500);
  color: transparent;
}

/* Editorial-white repurposing of the section utility classes:
   .bg-purple → cream alternation row (was vibrant purple gradient)
   .bg-deep   → white surface (was violet-950 dark)
   Sections that explicitly want the dark brand-purple anchor look
   should use .bg-purple--anchor (sparingly, max once per page). */
.bg-purple {
  background: var(--cream-50);
  color: var(--ink-900);
}

.bg-purple--anchor {
  background: var(--grad-purple);
  color: var(--paper);
}

.bg-deep {
  background: var(--paper);
  color: var(--ink-900);
  position: relative;
}

.bg-hero {
  background: var(--grad-hero);
  color: var(--ink-900);
  position: relative;
  isolation: isolate;
}

.bg-cream {
  background: var(--cream-50);
  color: var(--ink-900);
}

.grain-overlay::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("../images/motifs/grain.svg");
  background-size: 240px 240px;
  opacity: 0.12;
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 1;
}

.diag-divider {
  position: relative;
  overflow: hidden;
}

.diag-divider::after {
  content: "";
  position: absolute;
  inset-inline: -10%;
  height: 120px;
  bottom: -60px;
  background: inherit;
  transform: skewY(-3.5deg);
  z-index: 0;
}

.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity var(--dur-slow) var(--ease-out),
    transform var(--dur-slow) var(--ease-out);
  will-change: opacity, transform;
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal.reveal--delay-1 { transition-delay: 80ms; }
.reveal.reveal--delay-2 { transition-delay: 160ms; }
.reveal.reveal--delay-3 { transition-delay: 240ms; }
.reveal.reveal--delay-4 { transition-delay: 320ms; }
.reveal.reveal--delay-5 { transition-delay: 400ms; }

.stack {
  display: flex;
  flex-direction: column;
}

.stack > * + * { margin-top: var(--gap, 1.5rem); }

.row {
  display: flex;
  align-items: center;
  gap: var(--gap, 1rem);
  flex-wrap: wrap;
}

.grid {
  display: grid;
  gap: var(--gap, 1.5rem);
}

.grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

@media (max-width: 1024px) {
  .grid--4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .grid--3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px) {
  .grid--2,
  .grid--3,
  .grid--4 { grid-template-columns: 1fr; }
}

.ar {
  font-family: var(--font-arabic);
  direction: rtl;
  line-height: 1.9;
}

.ar-display {
  font-family: var(--font-arabic);
  font-weight: 900;
  direction: rtl;
}

.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

.swoosh-bg {
  position: absolute;
  inset: auto;
  z-index: 0;
  pointer-events: none;
  opacity: 0.35;
  filter: blur(0.4px);
}

@keyframes floatY {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-18px) rotate(1.2deg); }
}

@keyframes drift {
  0%   { transform: translate3d(0,0,0) scale(1); }
  33%  { transform: translate3d(3%, -2%, 0) scale(1.04); }
  66%  { transform: translate3d(-2%, 3%, 0) scale(0.98); }
  100% { transform: translate3d(0,0,0) scale(1); }
}

@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

@keyframes ribbonDrop {
  0% { transform: translateY(-32px) scaleY(0.8); opacity: 0; }
  60% { transform: translateY(4px) scaleY(1.02); opacity: 1; }
  100% { transform: translateY(0) scaleY(1); opacity: 1; }
}

html[lang="ar"] body {
  font-family: var(--font-arabic);
  direction: rtl;
}

html[lang="ar"] h1,
html[lang="ar"] h2,
html[lang="ar"] h3,
html[lang="ar"] h4 {
  font-family: var(--font-arabic);
  text-transform: none;
}
