/* ============================================================
   AKDAĞ HUKUK — Design System
   Cinematic premium law-firm theme · TR / EN / AR (RTL)
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&family=Poppins:wght@300;400;500;600&family=Sora:wght@300;400;500;600&family=Montserrat:wght@300;400;500;600;700&family=Hanken+Grotesk:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400;1,500&family=Noto+Kufi+Arabic:wght@300;400;500;600;700&family=Noto+Sans+Arabic:wght@300;400;500;600;700&display=swap');

/* ============================================================
   TOKENS
   ============================================================ */
:root{
  /* Dark Gold (default) */
  --bg:        #0a0a0c;
  --bg-2:      #0f0f12;
  --surface:   #16151a;
  --surface-2: #1c1b21;
  --text:      #f4f0e8;
  --muted:     #a7a193;
  --faint:     #6f6a60;
  --line:      rgba(244,240,232,.12);
  --line-2:    rgba(244,240,232,.06);
  --accent:    oklch(0.76 0.10 84);     /* warm gold */
  --accent-2:  oklch(0.82 0.075 88);    /* light gold */
  --accent-ink:#0a0a0c;
  --on-media:  #ffffff;

  /* type */
  --display: "Outfit", "Hanken Grotesk", system-ui, sans-serif;
  --sans:  "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;
  --arab-display: "Noto Kufi Arabic", "Hanken Grotesk", sans-serif;
  --arab-sans:  "Noto Sans Arabic", "Hanken Grotesk", sans-serif;
  --font-display: var(--display);
  --font-body: var(--sans);

  /* metrics */
  --maxw: 1280px;
  --gutter: clamp(20px, 5vw, 72px);
  --radius: 2px;
  --nav-h: 76px;

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

/* Deep Navy theme */
[data-theme="navy"]{
  --bg:#0a121f; --bg-2:#0c1626; --surface:#11203a; --surface-2:#16294a;
  --text:#eef2f8; --muted:#9fb0c8; --faint:#647494;
  --line:rgba(238,242,248,.14); --line-2:rgba(238,242,248,.06);
  --accent:oklch(0.84 0.07 86); --accent-2:oklch(0.88 0.05 88); --accent-ink:#0a121f;
}

/* Ivory (light) theme */
[data-theme="ivory"]{
  --bg:#f5f3ee; --bg-2:#efece4; --surface:#ffffff; --surface-2:#f2efe8;
  --text:#16140f; --muted:#6c665b; --faint:#9b958a;
  --line:rgba(22,20,15,.14); --line-2:rgba(22,20,15,.06);
  --accent:oklch(0.62 0.10 70); --accent-2:oklch(0.55 0.11 60); --accent-ink:#fff;
  --on-media:#ffffff;
}

/* font-display variants (Tweaks) */
[data-type="jakarta"]{ --display: "Plus Jakarta Sans", system-ui, sans-serif; --font-display: var(--display); }
[data-type="poppins"]{ --display: "Poppins", system-ui, sans-serif; --font-display: var(--display); }
[data-type="sora"]{ --display: "Sora", system-ui, sans-serif; --font-display: var(--display); }
[data-type="montserrat"]{ --display: "Montserrat", system-ui, sans-serif; --font-display: var(--display); }

/* Arabic */
html[lang="ar"]{ --font-display: var(--arab-display); --font-body: var(--arab-sans); }

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; overflow-x:clip; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--font-body); font-weight:400;
  font-size:clamp(15px,1.05vw,17px); line-height:1.7;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:clip;
}
img,video{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
h1,h2,h3,h4,h5,p{ margin:0; }
::selection{ background:var(--accent); color:var(--accent-ink); }

/* ============================================================
   TYPOGRAPHY HELPERS
   ============================================================ */
.kicker{
  font-family:var(--font-body); font-weight:600;
  font-size:clamp(11px,.78vw,12.5px); letter-spacing:.32em; text-transform:uppercase;
  color:var(--accent); display:inline-flex; align-items:center; gap:.7em;
}
html[lang="ar"] .kicker{ letter-spacing:0; }
.kicker::before{ content:""; width:26px; height:1px; background:currentColor; opacity:.7; }
.kicker.center::after{ content:""; width:26px; height:1px; background:currentColor; opacity:.7; }
.kicker.center{ justify-content:center; }

.display{
  font-family:var(--font-display); font-weight:500; line-height:1.04;
  letter-spacing:-.01em; font-size:clamp(40px,7vw,104px);
}
html[lang="ar"] .display{ line-height:1.2; letter-spacing:0; font-weight:600; }
.h1{ font-family:var(--font-display); font-weight:500; line-height:1.08; letter-spacing:-.01em; font-size:clamp(34px,5vw,68px); }
.h2{ font-family:var(--font-display); font-weight:500; line-height:1.12; letter-spacing:-.005em; font-size:clamp(28px,3.6vw,50px); }
.h3{ font-family:var(--font-display); font-weight:500; line-height:1.18; letter-spacing:0; font-size:clamp(22px,2.2vw,32px); }
.lead{ font-size:clamp(17px,1.5vw,22px); line-height:1.6; color:var(--muted); }
.serif-it{ font-family:var(--font-body); font-weight:500; font-style:italic; }
.muted{ color:var(--muted); }
.accent{ color:var(--accent); }

/* ============================================================
   LAYOUT
   ============================================================ */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(80px,11vw,168px); position:relative; overflow-x:clip; }
.section--tight{ padding-block:clamp(56px,7vw,104px); }
.divider{ height:1px; background:var(--line); border:0; margin:0; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; gap:.7em; white-space:nowrap;
  padding:1em 1.7em; font-family:var(--font-body); font-weight:600;
  font-size:13.5px; letter-spacing:.04em; border-radius:var(--radius);
  transition:transform .5s var(--ease), background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease);
  will-change:transform;
}
.btn .arw{ transition:transform .5s var(--ease); }
.btn:hover .arw{ transform:translateX(.3em); }
html[lang="ar"] .btn:hover .arw{ transform:translateX(-.3em); }
.btn--gold{ background:var(--accent); color:var(--accent-ink); }
.btn--gold:hover{ background:var(--accent-2); }
.btn--line{ border:1px solid var(--line); color:var(--text); }
.btn--line:hover{ border-color:var(--accent); color:var(--accent); }
.btn--ghost{ color:var(--text); padding-inline:0; }
.btn--ghost .ln{ position:relative; }
.btn--ghost .ln::after{ content:""; position:absolute; left:0; right:0; bottom:-3px; height:1px; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.btn--ghost:hover .ln::after{ transform:scaleX(1); }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
@media (prefers-reduced-motion: no-preference){
  [data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity 1s var(--ease-out), transform 1s var(--ease-out); }
  [data-reveal].in{ opacity:1; transform:none; }
  [data-reveal][data-delay="1"]{ transition-delay:.08s; }
  [data-reveal][data-delay="2"]{ transition-delay:.16s; }
  [data-reveal][data-delay="3"]{ transition-delay:.24s; }
  [data-reveal][data-delay="4"]{ transition-delay:.32s; }
  [data-reveal][data-delay="5"]{ transition-delay:.40s; }
  .reveal-line{ display:block; overflow:hidden; }
  .reveal-line > *{ display:block; transform:translateY(110%); transition:transform 1.1s var(--ease-out); }
  .in .reveal-line > *{ transform:none; }
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; inset-block-start:0; inset-inline:0; z-index:90; height:var(--nav-h);
  display:flex; align-items:center;
  transition:background .5s var(--ease), backdrop-filter .5s var(--ease), border-color .5s var(--ease), height .4s var(--ease);
  border-block-end:1px solid transparent;
}
.nav__row{ display:flex; align-items:center; justify-content:space-between; width:100%;
  max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.nav.scrolled{ background:color-mix(in oklab, var(--bg) 80%, transparent); backdrop-filter:blur(16px) saturate(1.2); border-block-end-color:var(--line); height:64px; }
[data-theme="ivory"] .nav.scrolled{ background:color-mix(in oklab, var(--bg) 88%, transparent); }

.brand{ display:flex; align-items:center; gap:.7em; flex:none; }
.brand__logo{ height:44px; display:flex; align-items:center; flex:none; }
.brand__logo img{ height:100%; width:auto; display:block; }
.brand__stack{ display:flex; flex-direction:column; }
.brand__word{ font-family:var(--font-display); font-weight:600; font-size:19px; letter-spacing:.2em; line-height:1.05; color:var(--text); white-space:nowrap; }
.nav:not(.scrolled).on-hero .brand__word{ color:#fff; }
.brand__sub{ font-family:var(--font-body); font-size:9.5px; font-weight:500; letter-spacing:.26em; text-transform:uppercase; color:var(--accent); margin-block-start:3px; white-space:nowrap; }

.nav__links{ display:flex; align-items:center; gap:clamp(14px,1.6vw,30px); list-style:none; margin:0; padding:0; }
.nav__links a{ font-size:13.5px; font-weight:500; letter-spacing:.02em; color:var(--text); position:relative; padding-block:6px; opacity:.86; transition:opacity .3s, color .3s; white-space:nowrap; }
.nav__links a:hover{ opacity:1; color:var(--accent); }
.nav__links a.active{ color:var(--accent); opacity:1; }
.nav:not(.scrolled).on-hero .nav__links a{ color:#fff; }
.nav:not(.scrolled).on-hero .nav__links a:hover,.nav:not(.scrolled).on-hero .nav__links a.active{ color:var(--accent-2); }

.nav__right{ display:flex; align-items:center; gap:18px; }
.langsw{ display:flex; align-items:center; gap:2px; border:1px solid var(--line); border-radius:999px; padding:3px; }
.nav:not(.scrolled).on-hero .langsw{ border-color:rgba(255,255,255,.22); }
.langsw button{ font-size:11px; font-weight:600; letter-spacing:.06em; padding:5px 9px; border-radius:999px; color:var(--muted); transition:.3s; line-height:1; }
.nav:not(.scrolled).on-hero .langsw button{ color:rgba(255,255,255,.7); }
.langsw button.active{ background:var(--accent); color:var(--accent-ink); }

.nav__cta{ display:inline-flex; }
.burger{ display:none; width:40px; height:40px; align-items:center; justify-content:center; }
.burger span{ display:block; width:22px; height:1.5px; background:var(--text); position:relative; transition:.4s; }
.nav:not(.scrolled).on-hero .burger span{ background:#fff; }
.burger span::before,.burger span::after{ content:""; position:absolute; left:0; width:22px; height:1.5px; background:inherit; transition:.4s; }
.burger span::before{ top:-7px; } .burger span::after{ top:7px; }
.burger.open span{ background:transparent; }
.burger.open span::before{ top:0; transform:rotate(45deg); }
.burger.open span::after{ top:0; transform:rotate(-45deg); }

/* mobile menu */
.mmenu{ position:fixed; inset:0; z-index:80; background:var(--bg); padding:calc(var(--nav-h) + 24px) var(--gutter) 40px;
  display:flex; flex-direction:column; gap:6px; transform:translateY(-100%); opacity:0; pointer-events:none;
  transition:transform .6s var(--ease-out), opacity .4s; }
.mmenu.open{ transform:none; opacity:1; pointer-events:auto; }
.mmenu a{ font-family:var(--font-display); font-size:32px; font-weight:500; letter-spacing:0; padding-block:10px; border-block-end:1px solid var(--line-2); }
.mmenu a:hover{ color:var(--accent); }

/* ============================================================
   HERO — scroll-scrub video
   ============================================================ */
.hero-track{ position:relative; }
.hero-sticky{ position:sticky; top:0; height:100svh; overflow:hidden; background:#000; }
.hero-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transform-origin:center; will-change:transform; }
/* cinematic fallback when codec unavailable (also acts as poster) */
.hero-fallback{ position:absolute; inset:0; opacity:0; transition:opacity .8s ease; transform-origin:center; will-change:transform;
  background:
    radial-gradient(120% 80% at 72% 12%, rgba(214,178,98,.22), transparent 52%),
    radial-gradient(90% 70% at 12% 88%, rgba(150,116,52,.16), transparent 58%),
    radial-gradient(60% 50% at 50% 50%, rgba(40,34,24,.0), rgba(6,6,8,.5) 100%),
    linear-gradient(165deg,#100e0b 0%,#0a0a0c 42%,#070707 70%,#0d0a06 100%);
}
.hero-track.video-failed .hero-fallback{ opacity:1; }
.hero-fallback::before{ content:""; position:absolute; inset:-10%;
  background:radial-gradient(40% 60% at 30% 30%, rgba(214,178,98,.10), transparent 60%);
  animation:drift 18s var(--ease) infinite alternate; }
.hero-fallback::after{ content:""; position:absolute; inset:0; opacity:.55; mix-blend-mode:overlay;
  background-image:
    repeating-linear-gradient(118deg, rgba(255,255,255,.045) 0 1px, transparent 1px 26px),
    repeating-linear-gradient(62deg, rgba(0,0,0,.20) 0 1px, transparent 1px 3px); }
@keyframes drift{ 0%{ transform:translate3d(-4%,-3%,0) } 100%{ transform:translate3d(6%,4%,0) } }

.hero-grade{ position:absolute; inset:0; pointer-events:none;
  background:
    linear-gradient(180deg, rgba(4,4,6,.62) 0%, rgba(4,4,6,.18) 22%, rgba(4,4,6,.10) 50%, rgba(4,4,6,.55) 82%, rgba(4,4,6,.9) 100%),
    radial-gradient(140% 100% at 50% 120%, rgba(4,4,6,.7), transparent 60%); }
.hero-vignette{ position:absolute; inset:0; pointer-events:none; box-shadow:inset 0 0 240px 60px rgba(0,0,0,.6); }

.hero-beats{ position:absolute; inset:0; color:#fff; }
.beat{ position:absolute; inset-inline:0; padding-inline:var(--gutter); display:flex; flex-direction:column;
  opacity:0; will-change:opacity, transform; }
.beat .inner{ max-width:var(--maxw); margin-inline:auto; width:100%; }

/* beat 1 — centered title */
.beat--1{ inset-block:0; align-items:center; justify-content:center; text-align:center; }
.beat--1 .inner{ display:flex; flex-direction:column; align-items:center; gap:22px; }
.beat--1 .display{ color:#fff; text-shadow:0 2px 60px rgba(0,0,0,.5); font-size:clamp(34px,6.2vw,86px); line-height:1.06; white-space:nowrap; font-weight:500; letter-spacing:.005em; }
.beat--1 .sub{ font-family:var(--font-body); font-weight:500; font-style:italic; font-size:clamp(18px,2vw,28px); color:rgba(255,255,255,.84); letter-spacing:.01em; }

/* beat 2 — left statement */
.beat--2{ inset-block:0; justify-content:center; }
.beat--2 .inner{ max-width:min(960px,100%); }
.beat--2 .stmt{ font-family:var(--font-display); font-weight:500; line-height:1.16; letter-spacing:-.01em;
  font-size:clamp(30px,4.4vw,64px); color:#fff; }
html[lang="ar"] .beat--2 .stmt{ line-height:1.3; }

/* beat 3 (mid) — right-aligned statement for rhythm */
.beat--mid{ inset-block:0; justify-content:center; align-items:flex-end; text-align:end; }
.beat--mid .inner{ max-width:min(960px,100%); }
.beat--mid .stmt{ font-family:var(--font-display); font-weight:500; line-height:1.16; letter-spacing:-.01em;
  font-size:clamp(30px,4.4vw,64px); color:#fff; }
html[lang="ar"] .beat--mid .stmt{ line-height:1.3; }

/* beat 3 — closing + CTA */
.beat--3{ inset-block:0; align-items:center; justify-content:center; text-align:center; }
.beat--3 .inner{ display:flex; flex-direction:column; align-items:center; gap:26px; max-width:880px; }
.beat--3 .stmt{ font-family:var(--font-display); font-weight:500; line-height:1.16; letter-spacing:-.01em; font-size:clamp(28px,3.8vw,56px); color:#fff; }
.beat--3 .ctas{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }
.beat--3 .btn--line{ border-color:rgba(255,255,255,.35); color:#fff; }
.beat--3 .btn--line:hover{ border-color:#fff; color:#fff; }

/* scroll cue + progress */
.hero-cue{ position:absolute; inset-block-end:30px; inset-inline:0; display:flex; flex-direction:column; align-items:center; gap:9px;
  color:rgba(255,255,255,.75); font-size:10.5px; letter-spacing:.3em; text-transform:uppercase; transition:opacity .5s; }
.hero-cue .track{ width:1px; height:46px; background:rgba(255,255,255,.25); position:relative; overflow:hidden; }
.hero-cue .track i{ position:absolute; inset-inline:0; top:0; height:40%; background:var(--accent); transform:translateY(-100%); animation:cue 2.4s var(--ease) infinite; }
@keyframes cue{ 0%{transform:translateY(-100%)} 60%,100%{transform:translateY(250%)} }
.hero-prog{ position:absolute; inset-block-end:0; inset-inline-start:0; height:2px; width:0; background:var(--accent); z-index:5; }

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto .h2{ max-width:18ch; }
.manifesto__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(32px,6vw,90px); align-items:end; }
.manifesto__aside{ border-inline-start:1px solid var(--line); padding-inline-start:clamp(20px,2.4vw,36px); }
.manifesto__aside p{ color:var(--muted); }
.sign{ margin-block-start:26px; }
.sign .nm{ font-family:var(--font-display); font-size:23px; font-weight:500; letter-spacing:0; }
.sign .ro{ font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--accent); margin-block-start:4px; }
.bigword{ position:absolute; inset-block-start:-2vw; inset-inline-end:-1vw; font-family:var(--font-display); font-size:24vw;
  line-height:.8; color:var(--text); opacity:.03; pointer-events:none; user-select:none; z-index:0; }

/* stat row */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border-block:1px solid var(--line); }
.stat{ background:var(--bg); padding:clamp(26px,3vw,42px) clamp(18px,2vw,30px); }
.stat .n{ font-family:var(--font-display); font-size:clamp(40px,5vw,68px); line-height:1; color:var(--accent); }
.stat .l{ margin-block-start:10px; font-size:13px; color:var(--muted); letter-spacing:.02em; }

/* ============================================================
   PRACTICE AREAS
   ============================================================ */
.areas{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.area{ background:var(--bg); padding:clamp(28px,3.4vw,52px); position:relative; overflow:hidden; transition:background .5s var(--ease); cursor:default; }
.area::before{ content:""; position:absolute; inset-block-start:0; inset-inline-start:0; width:0; height:2px; background:var(--accent); transition:width .6s var(--ease); }
.area:hover{ background:var(--surface); }
.area:hover::before{ width:100%; }
.area__no{ font-family:var(--font-display); font-size:15px; color:var(--accent); letter-spacing:.1em; }
.area__title{ font-family:var(--font-display); font-size:clamp(24px,2.4vw,34px); font-weight:500; letter-spacing:-.005em; margin-block:14px 12px; line-height:1.12; }
.area__desc{ color:var(--muted); font-size:15px; max-width:46ch; }
.area__more{ margin-block-start:20px; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--faint); display:inline-flex; align-items:center; gap:.6em; opacity:0; transform:translateY(6px); transition:.5s var(--ease); }
.area:hover .area__more{ opacity:1; transform:none; color:var(--accent); }

@media (min-width:900px){ .areas--3{ grid-template-columns:repeat(3,1fr); } }

/* ============================================================
   PROCESS
   ============================================================ */
.process{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,3vw,48px); }
.step{ position:relative; }
.step__no{ font-family:var(--font-display); font-size:clamp(56px,6vw,92px); line-height:1; color:var(--line);
  -webkit-text-stroke:1px var(--accent); color:transparent; }
[data-theme="ivory"] .step__no{ -webkit-text-stroke:1px var(--accent); }
.step__title{ font-family:var(--font-display); font-size:clamp(22px,2vw,28px); font-weight:500; letter-spacing:0; margin-block:18px 12px; }
.step__desc{ color:var(--muted); font-size:15.5px; }
.step__line{ height:1px; background:var(--line); margin-block-start:26px; position:relative; }
.step__line::before{ content:""; position:absolute; inset-inline-start:0; inset-block-start:0; width:38px; height:1px; background:var(--accent); }

/* ============================================================
   TEAM
   ============================================================ */
.team{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(20px,2.4vw,36px); }
.team--3{ grid-template-columns:repeat(3,1fr); }
.member{ position:relative; }
.member__photo{ position:relative; aspect-ratio:4/5; background:var(--surface); overflow:hidden; border:1px solid var(--line); }
.member__ph{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px;
  background-image:repeating-linear-gradient(135deg, var(--line-2) 0 1px, transparent 1px 14px); }
.member__ph .ic{ font-family:var(--font-display); font-size:64px; color:var(--line); }
.member__ph .tx{ font-family:ui-monospace,monospace; font-size:11px; letter-spacing:.12em; color:var(--faint); text-transform:uppercase; }
.member__photo img{ width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.02); transition:filter .6s, transform 1.2s var(--ease); }
.member:hover .member__photo img{ filter:grayscale(0); transform:scale(1.04); }
.member__bar{ position:absolute; inset-block-end:0; inset-inline:0; padding:20px; display:flex; align-items:flex-end; justify-content:space-between;
  background:linear-gradient(0deg, rgba(0,0,0,.72), transparent); }
.member__name{ font-family:var(--font-display); font-size:clamp(22px,2vw,28px); font-weight:500; letter-spacing:0; color:#fff; }
.member__role{ font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--accent-2); margin-block-start:4px; }
.member__socials{ display:flex; gap:10px; }
.member__socials a{ width:34px; height:34px; border:1px solid rgba(255,255,255,.3); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; transition:.4s; }
.member__socials a:hover{ background:var(--accent); border-color:var(--accent); color:var(--accent-ink); }
.member__socials svg{ width:15px; height:15px; }

/* ============================================================
   QUOTES
   ============================================================ */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border-block:1px solid var(--line); }
.quote{ background:var(--bg); padding:clamp(32px,3.5vw,56px); display:flex; flex-direction:column; gap:24px; }
.quote .mark{ font-family:var(--font-display); font-size:64px; line-height:.6; color:var(--accent); height:30px; }
.quote .tx{ font-family:var(--font-body); font-weight:500; font-style:italic; font-size:clamp(20px,1.9vw,26px); line-height:1.45; flex:1; letter-spacing:.005em; }
.quote .who{ font-size:13px; font-weight:600; letter-spacing:.02em; }
.quote .role{ font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-block-start:3px; }

/* ============================================================
   ARTICLES
   ============================================================ */
.articles{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,32px); }
.article{ border:1px solid var(--line); background:var(--bg-2); display:flex; flex-direction:column; transition:border-color .5s, transform .6s var(--ease); }
.article:hover{ border-color:var(--accent); transform:translateY(-4px); }
.article__img{ aspect-ratio:16/10; background:var(--surface); position:relative; overflow:hidden;
  background-image:repeating-linear-gradient(135deg, var(--line-2) 0 1px, transparent 1px 14px); }
.article__img .tag{ position:absolute; inset-block-start:14px; inset-inline-start:14px; font-size:11px; letter-spacing:.12em; text-transform:uppercase; white-space:nowrap;
  background:var(--accent); color:var(--accent-ink); padding:5px 10px; font-weight:600; }
.article__b{ padding:clamp(20px,2vw,28px); display:flex; flex-direction:column; gap:12px; flex:1; }
.article__date{ font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--faint); }
.article__title{ font-family:var(--font-display); font-size:clamp(20px,1.7vw,25px); font-weight:500; letter-spacing:0; line-height:1.22; }
.article__ex{ color:var(--muted); font-size:14.5px; flex:1; }
.article__more{ font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); display:inline-flex; gap:.5em; align-items:center; white-space:nowrap; }

/* ============================================================
   CTA STRIP / CONTACT
   ============================================================ */
.cta{ position:relative; text-align:center; overflow:hidden; }
.cta .h2{ max-width:20ch; margin-inline:auto; }
.cta__note{ margin-block-start:18px; }

.contact__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,80px); }
.cinfo{ display:flex; flex-direction:column; gap:30px; }
.cinfo__item .lab{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-block-end:8px; }
.cinfo__item .val{ font-family:var(--font-display); font-size:clamp(20px,1.8vw,26px); line-height:1.3; }
.cinfo__item .val a:hover{ color:var(--accent); }
.cmap{ border:1px solid var(--line); background:var(--surface); min-height:340px; position:relative; overflow:hidden;
  background-image:repeating-linear-gradient(135deg, var(--line-2) 0 1px, transparent 1px 16px); display:flex; align-items:center; justify-content:center; }
.cmap iframe{ width:100%; height:100%; min-height:340px; border:0; display:block; filter:grayscale(.3) contrast(1.05); }
.cmap .tx{ font-family:ui-monospace,monospace; font-size:11px; letter-spacing:.12em; color:var(--faint); text-transform:uppercase; }

/* form */
.form{ display:grid; gap:18px; align-content:start; background:var(--bg-2); border:1px solid var(--line); border-radius:6px; padding:clamp(24px,3vw,40px); }
.form__head{ margin-block-end:6px; }
.form__head .h3{ letter-spacing:-.015em; }
.form__ok{ background:color-mix(in oklab, var(--accent) 14%, transparent); border:1px solid var(--accent); color:var(--text); padding:14px 16px; border-radius:var(--radius); font-size:14px; }
/* contact-cta section on homepage */
.contact-cta{ background:var(--bg-2); border-block-start:1px solid var(--line); }
.contact-cta .contact__grid{ align-items:start; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{ font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.field input,.field textarea,.field select{ background:var(--surface); border:1px solid var(--line); color:var(--text); padding:14px 16px;
  border-radius:var(--radius); font:inherit; transition:border-color .3s; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--accent); }
.field textarea{ min-height:120px; resize:vertical; }
.form .row2{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ background:var(--bg-2); border-block-start:1px solid var(--line); padding-block:clamp(56px,7vw,90px) 30px; }
.foot__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:clamp(30px,4vw,60px); }
.foot__brand .brand__word{ font-size:26px; }
.foot__brand p{ color:var(--muted); margin-block-start:18px; max-width:34ch; }
.foot__col h4{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-block-end:18px; }
.foot__col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.foot__col a{ color:var(--muted); font-size:14.5px; transition:color .3s; }
.foot__col a:hover{ color:var(--text); }
.foot__bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap;
  margin-block-start:clamp(40px,5vw,64px); padding-block-start:26px; border-block-start:1px solid var(--line); }
.foot__bottom .links{ display:flex; gap:22px; }
.foot__bottom .links a{ font-size:12.5px; letter-spacing:.06em; color:var(--muted); }
.foot__bottom .links a:hover{ color:var(--accent); }
.foot__bottom .cp{ font-size:12.5px; color:var(--faint); }

/* ============================================================
   PAGE HEADER (interior pages)
   ============================================================ */
.phead{ padding-block:calc(var(--nav-h) + clamp(60px,8vw,120px)) clamp(40px,6vw,80px); position:relative; overflow:hidden; }
.phead__bg{ position:absolute; inset:0; z-index:0; opacity:.5;
  background:radial-gradient(100% 120% at 80% -10%, rgba(198,162,83,.12), transparent 55%); }
.phead .inner{ position:relative; z-index:1; }
.phead .display{ max-width:16ch; }
.crumbs{ display:flex; gap:.6em; align-items:center; font-size:12.5px; letter-spacing:.06em; color:var(--muted); margin-block-end:22px; }
.crumbs a:hover{ color:var(--accent); }
.crumbs .sep{ color:var(--faint); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .manifesto__grid{ grid-template-columns:1fr; gap:40px; }
  .foot__top{ grid-template-columns:1fr 1fr; }
  .stats{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:980px){ .team--3{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:820px){
  .nav__links,.nav__cta{ display:none; }
  .burger{ display:flex; }
  .areas,.areas--3{ grid-template-columns:1fr; }
  .process{ grid-template-columns:1fr; gap:36px; }
  .team{ grid-template-columns:1fr; }
  .quotes{ grid-template-columns:1fr; }
  .articles{ grid-template-columns:1fr; }
  .contact__grid{ grid-template-columns:1fr; }
  .foot__top{ grid-template-columns:1fr; }
  .form .row2{ grid-template-columns:1fr; }
}
@media (max-width:520px){
  .stats{ grid-template-columns:1fr 1fr; }
}

/* ============================================================
   MOBILE FINE-TUNING (hero video + brand)
   ============================================================ */
@media (max-width:820px){
  /* shorter scroll distance → snappier scrub on touch */
  .hero-track{ height:280vh !important; }
  .hero-sticky{ height:100svh; }
  .beat{ padding-inline:var(--gutter); }
  .beat--mid{ align-items:center; text-align:center; }
  .beat--2 .inner,.beat--mid .inner,.beat--3 .inner{ max-width:100%; }
  .hero-cue{ inset-block-end:22px; }
}
@media (max-width:600px){
  .nav__row{ gap:10px; }
  .brand__logo{ height:36px; }
  .brand__word{ font-size:16px; letter-spacing:.16em; }
  .brand__sub{ font-size:8px; letter-spacing:.2em; }
  .beat--1 .display{ white-space:normal; }
  .beat--2 .stmt,.beat--mid .stmt,.beat--3 .stmt{ font-size:clamp(26px,7vw,40px); }
  /* keep all three languages (incl. Arabic) visible, just more compact */
  .langsw{ padding:2px; gap:1px; }
  .langsw button{ padding:5px 7px; font-size:10.5px; }
}
@media (max-width:380px){
  .brand__sub{ display:none; }
}
/* coarse-pointer: ensure tap targets & no hover-only reveals trap content */
@media (hover:none){
  .area__more{ opacity:1; transform:none; }
}

/* ============================================================
   TWEAKS PANEL
   ============================================================ */
#tweaks{ position:fixed; inset-block-end:20px; inset-inline-end:20px; z-index:120; width:280px;
  background:var(--surface); border:1px solid var(--line); border-radius:6px; padding:20px;
  box-shadow:0 24px 60px rgba(0,0,0,.5); transform:translateY(14px) scale(.98); opacity:0; pointer-events:none;
  transition:opacity .35s var(--ease), transform .35s var(--ease); }
#tweaks.open{ opacity:1; transform:none; pointer-events:auto; }
#tweaks .tw-head{ display:flex; justify-content:space-between; align-items:center; margin-block-end:16px; }
#tweaks .tw-title{ font-family:var(--font-body); font-weight:700; font-size:13px; letter-spacing:.14em; text-transform:uppercase; }
#tweaks .tw-close{ width:26px; height:26px; display:flex; align-items:center; justify-content:center; color:var(--muted); border-radius:4px; }
#tweaks .tw-close:hover{ color:var(--text); background:var(--surface-2); }
#tweaks .tw-group{ margin-block-end:16px; }
#tweaks .tw-label{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-block-end:9px; }
#tweaks .tw-opts{ display:flex; gap:6px; flex-wrap:wrap; }
#tweaks .tw-opts button{ flex:1; min-width:62px; padding:9px 8px; border:1px solid var(--line); border-radius:4px;
  font-size:12px; font-weight:600; color:var(--muted); transition:.25s; display:flex; align-items:center; justify-content:center; gap:6px; }
#tweaks .tw-opts button:hover{ border-color:var(--accent); color:var(--text); }
#tweaks .tw-opts button.on{ border-color:var(--accent); color:var(--accent); background:color-mix(in oklab,var(--accent) 12%, transparent); }
#tweaks .sw{ width:13px; height:13px; border-radius:50%; display:inline-block; }

/* RTL fine-tuning */
html[dir="rtl"] .area::before{ inset-inline-start:0; }
html[dir="rtl"] .hero-cue .track i,
html[dir="rtl"] .bigword{ }
