*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#fffdf7;--card:#ffffff;--ink:#2b2440;--mut:#6f6885;--fial:#7048c8;--fial-d:#5a37a6;--roze:#e84e78;--tyrk:#12a5a0;--zlut:#f5b427;--line:#ece5f2}
html{scroll-behavior:smooth}
body{font-family:'Commissioner',sans-serif;background:var(--bg);color:var(--ink);line-height:1.7;font-size:16.5px;overflow-x:hidden}
h1,h2,h3{font-family:'Shantell Sans',cursive;font-weight:700;line-height:1.22}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}

.ribbon{background:var(--ink);color:#b3accb;font-size:13.5px;padding:9px 16px;text-align:center;position:relative;z-index:60}
.ribbon b{color:#fffdf7}
.ribbon a{display:inline-block;margin-left:12px;background:var(--roze);color:#fff;font-weight:700;padding:3px 14px;border-radius:99px;font-size:13px}
.ribbon a:hover{background:#cc3a62}

header{position:sticky;top:0;z-index:50;background:rgba(255,253,247,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:1140px;margin:0 auto;padding:0 24px}
.logo{font-family:'Shantell Sans',cursive;font-weight:800;font-size:22px;display:flex;align-items:center;gap:10px}
.logo svg{width:36px;height:36px}
.logo b{color:var(--fial)}
nav.menu{display:flex;gap:26px;align-items:center}
nav.menu a{font-size:15px;font-weight:600;color:var(--mut);transition:.15s}
nav.menu a:hover,nav.menu a.on{color:var(--fial)}
.cta-btn{background:var(--fial);color:#fff!important;padding:11px 24px;border-radius:99px;font-weight:700!important}
.cta-btn:hover{background:var(--fial-d)}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:26px;height:2.5px;border-radius:3px;background:var(--ink);margin:5px 0}

/* hero */
.hero{position:relative;overflow:hidden}
.hero .in{max-width:1140px;margin:0 auto;padding:70px 24px 66px;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.hero .kicker{display:inline-block;background:#f1ebfa;color:var(--fial-d);font-weight:700;padding:7px 16px;border-radius:99px;font-size:14px;margin-bottom:16px}
.hero h1{font-size:clamp(34px,4.8vw,54px)}
.hero h1 .c1{color:var(--roze)}
.hero h1 .c2{color:var(--tyrk)}
.hero h1 .c3{color:var(--zlut)}
.hero p{color:var(--mut);font-size:18px;margin:16px 0 28px;max-width:500px}
.btn{display:inline-block;background:var(--fial);color:#fff;padding:15px 30px;border-radius:99px;font-weight:700;font-size:16px;transition:.15s;border:0;cursor:pointer;font-family:'Commissioner',sans-serif;box-shadow:0 8px 24px rgba(112,72,200,.3)}
.btn:hover{background:var(--fial-d);transform:translateY(-2px)}
.btn.roze{background:var(--roze);box-shadow:0 8px 24px rgba(232,78,120,.3)}
.btn.roze:hover{background:#cc3a62}
.btn.ghost{background:#fff;color:var(--fial);border:2px solid var(--fial);box-shadow:none}
.btn.ghost:hover{background:var(--fial);color:#fff}
.hero-foto{position:relative}
.hero-foto img{width:100%;height:430px;object-fit:cover;border-radius:26px;box-shadow:0 22px 56px rgba(43,36,64,.2);transform:rotate(1.2deg)}
.hero-foto::before{content:"";position:absolute;top:-26px;left:-30px;width:90px;height:90px;background:radial-gradient(circle,var(--zlut) 30%,transparent 32%),radial-gradient(circle,transparent 60%,var(--roze) 62%,var(--roze) 70%,transparent 72%);z-index:2;opacity:.85}

section{padding:84px 0}
.shead{text-align:center;max-width:680px;margin:0 auto 48px}
.shead .eyebrow{display:inline-block;background:#f1ebfa;color:var(--fial-d);font-weight:700;padding:6px 16px;border-radius:99px;font-size:13.5px;margin-bottom:14px}
.shead h2{font-size:clamp(27px,3.8vw,40px)}
.shead h2 em{font-style:normal;color:var(--roze)}
.shead p{color:var(--mut);margin-top:12px}

/* obory */
.ob-g{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.ob{background:var(--card);border:2px solid var(--line);border-radius:22px;padding:28px 24px;text-align:center;transition:.18s;position:relative;overflow:hidden}
.ob::before{content:"";position:absolute;top:0;left:0;right:0;height:6px}
.ob.hud::before{background:var(--fial)}
.ob.vyt::before{background:var(--roze)}
.ob.tan::before{background:var(--tyrk)}
.ob.dra::before{background:var(--zlut)}
.ob:hover{transform:translateY(-5px) rotate(-.6deg);box-shadow:0 18px 44px rgba(43,36,64,.13)}
.ob .ico{width:58px;height:58px;margin:0 auto 14px;border-radius:18px;display:flex;align-items:center;justify-content:center}
.ob.hud .ico{background:#f1ebfa;color:var(--fial)}
.ob.vyt .ico{background:#fdecf1;color:var(--roze)}
.ob.tan .ico{background:#e7f6f5;color:var(--tyrk)}
.ob.dra .ico{background:#fdf3dd;color:#c28d13}
.ob .ico svg{width:28px;height:28px}
.ob h3{font-size:20px;margin-bottom:6px}
.ob p{color:var(--mut);font-size:14px}

/* gallery sticker */
.gal-g{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.gal-g img{width:100%;height:300px;object-fit:cover;border-radius:22px;border:5px solid #fff;box-shadow:0 14px 36px rgba(43,36,64,.15)}
.gal-g img:nth-child(odd){transform:rotate(-1.2deg)}
.gal-g img:nth-child(even){transform:rotate(1.1deg)}

/* rozvrh/list */
.plist{max-width:840px;margin:0 auto}
.plist .row{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:17px 6px;border-bottom:2px dashed var(--line)}
.plist h3{font-size:17.5px}
.plist p{color:var(--mut);font-size:14px;margin-top:2px}
.plist .price{font-family:'Shantell Sans',cursive;color:var(--fial);font-size:18px;white-space:nowrap;font-weight:700}

/* teachers */
.f-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.fc{background:var(--card);border:2px solid var(--line);border-radius:20px;padding:28px}
.fc h3{font-size:19px;margin-bottom:8px}
.fc p{color:var(--mut);font-size:14.5px}

/* form */
.form-g{display:grid;grid-template-columns:1fr 1fr;gap:50px}
.fg{margin-bottom:16px}
.fg label{display:block;margin-bottom:7px;font-weight:700;font-size:14.5px}
input,select,textarea{width:100%;background:#fff;border:2px solid var(--line);border-radius:14px;color:var(--ink);padding:12px 15px;font-family:inherit;font-size:15px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--fial)}
.fnote{font-size:13px;color:var(--mut);margin-top:10px}
.ok-msg{display:none;background:#f1ebfa;border:2px solid var(--fial);color:var(--fial-d);padding:16px;border-radius:14px;margin-top:14px;font-weight:700}
.k-card{background:var(--card);border:2px solid var(--line);border-radius:18px;padding:24px;margin-bottom:16px}
.k-card h3{font-size:18px;margin-bottom:6px}
.k-card p,.k-card a{color:var(--mut);font-size:15px}

.band{background:var(--fial);color:#fff;padding:70px 0;text-align:center;position:relative;overflow:hidden}
.band::before{content:"♪";position:absolute;left:8%;top:12%;font-size:70px;opacity:.15;transform:rotate(-12deg)}
.band::after{content:"♫";position:absolute;right:9%;bottom:10%;font-size:88px;opacity:.15;transform:rotate(10deg)}
.band h2{font-size:clamp(26px,4vw,42px);font-family:'Shantell Sans',cursive}
.band p{opacity:.9;margin:10px 0 24px}
.band a{background:var(--zlut);color:var(--ink);display:inline-block;padding:15px 32px;border-radius:99px;font-weight:800;position:relative;z-index:2}

footer{background:var(--ink);color:#b3accb;padding:56px 0 40px}
.f-g{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;max-width:1140px;margin:0 auto;padding:0 24px}
footer h4{font-family:'Shantell Sans',cursive;color:#fffdf7;font-size:17px;margin-bottom:12px}
footer a,footer p{color:#b3accb;font-size:14.5px;display:block;margin-bottom:8px}
footer a:hover{color:#fff}
.f-bot{max-width:1140px;margin:34px auto 0;padding:20px 24px 0;border-top:1px solid #443c5e;font-size:13px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

.phero{text-align:center;position:relative;overflow:hidden;background:linear-gradient(180deg,#f6f1fb,#fffdf7)}
.phero .in{max-width:820px;margin:0 auto;padding:64px 24px 52px}
.phero .eyebrow{display:inline-block;background:#fff;border:2px solid var(--line);color:var(--fial-d);font-weight:700;padding:6px 16px;border-radius:99px;font-size:13.5px;margin-bottom:16px}
.phero h1{font-size:clamp(30px,4.6vw,50px)}
.phero h1 em{font-style:normal;color:var(--roze)}
.phero p{color:var(--mut);margin-top:14px;font-size:17.5px}
section.hero,section.phero{padding:0}

@media(max-width:960px){
 .hero .in{grid-template-columns:1fr}
 .hero-foto img{height:330px}
 .ob-g{grid-template-columns:1fr 1fr}
 .gal-g,.form-g{grid-template-columns:1fr}
 .f-grid{grid-template-columns:1fr 1fr}
 .f-g{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
 nav.menu{position:absolute;top:100%;left:0;right:0;background:var(--bg);flex-direction:column;gap:0;padding:10px 0 20px;border-bottom:1px solid var(--line);display:none}
 nav.menu.open{display:flex}
 nav.menu a{padding:14px 24px;width:100%;font-size:16px}
 .cta-btn{margin:12px 24px 0;width:calc(100% - 48px);text-align:center}
 .burger{display:block}
 .ob-g,.f-grid,.f-g{grid-template-columns:1fr}
 section{padding:56px 0}
 .hero .in{padding:46px 20px 50px}
 .phero .in{padding:42px 20px 38px}
 .hero-foto::before{display:none}
}
