
:root{
--bg: #fff7fb;
--ink: #3b2c3f;
--muted:#6d5a72;
--brand:#ff79c6;      /* сакура-розовый */
--brand-2:#8ec5ff;    /* облачно-голубой */
--brand-3:#ffd7e8;    /* мягкий розовый фон */
--card:#ffffff;
--accent:#ffd1e6;
--ok:#6bd88f;
--warn:#ffb86b;
--shadow: 0 10px 30px rgba(255,121,198,0.22);
--radius:16px;
--ease: cubic-bezier(.2,.8,.2,1);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
font-family: ui-rounded, "SF Pro Rounded", "Segoe UI", system-ui, -apple-system, "Noto Sans", "Roboto", "Nunito", Arial, sans-serif;
color:var(--ink);
background:
    radial-gradient(1200px 600px at 80% -10%, #e9f4ff 0%, transparent 60%),
    radial-gradient(900px 500px at 10% -15%, #ffeef7 0%, transparent 60%),
    linear-gradient(180deg, var(--bg), #fff);
overflow-x:hidden;
}

/* Фиксированный хедер */
.header{
position:sticky; top:0; z-index:50;
background: linear-gradient(90deg, #ffe3f2, #e6f3ff);
backdrop-filter: blur(6px);
border-bottom:1px solid rgba(0,0,0,.06);
}
.bar{
max-width:1200px; margin:0 auto; padding:12px 16px;
display:flex; align-items:center; gap:12px;
}
.logo{
display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--ink);
}
.logo-badge{
width:36px; height:36px; border-radius:50%;
background: radial-gradient(circle at 30% 30%, #ffe3ef, #ffd1e6 45%, #ffb4d3 100%);
box-shadow: var(--shadow);
position:relative; overflow:hidden;
}
/* мини-облачко в логотипе */
.logo-badge::before, .logo-badge::after{
content:""; position:absolute; background:#fff;
border-radius:50%;
}
.logo-badge::before{ width:18px; height:18px; left:6px; top:10px; box-shadow: 14px 2px 0 0 #fff;}
.logo-badge::after{ width:26px; height:20px; left:10px; top:14px; }

.brand-title{font-weight:900; letter-spacing:.2px}
.brand-sub{font-size:12px; color:var(--muted); margin-top:-4px}

nav{margin-left:auto; display:flex; gap:8px; flex-wrap:wrap}
.nav-link{
text-decoration:none; color:var(--muted); font-weight:700; font-size:14px;
padding:8px 12px; border-radius:999px; transition:.25s var(--ease);
}
.nav-link:hover{ color:var(--ink); background: #ffffff88 }

.air-btn{
margin-left:8px;
padding:10px 16px; border-radius:999px; font-weight:900; text-decoration:none; color:#fff;
max-height: 42px;
background: linear-gradient(135deg, var(--brand), #ff97d8);
box-shadow: var(--shadow);
border:2px solid #fff4;
transition: transform .15s var(--ease), box-shadow .15s var(--ease);
}
.air-btn:hover{ transform:translateY(-1px); box-shadow: 0 14px 38px rgba(255,121,198,.28); }
.air-btn:active{ transform:translateY(1px) scale(.99); }

/* Canvas сакуры */
#sakura{
position:fixed; inset:0; width:100%; height:100%;
pointer-events:none; z-index:0; opacity:.8;
}

/* Hero */
.hero{
position:relative; z-index:1;
max-width:1200px; margin:22px auto 0; padding:32px 16px 8px;
display:grid; grid-template-columns: 1.2fr 1fr; gap:28px; align-items:center;
}
@media (max-width: 880px){ .hero{ grid-template-columns: 1fr; } }

.hero-card{
background: linear-gradient(180deg, #fff, #fff8fc);
border:1px solid #00000010;
border-radius:24px; padding:24px;
box-shadow: var(--shadow);
}
.kicker{ color:var(--brand); font-weight:900; letter-spacing:.6px; font-size:13px; text-transform:uppercase; }
.title{
font-size: clamp(28px, 4.5vw, 46px);
line-height:1.05; margin:8px 0 10px; font-weight:1000;
background: linear-gradient(90deg, #f65fb1, #6fb6ff);
-webkit-background-clip:text; background-clip:text; color:transparent;
}
.subtitle{ color:var(--muted); font-size:16px; }

.pill-row{ display:flex; gap:8px; flex-wrap:wrap; margin:14px 0 8px; }
.pill{
font-size:12px; font-weight:800; color:#6b5870;
background:linear-gradient(180deg, #fff, #fff3f8);
border:1px dashed #00000015; border-radius:999px; padding:8px 12px;
}

.controls{
display:flex; flex-wrap:wrap; gap:10px; margin-top:16px;
}
.btn{
display:inline-flex; align-items:center; gap:10px;
background: linear-gradient(135deg, #ffffff, #f8fcff);
border:1px solid #00000010; border-radius:14px; padding:10px 14px;
color:var(--ink); text-decoration:none; font-weight:900;
box-shadow: var(--shadow); transition:.2s var(--ease);
}
.btn:hover{ transform:translateY(-1px) }
.btn .dot{ width:10px; height:10px; border-radius:50%; background:var(--ok); box-shadow:0 0 0 4px #dbffe9; }

.player-card{
background: linear-gradient(180deg, #ffffff, #f0f7ff);
border:1px solid #00000010; border-radius:24px; padding:20px;
box-shadow: var(--shadow);
}
audio{
width:100%; height:40px; border-radius:12px;
accent-color: var(--brand);
}
.np{ margin-top:10px; font-size:14px; color:var(--muted); }
.np strong{ color:var(--ink) }



.visualizer{height:60px; display:flex; align-items:flex-end; gap:6px}
.hero-art{
    position:relative;

}
.kawaii{
    width:100%; aspect-ratio: 1 / 1; border-radius:18px; background: radial-gradient(circle at 30% 25%, #ffe7f3, transparent 45%),
    linear-gradient(135deg, #fff5fb, #eef9ff); position:relative; overflow:hidden;
}
.kawaii-face{position:absolute; inset:0; display:grid; place-items:center; font-size:62px}
.kawaii-note{position:absolute; font-size:20px; opacity:.8}
.kawaii-note:nth-child(1){top:12%; left:16%; transform:rotate(-10deg)}
.kawaii-note:nth-child(2){bottom:18%; right:14%; transform:rotate(8deg)}


/* Декоративные разделители-облачка */
.cloud-divider{
width:100%; height:60px; position:relative; margin:28px 0 12px; filter: drop-shadow(0 12px 16px rgba(0,0,0,.05));
}
.cloud-divider svg{ width:100%; height:100% }

/* Общий контейнер секций */
.section{
position:relative; z-index:1;
max-width:1200px; margin:0 auto; padding:8px 16px 38px;
}
.section h2{
font-size: clamp(22px, 3.5vw, 32px); margin:8px 0 12px; font-weight:1000;
}
.grid{
display:grid; gap:16px;
grid-template-columns: repeat(12, 1fr);
}

/* Карточки */
.card{
grid-column: span 4;
background: var(--card);
border:1px solid #00000010; border-radius:18px; padding:16px;
box-shadow: var(--shadow); transition:.25s var(--ease);
}
.card:hover{ transform:translateY(-2px); }
@media (max-width: 960px){ .card{ grid-column: span 6; } }
@media (max-width: 640px){ .card{ grid-column: span 12; } }

.badge{
display:inline-block; padding:6px 10px; border-radius:999px;
font-size:12px; font-weight:900; color:#7a4762;
background: linear-gradient(180deg, #fff, #fff0f6); border:1px dashed #00000015;
}
.tag{ font-size:12px; color:#927c95; }

/* Плейлист */
.track{ display:flex; align-items:center; gap:12px; padding:10px; border-radius:12px; background:#fff8fc; border:1px solid #0000000e; }
.track .num{ width:26px; height:26px; display:grid; place-items:center; font-weight:900; border-radius:8px; background:#ffe9f5; color:#a74381; }
.track .meta{ flex:1 }
.track .t{ font-weight:900 }
.track .a{ color:var(--muted); font-size:13px }
.track .act{ display:flex; gap:8px }
.mini{
padding:6px 10px; border-radius:10px; border:1px solid #00000012;
background:#fff; font-weight:800; font-size:12px; cursor:pointer;
transition:.2s var(--ease);
}
.mini:hover{ background:#fff5fb }

/* Ведущие */
.host{
display:flex; gap:12px; align-items:center;
}
.avatar{
width:58px; height:58px; border-radius:50%;
background: radial-gradient(ellipse at 30% 30%, #ffe3f3, #ffc0e1);
border:2px solid #fff; box-shadow: var(--shadow); position:relative; overflow:hidden;
}
/* милый глазик-пиктограмма :) */
.avatar::before, .avatar::after{
content:""; position:absolute; background:#5b4161; border-radius:50%;
}
.avatar::before{ width:10px; height:10px; left:18px; top:22px; box-shadow: 12px 0 0 0 #5b4161; }
.avatar::after{ width:34px; height:16px; left:12px; top:34px; background:#ffffff90; border-radius:16px; }

.host .name{ font-weight:1000; }
.host .role{ font-size:12px; color:var(--muted) }
.cult{ color:#a31e6b; background:#ffe2f0; border:1px solid #ffb9d6; }

/* Расписание */
.schedule{ display:grid; grid-template-columns: repeat(3, 1fr); gap:10px; }
@media (max-width:800px){ .schedule{ grid-template-columns: 1fr; } }
.slot{
background: linear-gradient(180deg, #fff, #fff7fc);
border:1px solid #00000010; border-radius:12px; padding:12px;
}
.slot .time{ font-weight:900; color:#854b7a }
.slot .prog{ font-weight:800 }

/* Соцсети */
.socials{ display:flex; flex-wrap:wrap; gap:10px }
.social{
display:inline-flex; align-items:center; gap:10px;
padding:10px 14px; border-radius:14px; border:1px solid #00000010;
background:#fff; font-weight:900; color:#3d3151; text-decoration:none;
box-shadow: var(--shadow);
}
.social:hover{ transform: translateY(-1px) }
.social svg{ width:18px; height:18px }

/* Заявки */
.form{ display:grid; gap:10px }
.input, .textarea{
width:100%; padding:10px 12px; border-radius:12px; border:1px solid #00000012; background:#fff;
font: inherit;
}
.textarea{ min-height:84px; resize:vertical }

/* Плавное появление секций */
.reveal{ opacity:0; transform: translateY(10px); transition: .6s var(--ease); }
.reveal.show{ opacity:1; transform:none; }

/* Footer */
.footer{
margin-top:10px; padding:16px; text-align:center; color:#846b85; font-size:13px;
}


/* Player */
/* Кастомный плеер Anime Radio MD */
.greeting-player-card {
    background: linear-gradient(120deg, #f9eaff 60%, #e9f3ff 100%);
    border-radius: 18px;
    box-shadow: 0 2px 16px 0 #e9e0f7;
    padding: 22px 24px 18px 24px;
    max-width: 420px;
    margin: 0 auto 18px auto;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
}
.greeting-player-badge {
    background: #ffe6f3;
    color: #b06fa7;
    font-weight: 600;
    font-size: 15px;
    border-radius: 8px;
    padding: 2px 14px;
    display: inline-block;
    margin-bottom: 8px;
    width: fit-content;
    box-shadow: 0 1px 4px #f3e0f7;
}
.greeting-player-main {
    display: flex;
    align-items: center;
    gap: 14px;
}
.greeting-player-btn {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: none;
    background: linear-gradient(120deg, #e9f3ff 60%, #ffe6f3 100%);
    box-shadow: 0 1px 6px #e9e0f7;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    color: #b06fa7;
    cursor: pointer;
    transition: background 0.2s, box-shadow 0.2s;
}
.greeting-player-btn:active {
    background: #ffe6f3;
    box-shadow: 0 1px 2px #e9e0f7;
}
.greeting-player-icon {
    font-family: inherit;
    font-size: 28px;
    line-height: 1;
}
.greeting-player-info {
    flex: 1;
    min-width: 0;
}
.greeting-player-title {
    font-weight: 700;
    font-size: 17px;
    color: #7e5c79;
    margin-bottom: 2px;
}
.greeting-player-status {
    font-size: 14px;
    color: #b06fa7;
    opacity: 0.85;
}
.greeting-player-visualizer {
    width: 80px;
    height: 24px;
    background: #f7f3ff;
    border-radius: 6px;
    box-shadow: 0 1px 2px #e9e0f7;
    margin-left: 8px;
}
.greeting-player-volume {
    width: 100%;
    margin: 0 0 4px 0;
    accent-color: #b06fa7;
    height: 4px;
}
.greeting-player-tip {
    font-size: 13px;
    color: #b06fa7;
    opacity: 0.7;
    margin-top: 4px;
}
@media (max-width: 600px) {
    .greeting-player-card { padding: 14px 6px 12px 6px; }
    .greeting-player-title { font-size: 15px; }
    .greeting-player-status { font-size: 12px; }
    .greeting-player-visualizer { width: 60px; height: 18px; }
}

/* Ночной режим по желанию */
.toggle-wrap{ position:fixed; right:12px; bottom:12px; z-index:20; }
.toggle{
appearance:none; width:54px; height:30px; border-radius:999px; background: linear-gradient(180deg, #ffe8f4, #f0f7ff);
border:1px solid #00000012; position:relative; cursor:pointer; box-shadow: var(--shadow);
}
.toggle::before{
content:""; position:absolute; top:3px; left:3px; width:24px; height:24px; border-radius:50%; background:#fff; box-shadow: 0 2px 8px rgba(0,0,0,.12);
transition: .25s var(--ease);
}
.toggle:checked::before{ transform: translateX(24px); background: radial-gradient(circle at 30% 30%, #ffd7e6, #ffc1de); }

.night body, .night{
background:
    radial-gradient(1200px 600px at 80% -10%, #0c1120 0%, transparent 60%),
    radial-gradient(900px 500px at 10% -15%, #141a2b 0%, transparent 60%),
    linear-gradient(180deg, #101422, #0c1120);
color:#eadeff;
}
.night .header{ background: linear-gradient(90deg, #1d1f32, #14243a); border-color:#ffffff10 }
.night .nav-link{ color:#c9bede }
.night .air-btn{ background: linear-gradient(135deg, #e35cae, #8ec5ff) }
.night .card, .night .hero-card, .night .player-card, .night .slot, .night .btn, .night .social{ background:#151a2a; border-color:#ffffff14; color:#eadeff }
.night .subtitle, .night .tag, .night .brand-sub, .night .muted{ color:#b7a8ca }
.night .track{ background:#171a2a; border-color:#ffffff10 }
.night .track .a{ color:#aca0c1 }
.night .avatar{ background: radial-gradient(ellipse at 30% 30%, #3a2740, #2a1f35) }
.night .cloud-divider{ filter:none; opacity:.85 }

@media (max-width: 860px){
    .hero {grid-template-columns: 1fr}
    .hero h1{font-size:32px}
}
@media (max-width: 768px) {
    .bar {
      flex-direction: column;
      align-items: stretch;
      gap: 16px;
    }
    nav {
      order: 3;
      justify-content: center;
      flex-wrap: wrap;
    }
    .logo, .air-btn { align-self: center; }
    #volumeSlider { width: 100px; }
    .title { font-size: 1.9rem; }
    .subtitle { font-size: 1.1rem; }
    .grid { grid-template-columns: 1fr; padding: 0 16px; }
    .card { grid-column: 1 / -1; }
    [style*="grid-column: span"] { grid-column: 1 / -1 !important; }
    .section { padding: 60px 0; }
    .section h2 { font-size: 1.8rem; margin-bottom: 40px; }
    .air-btn {
        align-self: center; /* центрируем по вертикали в строке */
        margin-right: 12px; /* отступ справа от слайдера */
        min-width: 80px;    /* чтобы кнопка не сжималась слишком сильно */
        text-align: center;
    }

    #volumeSlider {
        width: 120px;       /* чуть шире, чтобы удобно было двигать пальцем */
        margin-left: 0;     /* убираем старый margin-left */
        align-self: center;
    }

    /* Оборачиваем Play и Volume в одну строку */
    .bar > .air-btn,
    .bar > #volumeSlider {
        order: 2;           /* ставим их сразу после logo, перед nav */
        align-self: center;
    }

    /* Новый flex-контейнер для кнопки и слайдера */
    .bar {
        flex-direction: column;
        align-items: stretch;
        gap: 16px;
    }

    /* Добавляем отдельный ряд для плеера */
    .player-controls {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 12px;
        order: 2;
        width: 100%;
    }
    nav {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        background: rgba(255, 255, 255, 0.9); /* или твой фон */
        backdrop-filter: blur(10px);
        padding: 12px 0;
        justify-content: center;
        flex-wrap: wrap;
        gap: 12px;
        transform: translateY(100%); /* изначально скрыта снизу */
        transition: transform 0.3s ease-in-out;
        z-index: 99;
        border-top: 1px solid rgba(0,0,0,0.1);
        box-shadow: 0 -4px 10px rgba(0,0,0,0.05);
    }

    /* Когда добавляем класс .show — навигация видна */
    nav.show {
        transform: translateY(0);
    }

    /* Добавляем отступ снизу для контента, чтобы нав не перекрывал */
    body {
        padding-bottom: 80px; /* высота нав ≈ 60-70px + запас */
    }

    /* Опционально: делаем ссылки покомпактнее на мобиле */
    .nav-link {
        font-size: 0.9rem;
        padding: 8px 12px;
    }
}


@media (max-width: 480px) {
    .brand-title { font-size: 1.1rem; }
    .brand-sub { font-size: 0.8rem; }
    .pill-row { flex-direction: column; align-items: center; }
    .pill { width: 80%; text-align: center; }
  }
  /* Остальные стили (социалки, формы и т.д.) */
  .socials { display: flex; flex-wrap: wrap; gap: 20px; justify-content: center; }
  .social {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 20px;
    background: rgba(255,255,255,0.5);
    border-radius: 16px;
  }
  .form { display: grid; gap: 16px; }
  .input, .textarea {
    padding: 12px;
    border: 1px solid #e6d6f0;
    border-radius: 12px;
    font: inherit;
  }
  .textarea { min-height: 100px; resize: vertical; }
  .mini { padding: 10px 16px; background: var(--pink); color: white; border: none; border-radius: 12px; cursor: pointer; }
  .footer {
    text-align: center;
    padding: 40px 20px;
    font-size: 0.9rem;
    opacity: 0.8;
  }
  .toggle-wrap {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 100;
  }
  .toggle { transform: scale(1.4); }
