/* Google Fonts - Quicksand (игривый) и Nunito (читаемый) */
@import url('https://fonts.googleapis.com/css2?family=Quicksand:wght@400;500;600;700&family=Nunito:wght@400;600;700;800&display=swap');

:root{
  --bg1:#ffe6f3;
  --bg2:#e9dcff;
  --ink:#5a3f6b;
  --ink-soft:#7d5e92;
  --card:#ffffff;
  --grad: linear-gradient(135deg, #ffd8ef 0%, #e6ddff 100%);
  --grad-strong: linear-gradient(135deg, #f7c6e7 0%, #c9b6ff 100%);
  --shadow: 0 10px 30px rgba(138, 84, 166, .18);
  --radius: 18px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: ui-rounded, system-ui, -apple-system, Segoe UI, Roboto, "SF Pro", Arial, sans-serif;
  color: var(--ink);
  background: radial-gradient(circle at 10% 0%, var(--bg1), transparent 40%), 
              radial-gradient(circle at 90% 10%, var(--bg2), transparent 40%), #fff;
  min-height:100vh;
}
a{color:inherit;text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:24px}
.header{
  display:flex;align-items:center;gap:16px;justify-content:space-between;
  padding:10px 20px; position:sticky; top:0; z-index:30; backdrop-filter:saturate(1.2) blur(6px);
  background:rgba(255,255,255,.6); border-bottom:1px solid rgba(124,94,166,.12);
}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:36px}
.brand strong{font-size:0.95rem}
.nav{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.nav a{padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.7);transition:.3s;font-size:0.85rem;white-space:nowrap}
.nav a:hover{background:var(--grad-strong); color:white; box-shadow: var(--shadow)}
.nav a.btn{padding:8px 14px;font-size:0.85rem;font-weight:600}
.hero{
  display:grid;grid-template-columns: 1.2fr 1fr; gap:24px; align-items:center; padding:40px 24px;
}
.card{
  background:var(--card); border-radius:var(--radius); box-shadow:var(--shadow);
  padding:24px;
}
.btn{
  display:inline-block; padding:12px 18px; border-radius:14px; background:var(--grad);
  transition:.25s; font-weight:600;
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.grid{display:grid;grid-template-columns:repeat(3,1fr); gap:18px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr); gap:18px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr); gap:18px}
/* Десктоп - идеальные квадраты для ваших фото */
.program-card-image{width:100%;overflow:hidden;border-radius:14px;background:var(--card)}
.program-card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:14px;display:block}
.program-card h3{margin:12px 0 6px 0}
/* Стили для карточек аниматоров - используют те же обёртки */
.card .program-card-image{width:100%;overflow:hidden;border-radius:14px;background:var(--card)}
.card .program-card-image img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:14px;display:block}
.card .program-card-image .no-image{display:flex;align-items:center;justify-content:center;aspect-ratio:1;color:var(--ink-soft);font-size:0.9em;background:var(--card)}
.price{font-weight:700}
.footer{padding:30px 24px; text-align:center; color:var(--ink-soft)}
h1{font-size:clamp(28px,3vw,40px); margin:8px 0 4px}
h2{font-size:clamp(22px,2.2vw,28px); margin:0 0 10px}
.muted{color:var(--ink-soft)}
.quick{display:flex;align-items:center; gap:16px}

.hero-badge{display:inline-block;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.8); margin-bottom:10px}

.wheel-wrap{position:relative; height:380px}
.wheel{position:absolute; inset:0; display:grid; place-items:center; touch-action:pan-y; user-select:none}
.wheel-track{position:relative; width:280px; height:280px; border-radius:999px; }
.wheel-item{position:absolute; width:110px; height:110px; border-radius:50%; overflow:hidden; box-shadow:var(--shadow)}
.wheel-item img{width:100%; height:100%; object-fit:cover; display:block}
.wheel-center{position:absolute; width:140px; height:140px; border-radius:50%; background:var(--grad-strong); box-shadow:var(--shadow);
  display:grid; place-items:center; color:#fff; font-weight:700}

/* Адаптивные стили для колеса на мобильных устройствах */
@media (max-width: 560px){
  .wheel-wrap{height:320px}
  .wheel-track{width:240px; height:240px}
  .wheel-item{width:90px; height:90px}
  .wheel-center{width:110px; height:110px; font-size:0.9rem}
}

.review{background:var(--card); padding:16px; border-radius:16px; box-shadow:var(--shadow)}

.fab-call{
  position:fixed; right:18px; bottom:18px; z-index:50;
  display:none; align-items:center; gap:8px; padding:12px 16px; border-radius:999px; background:var(--grad-strong);
  color:#fff; box-shadow:var(--shadow);
}
.fab-call.show{display:flex}
.fab-call svg{width:18px;height:18px}

img[loading=lazy]{filter:saturate(1.05) contrast(1.02)}
figure{margin:0}
.gallery{columns: 3 260px; column-gap: 16px}
.gallery figure{break-inside: avoid; margin:0 0 16px 0; background:var(--card); border-radius:16px; overflow:hidden; box-shadow:var(--shadow)}
.gallery img{width:100%; height:auto; display:block}
.gallery figcaption{padding:10px 12px}

@media (max-width: 900px){
  .hero{grid-template-columns: 1fr}
  .grid{grid-template-columns:1fr 1fr}
  .grid-4{grid-template-columns:1fr 1fr}
  /* Планшеты - квадратные как на десктопе */
  .program-card-image{aspect-ratio:1;background:var(--card)}
  .program-card img{aspect-ratio:1;object-fit:cover}
}
@media (max-width: 560px){
  .grid, .grid-4, .grid-2{grid-template-columns:1fr}
  /* Мобильные - квадратные как на десктопе */
  .program-card-image{aspect-ratio:1;background:var(--card)}
  .program-card img{aspect-ratio:1;object-fit:cover}
}


/* === PATCH: Mobile nav === */
.menu-toggle{display:none}
@media (max-width: 900px){
  .header{padding:10px 16px;gap:12px}
  .brand img{height:32px}
  .brand strong{font-size:0.9rem}
  .nav{gap:6px}
  .nav a{padding:5px 9px;font-size:0.8rem}
  .nav a.btn{padding:7px 12px;font-size:0.8rem}
}

@media (max-width: 760px){
  .header{
    gap:10px;
    padding:10px 12px;
  }
  
  .brand{
    gap:8px;
    flex-shrink:0;
  }
  
  .brand img{
    height:32px;
  }
  
  .brand strong{
    font-size:0.9rem;
  }
  
  /* Скрываем обычное меню на мобильных */
  .nav{
    display:none;
  }
  
  /* Показываем кнопку меню если она есть */
  .menu-toggle{
    display:inline-flex; 
    align-items:center; 
    justify-content:center;
    padding:8px 12px; 
    border-radius:999px; 
    border:0; 
    font-weight:600;
    font-size:0.9rem;
    background: var(--grad-strong); 
    color:#fff; 
    box-shadow: var(--shadow);
    flex-shrink:0;
  }
  
  /* Меню в выпадающем виде */
  .nav.open{
    display:flex;
    position:fixed;
    left:12px;
    right:12px;
    top:60px;
    flex-direction:column;
    gap:8px;
    padding:16px;
    border-radius:16px;
    background:rgba(255,255,255,.98);
    backdrop-filter: blur(12px);
    box-shadow: 0 8px 32px rgba(0,0,0,.15);
    z-index:40;
    max-height:calc(100vh - 80px);
    overflow-y:auto;
  }
  
  .nav.open a{
    padding:12px 16px;
    font-size:0.95rem;
    border-radius:12px;
    background:rgba(255,255,255,.9);
    border:1px solid rgba(0,0,0,.06);
  }
  
  .nav.open a:hover{
    background:var(--grad-strong);
    color:white;
    border-color:transparent;
  }
  
  .nav.open a.btn{
    background:var(--grad-strong);
    color:white;
    font-weight:700;
    padding:14px 18px;
  }
  
  .nav.open a.btn:hover{
    transform:translateY(-1px);
    box-shadow:0 8px 20px rgba(255,122,165,.4);
  }
}

/* wheel: статичное фото + круглая маска */
.wheel-track .wheel-item{ border-radius:50%; overflow:hidden; }
.wheel-track .wheel-item img{ width:100%; height:100%; object-fit:cover; display:block; }
/* === AP wheel UI v4 (round mask + stable inner) === */
.wheel-track .wheel-item{ border-radius:50%; overflow:hidden; }
.wheel-track .ap-inner{ width:100%; height:100%; transform-origin:50% 50%; }
.wheel-track .ap-inner img,
.wheel-track .ap-inner picture,
.wheel-track .wheel-item > img{
  width:100%; height:100%; display:block; object-fit:cover;
}

