@import "./fonts.css";

:root {
  --bg: #08070f;
  --fg: #f0f6ff;
  --graphite: #14131e;
  --card: #0f0e1c;
  --muted: #6a7894;
  --border: rgba(118, 130, 180, 0.25);
  --cyan: #00f0ff;
  --magenta: #ff2bd6;
  --lime: #c6ff3d;
  --chrome: #cfd6e4;

  --gradient-holo: linear-gradient(135deg, #00f0ff, #ff2bd6 40%, #c6ff3d 80%, #00f0ff);
  --shadow-cyan: 0 0 20px rgba(0,240,255,.6), 0 0 40px rgba(0,240,255,.3);
  --shadow-magenta: 0 0 20px rgba(255,43,214,.6), 0 0 40px rgba(255,43,214,.3);

  --font-display: "Orbitron", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;
  --font-sans: "Space Grotesk", system-ui, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { background: var(--bg); color: var(--fg); font-family: var(--font-sans); -webkit-font-smoothing: antialiased; }
body {
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -20%, rgba(255,43,214,.18), transparent),
    radial-gradient(ellipse 60% 50% at 80% 100%, rgba(0,240,255,.18), transparent),
    radial-gradient(ellipse 60% 50% at 0% 80%, rgba(198,255,61,.10), transparent);
  background-attachment: fixed;
  overflow-x: hidden;
  min-height: 100vh;
}
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
img, svg { display: block; max-width: 100%; }
h1,h2,h3,h4 { font-family: var(--font-display); letter-spacing: .02em; font-weight: 900; }
::selection { background: var(--magenta); color: var(--bg); }

.container { max-width: 1200px; margin: 0 auto; padding: 0 1rem; }
@media (min-width: 768px) { .container { padding: 0 2rem; } }

/* ===== Layout ===== */
.app { display: flex; flex-direction: column; min-height: 100vh; }
.app > main { flex: 1; }

/* ===== Ticker ===== */
.ticker { border-bottom: 1px solid var(--border); background: rgba(8,7,15,.8); backdrop-filter: blur(10px); overflow: hidden; }
.ticker-track { display: flex; gap: 3rem; white-space: nowrap; padding: .5rem 0; font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; color: rgba(0,240,255,.8); animation: marquee 40s linear infinite; }
.ticker-item { display: inline-flex; align-items: center; gap: .75rem; }
.dot-lime { width: 6px; height: 6px; border-radius: 999px; background: var(--lime); animation: pulse-glow 2s ease-in-out infinite; }
@keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* ===== Nav ===== */
.nav { position: sticky; top: 0; z-index: 50; border-bottom: 1px solid var(--border); background: rgba(8,7,15,.7); backdrop-filter: blur(20px); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; padding: .75rem 1rem; max-width: 1200px; margin: 0 auto; }
@media (min-width: 768px) { .nav-inner { padding: .75rem 2rem; } }
.brand { display: flex; align-items: center; gap: .75rem; }
.brand-logo { position: relative; width: 36px; height: 36px; }
.brand-logo .bg { position: absolute; inset: 0; background: var(--gradient-holo); background-size: 200% 200%; animation: holo-shift 6s linear infinite; border-radius: 2px; }
.brand-logo .fg { position: absolute; inset: 2px; display: flex; align-items: center; justify-content: center; background: var(--bg); font-family: var(--font-display); font-weight: 900; font-size: 12px; }
.brand-logo .fg span { background: var(--gradient-holo); background-size: 200% 200%; animation: holo-shift 6s linear infinite; -webkit-background-clip: text; background-clip: text; color: transparent; }
.brand-name { font-family: var(--font-display); font-weight: 900; font-size: 14px; letter-spacing: .2em; line-height: 1; }
.brand-sub { font-family: var(--font-mono); font-size: 9px; letter-spacing: .3em; color: var(--muted); margin-top: 4px; }

.nav-links { display: none; align-items: center; gap: 4px; }
@media (min-width: 768px) { .nav-links { display: flex; } }
.nav-link { position: relative; padding: 8px 16px; font-family: var(--font-mono); font-size: 11px; font-weight: 500; letter-spacing: .22em; text-transform: uppercase; color: var(--muted); transition: color .2s; }
.nav-link:hover, .nav-link.active { color: var(--cyan); text-shadow: 0 0 10px rgba(0,240,255,.8); }
.nav-link::after { content: ""; position: absolute; left: 8px; right: 8px; bottom: 4px; height: 1px; background: var(--cyan); transform: scaleX(0); transition: transform .3s; }
.nav-link:hover::after, .nav-link.active::after { transform: scaleX(1); }

.menu-btn { display: flex; width: 40px; height: 40px; align-items: center; justify-content: center; border: 1px solid var(--border); }
@media (min-width: 768px) { .menu-btn { display: none; } }
.menu-btn-bars span { display: block; height: 1px; width: 20px; margin: 6px 0; }
.menu-btn-bars span:nth-child(1) { background: var(--cyan); }
.menu-btn-bars span:nth-child(2) { background: var(--magenta); }
.menu-btn-bars span:nth-child(3) { background: var(--lime); }

.mobile-menu { display: none; border-top: 1px solid var(--border); background: rgba(8,7,15,.95); backdrop-filter: blur(10px); padding: 16px; }
.mobile-menu.open { display: block; }
.mobile-menu a { display: block; border-bottom: 1px solid var(--border); padding: 16px 0; font-family: var(--font-display); font-size: 24px; font-weight: 900; }
.mobile-menu a small { display: block; font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; color: var(--muted); font-weight: 400; margin-bottom: 4px; }

/* ===== Buttons ===== */
.btn { display: inline-flex; align-items: center; gap: .5rem; padding: .875rem 1.5rem; font-family: var(--font-mono); font-size: .78rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; background: rgba(15,14,28,.9); color: var(--cyan); border: 1px solid rgba(0,240,255,.5); clip-path: polygon(8px 0, 100% 0, 100% calc(100% - 8px), calc(100% - 8px) 100%, 0 100%, 0 8px); transition: all .2s; }
.btn:hover { background: rgba(0,240,255,.15); box-shadow: var(--shadow-cyan); color: var(--fg); }
.btn-magenta { color: var(--magenta); border-color: rgba(255,43,214,.5); }
.btn-magenta:hover { background: rgba(255,43,214,.15); box-shadow: var(--shadow-magenta); color: var(--fg); }

/* ===== Holo border / cards ===== */
.holo { position: relative; background: var(--card); border-radius: 6px; }
.holo::before { content: ""; position: absolute; inset: 0; padding: 1px; border-radius: inherit; background: var(--gradient-holo); background-size: 200% 200%; animation: holo-shift 6s linear infinite; -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }

/* ===== Scanlines / grid / noise ===== */
.scanlines { position: relative; }
.scanlines::after { content: ""; position: absolute; inset: 0; background-image: repeating-linear-gradient(0deg, transparent 0, transparent 2px, rgba(240,246,255,.04) 2px, rgba(240,246,255,.04) 3px); pointer-events: none; mix-blend-mode: overlay; }
.bg-grid { background-image: linear-gradient(rgba(0,240,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(0,240,255,.08) 1px, transparent 1px); background-size: 48px 48px; }
.bg-grid-sm { background-image: linear-gradient(rgba(0,240,255,.06) 1px, transparent 1px), linear-gradient(90deg, rgba(0,240,255,.06) 1px, transparent 1px); background-size: 16px 16px; }

.scan-line { position: absolute; left: 0; right: 0; height: 60px; background: linear-gradient(to bottom, transparent, rgba(0,240,255,.18), transparent); animation: scan 6s linear infinite; pointer-events: none; }
@keyframes scan { 0% { transform: translateY(-100%); } 100% { transform: translateY(100vh); } }

/* ===== Text effects ===== */
.text-holo { background: var(--gradient-holo); background-size: 200% 200%; -webkit-background-clip: text; background-clip: text; color: transparent; animation: holo-shift 6s linear infinite; }
.text-chrome { background: linear-gradient(180deg, #f6f8fc, #4a5066 50%, #d8dde9); -webkit-background-clip: text; background-clip: text; color: transparent; }
.text-glow-cyan { text-shadow: 0 0 10px rgba(0,240,255,.8), 0 0 24px rgba(0,240,255,.4); }
.glitch { position: relative; display: inline-block; }
.glitch::before, .glitch::after { content: attr(data-text); position: absolute; left: 0; top: 0; width: 100%; pointer-events: none; }
.glitch::before { color: var(--magenta); transform: translate(2px, 0); mix-blend-mode: screen; clip-path: inset(0 0 60% 0); animation: glitch-x 3s infinite steps(1); }
.glitch::after { color: var(--cyan); transform: translate(-2px, 0); mix-blend-mode: screen; clip-path: inset(60% 0 0 0); animation: glitch-x 3.4s infinite steps(1) reverse; }
@keyframes glitch-x { 0%,90%,100% { transform: translate(0,0); } 92% { transform: translate(3px,-1px); } 94% { transform: translate(-3px,1px); } 96% { transform: translate(2px,2px); } }
@keyframes holo-shift { 0% { background-position: 0% 50%; } 100% { background-position: 200% 50%; } }
@keyframes pulse-glow { 0%,100% { opacity: .7;} 50% { opacity: 1;} }
@keyframes spin-slow { to { transform: rotate(360deg); } }
.spin-slow { animation: spin-slow 40s linear infinite; }
@keyframes blink { 50% { opacity: .2; } }
.blink { animation: blink 1.4s steps(2) infinite; }

/* ===== Cursor glow ===== */
.cursor-glow { position: fixed; pointer-events: none; z-index: 100; width: 320px; height: 320px; border-radius: 50%; background: radial-gradient(circle, rgba(0,240,255,.18), transparent 60%); mix-blend-mode: screen; transform: translate(-50%, -50%); transition: opacity .2s; opacity: 0; }
@media (max-width: 767px) { .cursor-glow { display: none; } }

/* ===== Hero ===== */
.hero { position: relative; overflow: hidden; }
.hero-grid { position: relative; display: grid; gap: 2.5rem; padding: 4rem 0; }
@media (min-width: 768px) { .hero-grid { grid-template-columns: 1fr 1fr; gap: 5rem; padding: 7rem 0; } }
.hero-tag { display: flex; align-items: center; gap: .75rem; font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; color: var(--cyan); }
.hero-tag .sq { width: 8px; height: 8px; background: var(--lime); animation: pulse-glow 2s infinite; }
.hero h1 { margin-top: 1.5rem; font-size: clamp(2.5rem, 7vw, 5.5rem); line-height: .95; letter-spacing: -.02em; }
.hero h1 span { display: block; }
.hero p.lead { margin-top: 1.5rem; max-width: 28rem; font-family: var(--font-mono); font-size: .875rem; line-height: 1.6; color: var(--muted); }
.hero-cta { margin-top: 2.5rem; display: flex; flex-wrap: wrap; gap: .75rem; }
.hero-stats { margin-top: 3rem; display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem; font-family: var(--font-mono); }
.hero-stat { padding: 12px; border-radius: 4px; }
.hero-stat .k { font-size: 9px; letter-spacing: .2em; color: var(--muted); }
.hero-stat .v { margin-top: 4px; font-size: 1.5rem; font-weight: 900; font-family: var(--font-display); }

.hero-orb { position: absolute; border-radius: 50%; opacity: .3; filter: blur(60px); pointer-events: none; }
.hero-orb.a { left: -8rem; top: 8rem; width: 24rem; height: 24rem; background: radial-gradient(circle, var(--magenta), transparent); }
.hero-orb.b { right: -8rem; bottom: 0; width: 28rem; height: 28rem; background: radial-gradient(circle, var(--cyan), transparent); }

/* Wheel */
.wheel-wrap { position: relative; aspect-ratio: 1; max-width: 520px; margin: 0 auto; }
.wheel-glyph { position: absolute; transform: translate(-50%, -50%); display: flex; width: 48px; height: 48px; align-items: center; justify-content: center; border: 1px solid rgba(0,240,255,.3); background: rgba(8,7,15,.7); backdrop-filter: blur(6px); font-family: var(--font-display); font-size: 24px; transition: all .3s; cursor: pointer; }
.wheel-glyph:hover { transform: translate(-50%, -50%) scale(1.25); border-color: var(--magenta); }
.wheel-core { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); text-align: center; }
.wheel-core .label { font-family: var(--font-mono); font-size: 10px; letter-spacing: .4em; color: var(--cyan); }
.wheel-core .big { font-family: var(--font-display); font-size: 36px; font-weight: 900; }
.wheel-core .sub { font-family: var(--font-mono); font-size: 9px; letter-spacing: .3em; color: var(--muted); }
.wheel-corner { position: absolute; width: 24px; height: 24px; border-color: rgba(0,240,255,.6); border-style: solid; border-width: 0; }

/* Briefing */
.briefing { position: relative; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); background: rgba(20,19,30,.4); padding: 2.5rem 0; }
.briefing-head { display: flex; justify-content: space-between; margin-bottom: 1rem; font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; }
.briefing-grid { display: grid; gap: .75rem; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 640px) { .briefing-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .briefing-grid { grid-template-columns: repeat(6, 1fr); } }
.briefing-cell { padding: 12px; border-radius: 4px; }
.briefing-cell .l { font-family: var(--font-mono); font-size: 9px; letter-spacing: .25em; color: var(--muted); }
.briefing-cell .v { margin-top: 4px; font-family: var(--font-display); font-size: 14px; font-weight: 700; }

/* Section */
.section { padding: 5rem 0; }
@media (min-width: 768px) { .section { padding: 7rem 0; } }
.section-head { margin-bottom: 2.5rem; display: flex; flex-direction: column; gap: .75rem; }
@media (min-width: 768px) { .section-head { flex-direction: row; align-items: flex-end; justify-content: space-between; } }
.section-eyebrow { font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; }
.section h2 { margin-top: .5rem; font-size: clamp(2rem, 5vw, 3.75rem); line-height: 1; letter-spacing: -.02em; }
.section-desc { max-width: 28rem; font-family: var(--font-mono); font-size: 12px; color: var(--muted); }

/* Zodiac grid */
.zgrid { display: grid; gap: 1rem; grid-template-columns: 1fr; }
@media (min-width: 640px) { .zgrid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .zgrid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1280px) { .zgrid { grid-template-columns: repeat(4, 1fr); } }
.zcard { padding: 20px; overflow: hidden; }
.zcard-head { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em; color: var(--muted); }
.zcard-head .ready { display: inline-flex; align-items: center; gap: 6px; color: var(--lime); }
.zcard-main { margin-top: 1rem; display: flex; align-items: flex-end; gap: 1rem; }
.zcard-glyph { font-family: var(--font-display); font-size: 60px; line-height: 1; transition: transform .5s; }
.zcard:hover .zcard-glyph { transform: scale(1.1); }
.zcard-name { font-family: var(--font-display); font-size: 24px; font-weight: 900; letter-spacing: .05em; }
.zcard-meta { font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em; color: var(--muted); }
.zcard-pred { margin-top: 1.25rem; font-family: var(--font-mono); font-size: 12px; line-height: 1.6; color: rgba(240,246,255,.8); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.meters { margin-top: 1.25rem; display: flex; flex-direction: column; gap: 10px; }
.meter .m-row { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 9px; letter-spacing: .25em; color: var(--muted); margin-bottom: 4px; }
.meter .m-bar { position: relative; height: 4px; background: rgba(106,120,148,.25); overflow: hidden; }
.meter .m-fill { position: absolute; inset: 0 auto 0 0; }
.zcard-cta { margin-top: 1.25rem; padding-top: 1rem; border-top: 1px solid var(--border); display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 11px; letter-spacing: .2em; color: var(--cyan); transition: color .2s; }
.zcard-cta:hover { color: var(--magenta); }

/* Compatibility teaser */
.compat-teaser { padding: 2rem; }
@media (min-width: 768px) { .compat-teaser { padding: 3.5rem; } }
.compat-grid { display: grid; gap: 2.5rem; }
@media (min-width: 768px) { .compat-grid { grid-template-columns: 1fr 1fr; } }
.compat-mini { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.compat-mini-cell { aspect-ratio: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; border-radius: 4px; }
.compat-mini-cell .lbl { font-family: var(--font-mono); font-size: 9px; letter-spacing: .3em; color: var(--muted); }
.compat-mini-cell .big { margin-top: 4px; font-family: var(--font-display); font-size: 30px; font-weight: 900; }
.compat-bars { grid-column: span 3; padding: 16px; }

/* Mag preview */
.mag-grid { display: grid; gap: 1rem; }
@media (min-width: 768px) { .mag-grid { grid-template-columns: repeat(3, 1fr); } }
.mag-card { padding: 24px; overflow: hidden; display: block; transition: transform .2s; }
.mag-card:hover .mag-title { color: var(--cyan); }
.mag-thumb { aspect-ratio: 4/3; position: relative; border-radius: 4px; overflow: hidden; }
.mag-thumb .cat { position: absolute; left: 12px; top: 12px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; }
.mag-thumb .num { position: absolute; right: 12px; bottom: 12px; font-family: var(--font-display); font-size: 48px; font-weight: 900; }
.mag-title { margin-top: 1rem; font-family: var(--font-display); font-size: 1.125rem; font-weight: 700; line-height: 1.3; transition: color .2s; }
.mag-meta { margin-top: 8px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em; color: var(--muted); }

/* Footer */
.footer { position: relative; margin-top: 8rem; border-top: 1px solid var(--border); padding: 4rem 0; }
.footer .container { position: relative; }
.footer-grid { display: grid; gap: 2.5rem; }
@media (min-width: 768px) { .footer-grid { grid-template-columns: repeat(4, 1fr); } }
.footer-brand-col { grid-column: span 2; }
.footer-brand { font-family: var(--font-display); font-size: 1.875rem; font-weight: 900; letter-spacing: .15em; }
.footer p { margin-top: .75rem; max-width: 28rem; font-family: var(--font-mono); font-size: 12px; line-height: 1.6; color: var(--muted); }
.footer .status { margin-top: 1.5rem; display: flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; color: var(--lime); }
.footer h4 { font-family: var(--font-mono); font-size: 10px; font-weight: 500; letter-spacing: .3em; color: var(--muted); }
.footer ul { margin-top: 1rem; list-style: none; display: flex; flex-direction: column; gap: 8px; font-family: var(--font-mono); font-size: 14px; }
.footer li.muted { color: var(--muted); }
.footer a:hover { color: var(--cyan); }

/* Profile page */
.profile-hero { position: relative; overflow: hidden; border-bottom: 1px solid var(--border); padding: 4rem 0; }
@media (min-width: 768px) { .profile-hero { padding: 6rem 0; } }
.profile-grid { position: relative; display: grid; gap: 2.5rem; }
@media (min-width: 768px) { .profile-grid { grid-template-columns: 1fr auto; } }
.profile-tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; color: var(--cyan); }
.profile-name { margin-top: .75rem; font-size: clamp(3rem, 9vw, 7rem); line-height: 1; letter-spacing: -.02em; }
.profile-pred { margin-top: 1.5rem; max-width: 36rem; font-family: var(--font-mono); font-size: 1rem; line-height: 1.6; color: rgba(240,246,255,.8); }
.profile-tags { margin-top: 2rem; display: flex; flex-wrap: wrap; gap: 12px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em; }
.profile-tags span { padding: 4px 10px; border: 1px solid var(--border); background: rgba(20,19,30,.4); color: var(--cyan); }

.profile-orb-wrap { display: flex; align-items: center; justify-content: center; }
.profile-orb { position: relative; width: 224px; height: 224px; }
@media (min-width: 768px) { .profile-orb { width: 288px; height: 288px; } }
.profile-orb .ring { position: absolute; inset: 0; border-radius: 50%; border: 1px dashed; }
.profile-orb .ring2 { position: absolute; inset: 12px; border-radius: 50%; border: 1px solid; animation: pulse-glow 2s ease-in-out infinite; }
.profile-orb .glyph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 160px; line-height: 1; }
@media (min-width: 768px) { .profile-orb .glyph { font-size: 192px; } }

.widgets { display: grid; gap: 1rem; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 768px) { .widgets { grid-template-columns: repeat(4, 1fr); } }
.widget { padding: 20px; }
.widget .l { font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; color: var(--muted); }
.widget .v { margin-top: 8px; font-family: var(--font-display); font-weight: 900; font-size: 1.875rem; }
.widget.big .v { font-size: 3rem; }
.widget .s { margin-top: 4px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em; color: var(--muted); }

.profile-sections { margin-top: 2.5rem; display: grid; gap: 1rem; }
@media (min-width: 768px) { .profile-sections { grid-template-columns: repeat(2, 1fr); } }
.psection { padding: 24px; }
.psection-head { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; }
.psection-head .ok { color: var(--muted); }
.psection p { margin-top: 1rem; font-family: var(--font-mono); font-size: 14px; line-height: 1.6; color: rgba(240,246,255,.85); }

.related { margin-top: 5rem; }
.related-head { font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; color: var(--muted); }
.related-grid { margin-top: 1rem; display: grid; gap: 12px; grid-template-columns: repeat(3, 1fr); }
@media (min-width: 640px) { .related-grid { grid-template-columns: repeat(6, 1fr); } }
.related-cell { padding: 16px; display: flex; flex-direction: column; align-items: center; justify-content: center; transition: transform .2s; }
.related-cell:hover { transform: scale(1.05); }
.related-cell .g { font-family: var(--font-display); font-size: 28px; }
.related-cell .s { margin-top: 4px; font-family: var(--font-mono); font-size: 9px; letter-spacing: .2em; color: var(--muted); }
.related-cell:hover .s { color: var(--cyan); }

/* Compat scanner */
.compat-pickers { display: grid; gap: 1.5rem; margin-top: 3rem; align-items: stretch; }
@media (min-width: 1024px) { .compat-pickers { grid-template-columns: 1fr auto 1fr; } }
.picker { padding: 24px; }
.picker .row1 { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; }
.picker .row2 { margin-top: 1rem; display: flex; align-items: center; gap: 1rem; }
.picker .pglyph { font-family: var(--font-display); font-size: 72px; line-height: 1; }
.picker .pname { font-family: var(--font-display); font-size: 1.875rem; font-weight: 900; }
.picker .pmeta { font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em; color: var(--muted); }
.picker select { margin-top: 1rem; width: 100%; padding: 10px 12px; background: var(--bg); border: 1px solid var(--border); color: var(--cyan); font-family: var(--font-mono); font-size: 12px; letter-spacing: .1em; }
.picker select:focus { outline: none; border-color: var(--magenta); }
.scan-btn-wrap { display: flex; align-items: center; justify-content: center; }

.compat-result { margin-top: 3rem; display: grid; gap: 1.5rem; }
@media (min-width: 1024px) { .compat-result { grid-template-columns: 1fr 1fr; } }
.radar-box { padding: 24px; overflow: hidden; }
.radar-wrap { position: relative; margin: 1rem auto 0; aspect-ratio: 1; max-width: 420px; }
.radar-svg { width: 100%; height: 100%; }
.radar-glyph { position: absolute; font-family: var(--font-display); font-size: 48px; }
.radar-glyph.a { left: 15%; top: 15%; }
.radar-glyph.b { right: 15%; bottom: 15%; }
.sync-num { text-align: center; margin-top: 8px; }
.sync-num .l { font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; color: var(--muted); }
.sync-num .v { font-family: var(--font-display); font-weight: 900; font-size: 4.5rem; }

.metrics-box { padding: 24px; }
.metrics-list { margin-top: 1.5rem; display: flex; flex-direction: column; gap: 1.25rem; }
.metric .h { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; letter-spacing: .25em; color: var(--muted); margin-bottom: 6px; }
.metric .bar { height: 8px; background: rgba(106,120,148,.25); overflow: hidden; }
.metric .fill { height: 100%; transition: width 1s ease-out; }
.verdict { margin-top: 2rem; padding-top: 1.25rem; border-top: 1px solid var(--border); }
.verdict .l { font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; color: var(--cyan); }
.verdict p { margin-top: 8px; font-family: var(--font-mono); font-size: 14px; line-height: 1.6; color: rgba(240,246,255,.85); }

/* Data Astro */
.indexes { margin-top: 3rem; display: grid; gap: 1rem; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 768px) { .indexes { grid-template-columns: repeat(4, 1fr); } }
.idx { padding: 20px; }
.idx .l { font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; color: var(--muted); }
.idx .v { margin-top: 8px; font-family: var(--font-display); font-weight: 900; font-size: 2.25rem; }
.idx .s { margin-top: 4px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em; color: var(--muted); }

.tablebox { margin-top: 2.5rem; overflow: hidden; }
.tablebox .head { padding: 12px 20px; border-bottom: 1px solid var(--border); font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; color: var(--cyan); }
.tablewrap { overflow-x: auto; }
.tablebox table { width: 100%; font-family: var(--font-mono); font-size: 12px; border-collapse: collapse; }
.tablebox th { padding: 12px 20px; text-align: left; font-weight: 500; font-size: 10px; letter-spacing: .2em; color: var(--muted); border-bottom: 1px solid var(--border); }
.tablebox td { padding: 16px 20px; border-bottom: 1px solid rgba(118,130,180,.1); }
.tablebox tr:hover td { background: rgba(255,43,214,.05); }
.tag-retro { display: inline-flex; align-items: center; gap: 8px; color: var(--magenta); }
.tag-retro span { width: 6px; height: 6px; border-radius: 999px; background: var(--magenta); animation: pulse-glow 2s infinite; }
.tag-direkt { display: inline-flex; align-items: center; gap: 8px; color: var(--lime); }
.tag-direkt span { width: 6px; height: 6px; border-radius: 999px; background: var(--lime); animation: pulse-glow 2s infinite; }

.weekly { margin-top: 3rem; }
.weekly h2 { margin-top: 8px; font-size: 1.875rem; }
@media (min-width: 768px) { .weekly h2 { font-size: 2.25rem; } }
.weekly-grid { margin-top: 1.5rem; display: grid; gap: 1rem; }
@media (min-width: 768px) { .weekly-grid { grid-template-columns: repeat(3, 1fr); } }
.wcard { padding: 20px; }
.wcard .d { font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; }
.wcard .t { margin-top: 8px; font-family: var(--font-display); font-size: 1.25rem; font-weight: 700; }
.wcard .x { margin-top: 8px; font-family: var(--font-mono); font-size: 12px; line-height: 1.6; color: var(--muted); }

/* Magazin */
.mag-hero { margin-top: 3rem; display: grid; overflow: hidden; }
@media (min-width: 768px) { .mag-hero { grid-template-columns: 1fr 1fr; } }
.mag-hero-thumb { position: relative; aspect-ratio: 5/4; overflow: hidden; }
.mag-hero-thumb .cat { position: absolute; left: 16px; top: 16px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; }
.mag-hero-thumb .num { position: absolute; right: 24px; bottom: 24px; font-family: var(--font-display); font-size: 9rem; font-weight: 900; line-height: 1; }
.mag-hero-body { padding: 2rem; display: flex; flex-direction: column; justify-content: center; }
@media (min-width: 768px) { .mag-hero-body { padding: 3rem; } }
.mag-hero-body .meta { font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; color: var(--muted); }
.mag-hero-body h2 { margin-top: 1rem; font-size: 1.875rem; line-height: 1.1; }
@media (min-width: 768px) { .mag-hero-body h2 { font-size: 3rem; } }
.mag-hero-body .ex { margin-top: 1rem; font-family: var(--font-mono); font-size: 14px; line-height: 1.6; color: rgba(240,246,255,.8); }
.mag-hero-body .btn { margin-top: 2rem; align-self: flex-start; }

.mag-list { margin-top: 3rem; display: grid; gap: 1rem; }
@media (min-width: 768px) { .mag-list { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .mag-list { grid-template-columns: repeat(3, 1fr); } }
.mag-item { display: flex; flex-direction: column; overflow: hidden; }
.mag-item .thumb { position: relative; aspect-ratio: 5/3; }
.mag-item .thumb .cat { position: absolute; left: 12px; top: 12px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .3em; }
.mag-item .thumb .num { position: absolute; right: 12px; bottom: 12px; font-family: var(--font-display); font-size: 48px; font-weight: 900; }
.mag-item .body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.mag-item .meta { font-family: var(--font-mono); font-size: 10px; letter-spacing: .2em; color: var(--muted); }
.mag-item h3 { margin-top: 8px; font-family: var(--font-display); font-size: 18px; font-weight: 700; line-height: 1.3; transition: color .2s; }
.mag-item:hover h3 { color: var(--cyan); }
.mag-item .ex { margin-top: 8px; font-family: var(--font-mono); font-size: 12px; line-height: 1.6; color: var(--muted); display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

/* Scrollbar */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--card); }
::-webkit-scrollbar-thumb { background: var(--gradient-holo); }
