/* =========================================================
   Fritzware.de · neu2026
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  --bg:        #0A0E1F;
  --bg-soft:   #0F1428;
  --surface:   rgba(255,255,255,0.04);
  --surface-2: rgba(255,255,255,0.08);
  --border:    rgba(255,255,255,0.10);
  --border-2:  rgba(255,255,255,0.18);
  --ink:       #ECF1F9;
  --ink-soft:  #C5CFE0;
  --muted:     #8FA0BD;

  --brand-1:   #7C7CFF;
  --brand-2:   #34D6F1;
  --brand-3:   #9AF09B;
  --accent:    linear-gradient(135deg,var(--brand-1) 0%, var(--brand-2) 55%, var(--brand-3) 100%);
  --accent-soft: linear-gradient(135deg, rgba(124,124,255,0.18), rgba(52,214,241,0.14), rgba(154,240,155,0.12));

  --radius:    18px;
  --radius-lg: 28px;
  --radius-sm: 12px;

  --shadow-1:  0 1px 0 rgba(255,255,255,0.04) inset, 0 10px 30px rgba(0,0,0,.30), 0 2px 8px rgba(0,0,0,.25);
  --shadow-2:  0 30px 80px -20px rgba(124,124,255,0.35), 0 10px 30px rgba(0,0,0,.35);

  --ease:      cubic-bezier(.22,.61,.36,1);
  --maxw:      1180px;

  --font-display: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-body:    "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

@supports (font-variation-settings: normal){
  :root{ --font-display: "Inter var", system-ui, sans-serif; }
}

[data-theme="light"]{
  --bg:        #F4F6FB;
  --bg-soft:   #FFFFFF;
  --surface:   rgba(10,14,31,0.04);
  --surface-2: rgba(10,14,31,0.06);
  --border:    rgba(10,14,31,0.10);
  --border-2:  rgba(10,14,31,0.18);
  --ink:       #0E1430;
  --ink-soft:  #2A3358;
  --muted:     #57617A;
  --shadow-1:  0 1px 0 rgba(255,255,255,0.6) inset, 0 10px 30px rgba(10,14,31,.08), 0 2px 8px rgba(10,14,31,.05);
  --shadow-2:  0 30px 80px -20px rgba(124,124,255,0.30), 0 10px 30px rgba(10,14,31,.10);
}

/* ---------- Reset / Base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family: var(--font-body);
  font-feature-settings: "ss01","cv02","cv03","cv04","cv11";
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:rgba(124,124,255,0.35);color:var(--ink)}

.container{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(16px,3vw,28px)}

.skip{position:absolute;left:-9999px;top:0}
.skip:focus{position:fixed;left:12px;top:12px;z-index:200;background:var(--bg-soft);color:var(--ink);padding:10px 14px;border-radius:10px;border:1px solid var(--border-2)}

/* ---------- Ambient background ---------- */
.bg{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.bg__grid{
  position:absolute;inset:0;
  background-image: url("../assets/grid.svg");
  background-size: 56px 56px;
  color: var(--ink);
  opacity:.5;
  mask-image: radial-gradient(ellipse at 50% 30%, #000 0%, transparent 70%);
          -webkit-mask-image: radial-gradient(ellipse at 50% 30%, #000 0%, transparent 70%);
}
.bg__blob{
  position:absolute;
  width:48vmax;height:48vmax;
  border-radius:50%;
  filter: blur(80px);
  opacity:.55;
  mix-blend-mode: screen;
  animation: float 22s var(--ease) infinite;
}
[data-theme="light"] .bg__blob{ mix-blend-mode: multiply; opacity:.35 }
.bg__blob--1{ background: radial-gradient(circle, #7C7CFF 0%, rgba(124,124,255,0) 60%); top:-20vmax; left:-12vmax; }
.bg__blob--2{ background: radial-gradient(circle, #34D6F1 0%, rgba(52,214,241,0) 60%); top:30vmax; right:-18vmax; animation-delay:-7s; }
.bg__blob--3{ background: radial-gradient(circle, #9AF09B 0%, rgba(154,240,155,0) 60%); bottom:-22vmax; left:20vmax; animation-delay:-14s; }
.bg__noise{
  position:absolute;inset:0;
  background-image:url("../assets/noise.svg");
  opacity:.06;
  mix-blend-mode:overlay;
  pointer-events:none;
}
@keyframes float{
  0%,100%{ transform: translate3d(0,0,0) scale(1) }
  33%   { transform: translate3d(4vmax,3vmax,0) scale(1.08) }
  66%   { transform: translate3d(-3vmax,-2vmax,0) scale(.95) }
}
@media (prefers-reduced-motion: reduce){
  .bg__blob{ animation:none }
  html{ scroll-behavior:auto }
}

/* ---------- Navigation ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  backdrop-filter: saturate(1.2) blur(14px);
  -webkit-backdrop-filter: saturate(1.2) blur(14px);
  background: color-mix(in srgb, var(--bg) 70%, transparent);
  border-bottom: 1px solid var(--border);
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 0}
.brand{display:inline-flex;align-items:center;color:var(--ink);transition:opacity .2s}
.brand:hover{opacity:.85}
.nav__links{display:flex;align-items:center;gap:6px}
.nav__links a{
  position:relative;
  padding:8px 12px;border-radius:10px;
  color:var(--ink-soft);font-size:14.5px;font-weight:500;
  transition:color .2s, background .2s;
}
.nav__links a:hover{color:var(--ink);background:var(--surface)}
.nav__cta{
  margin-left:8px;
  padding:10px 16px !important;
  background:var(--accent);
  color:#0A0E1F !important;
  font-weight:700 !important;
  border-radius:999px !important;
  box-shadow: var(--shadow-1);
  display:inline-flex;align-items:center;gap:8px;
}
.nav__cta:hover{ filter:brightness(1.05); transform:translateY(-1px) }
.theme-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:999px;
  border:1px solid var(--border);background:var(--surface);
  color:var(--ink);transition:all .2s;
  margin-left:6px;
}
.theme-toggle:hover{background:var(--surface-2);border-color:var(--border-2)}
.theme-toggle__sun{display:none}
[data-theme="light"] .theme-toggle__sun{display:block}
[data-theme="light"] .theme-toggle__moon{display:none}
.menu-toggle{
  display:none;
  width:42px;height:42px;border-radius:12px;
  border:1px solid var(--border);background:var(--surface);
  position:relative;
}
.menu-toggle span{
  position:absolute;left:10px;right:10px;height:2px;border-radius:2px;background:var(--ink);
  transition:transform .25s var(--ease), opacity .2s, top .25s var(--ease);
}
.menu-toggle span:nth-child(1){top:13px}
.menu-toggle span:nth-child(2){top:20px}
.menu-toggle span:nth-child(3){top:27px}
.menu-toggle[aria-expanded="true"] span:nth-child(1){top:20px;transform:rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){top:20px;transform:rotate(-45deg)}

/* ---------- Typography helpers ---------- */
.display{
  font-family: var(--font-display);
  font-weight:800;
  font-size: clamp(34px, 5.4vw, 68px);
  line-height:1.04;
  letter-spacing:-0.02em;
  margin:14px 0 18px;
  text-wrap: balance;
}
.lead{
  font-size: clamp(16px, 1.15vw, 19px);
  color:var(--ink-soft);
  line-height:1.65;
  max-width:60ch;
}
.gradient-text{
  background: var(--accent);
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 14px 7px 12px;border-radius:999px;
  background:var(--surface);border:1px solid var(--border);
  color:var(--ink-soft);font-size:13.5px;font-weight:500;
}
.eyebrow__dot{
  width:8px;height:8px;border-radius:99px;
  background:linear-gradient(180deg,#34D6F1,#0594A8);
  box-shadow:0 0 14px rgba(52,214,241,.7);
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 14px rgba(52,214,241,.7); transform:scale(1)}
  50%{box-shadow:0 0 22px rgba(52,214,241,.95); transform:scale(1.15)}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 20px;border-radius:14px;
  font-weight:700;font-size:15px;
  transition: transform .15s var(--ease), filter .2s, box-shadow .2s, background .2s, border-color .2s;
  will-change:transform;
}
.btn--lg{padding:16px 24px;font-size:16px;border-radius:16px}
.btn--primary{
  background: var(--accent);
  color:#0A0E1F;
  box-shadow: var(--shadow-1);
}
.btn--primary:hover{ transform:translateY(-2px); filter:brightness(1.05); box-shadow:var(--shadow-2) }
.btn--ghost{
  background:var(--surface);
  border:1px solid var(--border-2);
  color:var(--ink);
}
.btn--ghost:hover{ background:var(--surface-2); transform:translateY(-2px) }
.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.cta-row--center{justify-content:center}

/* ---------- HERO ---------- */
.hero{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: clamp(28px, 5vw, 64px);
  align-items:center;
  padding: clamp(48px,8vw,120px) 0 clamp(40px,6vw,80px);
}
.hero__copy{min-width:0}
.hero__stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
  margin: 36px 0 0;padding:0;
}
.hero__stats > div{
  padding:16px;border-radius:16px;
  background:var(--surface);
  border:1px solid var(--border);
  backdrop-filter: blur(8px);
}
.hero__stats dt{font-weight:800;font-size:18px;color:var(--ink);margin:0}
.hero__stats dd{margin:4px 0 0;color:var(--muted);font-size:13.5px}

.hero__art{position:relative}
.hero__art-card{
  position:relative;
  aspect-ratio:1/1;
  border-radius:var(--radius-lg);
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02)), var(--bg-soft);
  border:1px solid var(--border);
  box-shadow: var(--shadow-2);
  overflow:hidden;
}
.hero__art-card::before{
  content:"";position:absolute;inset:0;
  background: radial-gradient(60% 50% at 50% 40%, rgba(124,124,255,0.25), transparent 70%);
  pointer-events:none;
}
.hero__art-card img{
  width:100%;height:100%;object-fit:contain;
  animation: floatY 8s ease-in-out infinite;
}
@keyframes floatY{
  0%,100%{ transform: translateY(0) }
  50%   { transform: translateY(-10px) }
}
.hero__chip{
  position:absolute;
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;border-radius:999px;
  background: color-mix(in srgb, var(--bg-soft) 78%, transparent);
  border:1px solid var(--border-2);
  font-size:13px;font-weight:600;
  color:var(--ink);
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 20px rgba(0,0,0,.25);
  animation: floatY 6s ease-in-out infinite;
}
.hero__chip svg{color:var(--brand-2)}
.hero__chip--1{ top:8%;  left:-4%;  animation-delay:-1s }
.hero__chip--2{ top:46%; right:-6%; animation-delay:-3s }
.hero__chip--3{ bottom:8%;left:8%;  animation-delay:-5s }
.hero__chip--2 svg{color:var(--brand-1)}
.hero__chip--3 svg{color:var(--brand-3)}

/* ---------- Marquee ---------- */
.marquee{
  margin: clamp(20px,3vw,40px) 0;
  border-block: 1px solid var(--border);
  background: linear-gradient(90deg, transparent, var(--surface), transparent);
  overflow:hidden;
  mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
          -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
}
.marquee__track{
  display:flex;align-items:center;gap:28px;
  padding:18px 0;
  white-space:nowrap;
  animation: marquee 40s linear infinite;
  width:max-content;
}
.marquee__track span{font-weight:700;color:var(--ink-soft);font-size:15px;letter-spacing:.01em}
.marquee__track span[aria-hidden]{color:var(--brand-2);font-size:9px}
@keyframes marquee{
  from{ transform: translateX(0) }
  to{   transform: translateX(-50%) }
}
@media (prefers-reduced-motion: reduce){
  .marquee__track{ animation:none; transform:translateX(0) }
}

/* ---------- Manifest / Standpunkt ---------- */
.manifest{
  position:relative;
  padding: clamp(40px,5vw,72px) clamp(24px,4vw,56px);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, rgba(124,124,255,0.10), rgba(52,214,241,0.05) 50%, rgba(154,240,155,0.06)),
    var(--bg-soft);
  border:1px solid var(--border-2);
  box-shadow: var(--shadow-2);
  overflow:hidden;
  text-align:center;
}
.manifest::after{
  content:"";position:absolute;inset:0;
  border-radius:inherit;padding:1px;
  background: var(--accent);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity:.5;pointer-events:none;
}
.manifest__glow{
  position:absolute;
  width:80%;height:280px;left:10%;top:-140px;
  background: radial-gradient(50% 100% at 50% 50%, rgba(124,124,255,0.55), transparent 70%);
  filter: blur(60px);
  pointer-events:none;
}
.manifest .section__kicker{margin-bottom:14px}
.manifest__title{
  font-family: var(--font-display);
  font-size: clamp(28px, 4.2vw, 56px);
  line-height:1.08;letter-spacing:-0.02em;
  margin:0 auto 18px;
  max-width: 22ch;
  text-wrap:balance;
  font-weight:800;
}
.manifest__lead{
  margin: 0 auto;
  max-width: 62ch;
  font-size: clamp(16px, 1.2vw, 19px);
  line-height:1.65;
  color:var(--ink-soft);
}
.manifest__lead strong{
  background: var(--accent);
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
  font-weight:800;
}
.manifest__points{
  list-style:none;padding:0;
  margin: 32px auto 8px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
  text-align:left;
  max-width: 980px;
}
.manifest__point{
  display:flex;gap:14px;align-items:flex-start;
  padding:18px;border-radius:var(--radius);
  background:var(--surface);
  border:1px solid var(--border);
  transition: background .2s, border-color .2s, transform .2s var(--ease);
}
.manifest__point:hover{
  background:var(--surface-2);
  border-color:var(--border-2);
  transform: translateY(-2px);
}
.manifest__icon{
  flex:0 0 auto;
  width:42px;height:42px;border-radius:12px;
  display:grid;place-items:center;
  background: var(--accent-soft);
  border:1px solid var(--border-2);
  color: var(--brand-2);
}
.manifest__point > div{display:flex;flex-direction:column;gap:4px;min-width:0}
.manifest__point strong{font-size:15px;letter-spacing:.01em;color:var(--ink)}
.manifest__point span{color:var(--ink-soft);font-size:14px;line-height:1.55}
.manifest .cta-row{justify-content:center;margin-top:28px}

@media (max-width: 880px){
  .manifest__points{grid-template-columns:1fr}
  .manifest{text-align:center}
  .manifest__point{text-align:left}
}

/* ---------- Sections shared ---------- */
.section{padding: clamp(56px, 8vw, 110px) 0}
.section__head{max-width:60ch;margin-bottom: clamp(28px,4vw,52px)}
.section__head + *{margin-top:0}
.section__kicker{
  display:inline-block;
  font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--brand-2);
  margin-bottom:12px;
}
.section__title{
  font-family:var(--font-display);
  font-size: clamp(26px, 3.4vw, 42px);
  line-height:1.12;letter-spacing:-0.015em;
  margin:0 0 12px;
  text-wrap:balance;
}
.section__lead{color:var(--muted);font-size:17px;line-height:1.65;margin:0;max-width:60ch}

/* ---------- Cards (Leistungen) ---------- */
.cards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.card{
  position:relative;
  padding: 26px 24px 22px;
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02)) , var(--bg-soft);
  border:1px solid var(--border);
  box-shadow: var(--shadow-1);
  transition: transform .25s var(--ease), border-color .25s, box-shadow .25s;
  overflow:hidden;
}
.card::before{
  content:"";position:absolute;inset:0;
  background: radial-gradient(120% 60% at 50% 0%, rgba(124,124,255,0.18), transparent 60%);
  opacity:0;transition:opacity .3s;
  pointer-events:none;
}
.card:hover{ transform: translateY(-4px); border-color:var(--border-2); box-shadow:var(--shadow-2) }
.card:hover::before{ opacity:1 }
.card__icon{
  width:56px;height:56px;border-radius:14px;
  display:grid;place-items:center;
  background:var(--accent-soft);
  border:1px solid var(--border-2);
  margin-bottom:18px;
}
.card h3{font-size:20px;margin:0 0 10px;letter-spacing:-0.01em}
.card p{margin:0 0 16px;color:var(--ink-soft)}
.card__tags{display:flex;flex-wrap:wrap;gap:6px;list-style:none;padding:0;margin:0}
.card__tags li{
  font-size:12.5px;font-weight:600;
  padding:5px 10px;border-radius:999px;
  background:var(--surface);border:1px solid var(--border);
  color:var(--muted);
}
.card--featured{
  background: linear-gradient(180deg, rgba(124,124,255,0.10), rgba(52,214,241,0.04)), var(--bg-soft);
  border-color: rgba(124,124,255,0.30);
}
.card--featured::after{
  content:"";position:absolute;inset:0;
  border-radius:inherit;padding:1px;
  background: var(--accent);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity:.6;pointer-events:none;
}

/* ---------- About ---------- */
.about{
  display:grid;
  grid-template-columns: .8fr 1.2fr;
  gap: clamp(28px, 5vw, 72px);
  align-items:center;
}
.about__media{position:relative;display:flex;justify-content:center}
.about__photo{
  position:relative;
  width:100%;max-width:380px;
  aspect-ratio: 4 / 5;
  border-radius: 28px;
  padding: 4px;
  background: var(--accent);
  box-shadow: var(--shadow-2);
}
.about__photo::before{
  content:"";
  position:absolute;inset:-18px;
  border-radius:36px;
  background: radial-gradient(60% 50% at 50% 20%, rgba(124,124,255,0.35), transparent 70%);
  filter: blur(28px);
  z-index:-1;
}
.about__photo img{
  width:100%;height:100%;
  object-fit: cover;
  object-position: 50% 28%;
  border-radius: 24px;
  background: var(--bg-soft);
  display:block;
}
.about__badge{
  position:absolute;left:50%;bottom:-14px;transform:translateX(-50%);
  display:inline-flex;align-items:center;gap:10px;
  padding:9px 14px;border-radius:999px;
  background:var(--bg-soft);border:1px solid var(--border-2);
  font-size:13px;font-weight:600;
  box-shadow: var(--shadow-1);
  white-space:nowrap;
}
.about__badge-dot{
  width:8px;height:8px;border-radius:99px;background:#9AF09B;
  box-shadow:0 0 12px rgba(154,240,155,.8);
}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:26px}
.pillar{
  padding:18px;border-radius:var(--radius);
  background:var(--surface);border:1px solid var(--border);
}
.pillar h4{margin:0 0 8px;font-size:15px;letter-spacing:.01em;color:var(--ink)}
.pillar p{margin:0;color:var(--ink-soft);font-size:14.5px;line-height:1.55}

/* ---------- Timeline / Vorgehen ---------- */
.timeline{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  position:relative;
}
.timeline::before{
  content:"";position:absolute;left:0;right:0;top:46px;height:1px;
  background: linear-gradient(90deg, transparent, var(--brand-1), var(--brand-2), var(--brand-3), transparent);
  opacity:.5;
}
.timeline__step{
  position:relative;
  padding:22px;border-radius:var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02)), var(--bg-soft);
  border:1px solid var(--border);
  box-shadow: var(--shadow-1);
  transition: transform .25s var(--ease), border-color .25s;
}
.timeline__step:hover{transform:translateY(-3px);border-color:var(--border-2)}
.timeline__num{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:12px;
  background:var(--accent);color:#0A0E1F;font-weight:800;font-size:14px;
  margin-bottom:14px;letter-spacing:.02em;
  box-shadow: 0 6px 18px rgba(124,124,255,.45);
}
.timeline__body h3{margin:0 0 6px;font-size:18px;letter-spacing:-0.01em}
.timeline__body p{margin:0;color:var(--ink-soft);font-size:14.5px}

/* ---------- Stack grid ---------- */
.stack-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;
}
.stack-card{
  padding:16px 18px;border-radius:14px;
  background:var(--surface);border:1px solid var(--border);
  display:flex;flex-direction:column;gap:4px;
  transition: background .2s, border-color .2s, transform .2s var(--ease);
}
.stack-card:hover{background:var(--surface-2);border-color:var(--border-2);transform:translateY(-2px)}
.stack-card strong{font-size:15px;letter-spacing:.01em}
.stack-card span{color:var(--muted);font-size:13.5px}

/* ---------- Contact CTA ---------- */
.contact{
  position:relative;
  padding: clamp(36px,5vw,72px) clamp(24px,4vw,56px);
  border-radius: var(--radius-lg);
  text-align:center;
  background: linear-gradient(180deg, rgba(124,124,255,0.10), rgba(52,214,241,0.06)), var(--bg-soft);
  border:1px solid var(--border-2);
  overflow:hidden;
  box-shadow: var(--shadow-2);
}
.contact .section__head{margin:0 auto}
.contact .section__kicker{margin-bottom:14px}
.contact .section__title{font-size:clamp(28px,3.6vw,46px)}
.contact .section__lead{margin-inline:auto}
.contact__glow{
  position:absolute;inset:auto;
  width:60%;height:200px;left:20%;bottom:-100px;
  background: radial-gradient(50% 100% at 50% 0%, rgba(124,124,255,0.55), transparent 70%);
  filter: blur(40px);
  pointer-events:none;
}

/* ---------- Legal cards ---------- */
.legal-card{
  padding: 24px 26px;border-radius:var(--radius);
  background:var(--bg-soft);border:1px solid var(--border);
  box-shadow:var(--shadow-1);
}
.legal-card__row{
  display:grid;grid-template-columns:200px 1fr;gap:14px;
  padding:12px 0;
  border-bottom:1px dashed var(--border);
}
.legal-card__row:last-child{border-bottom:0}
.legal-card__row strong{color:var(--ink-soft);font-weight:600;font-size:14px}
.legal-card--prose h3{
  margin:18px 0 8px;font-size:16px;letter-spacing:.02em;
  color:var(--brand-2);text-transform:uppercase;font-weight:700;
}
.legal-card--prose p{margin:0 0 14px;color:var(--ink-soft);font-size:14.5px;line-height:1.65}
.legal-card--prose a{color:var(--ink);border-bottom:1px solid var(--border-2)}
.legal-card__stamp{margin-top:18px !important;color:var(--muted) !important;font-size:13px !important}

/* ---------- Footer ---------- */
.footer{
  margin-top: clamp(40px,6vw,80px);
  padding: 36px 0;
  border-top:1px solid var(--border);
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--bg) 70%, black 10%));
}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer__brand{display:flex;align-items:center;gap:14px;color:var(--muted)}
.footer__brand small{color:var(--muted);font-size:13.5px}
.footer__links{display:flex;gap:18px;flex-wrap:wrap}
.footer__links a{color:var(--muted);font-size:14px;transition:color .2s}
.footer__links a:hover{color:var(--ink)}

/* ---------- Reveal on scroll ---------- */
.reveal{ transition: opacity .7s var(--ease), transform .7s var(--ease) }
html.js .reveal{ opacity:0; transform: translateY(18px) }
html.js .reveal.is-visible{ opacity:1; transform:none }
@media (prefers-reduced-motion: reduce){
  html.js .reveal{opacity:1;transform:none}
}

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .hero{grid-template-columns:1fr}
  .hero__art{order:-1;max-width:420px;margin:0 auto}
  .cards{grid-template-columns:1fr 1fr}
  .about{grid-template-columns:1fr;text-align:center}
  .about__photo{max-width:300px}
  .pillars{grid-template-columns:1fr;text-align:left}
  .timeline{grid-template-columns:1fr 1fr}
  .timeline::before{display:none}
  .stack-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 720px){
  .nav__links{
    position:fixed;left:12px;right:12px;top:62px;
    flex-direction:column;align-items:stretch;gap:4px;
    padding:14px;border-radius:18px;
    background: color-mix(in srgb, var(--bg-soft) 92%, transparent);
    border:1px solid var(--border-2);
    box-shadow: var(--shadow-2);
    backdrop-filter: blur(14px);
    transform-origin: top right;
    transform: scale(.96) translateY(-6px); opacity:0; pointer-events:none;
    transition: transform .2s var(--ease), opacity .2s;
  }
  .nav__links[data-open="true"]{ transform:none; opacity:1; pointer-events:auto }
  .nav__links a{padding:12px 14px;font-size:15px}
  .menu-toggle{display:inline-block}
  .cards{grid-template-columns:1fr}
  .hero__stats{grid-template-columns:1fr 1fr}
  .timeline{grid-template-columns:1fr}
  .stack-grid{grid-template-columns:1fr}
  .legal-card__row{grid-template-columns:1fr;gap:4px}
  .footer__inner{justify-content:flex-start}
  .hero__chip--1{ top:4%;  left:4% }
  .hero__chip--2{ top:auto;bottom:46%;right:4% }
  .hero__chip--3{ bottom:4%;left:4% }
}
