/* =============================================================
   Shubak — simplified, 3D hero, one typeface
   ============================================================= */

/* =============================================================
   Intro splash — window-opening animation
   ============================================================= */
#intro {
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: auto;
}
#intro.intro--done { pointer-events: none; }

/* The 4 dark panels */
.intro__panel {
  position: absolute;
  width: 50%;
  height: 50%;
  background: #0A0A0F;
  will-change: transform;
}
.intro__panel--tl { top: 0; left: 0;
  animation: intro-tl 0.72s 0.95s cubic-bezier(0.76,0,0.24,1) forwards; }
.intro__panel--tr { top: 0; right: 0;
  animation: intro-tr 0.72s 1.05s cubic-bezier(0.76,0,0.24,1) forwards; }
.intro__panel--bl { bottom: 0; left: 0;
  animation: intro-bl 0.72s 1.05s cubic-bezier(0.76,0,0.24,1) forwards; }
.intro__panel--br { bottom: 0; right: 0;
  animation: intro-br 0.72s 0.95s cubic-bezier(0.76,0,0.24,1) forwards; }

@keyframes intro-tl { to { transform: translate(-100%, -100%); } }
@keyframes intro-tr { to { transform: translate( 100%, -100%); } }
@keyframes intro-bl { to { transform: translate(-100%,  100%); } }
@keyframes intro-br { to { transform: translate( 100%,  100%); } }

/* Thin amber cross — the window frame */
.intro__frame {
  position: absolute;
  inset: 0;
  pointer-events: none;
  animation: intro-frame-fade 0.5s 0.9s forwards;
}
.intro__frame::before,
.intro__frame::after {
  content: '';
  position: absolute;
  background: rgba(233,139,42,0.35);
}
.intro__frame::before { left: 50%; top: 0; bottom: 0; width: 1px; transform: translateX(-50%); }
.intro__frame::after  { top: 50%; left: 0; right: 0; height: 1px; transform: translateY(-50%); }
@keyframes intro-frame-fade { to { opacity: 0; } }

/* Logo centered */
.intro__logo {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  z-index: 1;
  animation: intro-logo-out 0.35s 0.85s forwards;
}
.intro__word {
  font-size: clamp(52px, 8vw, 96px);
  font-weight: 700;
  color: #F3EEE4;
  letter-spacing: -0.03em;
  animation: intro-word-in 0.55s 0.15s cubic-bezier(0.16,1,0.3,1) both;
}
.intro__sh { color: #E98B2A; }
.intro__tagline {
  font-size: clamp(13px, 1.2vw, 16px);
  font-weight: 400;
  color: rgba(243,238,228,0.45);
  letter-spacing: 0.08em;
  animation: intro-tag-in 0.5s 0.35s cubic-bezier(0.16,1,0.3,1) both;
}
@keyframes intro-word-in {
  from { opacity: 0; transform: translateY(18px) scale(0.94); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}
@keyframes intro-tag-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes intro-logo-out { to { opacity: 0; } }

@media (prefers-reduced-motion: reduce) {
  #intro { display: none; }
}

:root {
  /* Palette — matched to Shubak brand board */
  --bg: #0A0A0F;            /* ink */
  --bg-elev: #111118;       /* ink-80 */
  --bg-soft: #1A1A24;       /* ink-60 */
  --ink: #F3EEE4;           /* bone */
  --ink-dim: rgba(243, 238, 228, 0.68);
  --ink-mute: rgba(243, 238, 228, 0.44);
  --ink-faint: rgba(243, 238, 228, 0.22);
  --line: rgba(243, 238, 228, 0.10);
  --line-strong: rgba(243, 238, 228, 0.18);
  --accent: #E98B2A;         /* amber — brand primary */
  --accent-dim: rgba(233, 139, 42, 0.14);

  --font: 'Alexandria', system-ui, -apple-system, sans-serif;

  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --maxw: 1320px;
  --pad-x: clamp(20px, 4vw, 56px);

  color-scheme: dark;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font);
  font-size: 16px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
body { direction: rtl; }

a { color: inherit; text-decoration: none; }
button { border: none; background: none; color: inherit; cursor: pointer; font: inherit; }
ul, ol { list-style: none; }

::selection { background: var(--accent); color: var(--bg); }
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.08); border-radius: 8px; }

/* ---------- Layout ---------- */
.wrap {
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding-inline: var(--pad-x);
  position: relative;
}

.section { padding-block: clamp(80px, 10vw, 160px); position: relative; }
#services { overflow: visible; }

.label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.label::before {
  content: "";
  width: 5px; height: 5px;
  background: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 10px var(--accent);
}

/* ===========================================================
   Navbar
   =========================================================== */
.nav {
  position: fixed;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 6px 8px 6px 16px;
  border-radius: 999px;
  background: rgba(17, 17, 26, 0.82);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border: 1px solid var(--line);
  transition:
    top        0.7s cubic-bezier(0.34, 1.2, 0.64, 1),
    left       0.7s cubic-bezier(0.34, 1.2, 0.64, 1),
    transform  0.7s cubic-bezier(0.34, 1.2, 0.64, 1),
    padding    0.6s cubic-bezier(0.16, 1, 0.3, 1),
    border-radius 0.6s cubic-bezier(0.16, 1, 0.3, 1),
    background 0.5s ease,
    box-shadow 0.5s ease;
}

/* Scrolled-down: shrinks to logo only, floats top-left */
.nav--compact {
  top: 18px;
  left: 20px;
  transform: none;
  padding: 9px 13px;
  border-radius: 14px;
  gap: 0;
  box-shadow: 0 8px 32px -8px rgba(0,0,0,0.5);
}
.nav--compact .nav__brand {
  padding-inline-end: 0;
  border-inline-end: none;
  margin-inline-end: 0;
}
.nav__links,
.nav__lang,
.nav__cta {
  transition:
    opacity    0.25s ease,
    max-width  0.55s cubic-bezier(0.16, 1, 0.3, 1),
    padding    0.55s cubic-bezier(0.16, 1, 0.3, 1),
    margin     0.55s cubic-bezier(0.16, 1, 0.3, 1),
    visibility 0s linear 0.25s;
  max-width: 600px;
  overflow: hidden;
  white-space: nowrap;
}
.nav--compact .nav__links,
.nav--compact .nav__lang,
.nav--compact .nav__cta {
  opacity: 0;
  max-width: 0;
  padding: 0;
  margin: 0;
  pointer-events: none;
  visibility: hidden;
  transition:
    opacity    0.2s ease,
    max-width  0.5s cubic-bezier(0.16, 1, 0.3, 1),
    padding    0.5s cubic-bezier(0.16, 1, 0.3, 1),
    margin     0.5s cubic-bezier(0.16, 1, 0.3, 1),
    visibility 0s linear 0.2s;
}
.nav__brand {
  transition:
    padding-inline-end 0.55s cubic-bezier(0.16, 1, 0.3, 1),
    border-color       0.4s ease,
    margin-inline-end  0.55s cubic-bezier(0.16, 1, 0.3, 1);
}

.nav__brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-inline-end: 14px;
  border-inline-end: 1px solid var(--line);
  margin-inline-end: 4px;
  height: 34px;
}
.nav__brand svg { width: 18px; height: 18px; }
.nav__brand-name {
  font-size: 15px;
  line-height: 1;
  display: flex;
  align-items: center;
}

/* Arabic brand name — Rubik display */
.nav__brand-ar {
  font-family: 'Rubik', sans-serif;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.01em;
}
/* English brand name — Fraunces serif */
.nav__brand-en {
  font-family: 'Fraunces', serif;
  font-weight: 300;
  font-size: 16px;
  letter-spacing: -0.03em;
  font-variation-settings: "opsz" 32;
  display: none;
}
/* Show correct name per language */
[data-lang="ar"] .nav__brand-ar { display: inline; }
[data-lang="ar"] .nav__brand-en { display: none; }
[data-lang="en"] .nav__brand-ar { display: none; }
[data-lang="en"] .nav__brand-en { display: inline; }

.nav__links { display: flex; align-items: center; gap: 0; }
.nav__link {
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 400;
  color: var(--ink-dim);
  border-radius: 999px;
  white-space: nowrap;
  transition: color 0.25s, background 0.25s;
}
.nav__link:hover { color: var(--ink); background: rgba(255,255,255,0.04); }

.nav__lang {
  margin-inline-start: 4px;
  padding: 10px 14px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.12em;
  color: var(--ink-mute);
  border-radius: 999px;
}
.nav__lang:hover { color: var(--ink); }

.nav__cta {
  margin-inline-start: 4px;
  padding: 10px 18px;
  font-size: 12px;
  font-weight: 500;
  background: var(--accent);
  color: var(--bg);
  border-radius: 999px;
  white-space: nowrap;
  transition: transform 0.3s var(--ease), background 0.3s var(--ease);
}

.nav__lang { white-space: nowrap; }
.nav__cta:hover { transform: translateY(-1px); background: #F29A3F; }

/* ===========================================================
   Hero — 3D window tunnel
   =========================================================== */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding-top: 140px;
  padding-bottom: 80px;
  overflow: hidden;
}

.hero__grid {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, black 30%, transparent 85%);
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, black 30%, transparent 85%);
}

.hero__glow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(50% 40% at 50% 35%, color-mix(in oklab, var(--accent) 22%, transparent) 0%, transparent 70%);
}

.hero__inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  align-items: center;
  gap: 56px;
  width: 100%;
  padding-block: 40px 24px;
}
@media (max-width: 860px) {
  .hero__inner {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 32px;
  }
}

/* --- 3D Scene --- */
.scene {
  position: relative;
  width: 100%;
  max-width: 540px;
  justify-self: end;
  aspect-ratio: 1 / 1;
  perspective: 1400px;
  perspective-origin: 50% 50%;
  margin-bottom: 0;
}
@media (max-width: 860px) {
  .scene { justify-self: center; max-width: 460px; }
}
.scene__stack {
  position: absolute;
  inset: 0;
  transform-style: preserve-3d;
  transform: rotateX(18deg) rotateY(-18deg) rotateZ(0);
  animation: scene-drift 14s ease-in-out infinite;
}
@keyframes scene-drift {
  0%, 100% { transform: rotateX(18deg) rotateY(-18deg); }
  50%      { transform: rotateX(14deg) rotateY(-24deg); }
}

.scene__pane {
  position: absolute;
  inset: 0;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(17, 17, 26, 0.7);
  backdrop-filter: blur(10px);
  box-shadow:
    0 30px 80px -30px rgba(0, 0, 0, 0.8),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
  transform-style: preserve-3d;
}

/* Depth panes — tunnel */
.scene__pane--1 { transform: translateZ(0px);   opacity: 1; }
.scene__pane--2 { transform: translateZ(-90px) scale(0.90); opacity: 0.55; }
.scene__pane--3 { transform: translateZ(-180px) scale(0.80); opacity: 0.28; }
.scene__pane--4 { transform: translateZ(-270px) scale(0.70); opacity: 0.12; }

/* Window view — wireframe terrain */
.view {
  position: absolute;
  inset: 14px;
  border-radius: 14px;
  overflow: hidden;
  background: linear-gradient(180deg, #070712 0%, #0a0a18 48%, #0c0c16 50%, #0e0e18 100%);
  transform: translateZ(8px);
  color: var(--accent);
}

.view__sky {
  position: absolute;
  inset: 0 0 50% 0;
  background:
    radial-gradient(60% 90% at 50% 100%, color-mix(in oklab, var(--accent) 35%, transparent) 0%, transparent 70%),
    radial-gradient(40% 60% at 20% 30%, rgba(255,255,255,0.04) 0%, transparent 70%);
  overflow: hidden;
}
.view__sun {
  position: absolute;
  left: 50%; bottom: -18%;
  width: 55%; aspect-ratio: 2 / 1;
  transform: translateX(-50%);
  background: radial-gradient(ellipse at 50% 100%, var(--accent) 0%, color-mix(in oklab, var(--accent) 40%, transparent) 30%, transparent 65%);
  filter: blur(2px);
}
.view__star {
  position: absolute;
  left: var(--x); top: var(--y);
  width: 2px; height: 2px;
  background: #fff;
  border-radius: 50%;
  opacity: 0.6;
  animation: twinkle 3.5s ease-in-out infinite;
  animation-delay: var(--d);
}
@keyframes twinkle {
  0%, 100% { opacity: 0.2; transform: scale(0.8); }
  50%      { opacity: 0.9; transform: scale(1.2); }
}

.view__terrain {
  position: absolute;
  inset: 50% 0 0 0;
  width: 100%;
  height: 50%;
  color: var(--accent);
  overflow: visible;
}
.view__row {
  animation: wave 6s ease-in-out infinite;
  transform-origin: center;
}
.view__row--1 { animation-delay: -0.0s; }
.view__row--2 { animation-delay: -0.4s; }
.view__row--3 { animation-delay: -0.8s; }
.view__row--4 { animation-delay: -1.2s; }
.view__row--5 { animation-delay: -1.6s; }
.view__row--6 { animation-delay: -2.0s; }
.view__row--7 { animation-delay: -2.4s; }
.view__row--8 { animation-delay: -2.8s; }

@keyframes wave {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-2px); }
}

.view__pulse {
  position: absolute;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 10px #fff, 0 0 20px var(--accent);
  top: 50%;
  left: 50%;
  opacity: 0;
  animation: pulse-travel 5s linear infinite;
}
.view__pulse--1 { animation-delay: 0s; }
.view__pulse--2 { animation-delay: -1.7s; }
.view__pulse--3 { animation-delay: -3.3s; }
@keyframes pulse-travel {
  0%   { transform: translate(-50%, -50%) scale(0.3); opacity: 0; }
  10%  { opacity: 1; }
  100% { transform: translate(-50%, 160%) scale(1.2) translateX(var(--drift, 20px)); opacity: 0; }
}
.view__pulse--1 { --drift: -80px; }
.view__pulse--2 { --drift: 60px; }
.view__pulse--3 { --drift: 10px; }

/* HUD overlay */
.view__hud {
  position: absolute;
  top: 10px;
  inset-inline-start: 12px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 4px;
  font-size: 9px;
  font-weight: 500;
  letter-spacing: 0.12em;
  color: var(--ink-dim);
  font-variant-numeric: tabular-nums;
}
.view__hud--br { top: auto; bottom: 10px; inset-inline-start: auto; inset-inline-end: 12px; }
.view__hud-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 6px var(--accent);
}
.view__hud-dot--live {
  background: #ff5d5d;
  box-shadow: 0 0 6px #ff5d5d;
  animation: live-blink 1.4s ease-in-out infinite;
}
@keyframes live-blink {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.3; }
}
.view__hud-text { letter-spacing: 0.14em; }

/* Floating badges around scene */
.scene__badge {
  position: absolute;
  padding: 10px 14px;
  background: rgba(17, 17, 26, 0.92);
  backdrop-filter: blur(12px);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  box-shadow: 0 10px 30px -10px rgba(0,0,0,0.6);
  transform: translateZ(80px);
  animation: float 5s ease-in-out infinite;
}
.scene__badge::before {
  content: "";
  width: 6px; height: 6px;
  background: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 8px var(--accent);
}
.scene__badge--1 { top: 8%; inset-inline-start: -6%; animation-delay: 0s; }
.scene__badge--2 { top: 42%; inset-inline-end: -12%; animation-delay: -2s; }
.scene__badge--3 { bottom: 12%; inset-inline-start: 6%; animation-delay: -3.5s; }
@keyframes float {
  0%, 100% { transform: translateZ(80px) translateY(0); }
  50%      { transform: translateZ(80px) translateY(-10px); }
}

/* Hero copy below scene */
/* Hero copy — right column in RTL */
.hero__copy { max-width: 560px; text-align: start; }

.hero__title {
  font-size: clamp(28px, 3.6vw, 52px);
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-bottom: 22px;
}
.hero__title > span { display: inline; }
.hero__title .accent {
  color: var(--accent);
  font-weight: 600;
}

.hero__sub {
  font-size: clamp(15px, 1.15vw, 18px);
  line-height: 1.7;
  color: var(--ink-dim);
  max-width: 46ch;
  margin: 0 0 28px;
}

.hero__cta { display: flex; gap: 12px; flex-wrap: wrap; }
@media (max-width: 860px) {
  .hero__copy { max-width: 640px; margin-inline: auto; text-align: center; }
  .hero__sub { margin-inline: auto; }
  .hero__cta { justify-content: center; }
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 24px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.02em;
  transition: transform 0.3s var(--ease), background 0.25s, border-color 0.25s;
}
.btn--primary {
  background: var(--accent);
  color: var(--bg);
}
.btn--primary:hover { transform: translateY(-2px); background: #F29A3F; }
.btn--ghost {
  border: 1px solid var(--line-strong);
  color: var(--ink);
}
.btn--ghost:hover { background: rgba(255, 255, 255, 0.04); border-color: rgba(255, 255, 255, 0.24); }

.btn__arrow { transition: transform 0.3s; }
.btn:hover .btn__arrow { transform: translateX(-3px); }
body[dir="ltr"] .btn:hover .btn__arrow { transform: translateX(3px); }

/* ===========================================================
   Ticker
   =========================================================== */
.ticker {
  border-block: 1px solid var(--line);
  padding-block: 22px;
  overflow: hidden;
  background: #08080d;
}
.ticker__track {
  display: flex;
  gap: 56px;
  white-space: nowrap;
  animation: ticker 52s linear infinite;
  width: max-content;
}
@keyframes ticker {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
.ticker__item {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-dim);
}
.ticker__item svg { width: 10px; height: 10px; color: var(--accent); }

/* ===========================================================
   Section header
   =========================================================== */
.sec-head {
  text-align: center;
  margin-bottom: 72px;
}
.sec-head .label { margin-bottom: 18px; }
.sec-head__title {
  font-size: clamp(30px, 4.4vw, 56px);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.02em;
  max-width: 820px;
  margin: 0 auto;
}
.sec-head__title .accent { color: var(--accent); }

/* ===========================================================
   Services — clean 3-col grid
   =========================================================== */
.services__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
@media (min-width: 700px) { .services__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .services__grid { grid-template-columns: repeat(3, 1fr); } }

.svc {
  position: relative;
  padding: 32px 28px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: var(--bg-elev);
  overflow: hidden;
  transition: border-color 0.35s, transform 0.5s var(--ease), background 0.35s;
  min-height: 260px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  cursor: pointer;
}
.svc::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 50%), color-mix(in oklab, var(--accent) 10%, transparent), transparent 45%);
  opacity: 0;
  transition: opacity 0.4s;
  pointer-events: none;
}
.svc:hover {
  border-color: var(--line-strong);
  transform: translateY(-4px);
  background: var(--bg-soft);
}
.svc:hover::before { opacity: 1; }

.svc__ico {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  border: 1px solid var(--line-strong);
  border-radius: 12px;
  background: rgba(255,255,255,0.02);
  color: var(--ink);
  transition: all 0.35s;
}
.svc:hover .svc__ico { background: var(--accent-dim); color: var(--accent); border-color: transparent; }
.svc__ico svg { width: 20px; height: 20px; }

.svc__title {
  font-size: 20px;
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: -0.01em;
}
.svc__desc {
  font-size: 14px;
  color: var(--ink-dim);
  line-height: 1.7;
  flex: 1;
}
.svc__link {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--ink-mute);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: color 0.25s;
}
.svc:hover .svc__link { color: var(--accent); }
.svc__link-arrow { transition: transform 0.3s; }
.svc:hover .svc__link-arrow { transform: translateX(-3px); }
body[dir="ltr"] .svc:hover .svc__link-arrow { transform: translateX(3px); }

/* ===========================================================
   Process — alternating cards on a centered spine
   =========================================================== */
.tl {
  position: relative;
  max-width: 1000px;
  margin: 0 auto;
  padding: 8px 0;
  list-style: none;
}

/* spine — full track, CENTERED */
.tl__spine {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 18px;
  bottom: 18px;
  width: 2px;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    rgba(255,255,255,0.22) 12%,
    rgba(255,255,255,0.22) 88%,
    transparent 100%
  );
  pointer-events: none;
  z-index: 0;
}

/* spine — progress fill that draws down as user scrolls (uses --p 0..1) */
.tl__spine-fill {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 18px;
  width: 2px;
  height: calc((100% - 36px) * var(--p, 0));
  background: linear-gradient(to bottom, transparent 0%, var(--accent) 30%, var(--accent) 100%);
  box-shadow: 0 0 12px var(--accent);
  transition: height 0.6s var(--ease);
  pointer-events: none;
  z-index: 1;
}

/* travelling pulse riding the track */
.tl__pulse {
  position: absolute;
  left: 50%;
  top: 18px;
  width: 8px;
  height: 8px;
  margin-left: -4px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 14px var(--accent), 0 0 28px var(--accent-dim);
  transform: translateY(calc((100% - 36px) * var(--p, 0)));
  transition: transform 0.6s var(--ease);
  opacity: 0.9;
  pointer-events: none;
  z-index: 3;
}
.tl__pulse::before {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 1px solid var(--accent);
  animation: tl-ping 2.2s ease-out infinite;
}
@keyframes tl-ping {
  0%   { transform: scale(0.6); opacity: 0.8; }
  100% { transform: scale(2.6); opacity: 0; }
}

/* Each step = half-width card, alternating sides */
.tl__step {
  position: relative;
  width: 50%;
  padding-block: 26px;
  padding-inline-end: 56px;          /* gap between card and spine (RTL: toward the center) */
  display: block;
}
body[dir="ltr"] .tl__step { padding-inline-end: 56px; }

/* In RTL, first child is visually on the RIGHT. Odd steps -> right side, even -> left. */
.tl__step:nth-of-type(odd) {
  margin-inline-start: 50%;          /* push to far side (in RTL that's left-screen) */
  padding-inline-end: 0;
  padding-inline-start: 56px;        /* gap on the side that touches the spine */
}
/* default (even) keeps padding-inline-end: 56px */

/* connector line from spine to card — real element instead of pseudo */
.tl__conn {
  position: absolute;
  top: 52px;
  width: 40px;
  height: 1px;
  background: rgba(255,255,255,0.22);
  z-index: 1;
}
.tl__step:nth-of-type(odd) .tl__conn { inset-inline-start: 0; }
.tl__step:nth-of-type(even) .tl__conn { inset-inline-end: 0; }
/* NOTE: nth-child counts the .tl__spine and .tl__spine-fill spans too, so
   steps are 4th,5th,6th,7th children. We use odd/even on the li itself via a
   different trick below. */

/* Override — use position relative to count among LIs only */
.tl__step { --side: even; }

/* Active-step connector turns accent */
.tl__step.is-in .tl__conn {
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent-dim);
}

/* The card itself */
.tl__card {
  position: relative;
  background: linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.012));
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 22px 24px;
  transition: border-color 0.4s var(--ease), transform 0.4s var(--ease), box-shadow 0.4s var(--ease);
}
.tl__step.is-in .tl__card {
  border-color: color-mix(in oklab, var(--accent) 38%, var(--line));
  box-shadow: 0 10px 40px -20px var(--accent-dim);
}

/* dot sitting ON THE SPINE — positioned at the edge of each step that touches the spine */
.tl__dot {
  position: absolute;
  top: 44px;
  width: 17px;
  height: 17px;
  border-radius: 50%;
  background: var(--bg);
  border: 1.5px solid var(--line-strong);
  display: grid;
  place-items: center;
  z-index: 2;
  transition: border-color 0.4s var(--ease), transform 0.4s var(--ease);
}
.tl__step:nth-of-type(even) .tl__dot {
  /* even = near-side (RTL: right half), spine on inline-end */
  inset-inline-end: -8.5px;
}
.tl__step:nth-of-type(odd) .tl__dot {
  /* odd = far-side (RTL: left half), spine on inline-start */
  inset-inline-start: -8.5px;
}
.tl__dot-core {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--ink-faint);
  transition: background 0.4s var(--ease), box-shadow 0.4s var(--ease), transform 0.4s var(--ease);
}
.tl__step.is-in .tl__dot { border-color: var(--accent); }
.tl__step.is-in .tl__dot-core {
  background: var(--accent);
  box-shadow: 0 0 10px var(--accent);
  transform: scale(1.1);
}

.tl__num {
  display: block;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
  margin-bottom: 8px;
  transition: color 0.4s;
}
.tl__step.is-in .tl__num { color: var(--accent); }

.tl__name {
  font-size: clamp(20px, 2.1vw, 26px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin-bottom: 8px;
}

.tl__desc {
  font-size: 15px;
  color: var(--ink-dim);
  line-height: 1.7;
  margin: 0;
}

/* Mobile — collapse to single column on the starting side */
@media (max-width: 720px) {
  .tl__spine, .tl__spine-fill { left: 14px; transform: none; }
  .tl__pulse { left: 14px; margin-left: -4px; }
  .tl__step,
  .tl__step:nth-of-type(odd) {
    width: 100%;
    margin-inline-start: 0;
    padding-inline-start: 44px;
    padding-inline-end: 0;
  }
  .tl__conn {
    inset-inline-start: 14px !important;
    inset-inline-end: auto !important;
    width: 24px;
  }
  .tl__step:nth-of-type(odd) .tl__dot,
  .tl__step:nth-of-type(even) .tl__dot {
    inset-inline-start: 14px;
    inset-inline-end: auto;
    transform: translateX(-50%);
  }
}

/* staggered entry — starts visible; just enhances on is-in */
.tl__step {
  opacity: 1;
  transform: none;
  transition: opacity 0.7s var(--ease), transform 0.7s var(--ease);
}
.tl__step:not(.is-in) .tl__dot { border-color: var(--line); }
.tl__step:not(.is-in) .tl__dot-core { background: var(--ink-faint); }
.tl__step:nth-of-type(1).is-in { transition-delay: 0.05s; }
.tl__step:nth-of-type(2).is-in { transition-delay: 0.15s; }
.tl__step:nth-of-type(3).is-in { transition-delay: 0.25s; }
.tl__step:nth-of-type(4).is-in { transition-delay: 0.35s; }

/* ===========================================================
   Work — simple 2-col
   =========================================================== */
.work__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
@media (min-width: 900px) { .work__grid { grid-template-columns: 1fr 1fr; } }

.work-card {
  position: relative;
  border: 1px solid var(--line);
  border-radius: 20px;
  overflow: hidden;
  background: var(--bg-elev);
  transition: transform 0.5s var(--ease), border-color 0.3s;
}
.work-card:hover { transform: translateY(-4px); border-color: var(--line-strong); }

.work-card__media {
  aspect-ratio: 16 / 10;
  position: relative;
  overflow: hidden;
  background: #0c0c14;
  display: flex;
  align-items: center;
  justify-content: center;
}
.work-card__mock {
  width: 80%;
  height: 72%;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--bg-soft);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 50px -20px rgba(0,0,0,0.8);
}
.work-card__mock-bar {
  height: 22px;
  background: var(--bg-elev);
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 4px;
  padding-inline: 10px;
}
.work-card__mock-bar span {
  width: 7px; height: 7px; border-radius: 50%;
  background: rgba(255,255,255,0.12);
}
.work-card__mock-body {
  flex: 1;
  display: flex;
  padding: 14px;
  gap: 10px;
}
.work-card__mock-side {
  width: 30%;
  background: rgba(255,255,255,0.02);
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 10px;
}
.work-card__mock-side div { height: 6px; background: rgba(255,255,255,0.06); border-radius: 3px; }
.work-card__mock-side div:nth-child(odd) { width: 80%; }
.work-card__mock-side div:nth-child(even) { width: 60%; }
.work-card__mock-main { flex: 1; display: flex; flex-direction: column; gap: 8px; }
.work-card__mock-main > div { background: rgba(255,255,255,0.04); border-radius: 6px; }
.work-card__mock-main > div:nth-child(1) { height: 24px; width: 50%; }
.work-card__mock-main > div:nth-child(2) { height: 80px; background: var(--accent-dim); }
.work-card__mock-main > div:nth-child(3) { height: 10px; width: 90%; }
.work-card__mock-main > div:nth-child(4) { height: 10px; width: 65%; }

.work-card__info { padding: 24px 28px; display: flex; flex-direction: column; gap: 10px; }
.work-card__meta { display: flex; justify-content: space-between; align-items: center; }
.work-card__cat {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
}
.work-card__year {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: var(--ink-mute);
}
.work-card__title {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.3;
}
.work-card__desc { font-size: 14px; color: var(--ink-dim); line-height: 1.7; }

/* ===========================================================
/* ===========================================================
   CTA + Contact Form
   =========================================================== */
.cta {
  padding-block: clamp(100px, 12vw, 160px);
  position: relative;
  overflow: hidden;
}
.cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(55% 50% at 50% 30%, color-mix(in oklab, var(--accent) 12%, transparent) 0%, transparent 70%);
  pointer-events: none;
}
.cta__inner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: 72px;
  align-items: start;
  max-width: 1160px;
  margin: 0 auto;
}
@media (max-width: 900px) {
  .cta__inner { grid-template-columns: 1fr; gap: 48px; }
}
.cta__head { position: sticky; top: 100px; }
@media (max-width: 900px) { .cta__head { position: static; text-align: center; } }
.cta__title {
  font-size: clamp(36px, 4.8vw, 60px);
  font-weight: 600;
  line-height: 1.28;
  letter-spacing: -0.02em;
  margin: 18px 0 20px;
}
.cta__title .accent { color: var(--accent); }
.cta__sub {
  font-size: 16px;
  line-height: 1.7;
  color: var(--ink-dim);
  margin-bottom: 28px;
  max-width: 46ch;
}
@media (max-width: 900px) { .cta__sub { margin-inline: auto; } }
.cta__meta {
  display: inline-flex;
  gap: 20px;
  padding: 12px 20px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(17, 17, 26, 0.6);
  font-size: 12px;
  font-weight: 500;
  color: var(--ink-mute);
  flex-wrap: wrap;
}
.cta__meta a { color: var(--ink); }

/* ===========================================================
   Contact Wizard
   =========================================================== */

/* Wizard shell — window-frame feel */
.wz__hp {
  position: absolute;
  left: -9999px;
  width: 1px; height: 1px;
  opacity: 0;
  pointer-events: none;
  tabindex: -1;
}

.wz {
  position: relative;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.008));
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  overflow: hidden;
  isolation: isolate;
}
.wz::before {
  /* soft accent wash behind content */
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(80% 60% at 100% 0%, color-mix(in oklab, var(--accent) 10%, transparent), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,0.02), transparent 40%);
  z-index: -1;
  pointer-events: none;
}
.wz::after {
  /* corner chevrons — faint window marks */
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px dashed rgba(255,255,255,0.04);
  border-radius: 16px;
  z-index: -1;
  pointer-events: none;
}
@media (max-width: 600px) { .wz { padding: 20px; border-radius: 18px; } }

/* Head: stepper + progress bar */
.wz__head {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.wz__steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
.wz__pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,0.015);
  font-size: 12px;
  color: var(--ink-mute);
  transition: border-color 0.35s, color 0.35s, background 0.35s, transform 0.35s;
  min-width: 0;
}
.wz__pill-num {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: var(--ink-faint);
  font-variant-numeric: tabular-nums;
  transition: color 0.35s;
}
.wz__pill-label {
  font-weight: 500;
  color: var(--ink-dim);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: color 0.35s;
}
.wz__pill.is-done {
  border-color: color-mix(in oklab, var(--accent) 30%, var(--line));
  background: color-mix(in oklab, var(--accent) 5%, transparent);
}
.wz__pill.is-done .wz__pill-num { color: var(--accent); }
.wz__pill.is-active {
  border-color: var(--accent);
  background: color-mix(in oklab, var(--accent) 10%, transparent);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 14%, transparent);
  transform: translateY(-1px);
}
.wz__pill.is-active .wz__pill-num,
.wz__pill.is-active .wz__pill-label { color: var(--ink); }
.wz__pill.is-active .wz__pill-num { color: var(--accent); }
@media (max-width: 620px) {
  .wz__pill-label { display: none; }
  .wz__pill { justify-content: center; padding: 9px; }
}

.wz__bar {
  position: relative;
  height: 2px;
  border-radius: 999px;
  background: var(--line);
  overflow: hidden;
}
.wz__bar-fill {
  position: absolute;
  inset-inline-start: 0;
  top: 0;
  bottom: 0;
  width: var(--w, 25%);
  background: linear-gradient(to right, var(--accent), color-mix(in oklab, var(--accent) 50%, var(--ink)));
  box-shadow: 0 0 10px var(--accent);
  transition: width 0.55s var(--ease);
}

/* Stage holds all panes */
.wz__stage {
  position: relative;
  display: grid;
}
.wz__stage > .wz__pane { grid-area: 1 / 1; }

.wz__pane {
  display: flex;
  flex-direction: column;
  gap: 20px;
  opacity: 0;
  visibility: hidden;
  transform: translateX(24px);
  transition:
    opacity 0.45s var(--ease),
    transform 0.55s var(--ease),
    visibility 0s linear 0.5s;
  pointer-events: none;
  /* non-current panes don't occupy vertical space */
  height: 0;
  min-height: 0;
  overflow: hidden;
}
body[dir="rtl"] .wz__pane { transform: translateX(-24px); }
.wz__pane.is-current {
  opacity: 1;
  visibility: visible;
  transform: none;
  pointer-events: auto;
  height: auto;
  min-height: 0;
  overflow: visible;
  transition:
    opacity 0.5s var(--ease),
    transform 0.55s var(--ease),
    visibility 0s linear 0s;
}
.wz__pane.is-out {
  transform: translateX(-24px);
  opacity: 0;
}
body[dir="rtl"] .wz__pane.is-out { transform: translateX(24px); }

.wz__pane-head { display: flex; flex-direction: column; gap: 8px; }
.wz__kicker {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: var(--accent);
  text-transform: uppercase;
  font-variant-numeric: tabular-nums;
}
.wz__q {
  font-size: clamp(22px, 2.2vw, 28px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--ink);
}
.wz__q--center { text-align: center; }
.wz__hint {
  font-size: 13px;
  color: var(--ink-mute);
  line-height: 1.6;
}
.wz__hint--center { text-align: center; }

/* Tiles (step 1 + step 2) */
.wz__tiles {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.wz__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 10px;
}
@media (max-width: 520px) {
  .wz__tiles { grid-template-columns: 1fr; }
}

.tile {
  position: relative;
  cursor: pointer;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255,255,255,0.018);
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
  transition: border-color 0.3s, background 0.3s, transform 0.25s;
}
.tile:hover { border-color: var(--line-strong); background: rgba(255,255,255,0.035); transform: translateY(-1px); }
.tile input { position: absolute; opacity: 0; pointer-events: none; }
.tile__glyph {
  width: 36px; height: 36px;
  display: grid; place-items: center;
  border-radius: 10px;
  border: 1px solid var(--line);
  color: var(--ink-dim);
  background: rgba(0,0,0,0.2);
  transition: color 0.3s, border-color 0.3s, background 0.3s;
}
.tile__glyph svg { width: 20px; height: 20px; }
.tile__title { font-size: 14px; font-weight: 500; color: var(--ink); }
.tile__desc { font-size: 12px; color: var(--ink-mute); line-height: 1.55; }
.tile:has(input:checked) {
  border-color: var(--accent);
  background: color-mix(in oklab, var(--accent) 9%, transparent);
  box-shadow: 0 0 0 1px var(--accent) inset, 0 10px 32px -12px color-mix(in oklab, var(--accent) 60%, transparent);
}
.tile:has(input:checked) .tile__glyph {
  color: var(--accent);
  border-color: color-mix(in oklab, var(--accent) 50%, transparent);
  background: color-mix(in oklab, var(--accent) 12%, transparent);
}
.tile--sm { padding: 14px; flex-direction: row; align-items: center; gap: 12px; }
.tile--sm .tile__glyph { width: 34px; height: 34px; }
.tile--sm .tile__title { font-size: 13.5px; }

/* Budget bands (step 3) */
.wz__budget { display: flex; flex-direction: column; gap: 10px; }
.bband {
  position: relative;
  cursor: pointer;
  padding: 16px 18px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255,255,255,0.018);
  display: flex;
  align-items: center;
  overflow: hidden;
  transition: border-color 0.3s, background 0.3s;
}
.bband input { position: absolute; opacity: 0; pointer-events: none; }
.bband__bar {
  position: absolute;
  inset-block: 0;
  inset-inline-start: 0;
  width: 0;
  background: color-mix(in oklab, var(--accent) 10%, transparent);
  transition: width 0.55s var(--ease);
  pointer-events: none;
  border-inline-end: 1px solid color-mix(in oklab, var(--accent) 28%, transparent);
}
.bband:nth-child(1) .bband__bar { width: 18%; }
.bband:nth-child(2) .bband__bar { width: 36%; }
.bband:nth-child(3) .bband__bar { width: 56%; }
.bband:nth-child(4) .bband__bar { width: 78%; }
.bband:nth-child(5) .bband__bar { width: 100%; }
.bband__range {
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  z-index: 1;
}
.bband__note {
  grid-column: 1 / -1;
  font-size: 12px;
  color: var(--ink-mute);
  z-index: 1;
}
.bband:hover { border-color: var(--line-strong); background: rgba(255,255,255,0.03); }
.bband:has(input:checked) {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent) inset;
}
.bband--ghost { grid-template-columns: 1fr; }
.bband--ghost .bband__range { color: var(--ink-dim); font-weight: 400; }
.bband--ghost:has(input:checked) .bband__range { color: var(--ink); }

/* ghost band has no bar fill */
.bband--ghost .bband__bar { display: none; }

/* Fields (step 4) */
.wz__fields { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.field--full { grid-column: 1 / -1; }
@media (max-width: 560px) { .wz__fields { grid-template-columns: 1fr; } }
.field { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.field__label { font-size: 12px; font-weight: 500; color: var(--ink-mute); letter-spacing: 0.04em; }
.field input, .field textarea {
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px 14px;
  color: var(--ink);
  font: inherit;
  font-size: 15px;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
  resize: vertical;
  min-width: 0;
}
.field input::placeholder, .field textarea::placeholder { color: var(--ink-faint); }
.field input:focus, .field textarea:focus {
  outline: none;
  border-color: var(--accent);
  background: rgba(255,255,255,0.04);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent);
}
.field input:invalid:not(:placeholder-shown) {
  border-color: color-mix(in oklab, #f87171 50%, var(--line));
}

/* DONE pane */
.wz__done {
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 14px;
  padding-block: 20px;
}
.wz__done-glyph {
  color: var(--accent);
  filter: drop-shadow(0 0 18px color-mix(in oklab, var(--accent) 60%, transparent));
  animation: wz-pop 0.6s var(--ease) both;
}
@keyframes wz-pop {
  0% { opacity: 0; transform: scale(0.6); }
  60% { opacity: 1; transform: scale(1.08); }
  100% { opacity: 1; transform: scale(1); }
}
.wz__done-ping {
  transform-origin: 28px 28px;
  animation: wz-done-ping 1.8s ease-out infinite;
}
@keyframes wz-done-ping {
  0%   { transform: scale(0.7); opacity: 0.9; }
  100% { transform: scale(1.9); opacity: 0; }
}
.wz__restart { margin-top: 8px; }

/* Foot: navigation */
.wz__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-top: 1px solid var(--line);
  padding-top: 20px;
  margin-top: 4px;
}
.wz__counter {
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
}
.wz__counter-now { color: var(--accent); font-weight: 600; }
.wz__back { opacity: 0.85; }
.wz__back[disabled] { opacity: 0.35; pointer-events: none; }
.wz__next, .wz__submit { min-width: 120px; justify-content: center; }
.wz__next[hidden], .wz__submit[hidden] { display: none !important; }

body[dir="rtl"] .wz__next .btn__arrow,
body[dir="rtl"] .wz__submit .btn__arrow { transform: scaleX(-1); }

.wz__err {
  font-size: 13px;
  color: #f87171;
  text-align: center;
  margin: 0;
}

/* ===========================================================
   Footer
   =========================================================== */
.footer {
  border-top: 1px solid var(--line);
  padding-block: 48px;
  background: #08080d;
}
.footer__inner {
  display: grid;
  gap: 32px;
  grid-template-columns: 1fr;
  text-align: center;
}
@media (min-width: 700px) {
  .footer__inner {
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    text-align: start;
  }
}
.footer__brand { display: flex; align-items: center; gap: 10px; justify-content: center; }
@media (min-width: 700px) { .footer__brand { justify-content: flex-start; } }
.footer__brand svg { width: 18px; height: 18px; }
.footer__brand-name {
  font-size: 15px;
  line-height: 1;
  display: flex;
  align-items: center;
}

.footer__links { display: flex; gap: 20px; justify-content: center; flex-wrap: wrap; }
.footer__links a {
  font-size: 12px;
  color: var(--ink-dim);
  transition: color 0.25s;
}
.footer__links a:hover { color: var(--ink); }

.footer__meta {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: var(--ink-mute);
  text-align: end;
}
@media (max-width: 699px) { .footer__meta { text-align: center; } }

/* ===========================================================
   Tweaks panel
   =========================================================== */
.tweaks {
  position: fixed;
  inset-block-end: 20px;
  inset-inline-end: 20px;
  z-index: 200;
  width: 260px;
  padding: 16px;
  border-radius: 16px;
  background: rgba(17, 17, 26, 0.95);
  backdrop-filter: blur(20px);
  border: 1px solid var(--line-strong);
  box-shadow: 0 30px 80px -20px rgba(0,0,0,0.8);
  display: none;
  flex-direction: column;
  gap: 14px;
}
.tweaks--open { display: flex; }
.tweaks__head { display: flex; justify-content: space-between; align-items: center; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
.tweaks__title { font-size: 12px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; }
.tweaks__row { display: flex; flex-direction: column; gap: 8px; }
.tweaks__row-label { font-size: 10px; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-mute); }
.tweaks__opts { display: flex; gap: 6px; flex-wrap: wrap; }
.tweaks__opt {
  padding: 6px 12px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--ink-dim);
  transition: all 0.2s;
}
.tweaks__opt:hover { color: var(--ink); }
.tweaks__opt[aria-pressed="true"] { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.tweaks__swatch {
  width: 24px; height: 24px; border-radius: 50%;
  border: 1px solid var(--line-strong);
  padding: 0;
}
.tweaks__swatch[aria-pressed="true"] { box-shadow: 0 0 0 2px var(--bg), 0 0 0 3px var(--ink); }

body[data-accent="blue"]  { --accent: oklch(0.82 0.14 235); --accent-dim: oklch(0.82 0.14 235 / 0.14); }
body[data-accent="mint"]  { --accent: oklch(0.82 0.14 170); --accent-dim: oklch(0.82 0.14 170 / 0.14); }
body[data-accent="amber"] { --accent: #E98B2A;             --accent-dim: rgba(233,139,42,0.14); }
body[data-accent="rose"]  { --accent: oklch(0.80 0.14 15);  --accent-dim: oklch(0.80 0.14 15 / 0.14); }

body[data-depth="low"]  .scene__pane--3 { opacity: 0; }
body[data-depth="low"]  .scene__pane--4 { opacity: 0; }
body[data-depth="high"] .scene__pane--5 { display: block; }

/* Reveal */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity 0.9s var(--ease), transform 0.9s var(--ease); }
.reveal.is-in { opacity: 1; transform: none; }

/* Responsive */
@media (max-width: 720px) {
  .nav { padding: 4px 4px 4px 12px; }
  .nav__links, .nav__cta { display: none; }
  .nav__brand { border: none; padding-inline-end: 8px; margin-inline-end: 0; }
  .scene { max-width: 340px; }
  .scene__pane--3 { opacity: 0.2; }
  .scene__pane--4 { opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ===========================================================
   Project Detail Modal
   =========================================================== */
.proj-modal{
  position:fixed;inset:0;z-index:1000;
  pointer-events:none;opacity:0;
  transition:opacity 0.4s var(--ease);
}
.proj-modal.is-open{opacity:1;pointer-events:auto}
.proj-modal__backdrop{
  position:absolute;inset:0;
  background:rgba(5,5,10,.75);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  opacity:0;transition:opacity 0.4s var(--ease);
}
.proj-modal.is-open .proj-modal__backdrop{opacity:1}
.proj-modal__frame{
  position:absolute;top:50%;left:50%;
  width:min(920px,92vw);height:min(680px,88vh);
  transform:translate(-50%,-50%) scale(0.9) rotateX(8deg);
  border:1px solid var(--line-strong);border-radius:2px;
  background:linear-gradient(180deg,rgba(243,238,228,.03),rgba(243,238,228,0) 50%),var(--bg-elev);
  box-shadow:0 60px 120px -20px rgba(0,0,0,.7),0 0 180px -20px color-mix(in oklab,var(--accent) 18%,transparent);
  overflow:hidden;opacity:0;
  transition:transform 0.55s var(--ease),opacity 0.4s var(--ease);
}
.proj-modal.is-open .proj-modal__frame{
  opacity:1;transform:translate(-50%,-50%) scale(1) rotateX(0);
}
.proj-modal__chrome{
  display:flex;align-items:center;gap:14px;
  padding:12px 18px;border-bottom:1px solid var(--line);
  background:rgba(243,238,228,.02);font-size:12px;
}
.proj-modal__title-bar{
  flex:1;text-align:center;
  font-size:11.5px;letter-spacing:.05em;
  color:var(--ink-mute);
}
.proj-modal__close{
  flex-shrink:0;width:28px;height:28px;
  display:grid;place-items:center;
  background:transparent;border:1px solid var(--line);
  border-radius:2px;color:var(--ink-dim);cursor:pointer;
  transition:all 0.25s;
}
.proj-modal__close:hover{border-color:var(--accent);color:var(--accent)}
.proj-modal__close svg{width:14px;height:14px;display:block}
.proj-modal__body{
  height:calc(100% - 53px);overflow-y:auto;
  padding:40px 44px;opacity:0;transform:translateY(16px);
  transition:opacity 0.5s 0.1s var(--ease),transform 0.6s 0.1s var(--ease);
}
.proj-modal.is-open .proj-modal__body{opacity:1;transform:none}
.proj-modal__body::-webkit-scrollbar{width:6px}
.proj-modal__body::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:3px}
.proj-modal__hero{
  display:flex;flex-direction:column;gap:10px;
  padding-bottom:24px;border-bottom:1px solid var(--line);margin-bottom:24px;
}
.proj-modal__cat{
  font-size:12px;font-weight:500;letter-spacing:.22em;
  color:var(--accent);text-transform:uppercase;
}
.proj-modal__name{
  font-size:clamp(28px,3.5vw,40px);font-weight:600;
  line-height:1.15;letter-spacing:-.02em;color:var(--ink);
}
.proj-modal__tagline{
  font-size:16px;line-height:1.55;color:var(--ink-dim);max-width:580px;
}
.proj-modal__grid{
  display:grid;grid-template-columns:1fr;gap:22px;margin-bottom:28px;
}
@media(min-width:700px){
  .proj-modal__grid{grid-template-columns:repeat(2,1fr)}
  .proj-modal__block--wide{grid-column:1 / -1}
}
.proj-modal__block{display:flex;flex-direction:column;gap:10px}
.proj-modal__label{
  display:inline-block;font-size:11px;font-weight:500;
  letter-spacing:.2em;color:var(--ink-mute);
  padding-bottom:8px;border-bottom:1px solid var(--line);
}
.proj-modal__text{font-size:15px;line-height:1.75;color:var(--ink-dim)}
.proj-modal__list{
  list-style:none;display:flex;flex-direction:column;gap:8px;
  font-size:14px;color:var(--ink);
}
.proj-modal__list li{display:flex;gap:10px;align-items:baseline}
.proj-modal__list li::before{
  content:"";width:6px;height:6px;background:var(--accent);
  flex-shrink:0;transform:translateY(5px);
}
.proj-modal__chips{
  list-style:none;display:flex;flex-wrap:wrap;gap:6px;
}
.proj-modal__chips li{
  padding:5px 10px;font-size:12px;letter-spacing:.03em;
  color:var(--ink-soft);border:1px solid var(--line);border-radius:2px;
}
.proj-modal__cta{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  flex-wrap:wrap;padding-top:22px;border-top:1px solid var(--line);
}
.proj-modal__hint{
  font-size:11.5px;letter-spacing:.08em;color:var(--ink-mute);
}
body.proj-modal-open{overflow:hidden}

@media(max-width:680px){
  .proj-modal__frame{width:96vw;height:92vh}
  .proj-modal__body{padding:24px 20px}
}

/* work card clickable style */
.work-card[data-project]{cursor:pointer}
.work-card[data-project]:hover{transform:translateY(-6px);border-color:var(--line-strong)}


/* ===========================================================
   Services — Sticky Horizontal Scroll
   =========================================================== */

/* Section acts as tall scroll container — height set by JS (desktop only) */
@media (min-width: 720px) {
  #services { padding-block: 0; }
}

/* Services panel — JS controls position class */
.svc-sticky {
  position: relative;
  height: 100vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding-block: clamp(24px, 3.5vh, 56px);
}
/* While inside the scroll range: pin to viewport */
.svc-sticky--fixed {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
  background: var(--bg);
}
/* After scroll range: anchor to section bottom */
.svc-sticky--past {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background: var(--bg);
}

/* Clip track to wrap width */
#services .wrap { overflow: hidden; }

/* Track container */
.wgrid {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  flex-wrap: nowrap;
  direction: rtl;          /* card 01 at right — Arabic reading order */
  gap: clamp(10px, 1.2vw, 18px);
  padding: 8px 4px 32px;
  will-change: transform;
}

@media (max-width: 719px) {
  .wgrid {
    flex-wrap: wrap;
    gap: 12px;
    padding: 0;
    transform: none !important;
  }
}

/* ── Card base ── */
.wtile {
  direction: rtl;
  flex: 0 0 clamp(220px, 21vw, 340px);
  height: clamp(220px, calc(100vh - 340px), 440px);
  border-radius: 20px;
  overflow: hidden;
  cursor: pointer;
  outline: none;
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 0;
  background: rgba(20, 14, 7, 0.38);
  border: 1px solid rgba(233,139,42,0.18);
  transition: border-color 0.45s;
  will-change: transform;
  transform-origin: center center;
}

@media (max-width: 719px) {
  .wtile { flex: 0 0 calc(50% - 6px); height: clamp(180px, 38vw, 240px); }
}

/* Hover: amber border */
.wtile:hover, .wtile:focus-visible {
  border-color: rgba(233,139,42,0.60);
}

/* Service-specific background */
.wtile__glass {
  position: absolute; inset: 0;
  border-radius: inherit; border: none;
  z-index: 0; pointer-events: none;
}
/* Per-card jewel-tone glows — amber borders stay as brand anchor */
.wtile[data-svc="web"]      .wtile__glass { background: radial-gradient(ellipse at 30% 0%,  rgba(233,139,42, 0.22) 0%, transparent 62%); }
.wtile[data-svc="mobile"]   .wtile__glass { background: radial-gradient(ellipse at 65% 0%,  rgba(20,184,166,  0.20) 0%, transparent 60%); }
.wtile[data-svc="ai"]       .wtile__glass { background: radial-gradient(ellipse at 50% 0%,  rgba(59,130,246,  0.22) 0%, transparent 64%); }
.wtile[data-svc="security"] .wtile__glass { background: radial-gradient(ellipse at 40% 0%,  rgba(220,38,38,   0.20) 0%, transparent 62%); }
.wtile[data-svc="auto"]     .wtile__glass { background: radial-gradient(ellipse at 60% 0%,  rgba(139,92,246,  0.20) 0%, transparent 63%); }
.wtile[data-svc="infra"]    .wtile__glass { background: radial-gradient(ellipse at 50% 5%,  rgba(100,116,139, 0.26) 0%, transparent 61%); }
.wtile[data-svc="ux"]       .wtile__glass { background: radial-gradient(ellipse at 35% 0%,  rgba(236,72,153,  0.18) 0%, transparent 60%); }
.wtile[data-svc="consult"]  .wtile__glass { background: radial-gradient(ellipse at 55% 8%,  rgba(16,185,129,  0.20) 0%, transparent 64%); }

/* Per-card glyph accent */
.wtile[data-svc="mobile"]   .wtile__glyph { background: rgba(20,184,166,0.07);  border-color: rgba(20,184,166,0.18);  color: rgba(20,184,166,0.65);  }
.wtile[data-svc="ai"]       .wtile__glyph { background: rgba(59,130,246,0.07);  border-color: rgba(59,130,246,0.18);  color: rgba(59,130,246,0.65);  }
.wtile[data-svc="security"] .wtile__glyph { background: rgba(220,38,38,0.07);   border-color: rgba(220,38,38,0.18);   color: rgba(220,68,68,0.65);   }
.wtile[data-svc="auto"]     .wtile__glyph { background: rgba(139,92,246,0.07);  border-color: rgba(139,92,246,0.18);  color: rgba(139,92,246,0.65);  }
.wtile[data-svc="infra"]    .wtile__glyph { background: rgba(100,116,139,0.08); border-color: rgba(100,116,139,0.20); color: rgba(148,163,184,0.70); }
.wtile[data-svc="ux"]       .wtile__glyph { background: rgba(236,72,153,0.07);  border-color: rgba(236,72,153,0.18);  color: rgba(236,72,153,0.65);  }
.wtile[data-svc="consult"]  .wtile__glyph { background: rgba(16,185,129,0.07);  border-color: rgba(16,185,129,0.18);  color: rgba(16,185,129,0.65);  }

/* Hover: glyph brightens to its own accent */
.wtile[data-svc="mobile"]:hover   .wtile__glyph { background: rgba(20,184,166,0.14);  border-color: rgba(20,184,166,0.50);  color: rgb(20,184,166);   transform: rotate(-8deg) scale(1.1); }
.wtile[data-svc="ai"]:hover       .wtile__glyph { background: rgba(59,130,246,0.14);  border-color: rgba(59,130,246,0.50);  color: rgb(59,130,246);   transform: rotate(-8deg) scale(1.1); }
.wtile[data-svc="security"]:hover .wtile__glyph { background: rgba(220,38,38,0.14);   border-color: rgba(220,38,38,0.50);   color: rgb(220,68,68);    transform: rotate(-8deg) scale(1.1); }
.wtile[data-svc="auto"]:hover     .wtile__glyph { background: rgba(139,92,246,0.14);  border-color: rgba(139,92,246,0.50);  color: rgb(139,92,246);   transform: rotate(-8deg) scale(1.1); }
.wtile[data-svc="infra"]:hover    .wtile__glyph { background: rgba(100,116,139,0.16); border-color: rgba(148,163,184,0.45); color: rgb(148,163,184);  transform: rotate(-8deg) scale(1.1); }
.wtile[data-svc="ux"]:hover       .wtile__glyph { background: rgba(236,72,153,0.14);  border-color: rgba(236,72,153,0.50);  color: rgb(236,72,153);   transform: rotate(-8deg) scale(1.1); }
.wtile[data-svc="consult"]:hover  .wtile__glyph { background: rgba(16,185,129,0.14);  border-color: rgba(16,185,129,0.50);  color: rgb(16,185,129);   transform: rotate(-8deg) scale(1.1); }

/* Glass border ring */
.wtile__cross {
  position: absolute; inset: 0;
  border: 1px solid rgba(233,139,42,0.12);
  border-radius: inherit;
  box-sizing: border-box;
  pointer-events: none; z-index: 5;
  width: auto; height: auto;
  transform: none; left: 0; top: 0; margin: 0;
}
.wtile__cross::before, .wtile__cross::after { display: none; }

/* Hover: radial glow (mouse-follow) */
.wtile::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(
    260px circle at var(--mx,50%) var(--my,50%),
    color-mix(in oklab, var(--accent) 11%, transparent),
    transparent 65%
  );
  opacity: 0; transition: opacity 0.5s;
  z-index: 1; pointer-events: none;
  border-radius: inherit;
}
.wtile:hover::before, .wtile:focus-visible::before { opacity: 1; }

/* Top amber shimmer */
.wtile::after {
  content: "";
  position: absolute; top: 0; inset-inline: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(233,139,42,0.9) 50%, transparent);
  transform: scaleX(0); transform-origin: center;
  transition: transform 0.6s var(--ease); z-index: 6;
}
.wtile:hover::after, .wtile:focus-visible::after { transform: scaleX(1); }

/* ── Content layout ── */
.wtile__body {
  position: absolute; inset: 0; z-index: 3;
  display: flex; flex-direction: column;
  padding: 20px 20px 18px;
}

/* Ghost number */
.wtile__body::before {
  content: attr(data-num);
  position: absolute; bottom: -10px; inset-inline-end: -2px;
  font-size: 100px; font-weight: 800; line-height: 1;
  letter-spacing: -0.06em;
  color: rgba(233,139,42,0.05);
  pointer-events: none; z-index: 0;
  font-variant-numeric: tabular-nums; user-select: none;
  transition: color 0.55s;
}
.wtile:hover .wtile__body::before { color: rgba(233,139,42,0.12); }

.wtile__top {
  display: flex; align-items: center;
  justify-content: space-between;
  position: relative; z-index: 1;
  margin-bottom: auto;
}

.wtile__num {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.28em; color: rgba(233,139,42,0.48);
  font-variant-numeric: tabular-nums; transition: color 0.4s;
}
.wtile:hover .wtile__num { color: var(--accent); }

.wtile__glyph {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  background: rgba(233,139,42,0.07);
  border: 1px solid rgba(233,139,42,0.16);
  border-radius: 11px;
  color: rgba(233,139,42,0.55);
  transition: all 0.5s var(--ease); flex-shrink: 0;
}
.wtile__glyph svg { width: 20px; height: 20px; }
.wtile:hover .wtile__glyph, .wtile:focus-visible .wtile__glyph {
  background: rgba(233,139,42,0.14);
  border-color: rgba(233,139,42,0.5);
  color: var(--accent);
  transform: rotate(-8deg) scale(1.1);
  box-shadow: 0 0 16px -4px rgba(233,139,42,0.4);
}

.wtile__title {
  font-size: 18px; font-weight: 600;
  line-height: 1.3; letter-spacing: -0.02em;
  color: rgba(243,238,228,0.9);
  margin-bottom: 10px;
  position: relative; z-index: 1;
  transition: color 0.3s;
}
.wtile:hover .wtile__title { color: #fff; }

.wtile__desc {
  font-size: 12.5px; line-height: 1.7;
  color: rgba(243,238,228,0.32);
  position: relative; z-index: 1;
  margin-bottom: 14px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color 0.3s;
}
.wtile:hover .wtile__desc { color: rgba(243,238,228,0.58); }

.wtile__peek {
  display: inline-flex; align-items: center;
  gap: 6px; font-size: 10px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(233,139,42,0.42);
  position: relative; z-index: 1;
  transition: color 0.3s, gap 0.3s;
  font-family: 'JetBrains Mono', monospace;
}
.wtile:hover .wtile__peek, .wtile:focus-visible .wtile__peek {
  color: var(--accent); gap: 10px;
}
.wtile__peek svg {
  width: 13px; height: 9px;
  transition: transform 0.3s; transform: scaleX(-1);
}
body[dir="ltr"] .wtile__peek svg { transform: scaleX(1); }

/* Progress bar */
.svc-pbar {
  position: absolute;
  bottom: 20px;
  left: var(--pad-x);
  right: var(--pad-x);
  height: 2px;
  background: rgba(255,255,255,0.09);
  border-radius: 2px;
  overflow: hidden;
}
.svc-pbar__fill {
  height: 100%;
  background: var(--accent);
  border-radius: 2px;
  transform-origin: left center;
  transform: scaleX(0);
}

.wtile.is-opening { visibility: hidden; }

/* ===========================================================
   Window Detail — expanded service overlay
   =========================================================== */
.wdetail {
  position: fixed;
  inset: 0;
  z-index: 1000;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.45s var(--ease);
}
.wdetail.is-open {
  opacity: 1;
  pointer-events: auto;
}
.wdetail__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 5, 10, 0.72);
  backdrop-filter: blur(18px) saturate(1.1);
  -webkit-backdrop-filter: blur(18px) saturate(1.1);
  opacity: 0;
  transition: opacity 0.45s var(--ease);
}
.wdetail.is-open .wdetail__backdrop { opacity: 1; }

.wdetail__frame {
  position: absolute;
  top: 50%;
  left: 50%;
  width: min(980px, 92vw);
  height: min(720px, 88vh);
  border: 1px solid var(--line-strong);
  border-radius: 2px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0) 50%),
    var(--bg-elev);
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.02) inset,
    0 60px 120px -20px rgba(0,0,0,0.7),
    0 0 200px -20px color-mix(in oklab, var(--accent) 18%, transparent);
  overflow: hidden;
  opacity: 0;
  transform-origin: center;
  transform: translate(-50%, -50%) scale(0.88) rotateX(10deg);
  transition:
    transform 0.55s var(--ease),
    opacity 0.4s var(--ease);
}
.wdetail.is-open .wdetail__frame {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1) rotateX(0);
}

.wdetail__chrome {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 18px;
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,0.02);
  font-size: 12px;
}
.wdetail__dots { display: flex; gap: 6px; flex-shrink: 0; }
.wdetail__dots span {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--line-strong);
}
.wdetail__dots span:nth-child(1) { background: oklch(0.65 0.18 25); }
.wdetail__dots span:nth-child(2) { background: oklch(0.78 0.14 85); }
.wdetail__dots span:nth-child(3) { background: oklch(0.72 0.15 150); }

.wdetail__addr {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 6px 12px;
  border: 1px solid var(--line);
  border-radius: 2px;
  color: var(--ink-soft);
  font-size: 11.5px;
  letter-spacing: 0.05em;
  font-feature-settings: "tnum";
  max-width: 400px;
  margin: 0 auto;
}
.wdetail__addr-cross {
  width: 10px; height: 10px;
  position: relative;
  flex-shrink: 0;
}
.wdetail__addr-cross::before,
.wdetail__addr-cross::after {
  content: "";
  position: absolute;
  background: var(--accent);
  opacity: 0.8;
}
.wdetail__addr-cross::before { left: 50%; top: 0; bottom: 0; width: 1px; transform: translateX(-50%); }
.wdetail__addr-cross::after  { top: 50%; left: 0; right: 0; height: 1px; transform: translateY(-50%); }

.wdetail__close {
  flex-shrink: 0;
  width: 28px; height: 28px;
  display: grid; place-items: center;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 2px;
  color: var(--ink-dim);
  cursor: pointer;
  transition: all 0.25s;
}
.wdetail__close:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.wdetail__close svg { width: 14px; height: 14px; display: block; }

.wdetail__scroll {
  height: calc(100% - 53px);
  overflow-y: auto;
  padding: 42px 48px 40px;
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.5s 0.12s var(--ease), transform 0.6s 0.12s var(--ease);
}
.wdetail.is-open .wdetail__scroll { opacity: 1; transform: none; }
.wdetail__scroll::-webkit-scrollbar { width: 6px; }
.wdetail__scroll::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 3px; }

.wdetail__hero {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 28px;
}
.wdetail__num {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.22em;
  color: var(--accent);
  font-feature-settings: "tnum";
}
.wdetail__title {
  font-size: clamp(30px, 4vw, 44px);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.wdetail__tag {
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink-dim);
  max-width: 620px;
  text-wrap: pretty;
}

.wdetail__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-bottom: 32px;
}
@media (min-width: 760px) {
  .wdetail__grid { grid-template-columns: repeat(2, 1fr); }
  .wdetail__block--wide { grid-column: 1 / -1; }
}

.wdetail__block {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.wdetail__klabel {
  display: inline-block;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.2em;
  color: var(--ink-mute);
  padding-bottom: 8px;
  border-bottom: 1px solid var(--line);
}
.wdetail__over,
.wdetail__sample {
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink-dim);
  text-wrap: pretty;
}
.wdetail__sample {
  padding: 16px 18px;
  border: 1px solid var(--line);
  border-radius: 2px;
  background: rgba(255,255,255,0.015);
  font-style: italic;
}
.wdetail__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 14px;
  color: var(--ink);
}
.wdetail__list li {
  display: flex; gap: 10px;
  align-items: baseline;
}
.wdetail__list li::before {
  content: "";
  width: 6px; height: 6px;
  background: var(--accent);
  flex-shrink: 0;
  transform: translateY(6px);
}
.wdetail__chips {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.wdetail__chips li {
  padding: 5px 10px;
  font-size: 12px;
  letter-spacing: 0.03em;
  color: var(--ink-soft);
  border: 1px solid var(--line);
  border-radius: 2px;
  font-feature-settings: "tnum";
}
.wdetail__cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  padding-top: 24px;
  border-top: 1px solid var(--line);
}
.wdetail__hint {
  font-size: 11.5px;
  letter-spacing: 0.08em;
  color: var(--ink-mute);
  font-feature-settings: "tnum";
}
body.wdetail-open { overflow: hidden; }

@media (max-width: 680px) {
  .wdetail__frame { width: 96vw; height: 92vh; }
  .wdetail__scroll { padding: 28px 22px 30px; }
  .wdetail__addr { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .wtile, .wtile::before, .wtile::after,
  .wtile__glass, .wtile__glyph, .wtile__peek,
  .wdetail, .wdetail__backdrop, .wdetail__frame, .wdetail__scroll {
    transition: opacity 0.15s !important;
  }
  .wdetail.is-open .wdetail__frame { transform: translate(-50%, -50%); }
}