/* ============================================================
   Watan First Solutions — Resource Plan
   Brand-committed tokens (see DESIGN.md). Identity preservation.
   ============================================================ */

/* self-hosted brand fonts (no external CDN) */
@font-face{font-family:'Cairo';font-style:normal;font-weight:100 900;font-display:swap;src:url('fonts/cairo-arabic.woff2') format('woff2');unicode-range:U+0600-06FF,U+0750-077F,U+0870-088E,U+0898-08E1,U+08E3-08FF,U+200C-200E,U+2010-2011,U+204F,U+2E41,U+FB50-FDFF,U+FE70-FE74,U+FE76-FEFC}
@font-face{font-family:'Cairo';font-style:normal;font-weight:100 900;font-display:swap;src:url('fonts/cairo-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Noto Kufi Arabic';font-style:normal;font-weight:100 900;font-display:swap;src:url('fonts/notokufi-arabic.woff2') format('woff2');unicode-range:U+0600-06FF,U+0750-077F,U+0870-088E,U+0898-08E1,U+08E3-08FF,U+200C-200E,U+2010-2011,U+204F,U+2E41,U+FB50-FDFF,U+FE70-FE74,U+FE76-FEFC}
@font-face{font-family:'Noto Kufi Arabic';font-style:normal;font-weight:100 900;font-display:swap;src:url('fonts/notokufi-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Outfit';font-style:normal;font-weight:100 900;font-display:swap;src:url('fonts/outfit-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:100 900;font-display:swap;src:url('fonts/inter-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

:root {
  /* Navy family (foundation ~70%) */
  --navy-deep: #060F2E;
  --navy: #0B1A4A;
  --navy-mid: #10245F;
  --navy-soft: #1D2545;

  /* Structural blue */
  --blue: #2563C9;
  --blue-bright: #4F86E6;

  /* Gold (voice ~10%) */
  --gold: #E8C77E;
  --gold-strong: #D8B057;

  /* Light (room ~20%) */
  --mist: #EEF2F8;
  --paper: #FFFFFF;

  /* Ink on light */
  --ink: #060F2E;
  --ink-soft: #2A3357;
  --ink-muted: #515B82;     /* ≥4.5:1 on mist/paper */

  /* Ink on navy */
  --on-navy: #DCE4F6;
  --on-navy-soft: #98A6CE;
  --on-navy-faint: rgba(255, 255, 255, 0.14);

  /* diagonal weave (135deg) atmospheric texture */
  --diag: repeating-linear-gradient(135deg, rgba(150,175,230,.05) 0 1.5px, transparent 1.5px 17px);

  /* Type */
  --font-head-latin: 'Outfit', system-ui, sans-serif;
  --font-body-latin: 'Inter', system-ui, sans-serif;
  --font-head-ar: 'Cairo', system-ui, sans-serif;
  --font-body-ar: 'Noto Kufi Arabic', system-ui, sans-serif;

  --font-head: var(--font-head-ar);
  --font-body: var(--font-body-ar);

  /* Spacing rhythm */
  --space-section: clamp(4rem, 9vw, 8rem);
  --radius: 16px;
  --radius-lg: 24px;
  --maxw: 1180px;

  /* z-scale */
  --z-header: 100;
  --z-skip: 200;

  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);     /* ease-out-expo-ish */
}

html[lang="en"] {
  --font-head: var(--font-head-latin);
  --font-body: var(--font-body-latin);
}

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

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

body {
  font-family: var(--font-body);
  background: var(--navy-deep);
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 { font-family: var(--font-head); line-height: 1.12; font-weight: 600; }

.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(1.2rem, 4vw, 2.5rem); }

a { color: inherit; text-decoration: none; }
ul { list-style: none; }

.tnum { font-variant-numeric: tabular-nums; }

/* numbers stay LTR even in RTL */
[dir="rtl"] .ltr-num { direction: ltr; unicode-bidi: embed; display: inline-block; }

.skip-link {
  position: absolute; inset-inline-start: -999px; top: 0; z-index: var(--z-skip);
  background: var(--gold); color: var(--navy-deep); padding: 0.6rem 1rem;
  border-radius: 0 0 10px 0; font-weight: 600;
}
.skip-link:focus { inset-inline-start: 0; }

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

/* ============ HEADER ============ */
.site-header {
  position: sticky; top: 0; z-index: var(--z-header);
  background: color-mix(in oklab, var(--navy-deep) 82%, transparent);
  backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid var(--on-navy-faint);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; min-height: 64px; gap: 1rem; }

.brand { display: inline-flex; align-items: center; height: 100%; }
.brand img { height: clamp(24px, 3.2vh, 32px); width: auto; display: block; }

.lang-toggle {
  display: inline-flex; align-items: center; gap: 0.45rem;
  background: transparent; border: 1px solid var(--on-navy-faint);
  color: var(--on-navy-soft); border-radius: 999px; padding: 0.5rem 0.95rem;
  font-family: var(--font-body-latin); font-size: 0.82rem; cursor: pointer;
  transition: border-color 0.3s, color 0.3s;
}
.lang-toggle:hover { border-color: var(--gold); color: var(--on-navy); }
.lang-opt { transition: color 0.3s, font-weight 0.3s; }
.lang-opt.active { color: var(--gold); font-weight: 700; }
.lang-sep { opacity: 0.4; }

/* ============ Shared section bits ============ */
.section-title { font-size: clamp(1.9rem, 4.2vw, 3rem); letter-spacing: -0.03em; color: var(--ink); text-wrap: balance; }
.section-title.on-dark { color: var(--on-navy); }
.section-note { margin-top: 0.9rem; font-size: clamp(1rem, 2vw, 1.15rem); color: var(--on-navy-soft); max-width: 60ch; }
.section-note.muted { color: var(--ink-muted); }
.kicker {
  font-family: var(--font-body-latin); font-size: 0.8rem; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--gold); margin-bottom: 1.1rem;
}
[dir="rtl"] .kicker { letter-spacing: 0.06em; }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  padding: 0.85rem 1.6rem; border-radius: 999px; font-family: var(--font-head);
  font-weight: 600; font-size: 0.98rem; cursor: pointer; border: 1px solid transparent;
  transition: transform 0.3s var(--ease-out), background 0.3s, color 0.3s, border-color 0.3s;
}
.btn-gold { background: var(--gold); color: var(--navy-deep); }
.btn-gold:hover { background: #F0D595; transform: translateY(-2px); }
.btn-ghost { border-color: var(--on-navy-faint); color: var(--on-navy); }
.btn-ghost:hover { border-color: var(--gold); color: var(--gold); transform: translateY(-2px); }

/* ============ HERO ============ */
.hero {
  position: relative; overflow: hidden; isolation: isolate;
  background:
    radial-gradient(1100px 620px at 78% 8%, rgba(37, 99, 201, 0.28), transparent 60%),
    radial-gradient(700px 500px at 12% 92%, rgba(232, 199, 126, 0.10), transparent 60%),
    var(--navy-deep);
  color: var(--on-navy);
  padding-block: clamp(5rem, 14vh, 9rem) clamp(5rem, 13vh, 8rem);
}
.roadmap-weave {
  position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: 0.5;
  background-image: var(--diag);
  mask-image: linear-gradient(to bottom, transparent, #000 30%, #000 70%, transparent);
}

/* ---- Connection Wave (brand motif, drifting) ---- */
.stripes { position: absolute; inset: 0; pointer-events: none; z-index: 0; background-image: var(--diag);
  mask-image: radial-gradient(120% 120% at 80% 0%, #000, transparent 70%); }
.wave-band { position: absolute; left: 0; right: 0; top: 0; height: 100%; overflow: hidden; pointer-events: none;
  mix-blend-mode: screen; opacity: 0.72; z-index: 0; }
.wave-band .wave-svg { position: absolute; width: 200%; height: 100%; left: 0; top: 50%; transform: translateY(-50%); }
.wave-band .wave-svg path { fill: none; stroke: url(#wgrad); stroke-width: 1; vector-effect: non-scaling-stroke; }
.wave-band .wave-svg .drift { animation: waveDrift 26s linear infinite; }
.wave-band .wave-svg .drift.slow { animation-duration: 42s; }
.wave-band .wave-svg .drift.slower { animation-duration: 60s; }
@keyframes waveDrift { to { transform: translateX(-50%); } }
.hnodes { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; z-index: 0; opacity: 0.9; }
.hnodes circle { fill: url(#hnodeG); transform-box: fill-box; transform-origin: center; r: var(--nz, 9px);
  animation: hnode-tw infinite ease-in-out; filter: url(#hnodeGlow); }
@keyframes hnode-tw { 0%,100% { opacity: 0.35; r: calc(var(--nz) * 0.72); } 50% { opacity: 1; r: calc(var(--nz) * 1.22); } }

.hero-inner { position: relative; z-index: 2; max-width: 820px; }
.hero-title {
  font-size: clamp(2.6rem, 7vw, 5.2rem); letter-spacing: -0.035em; font-weight: 700;
  text-wrap: balance; margin-bottom: 1.3rem;
}
[dir="rtl"] .hero-title { letter-spacing: -0.01em; line-height: 1.18; }
.hero-sub { font-size: clamp(1.05rem, 2.3vw, 1.4rem); color: var(--on-navy-soft); max-width: 56ch; margin-bottom: 2.2rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 0.9rem; }

/* hero intro motion */
.hero .kicker, .hero-title, .hero-sub, .hero-actions {
  opacity: 0; transform: translateY(16px); animation: rise 0.9s var(--ease-out) forwards;
}
.hero .kicker { animation-delay: 0.1s; }
.hero-title { animation-delay: 0.24s; }
.hero-sub { animation-delay: 0.40s; }
.hero-actions { animation-delay: 0.54s; }
@keyframes rise { to { opacity: 1; transform: none; } }

/* ============ OVERVIEW ============ */
.overview { background: var(--mist); color: var(--ink); padding-block: var(--space-section); }
.overview-inner { display: grid; grid-template-columns: 1.3fr 0.7fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.lead { margin-top: 1.2rem; font-size: clamp(1.05rem, 2vw, 1.25rem); color: var(--ink-soft); max-width: 60ch; }
.figures { display: flex; flex-direction: column; gap: 1.1rem; }
.figures li {
  display: flex; flex-direction: column; gap: 0.15rem;
  padding-inline-start: 1.1rem; border-inline-start: 2px solid var(--gold);
}
.fig-num { font-family: var(--font-head); font-size: clamp(1.5rem, 3vw, 2.1rem); font-weight: 700; color: var(--navy); letter-spacing: -0.02em; }
.fig-label { font-size: 0.92rem; color: var(--ink-muted); }

/* ============ ROADMAP ============ */
.roadmap { position: relative; background: var(--navy-deep); color: var(--on-navy); padding-block: var(--space-section); overflow: hidden; }
.roadmap-head { text-align: center; max-width: 640px; margin-inline: auto; margin-bottom: clamp(2.5rem, 6vw, 4.5rem); }
.roadmap-head .section-note { margin-inline: auto; }

.wave-track { position: relative; }
.wave-svg { display: block; width: 100%; height: 220px; }
/* visible by default; .drawn only enhances with a draw-on animation */
.wave-path { stroke-dasharray: 1600; stroke-dashoffset: 0; }
.wave-path.drawn { animation: drawWave 2.2s var(--ease-out) both; }
@keyframes drawWave { from { stroke-dashoffset: 1600; } to { stroke-dashoffset: 0; } }

.wave-nodes { position: absolute; inset: 0; display: flex; }
.wave-node { flex: 1; position: relative; height: 100%; }
.node-anchor {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
}
.node-dot {
  width: 18px; height: 18px; border-radius: 50%; position: relative;
  background: var(--gold); box-shadow: 0 0 0 6px rgba(232, 199, 126, 0.16), 0 0 22px rgba(232, 199, 126, 0.45);
}
.node-dot::after {
  content: ""; position: absolute; inset: -11px; border-radius: 50%;
  border: 1px solid rgba(232, 199, 126, 0.4);
}
.node-info {
  position: absolute; left: 50%; transform: translateX(-50%);
  width: clamp(140px, 18vw, 190px); text-align: center;
}
/* visible by default; .show only enhances with a fade-rise animation */
.wave-node.show .node-info { animation: nodeIn 0.6s var(--ease-out) both; }
@keyframes nodeIn { from { opacity: 0; transform: translateX(-50%) translateY(14px); } to { opacity: 1; transform: translateX(-50%) translateY(0); } }
.wave-node.above .node-info { bottom: calc(50% + 26px); }
.wave-node.below .node-info { top: calc(50% + 26px); }
.node-step { display: block; font-family: var(--font-body-latin); font-size: 0.72rem; letter-spacing: 0.12em; color: var(--gold); }
.node-title { display: block; font-family: var(--font-head); font-weight: 600; font-size: 1.02rem; margin-top: 0.25rem; color: var(--on-navy); }
.node-date { display: block; font-size: 0.82rem; color: var(--on-navy-soft); margin-top: 0.2rem; }

/* ============ ROLES ============ */
.roles { background: var(--mist); color: var(--ink); padding-block: var(--space-section); }
.roles-head { margin-bottom: clamp(2rem, 5vw, 3.5rem); }
.roles-list { display: flex; flex-direction: column; gap: 1.4rem; }

.role {
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg);
  overflow: hidden; transition: border-color 0.35s var(--ease-out), box-shadow 0.45s var(--ease-out), transform 0.45s var(--ease-out);
}
.role:hover { border-color: #C6D2E8; box-shadow: 0 22px 50px -32px rgba(6, 15, 46, 0.32); transform: translateY(-2px); }
.role[open] { border-color: #C2CFE6; box-shadow: 0 26px 60px -34px rgba(6, 15, 46, 0.30); transform: none; }
.role.is-placeholder { background: linear-gradient(180deg, #F7F9FD, var(--paper)); }

.role-summary { list-style: none; }
.role-summary::-webkit-details-marker { display: none; }
.role-summary {
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: clamp(0.9rem, 2.4vw, 1.5rem);
  padding: clamp(1.25rem, 2.8vw, 1.7rem) clamp(1.3rem, 3vw, 2rem);
  width: 100%; background: none; border: 0; cursor: pointer; text-align: start; color: inherit; font: inherit;
}
.role-index {
  font-family: var(--font-head); font-size: 1rem; font-weight: 700; color: var(--gold-strong);
  width: 46px; height: 46px; display: grid; place-items: center; border-radius: 14px; flex-shrink: 0;
  background: linear-gradient(150deg, #FBF4E4, #F4E9CE); border: 1px solid #EEDFBB;
  transition: background 0.4s var(--ease-out), color 0.4s var(--ease-out), border-color 0.4s var(--ease-out);
}
.role[open] .role-index { background: var(--navy); color: var(--gold); border-color: var(--navy); }
.role-id { min-width: 0; display: flex; flex-direction: column; gap: 0.4rem; }
.role-title { font-size: clamp(1.18rem, 2.4vw, 1.5rem); letter-spacing: -0.02em; color: var(--navy); line-height: 1.16; text-wrap: balance; }
.role-teaser { font-size: 0.92rem; color: var(--ink-muted); line-height: 1.45; max-width: 60ch; }
.role[open] .role-teaser { display: none; }
.role-meta { display: flex; flex-wrap: wrap; gap: 0.45rem; margin-top: 0.1rem; }
.tag { font-size: 0.74rem; padding: 0.28rem 0.72rem; border-radius: 999px; background: var(--mist); color: var(--ink-soft); border: 1px solid var(--line); font-family: var(--font-body); }
.tag.gold { background: #FBF4E4; color: #8A6A1E; border-color: #ECDCB4; }
.role-toggle {
  width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center; flex-shrink: 0;
  color: var(--ink-soft); background: var(--surface, var(--paper)); border: 1px solid var(--line);
  transition: background 0.4s var(--ease-out), color 0.4s var(--ease-out), border-color 0.4s var(--ease-out);
}
.role-summary:hover .role-toggle { border-color: var(--gold-strong); color: var(--gold-strong); background: #FBF4E4; }
.role-toggle svg { transition: transform 0.45s var(--ease-out); }
.role[open] .role-toggle { background: var(--navy); border-color: var(--navy); color: var(--gold); }
.role[open] .role-toggle svg { transform: rotate(180deg); }

.role-body { padding: 0 clamp(1.3rem, 3vw, 2.1rem) clamp(1.6rem, 3vw, 2.2rem); }
.role-body-inner { border-top: 1px solid #E7ECF5; padding-top: 1.6rem; }

.jd-actions { display: flex; justify-content: flex-end; margin-bottom: 1.4rem; }
.copy-btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--font-head); font-size: 0.88rem; font-weight: 600;
  padding: 0.55rem 1.1rem; border-radius: 999px;
  background: #FBF4E4; color: #8A6A1E; border: 1px solid #ECDCB4; cursor: pointer;
  transition: background 0.3s, border-color 0.3s, color 0.3s, transform 0.3s var(--ease-out);
}
.copy-btn:hover { background: #F6EAC9; border-color: var(--gold); transform: translateY(-1px); }
.copy-btn:active { transform: translateY(0); }
.copy-btn svg { flex-shrink: 0; }
.copy-btn.copied { background: var(--navy); color: var(--gold); border-color: var(--navy); }
.copy-btn.failed { background: #FBECEC; color: #9B2C2C; border-color: #E7C3C3; }
.role-nature { font-size: 1.02rem; color: var(--ink-soft); max-width: 72ch; margin-bottom: 1.8rem; }

.jd-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: clamp(1.4rem, 3vw, 2.4rem); }
.jd-block h4 { font-size: 0.82rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gold-strong);
  font-family: var(--font-body-latin); margin-bottom: 0.9rem; }
[dir="rtl"] .jd-block h4 { text-transform: none; letter-spacing: 0; font-family: var(--font-head); font-size: 0.95rem; }
.jd-list li { position: relative; padding-inline-start: 1.4rem; margin-bottom: 0.7rem; color: var(--ink-soft); font-size: 0.96rem; line-height: 1.55; }
.jd-list li::before { content: ""; position: absolute; inset-inline-start: 0; top: 0.62em; width: 6px; height: 6px; border-radius: 50%; background: var(--blue); }
.jd-list.suggest li::before { background: var(--gold-strong); }
.jd-suggest-label { margin-top: 1.5rem; }

.placeholder-note {
  display: flex; align-items: center; gap: 0.7rem; padding: 1.1rem 1.3rem; border-radius: var(--radius);
  background: #F2F5FB; border: 1px dashed #C6D2E8; color: var(--ink-muted); font-size: 0.95rem;
}
.placeholder-note svg { color: var(--gold-strong); flex-shrink: 0; }

/* ============ SUMMARY ============ */
.summary { background: var(--navy-deep); color: var(--on-navy); padding-block: var(--space-section); }
.summary .section-title { margin-bottom: clamp(1.8rem, 4vw, 2.6rem); }
.table-wrap { overflow-x: auto; border: 1px solid var(--on-navy-faint); border-radius: var(--radius-lg); }
.summary-table { width: 100%; border-collapse: collapse; min-width: 640px; }
.summary-table th, .summary-table td { padding: 1rem 1.15rem; text-align: start; font-size: 0.92rem; }
.summary-table thead th {
  font-family: var(--font-body-latin); font-size: 0.74rem; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--on-navy-soft); border-bottom: 1px solid var(--on-navy-faint); font-weight: 600;
}
[dir="rtl"] .summary-table thead th { font-family: var(--font-head); text-transform: none; letter-spacing: 0; }
.summary-table tbody tr { border-bottom: 1px solid rgba(234,239,248,0.07); transition: background 0.3s; }
.summary-table tbody tr:last-child { border-bottom: 0; }
.summary-table tbody tr:hover { background: rgba(234,239,248,0.035); }
.summary-table td.role-cell { color: var(--on-navy); font-weight: 600; font-family: var(--font-head); }
.status-pill { font-size: 0.78rem; padding: 0.22rem 0.7rem; border-radius: 999px; white-space: nowrap; }
.status-pill.open { background: rgba(232,199,126,0.16); color: var(--gold); border: 1px solid rgba(232,199,126,0.3); }
.status-pill.draft { background: rgba(79,134,230,0.14); color: var(--blue-bright); border: 1px solid rgba(79,134,230,0.3); }

/* ============ FOOTER ============ */
.site-footer { background: #04091F; color: var(--on-navy-soft); padding-block: 2.5rem; border-top: 1px solid var(--on-navy-faint); }
.footer-inner { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 0.8rem; font-size: 0.88rem; }
.footer-brand { font-family: var(--font-head); color: var(--on-navy); }

/* ============ REVEAL ============ */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out); }
.reveal.in { opacity: 1; transform: none; }

/* ============ RESPONSIVE ============ */
@media (max-width: 860px) {
  .overview-inner { grid-template-columns: 1fr; }
  .figures { flex-direction: row; flex-wrap: wrap; gap: 1.5rem 2rem; margin-top: 0.5rem; }
  .figures li { flex: 1 1 30%; }

  /* roadmap becomes a vertical timeline below 860px (avoids horizontal label crowding) */
  .wave-track .wave-svg { display: none; }
  .wave-track { position: relative; }
  .wave-nodes { position: static; flex-direction: column; gap: 0.2rem; }
  .wave-nodes::before { content: ""; position: absolute; inset-inline-start: 9px; top: 14px; bottom: 14px; width: 2px;
    background: linear-gradient(var(--blue-bright), var(--gold)); }
  .wave-node { flex: none; height: auto; display: grid; grid-template-columns: auto 1fr; gap: 0.1rem 1.1rem;
    align-items: start; padding-block: 0.95rem; }
  .node-anchor { position: static; transform: none; opacity: 1; grid-row: 1 / span 3; align-self: start; margin-top: 0.3rem; }
  .node-info { position: static; transform: none !important; left: auto; width: auto; text-align: start; opacity: 1; }
  .wave-node.above .node-info, .wave-node.below .node-info { top: auto; bottom: auto; }
}

@media (max-width: 720px) {
  .role-summary { gap: 0.8rem; padding-inline: 1.1rem; }
  .role-index { width: 40px; height: 40px; }
  .role-toggle { width: 40px; height: 40px; }
  .footer-inner { flex-direction: column; }
}

/* ============ REDUCED MOTION ============ */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-delay: 0s !important; transition-duration: 0.001ms !important; }
  .hero .kicker, .hero-title, .hero-sub, .hero-actions { opacity: 1; transform: none; }
  .wave-path { stroke-dashoffset: 0; }
  .wave-band .wave-svg .drift { animation: none !important; }
  .hnodes circle { animation: none !important; opacity: 0.7; }
  .wave-node { opacity: 1; }
  .reveal { opacity: 1; transform: none; }
}
