/* =======================================================================
   Steuris Crypto Investments — Variante A "Corporate"
   Blau-Palette aus Konzept.docx · dunkel, crypto-modern, institutionell
   Micro-Animationen bewusst dezent (Andreas: feel ~20/100)
   ======================================================================= */

:root {
	/* Surfaces */
	--bg-primary: #0A0F1E;     /* tiefes Marine-Dunkel */
	--bg-elevated: #0F1729;
	--bg-deep: #070B16;
	--bg-surface: rgba(255, 255, 255, 0.02);
	--bg-surface-2: rgba(255, 255, 255, 0.045);

	--border-soft: rgba(146, 189, 249, 0.09);
	--border-strong: rgba(49, 111, 246, 0.26);

	--text-primary: #EAEAEA;
	--text-muted: #8392AC;
	--text-subtle: #54668A;

	/* Blue scale */
	--accent-deep: #04125C;    /* tiefes Marine */
	--accent-mid: #1941BA;     /* Royal-Blau */
	--accent-bright: #316FF6;  /* helles Akzentblau */
	--accent-light: #92BDF9;   /* Lichtblau */
	--accent-warn: #FF4466;    /* Bear / Warnung, sparsam */

	/* Tweakable accent — JS overrides --accent + --accent-2 on :root */
	--accent: var(--accent-mid);
	--accent-2: var(--accent-light);

	--gradient-corp: linear-gradient(135deg, var(--accent-deep) 0%, var(--accent) 100%);
	--gradient-data: linear-gradient(90deg, var(--accent-mid) 0%, var(--accent-2) 100%);

	/* Glow — kept restrained for the calm/corporate read */
	--glow-soft: 0 0 44px rgba(49, 111, 246, 0.12);
	--glow-bright: 0 0 38px rgba(49, 111, 246, 0.22);

	/* Keine Ecken, nur Rundungen — 8/16/24/32 */
	--r-sm: 8px;
	--r-md: 16px;
	--r-lg: 24px;
	--r-xl: 32px;
	--r-pill: 999px;

	--sp-1: 0.25rem;
	--sp-2: 0.5rem;
	--sp-3: 0.75rem;
	--sp-4: 1rem;
	--sp-5: 1.25rem;
	--sp-6: 1.5rem;
	--sp-8: 2rem;
	--sp-10: 2.5rem;
	--sp-12: 3rem;
	--sp-16: 4rem;
	--sp-20: 5rem;
	--sp-24: 6rem;

	--font-body: 'Inter', system-ui, sans-serif;
	--font-display: 'Space Grotesk', 'Inter', sans-serif;
	--font-mono: 'JetBrains Mono', ui-monospace, monospace;

	--ease: cubic-bezier(0.22, 1, 0.36, 1);

	/* Ambient / honeycomb intensity — driven by data-honeycomb */
	--ambient-op: 0.13;
	--hex-op: 0.05;
	--hex-spin: 160s;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
	font-family: var(--font-body);
	background: var(--bg-primary);
	color: var(--text-primary);
	line-height: 1.6;
	overflow-x: hidden;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

/* Ambient background — soft radial blue field */
body::before {
	content: '';
	position: fixed;
	inset: 0;
	background:
		radial-gradient(ellipse 60% 42% at 18% -4%, rgba(49, 111, 246, var(--ambient-op)), transparent 68%),
		radial-gradient(ellipse 48% 34% at 86% 26%, rgba(25, 65, 186, calc(var(--ambient-op) * 0.7)), transparent 70%);
	pointer-events: none;
	z-index: 0;
	transition: opacity 0.5s var(--ease);
}

main, nav, footer { position: relative; z-index: 1; }

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
img, svg { display: block; max-width: 100%; }

/* === Layout helpers === */
.container { max-width: 1200px; margin: 0 auto; padding: 0 var(--sp-6); }
.section { padding: var(--sp-24) 0; }
@media (max-width: 768px) { .section { padding: var(--sp-16) 0; } }

.eyebrow {
	display: inline-block;
	font-family: var(--font-mono);
	font-size: 0.72rem;
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--accent-light);
	padding: var(--sp-2) var(--sp-4);
	border: 1px solid var(--border-strong);
	border-radius: var(--r-pill);
	background: rgba(49, 111, 246, 0.07);
	margin-bottom: var(--sp-5);
}

h1, h2, h3, h4 {
	font-family: var(--font-display);
	font-weight: 700;
	line-height: 1.06;
	letter-spacing: -0.028em;
	color: var(--text-primary);
}
h1 { font-size: clamp(2.4rem, 5.4vw, 4.25rem); }
h2 { font-size: clamp(1.9rem, 3.8vw, 3rem); margin-bottom: var(--sp-4); }
h3 { font-size: 1.2rem; margin-bottom: var(--sp-3); }
p { color: var(--text-muted); max-width: 60ch; text-wrap: pretty; }
.lead { font-size: 1.12rem; }
.grad-text {
	background: var(--gradient-data);
	-webkit-background-clip: text; background-clip: text;
	color: transparent;
	font-weight: 800;
}
.num { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }

/* === Buttons === */
.btn-primary, .btn-ghost {
	display: inline-flex; align-items: center; gap: var(--sp-2);
	padding: var(--sp-4) var(--sp-8);
	border-radius: var(--r-pill);
	font-weight: 600; font-size: 0.95rem;
	transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease),
		border-color 0.3s var(--ease), background 0.3s var(--ease), color 0.3s var(--ease);
	will-change: transform;
}
.btn-primary {
	background: var(--gradient-corp);
	color: #fff;
	box-shadow: var(--glow-soft);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: var(--glow-bright); }
.btn-ghost {
	border: 1px solid var(--border-strong);
	color: var(--text-primary);
}
.btn-ghost:hover { border-color: var(--accent); color: var(--accent-light); background: rgba(49, 111, 246, 0.06); }
.btn-primary svg, .btn-ghost svg { transition: transform 0.3s var(--ease); }
.btn-primary:hover svg, .btn-ghost:hover svg { transform: translateX(3px); }

/* === NAV === */
nav.top {
	position: sticky; top: 0;
	padding: var(--sp-4) var(--sp-6);
	background: rgba(4, 6, 12, 0.94);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border-bottom: 1px solid var(--border-soft);
	z-index: 100;
}
nav.top .inner { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: var(--sp-6); }
.logo { display: flex; align-items: center; gap: var(--sp-3); font-family: var(--font-display); font-weight: 800; font-size: 1.08rem; letter-spacing: -0.01em; }
.logo-mark {
	width: 38px; height: 38px;
	display: grid; place-items: center;
	position: relative;
}
.logo-mark img { width: 100%; height: 100%; object-fit: contain; filter: drop-shadow(0 0 10px rgba(49, 111, 246, 0.35)); }
.nav-links { display: flex; gap: var(--sp-6); list-style: none; }
.nav-links a { font-size: 0.9rem; color: var(--text-muted); transition: color 0.25s var(--ease); }
.nav-links a:hover { color: var(--accent-light); }
.nav-cta {
	padding: var(--sp-3) var(--sp-6);
	border-radius: var(--r-pill);
	background: var(--gradient-corp);
	color: #fff !important;
	font-weight: 600; font-size: 0.88rem;
	box-shadow: var(--glow-soft);
	white-space: nowrap;
	transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
.nav-cta:hover { transform: translateY(-1px); box-shadow: var(--glow-bright); }
.nav-actions { display: flex; align-items: center; gap: var(--sp-3); }
.nav-login { font-size: 0.88rem; color: var(--text-muted); padding: var(--sp-3) var(--sp-4); border-radius: var(--r-pill); border: 1px solid var(--border-soft); white-space: nowrap; transition: color 0.25s var(--ease), border-color 0.25s var(--ease); }
.nav-login:hover { color: var(--accent-light); border-color: var(--border-strong); }
.logo-word { white-space: nowrap; }
@media (max-width: 980px) { .nav-links { display: none; } }
@media (max-width: 600px) {
	nav.top { padding: var(--sp-3) var(--sp-4); }
	nav.top .inner { gap: var(--sp-3); }
	.logo { font-size: 1rem; gap: var(--sp-2); }
	.logo-mark { width: 32px; height: 32px; }
	.logo-rest { display: none; }
	.nav-cta { white-space: nowrap; padding: var(--sp-3) var(--sp-4); font-size: 0.8rem; }
	.nav-actions { gap: var(--sp-2); }
	.nav-login { padding: var(--sp-2) var(--sp-3); font-size: 0.8rem; }
}

/* === HERO === */
.hero { padding: var(--sp-20) 0 var(--sp-16); }
.hero-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.04fr) minmax(0, 1fr);
	gap: var(--sp-16);
	align-items: center;
}
.hero-grid > * { min-width: 0; }
@media (max-width: 960px) { .hero-grid { grid-template-columns: minmax(0, 1fr); gap: var(--sp-12); } }

.hero h1 strong { font-weight: 800; }
.hero h1 strong.grad-text { font-weight: 800; }
.hero-lede { margin-top: var(--sp-6); font-size: 1.12rem; color: var(--text-muted); max-width: 52ch; }
.hero-actions { margin-top: var(--sp-8); display: flex; gap: var(--sp-4); flex-wrap: wrap; }
.hero-meta { margin-top: var(--sp-8); display: flex; gap: var(--sp-6); color: var(--text-subtle); font-size: 0.84rem; flex-wrap: wrap; }
.hero-meta span { display: inline-flex; align-items: center; gap: var(--sp-2); }
.hero-meta .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 10px var(--accent); animation: pulse 2.4s ease-in-out infinite; }

/* === Plattform-Mockup (live gerendert) === */
.hero-visual {
	position: relative;
	--ty: -9deg; --tx: 3deg;
	transform: perspective(1700px) rotateY(var(--ty)) rotateX(var(--tx));
	transform-origin: 60% center;
	transform-style: preserve-3d;
	transition: transform 0.25s var(--ease);
}
.platform-card {
	position: relative;
	background: linear-gradient(180deg, var(--bg-elevated) 0%, #0B1226 100%);
	border: 1px solid var(--border-strong);
	border-radius: var(--r-lg);
	padding: var(--sp-6);
	box-shadow:
		inset 0 1px 0 rgba(146, 189, 249, 0.07),
		0 0 70px rgba(49, 111, 246, 0.10),
		0 30px 70px rgba(0, 0, 0, 0.6);
	transition: box-shadow 0.4s var(--ease);
}
.platform-card:hover { box-shadow: inset 0 1px 0 rgba(146,189,249,0.1), 0 0 90px rgba(49,111,246,0.16), 0 36px 80px rgba(0,0,0,0.62); }

.platform-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: var(--sp-5); padding-bottom: var(--sp-3); border-bottom: 1px solid var(--border-soft); }
.platform-head .title { font-family: var(--font-mono); font-size: 0.7rem; color: var(--text-muted); letter-spacing: 0.12em; text-transform: uppercase; }
.platform-head .status { font-family: var(--font-mono); font-size: 0.7rem; color: var(--accent-light); display: inline-flex; align-items: center; gap: var(--sp-2); }
.platform-head .status::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 9px var(--accent); animation: pulse 2.4s ease-in-out infinite; }

.platform-body { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.metric { background: var(--bg-surface-2); padding: var(--sp-4); border-radius: var(--r-md); border: 1px solid var(--border-soft); }
.metric .label { font-family: var(--font-mono); font-size: 0.62rem; color: var(--text-subtle); text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: var(--sp-2); }
.metric .value { font-family: var(--font-mono); font-size: 1.45rem; font-weight: 700; color: var(--text-primary); line-height: 1; }
.metric .delta { font-family: var(--font-mono); font-size: 0.7rem; color: var(--accent-light); margin-top: var(--sp-2); }

.platform-chart-row { display: grid; grid-template-columns: 1.7fr 1fr; gap: var(--sp-3); align-items: stretch; }
.platform-chart { background: var(--bg-surface); border: 1px solid var(--border-soft); border-radius: var(--r-md); padding: var(--sp-4); }
.platform-chart .chart-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: var(--sp-3); }
.platform-chart .chart-title { font-family: var(--font-mono); font-size: 0.6rem; color: var(--text-subtle); letter-spacing: 0.1em; text-transform: uppercase; }
.platform-chart .chart-value { font-family: var(--font-mono); font-size: 1rem; color: var(--accent-light); font-weight: 700; }
.sparkline { width: 100%; height: 58px; overflow: visible; }
.sparkline .spark-line { stroke: url(#spark-grad); stroke-width: 2; fill: none; stroke-linecap: round; stroke-linejoin: round; }
.sparkline .spark-fill { fill: url(#spark-fill); opacity: 0; transition: opacity 0.8s var(--ease); }

.platform-side { background: var(--bg-surface); border: 1px solid var(--border-soft); border-radius: var(--r-md); padding: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-2); justify-content: center; }
.platform-side .row { display: flex; justify-content: space-between; align-items: center; font-family: var(--font-mono); font-size: 0.74rem; gap: var(--sp-2); }
.platform-side .row .lvl { color: var(--text-muted); width: 1.6em; flex-shrink: 0; }
.platform-side .row .pct { color: var(--accent-light); width: 2.4em; text-align: right; flex-shrink: 0; }
.platform-side .row .bar { flex: 1; height: 3px; background: var(--bg-deep); border-radius: var(--r-pill); position: relative; overflow: hidden; }
.platform-side .row .bar::after { content: ''; position: absolute; left: 0; top: 0; height: 100%; width: var(--w, 0%); background: var(--gradient-data); border-radius: var(--r-pill); transition: width 1.1s var(--ease); }

/* Ticker strip below the card */
.ticker-strip {
	margin-top: var(--sp-4);
	background: var(--bg-elevated);
	border: 1px solid var(--border-soft);
	border-radius: var(--r-md);
	padding: var(--sp-3) var(--sp-4);
	display: flex; align-items: center; gap: var(--sp-5);
	overflow: hidden; width: 100%; min-width: 0;
	box-shadow: 0 14px 34px rgba(0, 0, 0, 0.4);
}
.ticker-strip .label { font-family: var(--font-mono); font-size: 0.6rem; color: var(--text-subtle); letter-spacing: 0.12em; text-transform: uppercase; flex-shrink: 0; padding-right: var(--sp-4); border-right: 1px solid var(--border-soft); }
.ticker-track-wrap { flex: 1; min-width: 0; overflow: hidden; -webkit-mask: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.ticker-track { display: flex; gap: var(--sp-6); animation: tickerSlide 38s linear infinite; width: max-content; }
.ticker-item { display: inline-flex; align-items: baseline; gap: var(--sp-2); font-family: var(--font-mono); font-size: 0.76rem; flex-shrink: 0; white-space: nowrap; }
.ticker-item .sym { color: var(--text-primary); font-weight: 700; }
.ticker-item .px { color: var(--text-muted); }
.ticker-item .ch.up { color: var(--accent-light); }
.ticker-item .ch.dn { color: var(--accent-warn); }

/* === Sozialer Beweis === */
.proof {
	padding: var(--sp-12) 0;
	border-top: 1px solid var(--border-soft);
	border-bottom: 1px solid var(--border-soft);
	background: linear-gradient(180deg, transparent, rgba(4, 18, 92, 0.10), transparent);
}
.proof-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-8); align-items: start; }
@media (max-width: 768px) { .proof-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-8) var(--sp-6); } }
.proof-item { text-align: left; padding-left: var(--sp-4); border-left: 2px solid var(--border-strong); position: relative; }
.proof-item::before { content: ''; position: absolute; left: -2px; top: 0; width: 2px; height: 26px; background: var(--accent); box-shadow: 0 0 8px var(--accent); }
.proof-item .pnum { font-family: var(--font-display); font-size: 2.6rem; font-weight: 800; background: var(--gradient-data); -webkit-background-clip: text; background-clip: text; color: transparent; line-height: 1; letter-spacing: -0.02em; }
.proof-item .label { color: var(--text-primary); font-size: 0.9rem; margin-top: var(--sp-3); font-weight: 500; }
.proof-item .note { color: var(--text-subtle); font-size: 0.7rem; margin-top: var(--sp-1); font-family: var(--font-mono); letter-spacing: 0.04em; }

/* === Cluster-Konzept (Honeycomb) === */
.cluster-explain .inner { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-16); align-items: center; }
@media (max-width: 960px) { .cluster-explain .inner { grid-template-columns: 1fr; gap: var(--sp-12); } }

.honeycomb-stage {
	position: relative; aspect-ratio: 1 / 1; max-width: 560px; margin: 0 auto;
	display: grid; place-items: center; width: 100%;
	--hex-ty: 0deg; --hex-tx: 0deg;
	transform: perspective(1600px) rotateY(var(--hex-ty)) rotateX(var(--hex-tx));
	transform-style: preserve-3d;
	transition: transform 0.25s var(--ease);
}
.honeycomb-stage::before {
	content: '';
	position: absolute; inset: -10%;
	background-image:
		radial-gradient(circle at center, rgba(49, 111, 246, 0.12), transparent 56%),
		repeating-radial-gradient(circle at 50% 50%, transparent 0, transparent 27px, rgba(146, 189, 249, var(--hex-op)) 27px, rgba(146, 189, 249, var(--hex-op)) 29px);
	border-radius: 50%;
	pointer-events: none; z-index: 0;
	transition: opacity 0.5s var(--ease);
}
[data-honeycomb="off"] .honeycomb-stage::before { opacity: 0; }
.honeycomb { position: absolute; inset: 0; z-index: 1; animation: rotateSlow var(--hex-spin) linear infinite; }
.hex-cell {
	position: absolute;
	width: 128px; height: 148px;
	clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
	background: var(--bg-elevated);
	border: 1px solid var(--border-strong);
	display: grid; place-items: center;
	text-align: center; padding: var(--sp-2);
	transition: filter 0.4s var(--ease), background 0.4s var(--ease);
}
.hex-cell-text { display: block; animation: rotateSlowReverse var(--hex-spin) linear infinite; }
.hex-cell .lvl { font-family: var(--font-mono); font-size: 0.7rem; color: var(--accent-light); margin-bottom: 6px; letter-spacing: 0.1em; display: block; text-transform: uppercase; }
.hex-cell .risk { font-family: var(--font-display); font-weight: 700; font-size: 1.08rem; display: block; color: var(--text-primary); }
.hex-cell:hover { background: rgba(49, 111, 246, 0.20); filter: drop-shadow(0 0 16px rgba(49, 111, 246, 0.5)); z-index: 10; }
.h-c { left: 50%; top: 50%; transform: translate(-50%, -50%); border-color: var(--accent); background: rgba(49, 111, 246, 0.16); }
.h-1 { left: 50%; top: 3%; transform: translateX(-50%); }
.h-2 { right: 3%; top: 31%; }
.h-3 { right: 3%; bottom: 3%; }
.h-4 { left: 3%; bottom: 3%; }
.h-5 { left: 3%; top: 31%; }
@media (max-width: 600px) {
	.honeycomb-stage { max-width: 360px; }
	.hex-cell { width: 92px; height: 106px; }
	.hex-cell .risk { font-size: 0.84rem; }
	.hex-cell .lvl { font-size: 0.58rem; }
}

/* === Schritte === */
.steps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); margin-top: var(--sp-12); position: relative; }
.steps-grid::before {
	content: '';
	position: absolute; top: 52px; left: 9%; right: 9%; height: 1px;
	background: linear-gradient(90deg, transparent, var(--border-strong) 20%, var(--border-strong) 80%, transparent);
	z-index: 0;
}
@media (max-width: 768px) { .steps-grid { grid-template-columns: 1fr; } .steps-grid::before { display: none; } }
.step { background: var(--bg-elevated); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: var(--sp-8); position: relative; z-index: 1; transition: border-color 0.35s var(--ease), transform 0.35s var(--ease), box-shadow 0.35s var(--ease); }
.step:hover { border-color: var(--border-strong); transform: translateY(-4px); box-shadow: var(--glow-soft); }
.step .ix { font-family: var(--font-display); font-size: 2.6rem; font-weight: 800; background: var(--gradient-data); -webkit-background-clip: text; background-clip: text; color: transparent; line-height: 1; display: block; margin-bottom: var(--sp-4); letter-spacing: -0.02em; }
.step .ix small { font-family: var(--font-mono); font-size: 0.68rem; color: var(--text-subtle); font-weight: 500; -webkit-text-fill-color: var(--text-subtle); margin-left: var(--sp-2); letter-spacing: 0.12em; vertical-align: middle; }
.step h3 { margin-bottom: var(--sp-3); }
.step p { color: var(--text-muted); font-size: 0.9rem; }

/* === Sicherheit === */
.tint { background: linear-gradient(180deg, transparent, rgba(4, 18, 92, 0.16) 50%, transparent); }
.security-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-6); margin-top: var(--sp-12); }
@media (max-width: 960px) { .security-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .security-grid { grid-template-columns: 1fr; } }
.sec-card { background: var(--bg-surface); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: var(--sp-6); transition: border-color 0.35s var(--ease), background 0.35s var(--ease), transform 0.35s var(--ease); }
.sec-card:hover { border-color: var(--border-strong); background: var(--bg-surface-2); transform: translateY(-3px); }
.sec-icon { width: 42px; height: 42px; border-radius: var(--r-sm); background: rgba(49, 111, 246, 0.12); border: 1px solid var(--border-strong); display: grid; place-items: center; color: var(--accent-light); margin-bottom: var(--sp-4); }
.sec-card h3 { font-size: 1rem; margin-bottom: var(--sp-2); }
.sec-card p { font-size: 0.85rem; color: var(--text-muted); }

.risk-strip { background: rgba(255, 68, 102, 0.055); border: 1px solid rgba(255, 68, 102, 0.2); border-radius: var(--r-md); padding: var(--sp-4) var(--sp-6); margin-top: var(--sp-8); font-size: 0.82rem; color: var(--text-muted); max-width: none; }
.risk-strip strong { color: var(--accent-warn); display: inline-block; margin-right: var(--sp-2); font-family: var(--font-mono); letter-spacing: 0.08em; }

/* === Cluster-Übersicht: Tabelle + Karten (auf der Seite umschaltbar) === */
.cluster-head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--sp-8); flex-wrap: wrap; }
.cluster-toggle { display: inline-flex; gap: 4px; padding: 4px; border-radius: var(--r-pill); background: var(--bg-surface-2); border: 1px solid var(--border-soft); flex-shrink: 0; }
.ct-btn { font-family: var(--font-mono); font-size: 0.72rem; font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-muted); padding: var(--sp-2) var(--sp-5); border-radius: var(--r-pill); transition: background 0.3s var(--ease), color 0.3s var(--ease), box-shadow 0.3s var(--ease); }
.ct-btn:not(.is-active):hover { color: var(--accent-light); }
.ct-btn.is-active { background: var(--gradient-corp); color: #fff; box-shadow: var(--glow-soft); }
@media (max-width: 600px) { .cluster-toggle { width: 100%; } .ct-btn { flex: 1; } }

.cluster-view[data-mode="table"] .cluster-cards,
.cluster-view[data-mode="cards"] .cluster-table-wrap { display: none; }

.cluster-table-wrap { margin-top: var(--sp-8); background: var(--bg-elevated); border: 1px solid var(--border-soft); border-radius: var(--r-lg); overflow-x: auto; }
.cluster-table { width: 100%; border-collapse: collapse; min-width: 680px; }
.cluster-table th, .cluster-table td { padding: var(--sp-4) var(--sp-6); text-align: left; border-bottom: 1px solid var(--border-soft); font-size: 0.9rem; }
.cluster-table th { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-subtle); font-weight: 600; background: rgba(255, 255, 255, 0.02); }
.cluster-table tr:last-child td { border-bottom: none; }
.cluster-table tbody tr { transition: background 0.25s var(--ease); }
.cluster-table tbody tr:hover td { background: rgba(49, 111, 246, 0.06); }
.cluster-table .lvl-cell { font-family: var(--font-mono); font-weight: 700; color: var(--accent-light); white-space: nowrap; }
.cluster-table .coins { color: var(--text-muted); font-size: 0.85rem; }
.cluster-table .coins strong { color: var(--text-primary); font-weight: 600; }

.risk-dots { display: inline-flex; gap: 4px; align-items: center; }
.risk-dots .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--border-strong); }
.risk-dots .dot.on { background: var(--accent); box-shadow: 0 0 6px rgba(49, 111, 246, 0.55); }
.risk-label { font-family: var(--font-mono); font-size: 0.7rem; color: var(--text-subtle); margin-left: var(--sp-2); letter-spacing: 0.04em; text-transform: uppercase; }

.cluster-cards { margin-top: var(--sp-8); display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--sp-4); }
@media (max-width: 960px) { .cluster-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .cluster-cards { grid-template-columns: 1fr; } }
.cl-card { background: var(--bg-elevated); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-3); transition: border-color 0.35s var(--ease), transform 0.35s var(--ease), box-shadow 0.35s var(--ease); }
.cl-card:hover { border-color: var(--border-strong); transform: translateY(-4px); box-shadow: var(--glow-soft); }
.cl-card .cl-head { display: flex; align-items: baseline; justify-content: space-between; }
.cl-card .cl-name { font-family: var(--font-mono); font-weight: 700; color: var(--accent-light); font-size: 0.82rem; letter-spacing: 0.06em; }
.cl-card .cl-risk-word { font-family: var(--font-mono); font-size: 0.62rem; color: var(--text-subtle); text-transform: uppercase; letter-spacing: 0.08em; }
.cl-card .cl-coins { display: flex; flex-wrap: wrap; gap: var(--sp-1); }
.cl-card .coin-chip { font-family: var(--font-mono); font-size: 0.68rem; color: var(--text-primary); background: var(--bg-surface-2); border: 1px solid var(--border-soft); border-radius: var(--r-sm); padding: 3px 7px; }
.cl-card .cl-char { font-size: 0.78rem; color: var(--text-muted); margin-top: auto; }

.indikativ { font-family: var(--font-mono); font-size: 0.7rem; color: var(--text-subtle); margin-top: var(--sp-4); display: block; letter-spacing: 0.04em; }

/* === FAQ === */
.faq-list { margin-top: var(--sp-8); display: flex; flex-direction: column; gap: var(--sp-3); max-width: 880px; }
.faq-item { background: var(--bg-surface); border: 1px solid var(--border-soft); border-radius: var(--r-md); overflow: hidden; transition: border-color 0.3s var(--ease); }
.faq-item[open] { border-color: var(--border-strong); }
.faq-item summary { padding: var(--sp-5) var(--sp-6); cursor: pointer; font-weight: 600; font-size: 1rem; display: flex; justify-content: space-between; align-items: center; gap: var(--sp-4); list-style: none; color: var(--text-primary); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: '+'; font-family: var(--font-mono); color: var(--accent-light); font-size: 1.5rem; transition: transform 0.3s var(--ease); flex-shrink: 0; }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-body { padding: 0 var(--sp-6) var(--sp-6); color: var(--text-muted); font-size: 0.94rem; max-width: 78ch; }

/* === CTA === */
.cta-card { background: var(--bg-elevated); border: 1px solid var(--border-strong); border-radius: var(--r-xl); padding: var(--sp-12); position: relative; overflow: hidden; box-shadow: var(--glow-soft); display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--sp-12); align-items: center; }
@media (max-width: 768px) { .cta-card { grid-template-columns: 1fr; padding: var(--sp-8); gap: var(--sp-8); } }
.cta-card::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 40% 60% at 0% 50%, rgba(49, 111, 246, 0.16), transparent 70%), radial-gradient(ellipse 30% 50% at 100% 50%, rgba(146, 189, 249, 0.08), transparent 70%); pointer-events: none; }
.cta-card > * { position: relative; z-index: 1; }
.cta-card h2 { margin-bottom: var(--sp-4); }
.cta-card p { color: var(--text-muted); margin-bottom: var(--sp-6); }
.cta-actions { display: flex; gap: var(--sp-4); flex-wrap: wrap; }
.cta-contact { background: var(--bg-surface); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: var(--sp-6); }
.cta-contact .row { display: flex; align-items: center; gap: var(--sp-4); padding: var(--sp-3) 0; border-bottom: 1px solid var(--border-soft); }
.cta-contact .row:last-child { border-bottom: none; }
.cta-contact .row .icon { width: 38px; height: 38px; border-radius: var(--r-sm); background: rgba(49, 111, 246, 0.12); border: 1px solid var(--border-strong); display: grid; place-items: center; color: var(--accent-light); flex-shrink: 0; }
.cta-contact .row .meta { display: flex; flex-direction: column; line-height: 1.35; }
.cta-contact .row .meta small { font-family: var(--font-mono); font-size: 0.62rem; color: var(--text-subtle); letter-spacing: 0.1em; text-transform: uppercase; }
.cta-contact .row .meta a, .cta-contact .row .meta span { font-size: 0.92rem; color: var(--text-primary); transition: color 0.25s var(--ease); }
.cta-contact .row .meta a:hover { color: var(--accent-light); }

/* === FOOTER === */
footer.bottom { padding: var(--sp-16) 0 var(--sp-8); border-top: 1px solid var(--border-soft); background: rgba(4, 18, 92, 0.16); }
.footer-logo[data-wordmark-only] img[data-logo-cycle] { width: auto !important; height: 56px !important; }
.footer-logo[data-wordmark-only] img:not([data-logo-cycle]) { display: none; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: var(--sp-8); margin-bottom: var(--sp-12); }
@media (max-width: 768px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--sp-8); } }
.footer-brand h4 { font-family: var(--font-display); font-size: 1rem; margin-bottom: var(--sp-3); }
.footer-brand p { font-size: 0.85rem; color: var(--text-muted); max-width: 34ch; }
.footer-col h5 { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-subtle); margin-bottom: var(--sp-4); }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: var(--sp-2); }
.footer-col a { font-size: 0.85rem; color: var(--text-muted); transition: color 0.25s var(--ease); }
.footer-col a:hover { color: var(--accent-light); }
.footer-legal { padding-top: var(--sp-8); border-top: 1px solid var(--border-soft); font-size: 0.74rem; color: var(--text-subtle); display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--sp-4); }
.compliance-badge { display: inline-flex; align-items: center; gap: var(--sp-2); padding: var(--sp-1) var(--sp-3); background: rgba(49, 111, 246, 0.08); border: 1px solid var(--border-strong); border-radius: var(--r-pill); font-family: var(--font-mono); font-size: 0.74rem; color: var(--accent-light); }

/* === Reveal animation — additive, never hides content === */
.reveal { opacity: 1; transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.reveal-armed { opacity: 0; transform: translateY(22px); }
.reveal-armed.in { opacity: 1; transform: translateY(0); }

@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.35; } }
@keyframes tickerSlide { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes rotateSlow { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes rotateSlowReverse { from { transform: rotate(0deg); } to { transform: rotate(-360deg); } }

/* Animation feel: "lively" speeds things up + adds motion, "calm" is the default */
[data-anim="lively"] { --hex-spin: 80s; }
[data-anim="lively"] .ticker-track { animation-duration: 24s; }
[data-anim="calm"] { --hex-spin: 220s; }
[data-anim="calm"] .ticker-track { animation-duration: 50s; }
[data-anim="fast"] { --hex-spin: 38s; }
[data-anim="fast"] .ticker-track { animation-duration: 11s; }

/* Ticker is clickable — cycles the animation tempo */
.ticker-strip { cursor: pointer; }
.ticker-strip:hover { border-color: var(--border-strong); }
.ticker-strip:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

@media (prefers-reduced-motion: reduce) {
	.honeycomb, .ticker-track, .hex-cell-text { animation: none; }
	.reveal-armed { opacity: 1; transform: none; transition: none; }
	html { scroll-behavior: auto; }
}

/* Floating viewport-switch link */
.viewport-link { position: fixed; left: 16px; bottom: 16px; z-index: 90; display: inline-flex; align-items: center; gap: var(--sp-2); padding: var(--sp-2) var(--sp-4); border-radius: var(--r-pill); background: rgba(15, 23, 41, 0.85); border: 1px solid var(--border-strong); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.04em; color: var(--accent-light); transition: border-color 0.25s var(--ease), color 0.25s var(--ease); }
.viewport-link:hover { border-color: var(--accent); color: var(--text-primary); }
@media (max-width: 600px) { .viewport-link { display: none; } }

/* === Live Cal-Integration === */
[hidden] { display: none !important; }
.cal-head { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-4); padding-bottom: var(--sp-4); border-bottom: 1px solid var(--border-soft); }
.cal-head .av { width: 48px; height: 48px; border-radius: 50%; background: var(--gradient-corp); padding: 2px; overflow: hidden; flex-shrink: 0; }
.cal-head .av img { width: 100%; height: 100%; border-radius: 50%; object-fit: cover; display: block; }
.cal-head h4 { font-family: var(--font-display, var(--font-body, sans-serif)); font-size: 0.95rem; margin: 0; }
.cal-head small { font-family: var(--font-mono); font-size: 0.7rem; color: var(--text-subtle); letter-spacing: 0.05em; }
.cal-view-label { font-family: var(--font-mono); font-size: 0.72rem; color: var(--text-subtle); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: var(--sp-3); margin-top: var(--sp-4); }
.cal-view-label strong { color: var(--accent-light); text-transform: none; letter-spacing: 0; }
.cal-slots { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-2); margin-bottom: var(--sp-4); }
.cal-day { padding: var(--sp-3) var(--sp-2); text-align: center; background: var(--bg-surface); border: 1px solid var(--border-soft); border-radius: var(--r-sm); font-family: var(--font-mono); font-size: 0.78rem; color: var(--text-muted); cursor: pointer; transition: border-color 0.2s, color 0.2s, background 0.2s; display: flex; flex-direction: column; gap: 2px; }
.cal-day:hover { border-color: var(--accent-bright); color: var(--accent-light); background: rgba(49, 111, 246, 0.08); }
.cal-day-name { font-weight: 700; }
.cal-day-count { font-size: 0.65rem; color: var(--text-subtle); letter-spacing: 0.04em; }
.cal-day:hover .cal-day-count { color: var(--accent-light); }
.cal-slot { padding: var(--sp-3) 0; text-align: center; background: var(--bg-surface); border: 1px solid var(--border-soft); border-radius: var(--r-sm); font-family: var(--font-mono); font-size: 0.82rem; color: var(--text-muted); cursor: pointer; transition: border-color 0.2s, color 0.2s, background 0.2s; }
.cal-slot:hover { border-color: var(--accent-bright); color: var(--accent-light); background: rgba(49, 111, 246, 0.08); }
.cal-slot.sel { border-color: var(--accent-bright); background: rgba(49, 111, 246, 0.18); color: var(--accent-light); }
.cal-more { width: 100%; padding: var(--sp-3); margin-top: var(--sp-3); background: transparent; border: 1px solid var(--border-soft); border-radius: var(--r-pill); color: var(--text-muted); font-family: var(--font-mono); font-size: 0.78rem; cursor: pointer; transition: border-color 0.2s, color 0.2s; }
.cal-more:hover { border-color: var(--accent-bright); color: var(--accent-light); }
.cal-back-btn { padding: var(--sp-3) var(--sp-5); border-radius: var(--r-pill); background: transparent; border: 1px solid var(--border-soft); color: var(--text-muted); font-family: var(--font-mono); font-size: 0.85rem; cursor: pointer; transition: border-color 0.2s, color 0.2s; }
.cal-back-btn:hover { border-color: var(--accent-bright); color: var(--accent-light); }
.cal-back-bottom { width: 100%; margin-top: var(--sp-4); text-align: center; }
.cal-loading, .cal-empty { font-size: 0.85rem; color: var(--text-muted); text-align: center; padding: var(--sp-6, 1.5rem) 0; grid-column: 1 / -1; }
.cal-slot-pill { display: inline-block; padding: var(--sp-2) var(--sp-4); background: rgba(49, 111, 246, 0.18); border: 1px solid var(--accent-bright); border-radius: var(--r-pill); color: var(--accent-light); font-family: var(--font-mono); font-size: 0.82rem; margin-bottom: var(--sp-2); }
.cal-field { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-3); }
.cal-field span { font-size: 0.78rem; color: var(--text-muted); font-family: var(--font-mono); letter-spacing: 0.04em; text-transform: uppercase; }
.cal-field span em { font-style: normal; text-transform: none; color: var(--text-subtle); }
.cal-field input, .cal-field textarea { background: var(--bg-surface-2); border: 1px solid var(--border-soft); border-radius: var(--r-sm); padding: var(--sp-3); color: var(--text-primary); font-family: inherit; font-size: 0.95rem; transition: border-color 0.2s ease; }
.cal-field input:focus, .cal-field textarea:focus { outline: none; border-color: var(--accent-bright); }
.cal-actions-row { display: grid; grid-template-columns: auto 1fr; gap: var(--sp-3); margin-top: var(--sp-2); align-items: stretch; }
.cal-actions-row .btn-primary { margin: 0; border: none; cursor: pointer; font-family: inherit; }
.cal-actions-row .btn-primary[disabled] { opacity: 0.6; cursor: wait; }
[data-success] h3 { color: var(--accent-light); font-family: var(--font-display, var(--font-body, sans-serif)); margin-bottom: var(--sp-3); }
[data-success] p { font-size: 0.9rem; color: var(--text-muted); margin-bottom: var(--sp-2); }
.cal-success-foot { font-family: var(--font-mono); font-size: 0.75rem; color: var(--text-subtle); }
.cal-error { color: var(--accent-warn); border: 1px solid var(--accent-warn); border-radius: var(--r-sm); padding: var(--sp-3); margin-top: var(--sp-3); font-size: 0.82rem; }
