:root{
  --bg1:#667eea;
  --bg2:#764ba2;
  --bg3:#8b5cf6;
  --card:#ffffff;
  --soft:#f4f6fb;
  --text:#111827;
  --muted:#667085;
  --line:rgba(17,24,39,.10);
  --primary:#6544e9;
  --primary2:#8b35f6;
  --good:#12b76a;
  --bad:#f04438;
  --warn:#f59e0b;
  --shadow:0 14px 34px rgba(39,25,93,.18);
  --radius:22px;
}
*{box-sizing:border-box}
html{min-height:100%;background:linear-gradient(135deg,var(--bg1),var(--bg2));scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Arial,sans-serif;
  background:
    radial-gradient(circle at 20% 0%, rgba(255,255,255,.28) 0 0, transparent 34%),
    radial-gradient(circle at 95% 90%, rgba(255,255,255,.22) 0 0, transparent 28%),
    linear-gradient(135deg,var(--bg1),var(--bg2));
  color:var(--text);
  overflow-x:hidden;
}
body.dark{
  --bg1:#11143a;
  --bg2:#24144b;
  --bg3:#3b1971;
  --card:#151827;
  --soft:#202437;
  --text:#f7f9fc;
  --muted:#a8b1c2;
  --line:rgba(255,255,255,.10);
  --shadow:0 16px 38px rgba(0,0,0,.28);
}
.bg-orb{position:fixed;border-radius:50%;filter:blur(18px);opacity:.16;pointer-events:none;z-index:0}
.orb-1{width:250px;height:250px;background:#fff;left:-110px;top:-90px}
.orb-2{width:390px;height:390px;background:#f1ddff;right:-160px;bottom:-180px}
body.dark .orb-1{background:#7c3aed;opacity:.12}
body.dark .orb-2{background:#22c55e;opacity:.08}
#app{position:relative;z-index:1;width:min(980px,94vw);margin:0 auto;padding:18px 0 34px}

.header{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px;color:#fff}
.brand{display:flex;gap:12px;align-items:center;min-width:0;cursor:pointer;color:#fff}
.logo{width:46px;height:46px;border-radius:16px;background:rgba(255,255,255,.20);display:flex;align-items:center;justify-content:center;font-size:23px;box-shadow:0 12px 26px rgba(0,0,0,.13);border:1px solid rgba(255,255,255,.30);backdrop-filter:blur(12px)}
.brand h1{font-size:clamp(22px,4vw,31px);line-height:1.05;margin:0;letter-spacing:-.7px;color:#fff}
.brand p{margin:4px 0 0;font-size:13px;color:rgba(255,255,255,.82);font-weight:750}
.header-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
button,input,select{font-family:inherit}.pill-btn,.btn{appearance:none;border:0;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:38px;padding:9px 13px;border-radius:999px;font-weight:850;font-size:13px;transition:.16s ease;white-space:nowrap}
.pill-btn{color:#fff;background:rgba(255,255,255,.17);border:1px solid rgba(255,255,255,.28);box-shadow:0 8px 18px rgba(0,0,0,.07);backdrop-filter:blur(10px)}
.pill-btn:hover,.btn:hover,.menu-card:hover{transform:translateY(-1px)}
.lang-switch{display:flex;align-items:center;gap:3px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28);border-radius:999px;padding:3px;backdrop-filter:blur(10px)}
.lang-switch button{border:0;background:transparent;color:rgba(255,255,255,.84);font-weight:900;border-radius:999px;padding:7px 11px;min-height:30px;cursor:pointer}.lang-switch button.active{background:#fff;color:var(--primary)}
.btn{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;box-shadow:0 10px 20px rgba(74,44,204,.20)}.btn.secondary{background:var(--soft);color:var(--text);border:1px solid var(--line);box-shadow:none}.btn.good{background:var(--good)}.btn.bad{background:var(--bad)}.btn.small{min-height:32px;padding:7px 10px;font-size:12px}.btn.full{width:100%}

.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(16px,3vw,24px);border:1px solid rgba(255,255,255,.18);animation:fade .22s ease;color:var(--text)}
.card h2{color:var(--text);margin-top:0;letter-spacing:-.45px}.mini{font-size:13px;color:var(--muted);font-weight:750;line-height:1.45}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:0 0 12px}.stat{background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.26);border-radius:18px;padding:11px;text-align:center;box-shadow:0 10px 22px rgba(0,0,0,.08);backdrop-filter:blur(12px)}.stat b{display:block;font-size:25px;line-height:1}.stat span{font-size:12px;font-weight:800;color:rgba(255,255,255,.82)}

.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.menu-card{min-height:106px;text-align:left;background:rgba(255,255,255,.96);color:var(--text);border:1px solid rgba(255,255,255,.45);border-radius:20px;padding:14px;cursor:pointer;transition:.16s ease;box-shadow:0 12px 28px rgba(31,22,85,.14);position:relative;overflow:hidden}.menu-card:before{content:"";position:absolute;right:-26px;top:-26px;width:82px;height:82px;border-radius:50%;background:linear-gradient(135deg,rgba(101,68,233,.12),rgba(139,53,246,.05))}.menu-icon{font-size:23px;margin-bottom:7px;position:relative}.menu-card h3{margin:0 0 4px;font-size:16px;line-height:1.15;color:var(--text);letter-spacing:-.35px;position:relative}.menu-card p{margin:0;color:var(--muted);font-size:12px;line-height:1.25;font-weight:700;position:relative}
body.dark .menu-card{background:var(--card);border-color:var(--line)}

.toolbar{position:sticky;top:6px;z-index:10;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:8px;background:rgba(255,255,255,.18);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.26);padding:8px;border-radius:20px;margin-bottom:12px}body.dark .toolbar{background:rgba(15,18,31,.76)}.search,.select{width:100%;border:0;outline:0;border-radius:14px;background:var(--card);color:var(--text);padding:11px 13px;font-weight:780;border:1px solid var(--line)}
.recipe-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;align-items:start}.recipe{background:var(--card);border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow);color:var(--text)}.recipe.open{grid-column:1/-1}.recipe-head{padding:15px;display:flex;justify-content:space-between;gap:10px;align-items:flex-start;cursor:pointer}.recipe-title{min-width:0}.recipe h3{margin:0 0 5px;font-size:19px;color:var(--text);letter-spacing:-.35px}.recipe small{color:var(--muted);font-weight:750}.recipe-body{display:none;padding:0 15px 15px}.recipe.open .recipe-body{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.9fr);gap:10px 14px;align-items:start}.recipe.open .rule,.recipe.open .note-box{grid-column:1/-1}.recipe.open .size-table,.recipe.open .steps{margin:0}.star{width:40px;height:40px;border-radius:14px;border:1px solid var(--line);background:var(--soft);font-size:20px;cursor:pointer;flex:0 0 auto;color:var(--text)}.star.on{background:#fff7cd;color:#a15c00;border-color:#ffe08a}body.dark .star.on{background:#3a2d08;color:#ffd56a;border-color:#765b13}
.badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.badge{font-size:11px;font-weight:850;padding:5px 8px;border-radius:999px;background:#eef2ff;color:#4338ca}.badge.warn{background:#fff7ed;color:#b45309}.badge.green{background:#dcfce7;color:#15803d}.badge.gray{background:var(--soft);color:var(--muted)}body.dark .badge{background:#252449;color:#c7d2fe}body.dark .badge.green{background:#123a2a;color:#8df3bd}body.dark .badge.warn{background:#3a2914;color:#fbbf24}
.rule,.volume-line{padding:11px 12px;border-radius:15px;background:var(--soft);border:1px solid var(--line);font-weight:750;color:var(--text)}.rules{display:grid;gap:9px;margin:12px 0}.size-table{width:100%;border-collapse:separate;border-spacing:0;margin:10px 0;border:1px solid var(--line);border-radius:16px;overflow:hidden;font-size:13px}.size-table th,.size-table td{padding:9px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);vertical-align:top;color:var(--text)}.size-table tr:last-child td{border-bottom:0}.size-table th:last-child,.size-table td:last-child{border-right:0}.size-table th{background:var(--soft);text-align:left;font-weight:900}.size-table td{font-weight:650}.steps{margin:10px 0 0;padding-left:22px}.steps li{margin:7px 0;line-height:1.4;color:var(--text)}.note-box{margin-top:10px;padding:11px 12px;border-radius:15px;background:#fff7ed;color:#92400e;font-size:13px;font-weight:750;border:1px solid rgba(245,158,11,.25)}body.dark .note-box{background:rgba(245,158,11,.12);color:#fbbf24}
.quiz-card{max-width:660px;margin:0 auto}.mode-row{display:grid;grid-template-columns:repeat(2,1fr);gap:9px;margin-top:14px}.mode-row .btn{min-height:42px;border-radius:16px}.qtop{display:flex;justify-content:space-between;gap:10px;color:var(--muted);font-size:13px;font-weight:850;margin-bottom:8px}.progress{height:8px;background:var(--soft);border-radius:999px;overflow:hidden;margin:12px 0}.bar{height:100%;width:0;background:var(--primary);transition:.25s ease}.question{font-size:22px;font-weight:900;line-height:1.25;margin:14px 0;color:var(--text);letter-spacing:-.35px}.options{display:grid;gap:8px}.option{border:1px solid var(--line);background:var(--soft);color:var(--text);border-radius:15px;padding:12px 13px;font-weight:800;text-align:left;cursor:pointer;transition:.14s ease}.option:hover{transform:translateY(-1px);border-color:#c7d7fe}.option.correct{background:#dcfce7;border-color:#22c55e;color:#14532d}.option.wrong{background:#fee2e2;border-color:#ef4444;color:#7f1d1d}.option[disabled]{cursor:not-allowed;opacity:1}.explain{margin-top:10px;padding:12px;border-radius:15px;background:var(--soft);border:1px solid var(--line);font-weight:750;line-height:1.45;color:var(--text)}.next-wrap{margin-top:10px}.result{display:grid;gap:12px;text-align:center}.result h2{font-size:38px;margin:0}.kpi{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.kpi div{background:var(--soft);border-radius:15px;padding:12px}.kpi b{display:block;font-size:24px}.kpi span{font-size:12px;color:var(--muted);font-weight:800}.empty{text-align:center;color:var(--muted);font-weight:800;padding:26px 12px}.flex{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.storage-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px}.storage-table{min-width:850px;width:100%;border-collapse:collapse;font-size:13px}.storage-table th,.storage-table td{padding:10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top;color:var(--text)}.storage-table th{background:var(--soft);position:sticky;top:0}.loader-card{max-width:620px;margin:40px auto;text-align:center}.hidden{display:none!important}
@keyframes fade{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
@media(max-width:980px){.grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){#app{width:94vw}.header{align-items:flex-start;flex-direction:column}.header-actions{width:100%;display:grid;grid-template-columns:1fr auto 1fr}.pill-btn{width:100%;min-height:36px;padding:8px 9px}.lang-switch{justify-content:center}.stats{grid-template-columns:repeat(4,1fr);gap:8px}.stat{padding:9px 5px;border-radius:16px}.stat b{font-size:22px}.stat span{font-size:11px}.grid{grid-template-columns:repeat(2,1fr);gap:9px}.menu-card{min-height:82px;border-radius:17px;padding:12px}.menu-icon{font-size:21px;margin-bottom:5px}.menu-card h3{font-size:15px}.menu-card p{display:none}.toolbar{grid-template-columns:1fr}.recipe-list{grid-template-columns:1fr}.recipe.open{grid-column:auto}.recipe.open .recipe-body{display:block}.recipe.open .size-table{margin:10px 0}.recipe.open .steps{margin:10px 0 0}.brand h1{font-size:25px}.logo{width:44px;height:44px}.mode-row{grid-template-columns:1fr}.mode-row .btn{min-height:40px}.question{font-size:20px}.kpi{grid-template-columns:1fr}}
@media(max-width:380px){.menu-card{min-height:76px;padding:10px}.menu-card h3{font-size:14px}.menu-icon{font-size:19px}.stats{grid-template-columns:repeat(2,1fr)}}


/* Главная без вертикального скролла */
body.home-page{
  height:100svh;
  max-height:100svh;
  overflow:hidden;
  position:fixed;
  inset:0;
  width:100%;
  overscroll-behavior:none;
}
body.home-page #app{
  height:100svh;
  max-height:100svh;
  overflow:hidden;
  padding-top:12px;
  padding-bottom:12px;
  display:flex;
  flex-direction:column;
}
body.home-page .stats{flex:0 0 auto}
body.home-page .grid{flex:0 0 auto}
body.home-page .last-results{display:none}

@media(max-width:760px){
  body.home-page #app{padding-top:10px;padding-bottom:10px;width:94vw}
  body.home-page .header{margin-bottom:10px;gap:10px}
  body.home-page .brand{display:none}
  body.home-page .header-actions{grid-template-columns:1fr auto 1fr;gap:7px}
  body.home-page .pill-btn{min-height:34px;padding:7px 8px;font-size:12px}
  body.home-page .lang-switch button{min-height:28px;padding:6px 10px;font-size:12px}
  body.home-page .stats{gap:7px;margin-bottom:10px}
  body.home-page .stat{padding:8px 4px;border-radius:15px}
  body.home-page .stat b{font-size:21px}
  body.home-page .stat span{font-size:10px;line-height:1.1}
  body.home-page .grid{gap:8px}
  body.home-page .menu-card{min-height:74px;padding:10px 11px;border-radius:16px}
  body.home-page .menu-icon{font-size:19px;margin-bottom:4px}
  body.home-page .menu-card h3{font-size:14px;line-height:1.12}
  body.home-page .menu-card:before{width:70px;height:70px;right:-24px;top:-24px}
}
@media(max-width:380px){
  body.home-page .stats{grid-template-columns:repeat(4,1fr)}
  body.home-page .stat b{font-size:18px}
  body.home-page .stat span{font-size:9px}
  body.home-page .grid{gap:7px}
  body.home-page .menu-card{min-height:68px;padding:9px}
  body.home-page .menu-icon{font-size:18px}
  body.home-page .menu-card h3{font-size:13px}
}
