:root {
  color-scheme: light;
  --bg: #f5f8fb;
  --bg-soft: #eef6fb;
  --card: rgba(255,255,255,.78);
  --card-solid: #fff;
  --text: #102033;
  --muted: #66758a;
  --line: rgba(41, 65, 90, .12);
  --accent: #0db7d8;
  --accent-2: #6267f2;
  --accent-soft: rgba(13, 183, 216, .12);
  --success: #16a36a;
  --warning: #f6a21a;
  --shadow: 0 18px 60px rgba(28, 53, 82, .12);
  --radius-xl: 30px;
  --radius-lg: 22px;
  --radius-md: 16px;
  --header: rgba(255,255,255,.75);
}

html[data-theme="dark"] {
  color-scheme: dark;
  --bg: #0b111a;
  --bg-soft: #101a27;
  --card: rgba(18, 29, 42, .78);
  --card-solid: #121d2a;
  --text: #eef6ff;
  --muted: #9aaabd;
  --line: rgba(220,235,255,.12);
  --accent: #20c7e8;
  --accent-2: #8b8dff;
  --accent-soft: rgba(32,199,232,.14);
  --shadow: 0 18px 60px rgba(0, 0, 0, .28);
  --header: rgba(11,17,26,.76);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
section { scroll-margin-top: 8.5rem; }
html, body { max-width: 100%; overflow-x: hidden; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at top left, var(--bg-soft), transparent 36rem),
    linear-gradient(180deg, var(--bg), var(--bg-soft));
  color: var(--text);
  min-height: 100vh;
}
body.has-audio-player { padding-bottom: 6rem; }

a { color: inherit; text-decoration: none; }
button, input { font: inherit; }

.bg-orb {
  position: fixed;
  width: 26rem;
  height: 26rem;
  border-radius: 999px;
  filter: blur(48px);
  opacity: .24;
  pointer-events: none;
  z-index: -1;
}
.orb-a { top: 7rem; left: -9rem; background: #1dc8e8; }
.orb-b { right: -8rem; top: 22rem; background: #7771ff; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1.5rem;
  padding: .85rem clamp(1rem, 3vw, 2.5rem);
  background: var(--header);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(18px);
}

.brand { display: flex; align-items: center; gap: .75rem; min-width: 0; }
.brand strong { display:block; font-weight: 800; letter-spacing: -.03em; }
.brand small { display:block; color: var(--muted); font-size: .75rem; margin-top: .08rem; }
.brand span:last-child { min-width:0; }
.brand strong, .brand small { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.brand-mark {
  position: relative;
  width: 2.65rem;
  height: 2.65rem;
  border-radius: 1rem;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: 0 10px 26px rgba(13, 183, 216, .28);
  overflow: hidden;
}
.brand-mark .dot {
  position: absolute; inset: 50% auto auto 50%; width: .45rem; height: .45rem;
  background: #fff; border-radius: 999px; transform: translate(-50%, -50%);
}
.wave { position:absolute; border:2px solid rgba(255,255,255,.88); border-left:0; border-bottom:0; transform: rotate(45deg); border-radius: .1rem; }
.wave-1 { width: .8rem; height: .8rem; left: .72rem; top: .88rem; }
.wave-2 { width: 1.35rem; height: 1.35rem; left: .48rem; top: .6rem; opacity:.72; }

.main-nav { display:flex; gap:.25rem; justify-content:center; flex-wrap:wrap; min-width:0; }
.main-nav a { color: var(--muted); font-weight: 600; font-size: .92rem; padding:.58rem .75rem; border-radius: 999px; transition:.2s ease; }
.main-nav a span { display:block; }
.main-nav a small { display:none; }
.main-nav a:hover { color: var(--text); background: var(--accent-soft); }

.header-actions { display:flex; align-items:center; gap:.55rem; min-width:0; }
.search-box { display:flex; align-items:center; gap:.35rem; min-width: 18rem; padding: .58rem .8rem; border:1px solid var(--line); border-radius:999px; background: var(--card-solid); color:var(--muted); }
.search-box input { width:100%; border:0; outline:0; background:transparent; color:var(--text); }
.server-pill, .theme-toggle { border:1px solid var(--line); background:var(--card-solid); border-radius:999px; padding:.58rem .75rem; color:var(--text); }
.theme-toggle { cursor:pointer; width:2.45rem; }
.menu-toggle {
  display:none;
  width:2.45rem;
  height:2.45rem;
  padding:0;
  border:1px solid var(--line);
  background:var(--card-solid);
  border-radius:999px;
  color:var(--text);
  box-shadow:none;
}
.menu-toggle span {
  display:block;
  width:1rem;
  height:2px;
  background:currentColor;
  border-radius:999px;
  transition:.22s ease;
}

.section-shell { width:min(1180px, calc(100% - 2rem)); margin:0 auto; }
.hero { display:grid; grid-template-columns: 1.2fr .8fr; gap:2rem; align-items:center; min-height: 650px; padding: 5rem 0 3rem; }
.eyebrow { display:inline-flex; color: var(--accent); font-weight:800; font-size:.78rem; text-transform:uppercase; letter-spacing:.12em; margin-bottom:.75rem; }
h1, h2, h3, p { margin-top:0; }
h1 { font-size: clamp(3.4rem, 7vw, 6.8rem); line-height:.88; letter-spacing:-.08em; margin-bottom:1.35rem; max-width: 860px; }
h2 { font-size: clamp(2rem, 4vw, 3.4rem); line-height:.98; letter-spacing:-.055em; margin-bottom:0; }
h3 { font-size:1.18rem; letter-spacing:-.025em; }
p { color:var(--muted); line-height:1.7; }
.hero-copy p { font-size:1.18rem; max-width: 680px; }
.hero-actions { display:flex; gap:.8rem; flex-wrap:wrap; margin-top:1.8rem; }
.btn, button, .station-actions a { display:inline-flex; align-items:center; justify-content:center; gap:.4rem; border:0; border-radius:999px; padding:.78rem 1.1rem; font-weight:750; cursor:pointer; transition:.22s ease; }
.btn.primary, .station-actions button:first-child { color:#fff; background: linear-gradient(135deg, var(--accent), var(--accent-2)); box-shadow: 0 14px 28px rgba(13,183,216,.22); }
.btn.ghost, .station-actions button, .station-actions a, .filter { background: var(--card-solid); color:var(--text); border:1px solid var(--line); }
.play-btn.is-playing { color:#fff; background: linear-gradient(135deg, var(--success), var(--accent)); border-color:transparent; }
.btn:hover, button:hover, .station-actions a:hover { transform: translateY(-2px); box-shadow: var(--shadow); }

.hero-card, .info-card, .station-card, .code-card, .app-card, .map-panel, .modern-form, .preview-card {
  background: var(--card);
  border:1px solid var(--line);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
}
.hero-card { padding:1.1rem; }
.live-chip { display:inline-flex; align-items:center; gap:.45rem; background:var(--accent-soft); color:var(--accent); border-radius:999px; padding:.45rem .7rem; font-weight:800; font-size:.82rem; }
.live-chip span { width:.55rem; height:.55rem; border-radius:50%; background:var(--success); box-shadow:0 0 0 7px rgba(22,163,106,.12); }
.stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:.8rem; margin:1.1rem 0; }
.stat-grid div { background:var(--card-solid); border:1px solid var(--line); border-radius:1.3rem; padding:1.1rem; }
.stat-grid strong { display:block; font-size:1.9rem; letter-spacing:-.05em; }
.stat-grid small { color:var(--muted); font-weight:650; }
.mini-player { display:flex; align-items:center; gap:.9rem; background:linear-gradient(135deg, rgba(13,183,216,.1), rgba(98,103,242,.1)); border:1px solid var(--line); border-radius:1.5rem; padding:.85rem; }
.mini-player div:nth-child(2) { flex:1; }
.mini-player strong, .mini-player span { display:block; }
.mini-player span { color:var(--muted); font-size:.9rem; }

.station-art { flex:0 0 auto; width:4.6rem; height:4.6rem; display:grid; place-items:center; color:#fff; font-weight:900; border-radius:1.4rem; letter-spacing:-.06em; overflow:hidden; text-align:center; font-size:.95rem; box-shadow: inset 0 0 0 1px rgba(255,255,255,.2); }
.station-art.rtl, .logo-red { background:linear-gradient(135deg,#f10021,#b60021); }
.france-info { background:linear-gradient(135deg,#ffd339,#f58220); color:#151515; font-size:.73rem; }
.vinyl { background:radial-gradient(circle,#eff4ff 0 18%,#242b38 20% 33%,#111827 34%); }
.gradient { background:linear-gradient(135deg,#18c7de,#735cff); }

.intro-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; padding:2rem 0; }
.info-card { padding:1.5rem; }
.info-card h2 { font-size: clamp(1.25rem, 1.8vw, 1.65rem); letter-spacing:-.035em; white-space: nowrap; }
.icon { display:inline-flex; width:2.5rem; height:2.5rem; border-radius:.9rem; align-items:center; justify-content:center; background:var(--accent-soft); color:var(--accent); font-weight:850; margin-bottom:1rem; }
.section-heading { display:flex; align-items:end; justify-content:space-between; gap:1rem; margin:4rem 0 1.2rem; }
.filter-row { display:flex; flex-wrap:wrap; gap:.5rem; }
.filter.active { background:var(--accent); color:#fff; border-color:transparent; }
.station-list { display:grid; gap:.9rem; }
.station-card { display:grid; grid-template-columns:auto 1fr auto; gap:1.05rem; align-items:center; padding:1rem; border-radius:var(--radius-lg); }
.station-title-row { display:flex; align-items:center; gap:.7rem; flex-wrap:wrap; }
.station-title-row h3 { margin:0; }
.station-main p { margin:.2rem 0 .65rem; }
.status { border-radius:999px; padding:.25rem .52rem; font-size:.75rem; font-weight:850; }
.status.online { background:rgba(22,163,106,.12); color:var(--success); }
.status.verified { background:rgba(98,103,242,.13); color:var(--accent-2); }
.status.geo { background:rgba(246,162,26,.14); color:var(--warning); }
.tags, .format-list { display:flex; flex-wrap:wrap; gap:.4rem; }
.tags span, .format-list span { background:var(--accent-soft); color:var(--accent); border-radius:999px; padding:.42rem .6rem; font-weight:700; font-size:.84rem; }
details { margin-top:.75rem; }
summary { color:var(--muted); font-weight:750; cursor:pointer; }
.tech-grid { display:grid; grid-template-columns:1fr 1fr; gap:.65rem; margin:.8rem 0 0; }
.tech-grid div { min-width:0; background:var(--card-solid); border:1px solid var(--line); border-radius:1rem; padding:.75rem; }
dt { color:var(--muted); font-size:.75rem; font-weight:800; text-transform:uppercase; letter-spacing:.05em; }
dd { margin:.2rem 0 0; word-break:break-all; }
.station-actions { display:flex; flex-direction:column; gap:.45rem; min-width:8rem; }

.api-grid, .contribute-grid { display:grid; grid-template-columns:.8fr 1.2fr; gap:1rem; min-width:0; }
.api-grid > *, .contribute-grid > * { min-width:0; }
.code-card { padding:1.3rem; }
pre { margin:0; white-space:pre-wrap; background:#08111d; color:#d9f8ff; padding:1rem; border-radius:1rem; overflow:auto; max-width:100%; }
code { overflow-wrap:anywhere; }
.app-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }
.app-card { padding:1.2rem; min-height:7rem; transition:.22s ease; }
.app-card:hover { transform:translateY(-4px); }
.app-card strong, .app-card span { display:block; }
.app-card span { color:var(--muted); margin-top:.45rem; line-height:1.55; }
.recommended { background:linear-gradient(135deg, var(--card), var(--accent-soft)); }

.map-section { display:grid; grid-template-columns:.42fr .58fr; gap:1rem; align-items:stretch; margin-top:4rem; }
.map-panel { padding:1.5rem; }
.check-row { display:flex; gap:.9rem; flex-wrap:wrap; color:var(--muted); font-weight:700; }
.mock-map { position:relative; min-height:380px; border-radius:var(--radius-xl); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow); background:
  radial-gradient(circle at 35% 45%, rgba(255,255,255,.7) 0 9%, transparent 10%),
  radial-gradient(circle at 60% 52%, rgba(255,255,255,.65) 0 13%, transparent 14%),
  radial-gradient(circle at 48% 34%, rgba(255,255,255,.5) 0 8%, transparent 9%),
  linear-gradient(135deg,#aaddec,#d7f3f6);
}
.pin { position:absolute; width:1rem; height:1rem; background:var(--accent-2); border:3px solid #fff; border-radius:999px; box-shadow:0 8px 16px rgba(0,0,0,.22); animation:pulse 2.5s infinite; }
.p1 { left:48%; top:46%; } .p2 { left:39%; top:38%; } .p3 { left:64%; top:55%; } .p4 { left:24%; top:52%; }
.map-card { position:absolute; left:50%; top:54%; transform:translateX(-50%); background:var(--card-solid); border:1px solid var(--line); border-radius:1.2rem; padding:.9rem; box-shadow:var(--shadow); display:grid; gap:.25rem; min-width:190px; }
.map-card small { color:var(--muted); }
.map-card button { justify-self:start; padding:.45rem .75rem; background:var(--accent); color:#fff; margin-top:.4rem; }

.contribute-section { padding-bottom:4rem; }
.modern-form, .preview-card { padding:1.4rem; }
.modern-form { display:grid; gap:.9rem; }
.modern-form label { display:grid; gap:.35rem; color:var(--muted); font-weight:800; }
.modern-form input { width:100%; border:1px solid var(--line); background:var(--card-solid); color:var(--text); border-radius:1rem; padding:.9rem 1rem; outline:0; font-weight:500; }
.modern-form input::placeholder { color: color-mix(in srgb, var(--muted) 68%, transparent); font-weight:400; }
.form-split { display:grid; grid-template-columns:1fr 1fr; gap:.8rem; }
.preview-card p { margin-top:1rem; }
.mini-player.large { align-items:flex-start; }

.site-footer { width:min(1180px, calc(100% - 2rem)); margin:0 auto 2rem; border-top:1px solid var(--line); padding:1.5rem 0; display:flex; justify-content:space-between; gap:1rem; color:var(--muted); }
.site-footer strong { color:var(--text); }

.audio-bar {
  position: fixed;
  z-index: 30;
  left: 50%;
  bottom: max(1rem, env(safe-area-inset-bottom));
  transform: translateX(-50%);
  width: min(760px, calc(100% - 2rem));
  display: grid;
  grid-template-columns: auto 1fr minmax(220px, 380px) auto;
  gap: .8rem;
  align-items: center;
  background: var(--card-solid);
  border: 1px solid var(--line);
  border-radius: 1.4rem;
  box-shadow: var(--shadow);
  padding: .75rem .8rem .75rem 1rem;
}
.audio-bar[hidden] { display:none; }
.audio-art {
  width: 3.2rem;
  height: 3.2rem;
  display: grid;
  place-items: center;
  border-radius: 1rem;
  color: #fff;
  font-weight: 900;
  font-size: .78rem;
  letter-spacing: -.055em;
  text-align: center;
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.22), 0 10px 24px rgba(16,32,51,.16);
}
.audio-title, .audio-subtitle { display:block; }
.audio-subtitle { color:var(--muted); font-size:.86rem; margin-top:.15rem; }
.audio-bar audio { width:100%; height:2.4rem; }
.audio-close { width:2.25rem; height:2.25rem; padding:0; border:1px solid var(--line); background:var(--card); color:var(--text); }

.reveal { opacity:0; transform:translateY(18px); animation: reveal .7s cubic-bezier(.2,.8,.2,1) forwards; }
.delay-1 { animation-delay:.12s; } .delay-2 { animation-delay:.24s; }
@keyframes reveal { to { opacity:1; transform:none; } }
@keyframes pulse { 50% { transform:scale(1.35); box-shadow:0 0 0 12px rgba(98,103,242,.12); } }
@keyframes menuIn { from { opacity:0; transform: translateY(-6px) scale(.98); } to { opacity:1; transform:none; } }

@media (max-width: 980px) {
  section { scroll-margin-top: 10.5rem; }
  .site-header { grid-template-columns:minmax(0, 1fr) auto; }
  .main-nav { order:3; grid-column:1 / -1; justify-content:flex-start; overflow-x:auto; overflow-y:hidden; flex-wrap:nowrap; padding-bottom:.2rem; scrollbar-width:none; }
  .main-nav::-webkit-scrollbar { display:none; }
  .search-box { min-width: 12rem; }
  .hero, .api-grid, .map-section, .contribute-grid { grid-template-columns:1fr; }
  .intro-grid, .app-grid { grid-template-columns:1fr 1fr; }
  .station-card { grid-template-columns:auto 1fr; }
  .station-actions { grid-column: 1 / -1; flex-direction:row; flex-wrap:wrap; }
}
@media (max-width: 640px) {
  section { scroll-margin-top: 12.5rem; }
  .site-header {
    grid-template-columns:minmax(0, 1fr) auto auto auto;
    gap:.55rem;
    padding: max(1rem, calc(env(safe-area-inset-top) + .65rem)) .95rem .8rem;
  }
  .brand { grid-column:1; max-width:100%; gap:.58rem; }
  .brand-mark { width:2.25rem; height:2.25rem; border-radius:.85rem; }
  .brand small { display:none; }
  .menu-toggle { display:inline-flex; grid-column:4; grid-row:1; align-items:center; justify-content:center; flex-direction:column; gap:4px; }
  .site-header.menu-open .menu-toggle span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
  .site-header.menu-open .menu-toggle span:nth-child(2) { opacity:0; }
  .site-header.menu-open .menu-toggle span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
  .header-actions { display:contents; }
  .server-pill { grid-column:2; grid-row:1; white-space:nowrap; padding:.52rem .68rem; font-size:.9rem; }
  .theme-toggle { grid-column:3; grid-row:1; width:2.2rem; padding:.52rem 0; }
  .search-box { grid-column:1 / -1; grid-row:2; width:100%; min-width:0; padding:.62rem .78rem; }
  .main-nav {
    display:none;
    grid-column:1 / -1;
    grid-row:3;
    margin-inline:0;
    padding:.7rem;
    border:1px solid var(--line);
    border-radius:1.45rem;
    background:
      radial-gradient(circle at top left, var(--accent-soft), transparent 55%),
      var(--card-solid);
    box-shadow:var(--shadow);
    overflow:visible;
    transform-origin: top right;
    animation: menuIn .18s ease-out both;
  }
  .site-header.menu-open .main-nav { display:grid; grid-template-columns:1fr; gap:.45rem; }
  .main-nav a {
    position:relative;
    flex:0 0 auto;
    justify-content:flex-start;
    padding:.88rem 1rem;
    background:rgba(255,255,255,.5);
    border:1px solid var(--line);
    border-radius:1rem;
    color:var(--text);
  }
  html[data-theme="dark"] .main-nav a { background:rgba(255,255,255,.045); }
  .main-nav a::after {
    content:'›';
    position:absolute;
    right:1rem;
    top:50%;
    transform:translateY(-50%);
    color:var(--accent);
    font-size:1.35rem;
  }
  .main-nav a span { font-weight:850; }
  .main-nav a small { display:block; margin-top:.18rem; color:var(--muted); font-size:.78rem; font-weight:650; }
  .api-section { width: min(1180px, calc(100% - 2rem)); overflow:hidden; }
  .api-grid { width:100%; }
  .code-card { width:100%; max-width:100%; }
  h1 { font-size:clamp(2.55rem, 13vw, 3.2rem); line-height:.93; letter-spacing:-.07em; }
  .hero-copy p { font-size:1rem; }
  .hero-actions .btn { flex:1 1 11rem; min-width:0; }
  .hero { padding-top:3rem; min-height:auto; }
  .intro-grid, .app-grid, .stat-grid, .tech-grid, .form-split { grid-template-columns:1fr; }
  .info-card h2 { white-space: normal; }
  .section-heading { align-items:flex-start; flex-direction:column; }
  .station-card { grid-template-columns:1fr; }
  .station-art { width:4.2rem; height:4.2rem; }
  .site-footer { flex-direction:column; }
  body.has-audio-player { padding-bottom: 8.5rem; }
  .audio-bar {
    position: fixed;
    left: .75rem;
    right: .75rem;
    bottom: max(.75rem, env(safe-area-inset-bottom));
    transform: none;
    width: auto;
    grid-template-columns:auto 1fr auto;
    border-radius: 1.25rem;
    padding: .65rem;
  }
  .audio-art { width:2.85rem; height:2.85rem; border-radius:.85rem; }
  .audio-bar audio { grid-column:1 / -1; order:3; }
}
