*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-body);
  min-height:100dvh;display:flex;flex-direction:column}
a{color:inherit;text-decoration:none}
/* form controls: inherit theme ink so typed text is visible on every theme */
input,textarea,select{color:var(--ink);font-family:var(--font-body)}
input::placeholder,textarea::placeholder{color:var(--dim)}
/* Единая ширина страницы: контент до 1040px + боковой отступ 20px (padding внутри
   max-width 1080). Топбар (.topbar2) подогнан к той же геометрии — всё одной ширины. */
.wrap{max-width:1080px;margin:0 auto;padding:0 20px;width:100%;flex:1 0 auto}
footer{flex-shrink:0}
.muted{color:var(--dim)}
.h1{font-family:var(--font-display);font-weight:900;font-size:var(--text-hero);margin:0}
.h2{font-family:var(--font-display);font-weight:900;font-size:var(--text-xl);margin:0}

.topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:var(--surface);border:var(--ol);box-shadow:var(--shadow);border-radius:16px;
  padding:12px 16px;margin:18px auto;max-width:1040px}
.brand{font-family:var(--font-display);font-weight:900;font-size:20px;color:var(--primary)}
.top-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.lang{display:flex;align-items:center;gap:6px;background:var(--chip-bg);border:var(--ol2);
  border-radius:12px;padding:7px 12px;font-weight:800;font-size:14px;position:relative}
.lang .menu{position:absolute;top:110%;right:0;background:var(--surface);border:var(--ol2);
  border-radius:10px;box-shadow:var(--shadow-sm);padding:6px;display:none;z-index:9;min-width:140px}
.lang:hover .menu,.lang:focus-within .menu{display:block}
.lang .menu a{display:block;padding:7px 10px;border-radius:8px;font-size:14px}
.lang .menu a:hover{background:var(--chip-bg)}

/* ============ Command bar (variant E): search + 💎 + account menu ============ */
.topbar2{display:flex;align-items:center;gap:14px;width:calc(100% - 40px);max-width:1040px;margin:18px auto;
  background:var(--surface);border:var(--ol);box-shadow:var(--shadow);border-radius:16px;padding:12px 16px}
.brand2{font-family:var(--font-display);font-weight:900;font-size:20px;color:var(--primary);
  display:flex;align-items:center;gap:8px;white-space:nowrap}
.topsearch{flex:1;max-width:440px;margin:0 auto;display:flex;align-items:center;gap:10px;
  background:var(--surface-2);border:var(--ol2);border-radius:14px;padding:0 14px}
.topsearch .ts-ic{font-size:15px;opacity:.8}
.topsearch input{flex:1;background:transparent;border:none;outline:none;color:var(--ink);
  font-family:var(--font-body);font-weight:700;font-size:14px;padding:11px 0;min-width:0}
.topsearch input::placeholder{color:var(--dim)}
.topright{display:flex;align-items:center;gap:12px;position:relative}

.gem{display:inline-flex;align-items:center;gap:6px;font-weight:900;font-size:15px;color:#0c1330;
  background:linear-gradient(135deg,#FFE08A,#FBBF24);border-radius:999px;padding:7px 13px;
  box-shadow:0 4px 12px rgba(251,191,36,.35);white-space:nowrap}
.avatar2{width:42px;height:42px;border-radius:50%;background:var(--grad);display:grid;place-items:center;
  font-family:var(--font-display);font-size:19px;font-weight:900;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);
  border:2px solid rgba(255,255,255,.25);cursor:pointer}
.avatar2.sm{width:36px;height:36px;font-size:16px}
.iconbtn{width:46px;height:46px;border-radius:12px;background:var(--chip-bg);border:var(--ol2);
  display:grid;place-items:center;font-size:18px;cursor:pointer}

/* account/settings menu via <details> */
.acctmenu{position:relative}
.acctmenu>summary{list-style:none}
.acctmenu>summary::-webkit-details-marker{display:none}
.acctmenu>summary::marker{content:""}
.acct-scrim{display:none}
.acctpanel{position:absolute;top:calc(100% + 14px);right:-8px;width:262px;z-index:50;
  background:var(--surface);border:var(--ol2);border-radius:16px;box-shadow:var(--shadow);padding:10px}
/* кнопка-таблетка в топбаре: аватар + ник (на мобиле остаётся только аватар) */
.userpill{display:flex;align-items:center;gap:9px;background:var(--chip-bg);border:var(--ol2);
  border-radius:999px;padding:4px 14px 4px 4px;cursor:pointer;list-style:none}
.userpill::-webkit-details-marker{display:none}
.userpill::marker{content:""}
.userpill .upnick{font-family:var(--font-display);font-weight:800;font-size:14.5px;color:var(--ink);
  max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acct-name{font-family:var(--font-display);font-weight:800}
.acct-item{display:flex;align-items:center;gap:11px;padding:12px 10px;border-radius:10px;
  font-weight:800;font-size:14px;color:var(--ink)}
.acct-item:hover{background:var(--chip-bg)}
.acct-sect{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--dim);
  font-weight:800;margin:12px 10px 4px}
.acct-div{border:none;border-top:2px solid rgba(127,127,150,.28);margin:9px 4px}
.acct-row{display:flex;gap:6px;padding:0 8px 2px}
.acct-row.langs a{display:grid;place-items:center;min-width:40px;height:40px;
  border-radius:10px;font-size:13px;font-weight:900;color:var(--ink);
  background:var(--chip-bg);border:var(--ol2);text-decoration:none}
.acct-row a.on{background:var(--primary);box-shadow:0 0 0 2px var(--primary)}

/* responsive visibility helpers (desktop bar vs mobile burger) */
.m-only{display:none}

@media (max-width:640px){
  .topbar2{flex-wrap:wrap}
  .brand2{order:1}
  .topright{order:2;margin-left:auto}
  .topsearch{order:3;flex-basis:100%;max-width:100%;margin:0}
  .d-only{display:none!important}
  .m-only{display:inline-flex}
  .userpill{padding:4px}
  .acct-item.m-only{display:flex}
  /* dropdown becomes a bottom sheet */
  .acctmenu[open] .acct-scrim{display:block;position:fixed;inset:0;background:rgba(5,6,15,.55);z-index:60}
  .acctmenu[open] .acctpanel{position:fixed;left:0;right:0;bottom:0;top:auto;width:auto;z-index:61;
    border-radius:18px 18px 0 0;padding:14px 14px 22px}
  .acct-item{padding:14px 10px;font-size:15px}
  .acct-row.langs a{min-width:46px;height:46px;font-size:15px}
}

/* a11y: large tap targets + visible keyboard focus */

.btn{font-family:var(--font-display);font-weight:900;font-size:15px;cursor:pointer;color:var(--btn-text);
  background:var(--grad);border:var(--ol);border-radius:var(--btn-radius);padding:12px 18px;box-shadow:var(--btn-shadow)}
.btn-lg{font-size:17px;padding:15px 24px}
.btn-ghost{background:var(--chip-bg);color:var(--ink);box-shadow:none;border:var(--ol2)}
.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}

.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:16px;margin-top:16px}
.tile{background:var(--surface);border:var(--ol);box-shadow:var(--shadow-sm);border-radius:14px;overflow:hidden;position:relative}
.tile .cov{height:104px;display:flex;align-items:center;justify-content:center;font-size:52px;background:var(--grad)}
.tile .cap{padding:9px 11px;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tile .meta{padding:0 11px 10px;display:flex;gap:10px;color:var(--dim);font-weight:800;font-size:13px}
/* подвал карточки каталога: автор слева, счётчики справа (вариант A) */
.tile .tfoot{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 11px 11px}
.tile .tauth{display:flex;align-items:center;gap:6px;min-width:0;font-weight:800;font-size:12px;color:var(--dim)}
.tile .tav{width:22px;height:22px;border-radius:50%;background:var(--grad);display:grid;place-items:center;font-size:12px;flex:none}
.tile .tnm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tile .tcnt{color:var(--dim);font-weight:800;font-size:12.5px;white-space:nowrap}

/* витрина: секции Моё/Новые/Популярные/Друзья — сетки до ~3 рядов */
.shelf-h{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:900;
  font-size:21px;margin:24px 0 2px}
.shelf-h .all{margin-left:auto;font-size:13px;color:var(--primary);font-weight:800;white-space:nowrap}
.shelf-it{position:relative}
.shelf-it .tile{display:block;height:100%}
.tedit{position:absolute;top:8px;right:8px;background:var(--surface);border-radius:10px;
  padding:3px 8px;font-size:13px;box-shadow:var(--shadow-sm);z-index:2}
/* "create game" tile — first card in the catalog (variant E) */
.tile.add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  min-height:160px;background:var(--surface-2);border:var(--ol2);border-style:dashed;
  color:var(--primary);font-family:var(--font-display);font-weight:900;font-size:15px;text-align:center;padding:12px}
.tile.add .plus{font-size:40px;line-height:1}
.tile.add:hover{background:var(--chip-bg)}

.chip{display:inline-flex;align-items:center;gap:6px;font-weight:900;font-size:14px;background:var(--chip-bg);border:var(--ol2);border-radius:12px;padding:7px 12px}
.panel{background:var(--surface);border:var(--ol);box-shadow:var(--shadow);border-radius:16px;padding:20px}

/* password field with show/hide (eye) toggle — works in all themes */
.pwd{position:relative;display:block;margin:6px 0 14px}
.pwd .chip{display:block;width:100%;margin:0;padding-right:48px}
.pwd .eye{position:absolute;top:0;right:0;height:100%;width:46px;display:grid;place-items:center;
  background:transparent;border:none;cursor:pointer;font-size:19px;line-height:1;color:var(--ink);opacity:.75}
.pwd .eye:hover{opacity:1}
/* segmented PIN boxes (variant C): 4–6 digits, last two optional.
   inset box-shadow as the border. */
.boxset{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:6px 0 16px}
.boxset .box{width:46px;height:58px;border:none;border-radius:14px;background:var(--surface-2);
  color:var(--ink);font-family:var(--font-display);font-weight:900;font-size:24px;text-align:center;
  caret-color:var(--primary);box-shadow:inset 0 0 0 2px rgba(127,127,150,.35)}
.boxset .box:focus{outline:none;box-shadow:inset 0 0 0 2px var(--primary),0 0 0 3px rgba(124,92,252,.3)}
.boxset .box.filled{box-shadow:inset 0 0 0 2px var(--primary)}
.boxset .box.opt{opacity:.6;box-shadow:inset 0 0 0 2px rgba(127,127,150,.35) , 0 0 0 0 transparent}
.boxset .box.opt::placeholder{color:transparent}
/* centered submit button (registration) */
.btn-center{display:block;width:fit-content;margin:2px auto 0}

/* avatar picker (kids signup: avatar + PIN) */
.avpick{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin:6px 0 16px}
.avopt{cursor:pointer}
.avopt input{position:absolute;opacity:0;width:0;height:0}
.avopt span{display:grid;place-items:center;aspect-ratio:1/1;font-size:26px;
  background:var(--chip-bg);border:var(--ol2);border-radius:50%}
.avopt input:checked+span{outline:3px solid var(--accent);outline-offset:2px;background:var(--grad)}
.avopt input:focus-visible+span{outline:3px solid var(--accent);outline-offset:2px}
.tabs{display:flex;gap:10px;margin:14px 0}
.tab{padding:9px 16px;border:var(--ol2);border-radius:999px;font-weight:900;background:var(--surface)}
.tab.on{background:var(--primary);color:#fff}
.empty{text-align:center;padding:48px 20px;color:var(--dim);font-weight:800}
.mascot{display:flex;gap:12px;align-items:flex-start}
.mascot .face{width:50px;height:50px;border-radius:14px;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:26px;border:var(--ol)}
.bubble{background:var(--surface);border:var(--ol);box-shadow:var(--shadow-sm);border-radius:14px;padding:12px 16px}

/* ===== game create/edit form: visual pickers, toggle, AI chat ===== */
.gf-step{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:900;font-size:19px;margin:22px 0 12px}
.gf-step .gf-n,.gf-card-h .gf-n{width:30px;height:30px;border-radius:9px;background:var(--grad);color:#fff;border:var(--ol2);
  display:grid;place-items:center;font-size:14px;flex:none}
/* Шаги формы как отдельные карточки (вариант A). Отрицательные боковые margin
   компенсируют боковой padding .wrap (20px) — край карточек совпадает с верхним
   меню (.topbar2 — потомок body на 1040px). Доходит ровно до края .wrap, без скролла. */
.gf-card{background:var(--surface);border:var(--ol);box-shadow:var(--shadow-sm);border-radius:16px;padding:18px 20px;margin:0 0 16px}
.gf-card-h{display:flex;align-items:center;gap:10px;margin-bottom:14px;font-family:var(--font-display);font-weight:900;font-size:19px}
.gf-grid{display:flex;gap:24px;flex-wrap:wrap;align-items:flex-start}
.gf-fields{flex:1;min-width:280px}
.gf-row2{display:flex;gap:24px;flex-wrap:wrap;margin-top:14px}
.gf-preview{text-align:center}
.gf-cover{width:120px;height:120px;border-radius:16px;border:var(--ol);box-shadow:var(--shadow-sm);
  display:grid;place-items:center;font-size:56px}
.gf-cap{font-family:var(--font-display);font-weight:900;margin-top:8px;max-width:140px;
  line-height:1.2;word-break:break-word;overflow:hidden;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}

/* AI loading overlay */
.ai-overlay{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;
  background:color-mix(in oklab, var(--bg) 70%, transparent);backdrop-filter:blur(8px)}
.ai-overlay[hidden]{display:none}
.ai-box{text-align:center;background:var(--surface);border:var(--ol);box-shadow:var(--shadow);
  border-radius:20px;padding:30px 36px;max-width:320px;margin:16px}
.ai-orbit{height:50px;display:flex;gap:10px;justify-content:center;align-items:center;font-size:38px}
.ai-orbit span{display:inline-block;animation:ai-bounce 1s ease-in-out infinite}
.ai-orbit span:nth-child(2){animation-delay:.15s}
.ai-orbit span:nth-child(3){animation-delay:.3s}
@keyframes ai-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.ai-text{font-family:var(--font-display);font-weight:900;font-size:19px;margin-top:8px}
.ai-dots{display:flex;gap:7px;justify-content:center;margin:12px 0 8px}
.ai-dots i{width:9px;height:9px;border-radius:50%;background:var(--primary);opacity:.4;
  animation:ai-dot 1.2s ease-in-out infinite}
.ai-dots i:nth-child(2){animation-delay:.2s}
.ai-dots i:nth-child(3){animation-delay:.4s}
@keyframes ai-dot{0%,100%{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1.2)}}
.ai-hint{color:var(--dim);font-size:13px}

/* "Game ready" celebration banner */
.celebrate{text-align:center}
.celebrate .cel-emoji{font-size:46px;line-height:1;animation:ai-bounce 1.4s ease-in-out infinite}
.celebrate h2{font-family:var(--font-display);font-weight:900;font-size:21px;margin:8px 0 4px}
.celebrate p{color:var(--dim);margin:0 auto 14px;max-width:440px}
@media (prefers-reduced-motion: reduce){
  .ai-orbit span,.ai-dots i,.celebrate .cel-emoji{animation:none}
}

/* Share button: icon-only on mobile so it doesn't wrap to a second line */
@media (max-width:560px){
  #shareBtn{padding-left:14px;padding-right:14px}
  #shareBtn .btn-txt{display:none}
}

/* Reward pill inside the share modal */
.modal-reward{display:inline-block;font-weight:900;font-size:15px;color:var(--ink);
  background:color-mix(in oklab, var(--accent) 18%, var(--surface));
  border:1px solid color-mix(in oklab, var(--accent) 45%, transparent);
  border-radius:999px;padding:6px 14px;margin:0 0 14px}

/* Game tile status badge — small, with subtle border */
.tile-badge{position:absolute;top:8px;left:8px;font-size:10px;font-weight:800;line-height:1.5;
  padding:2px 8px;border-radius:999px;color:var(--ink);
  background:color-mix(in oklab, var(--surface) 86%, transparent);
  border:1px solid rgba(127,127,150,.38);box-shadow:none}

/* Generic modal (share-my-page) */
.modal{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;padding:16px;
  background:color-mix(in oklab, var(--bg) 64%, transparent);backdrop-filter:blur(8px)}
.modal[hidden]{display:none}
.modal-card{position:relative;background:var(--surface);border:var(--ol);box-shadow:var(--shadow);
  border-radius:20px;padding:26px 28px;max-width:340px;width:100%;text-align:center}
.modal-x{position:absolute;top:12px;right:14px;border:none;background:transparent;cursor:pointer;
  font-size:18px;font-weight:900;color:var(--dim);line-height:1}
.modal-x:hover{color:var(--ink)}
.modal-h{font-family:var(--font-display);font-weight:900;font-size:19px;margin:0 0 16px}
.modal-qr{width:170px;height:170px;margin:0 auto 14px;background:#fff;border:var(--ol2);
  border-radius:14px;padding:10px;box-shadow:var(--shadow-sm)}
.modal-qr svg{width:100%;height:100%;display:block}
.modal-card .btn{width:100%;justify-content:center}
.lbl{display:block;font-weight:800;margin:0 0 6px}
.inp,.ta{width:100%;background:var(--surface-2);border:var(--ol2);color:var(--ink);border-radius:12px;
  padding:11px 14px;font-family:var(--font-body);font-weight:700;font-size:15px}
.ta{min-height:80px;resize:vertical}
/* cover: category tabs (text labels) + emoji grid of the active group */
.gf-cats{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.gf-cat{font-family:var(--font-display);font-weight:900;font-size:14px;padding:8px 16px;
  border:var(--ol2);border-radius:999px;background:var(--surface);color:var(--ink);cursor:pointer}
.gf-cat.on{background:var(--primary);color:#fff}
.gf-emoji{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:8px}
.gf-emoji[hidden]{display:none}
.gf-em{aspect-ratio:1/1;font-size:26px;background:var(--surface-2);border:var(--ol2);border-radius:12px;cursor:pointer;display:grid;place-items:center}
.gf-em.on{background:var(--grad);outline:3px solid var(--accent);outline-offset:1px}
.gf-swatches{display:flex;gap:10px;flex-wrap:wrap}
.gf-sw{width:40px;height:40px;border-radius:50%;border:var(--ol2);cursor:pointer;padding:0}
.gf-sw.on{outline:3px solid var(--ink);outline-offset:2px}
.gf-seg{display:inline-flex;border:var(--ol2);border-radius:999px;overflow:hidden;background:var(--surface-2)}
.gf-seg button{border:none;background:transparent;font-family:var(--font-display);font-weight:900;font-size:14px;padding:10px 16px;cursor:pointer;color:var(--ink)}
.gf-seg button.on{background:var(--grad);color:#fff}
.gf-cost{font-size:12px;opacity:.85}
.gf-sm{padding:8px 12px!important;font-size:13px!important;min-height:auto!important}
.gf-code{margin-top:14px;border:var(--ol2);border-radius:12px;background:var(--surface-2);padding:0 14px}
.gf-code>summary{cursor:pointer;font-weight:900;padding:12px 0;list-style:none}
.gf-code>summary::-webkit-details-marker{display:none}
.gf-prompt{white-space:pre-wrap;background:#1E2A52;color:#D5E2FF;border-radius:10px;padding:12px;font-size:12px}
.gf-chatwrap{display:grid;grid-template-columns:1.3fr .9fr;gap:16px;margin-top:12px}
.gf-thread{display:flex;flex-direction:column;gap:10px;max-height:340px;overflow:auto;padding-right:4px}
.gf-msg{max-width:88%;padding:10px 13px;border-radius:14px;font-weight:700;font-size:14px;border:var(--ol2)}
.gf-msg.kid{align-self:flex-end;background:var(--grad);color:#fff}
.gf-msg.ai{align-self:flex-start;background:var(--surface-2)}
.gf-vchip{display:inline-block;margin-left:6px;font-size:12px;font-weight:900;background:var(--surface);color:var(--ink);border:var(--ol2);border-radius:999px;padding:1px 8px}
.gf-composer{display:flex;gap:8px;margin-top:12px}
.gf-composer .inp{flex:1}
.gf-side .lbl{margin-top:0}
.gf-vers{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow:auto}
.gf-ver{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:var(--ol2);border-radius:12px;padding:8px 10px;font-weight:800;font-size:13px}
.gf-vbtn{border:var(--ol2);background:var(--surface);border-radius:8px;padding:3px 8px;font-weight:900;cursor:pointer;font-size:13px}
@media(max-width:680px){.gf-chatwrap{grid-template-columns:1fr}}
@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}

/* a11y: large tap targets + visible keyboard focus */
.btn, .tab, .pill, .chip, .lang { min-height: 44px }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible {
  outline: 3px solid var(--accent); outline-offset: 2px
}
