:root{
  --ink:#20123A;--ink2:#311B5E;--paper:#FFF6E9;
  --coral:#FF5E5B;--gold:#FFC845;--mint:#2BD9A8;--pink:#FF7AC6;--blue:#6C8BFF;--lilac:#C6A0FF;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;}
body{font-family:'Nunito',system-ui,sans-serif;
  background:radial-gradient(circle at 30% 20%,#3A1D6E 0%,var(--ink) 55%,#160C2B 100%);
  color:var(--paper);overflow:hidden;user-select:none;-webkit-user-select:none;}
.screen{position:fixed;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;
  padding:max(22px,env(safe-area-inset-top)) 22px max(22px,env(safe-area-inset-bottom));text-align:center;animation:fade .35s ease;}
.screen.active{display:flex;}
.scroll{justify-content:flex-start;overflow-y:auto;}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.logo{font-family:'Fredoka',sans-serif;font-weight:700;letter-spacing:-1px;line-height:.92;}
.logo .big{display:block;font-size:clamp(48px,16vw,120px);
  background:linear-gradient(95deg,var(--gold),var(--coral) 55%,var(--pink));
  -webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 6px 0 rgba(0,0,0,.18));}
.tagline{margin-top:14px;font-size:18px;font-weight:700;opacity:.82;max-width:340px;}

.btn{font-family:'Fredoka',sans-serif;font-weight:600;border:none;border-radius:22px;padding:16px 30px;font-size:21px;
  color:var(--ink);cursor:pointer;box-shadow:0 8px 0 rgba(0,0,0,.22);transition:transform .08s,box-shadow .08s;}
.btn:active{transform:translateY(5px);box-shadow:0 3px 0 rgba(0,0,0,.22);}
.btn-primary{background:linear-gradient(180deg,var(--gold),#FFB01F);}
.btn-ghost{background:rgba(255,255,255,.10);color:var(--paper);box-shadow:none;border:2px solid rgba(255,255,255,.22);}
.btn-sm{padding:11px 18px;font-size:16px;border-radius:16px;box-shadow:0 5px 0 rgba(0,0,0,.2);}
.btn-row{display:flex;gap:12px;margin-top:26px;flex-wrap:wrap;justify-content:center;}

.h2{font-family:'Fredoka',sans-serif;font-weight:600;font-size:25px;margin-bottom:6px;}
.sub{opacity:.7;font-size:15px;margin-bottom:18px;max-width:430px;}

.decks{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px;width:100%;max-width:480px;}
.deck{border:none;border-radius:22px;padding:18px 14px;cursor:pointer;color:var(--ink);text-align:left;
  font-family:'Fredoka',sans-serif;box-shadow:0 6px 0 rgba(0,0,0,.18);transition:transform .08s;
  min-height:112px;display:flex;flex-direction:column;justify-content:space-between;position:relative;}
.deck:active{transform:translateY(4px);}
.deck .ico{font-size:32px;}
.deck .name{font-weight:600;font-size:18px;line-height:1.05;}
.deck .cnt{font-family:'Nunito';font-weight:700;font-size:12px;opacity:.65;}
.deck.add{background:rgba(255,255,255,.07);color:var(--paper);border:2px dashed rgba(255,255,255,.35);
  box-shadow:none;align-items:center;justify-content:center;text-align:center;}
.deck.add .ico{font-size:30px;}
.deck .edit-btn{position:absolute;top:8px;right:10px;font-size:15px;background:rgba(0,0,0,.18);
  border-radius:10px;padding:2px 7px;color:#fff;cursor:pointer;}

.time-pick{display:flex;gap:10px;margin:6px 0 16px;flex-wrap:wrap;justify-content:center;}
.chip{border:2px solid rgba(255,255,255,.25);background:transparent;color:var(--paper);border-radius:999px;
  padding:7px 15px;font-family:'Fredoka';font-weight:600;font-size:15px;cursor:pointer;}
.chip.on{background:var(--paper);color:var(--ink);border-color:var(--paper);}

.ready-card{background:rgba(0,0,0,.18);border-radius:26px;padding:24px;max-width:430px;}
.ready-card ul{list-style:none;text-align:left;margin-top:12px;display:grid;gap:11px;}
.ready-card li{display:flex;gap:11px;align-items:flex-start;font-size:15px;font-weight:600;}
.ready-card li b{color:var(--gold);}
.arrow{font-size:21px;line-height:1;}

#countdown{font-family:'Fredoka';font-weight:700;font-size:clamp(120px,40vw,260px);color:var(--gold);
  filter:drop-shadow(0 8px 0 rgba(0,0,0,.2));animation:pop .6s ease;}
@keyframes pop{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}

#game{padding:0;}
#game .word{font-family:'Fredoka',sans-serif;font-weight:700;font-size:clamp(46px,11vw,120px);line-height:1;padding:0 16px;word-break:break-word;}
#game .emoji{font-size:clamp(110px,30vw,260px);line-height:1;}
#game img.photo{max-width:78vw;max-height:60vh;border-radius:20px;box-shadow:0 12px 40px rgba(0,0,0,.4);}
#game .photo-cap{font-family:'Fredoka';font-weight:600;font-size:clamp(24px,6vw,56px);margin-top:10px;}
#game .badge{position:absolute;top:max(16px,env(safe-area-inset-top));left:50%;transform:translateX(-50%);
  font-family:'Fredoka';font-weight:600;font-size:14px;letter-spacing:1px;text-transform:uppercase;opacity:.7;}
#timer{position:absolute;top:0;left:0;height:8px;background:var(--gold);width:100%;transition:background .3s;}
#score{position:absolute;top:max(40px,calc(env(safe-area-inset-top) + 28px));right:24px;font-family:'Fredoka';font-weight:700;font-size:30px;}
.flash{position:fixed;inset:0;opacity:0;pointer-events:none;z-index:5;display:flex;align-items:center;justify-content:center;
  font-family:'Fredoka';font-weight:700;font-size:clamp(50px,15vw,140px);color:#fff;}
.flash.show{animation:flash .6s ease;}
@keyframes flash{0%{opacity:1}80%{opacity:1}100%{opacity:0}}
.tap-help{position:absolute;bottom:max(18px,env(safe-area-inset-bottom));left:0;right:0;display:flex;justify-content:space-between;padding:0 24px;font-weight:700;font-size:13px;opacity:.45;}

.result-list{width:100%;max-width:420px;margin-top:16px;display:grid;gap:8px;max-height:42vh;overflow:auto;}
.result-item{display:flex;align-items:center;gap:10px;background:rgba(0,0,0,.18);border-radius:14px;padding:9px 13px;font-weight:700;font-size:16px;text-align:left;}
.result-item .mk{font-size:20px;}
.ok{color:var(--mint);}
.no{color:var(--coral);opacity:.85;}
.score-big{font-family:'Fredoka';font-weight:700;font-size:78px;color:var(--gold);line-height:1;}

/* РЕДАКТОР */
#editor{padding-top:max(26px,env(safe-area-inset-top));}
.ed-wrap{width:100%;max-width:480px;display:grid;gap:14px;}
.field{background:rgba(0,0,0,.18);border-radius:18px;padding:14px;text-align:left;}
.field label{display:block;font-family:'Fredoka';font-weight:600;font-size:14px;opacity:.8;margin-bottom:8px;}
.input,textarea{width:100%;background:rgba(255,255,255,.08);border:2px solid rgba(255,255,255,.18);border-radius:12px;
  color:var(--paper);font-family:'Nunito';font-weight:700;font-size:16px;padding:11px 13px;outline:none;}
.input:focus,textarea:focus{border-color:var(--gold);}
textarea{min-height:120px;resize:vertical;line-height:1.5;}
.row{display:flex;gap:10px;flex-wrap:wrap;}
.picker{display:flex;gap:8px;flex-wrap:wrap;}
.swatch{width:34px;height:34px;border-radius:10px;border:3px solid transparent;cursor:pointer;}
.swatch.on{border-color:#fff;}
.icobtn{font-size:22px;width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.08);border:2px solid transparent;cursor:pointer;}
.icobtn.on{border-color:var(--gold);background:rgba(255,200,69,.15);}
.tabs{display:flex;gap:8px;}
.tab{flex:1;padding:10px;border-radius:14px;background:rgba(255,255,255,.06);border:none;color:var(--paper);
  font-family:'Fredoka';font-weight:600;font-size:15px;cursor:pointer;}
.tab.on{background:var(--paper);color:var(--ink);}
.ai-box{background:linear-gradient(135deg,rgba(198,160,255,.18),rgba(108,139,255,.12));
  border:2px solid rgba(198,160,255,.35);border-radius:18px;padding:14px;text-align:left;}
.ai-box .title{font-family:'Fredoka';font-weight:600;font-size:15px;margin-bottom:8px;display:flex;align-items:center;gap:6px;}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px;}
.gcell{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;background:rgba(255,255,255,.06);}
.gcell img{width:100%;height:100%;object-fit:cover;}
.gcell .cap{position:absolute;left:0;right:0;bottom:0;background:rgba(0,0,0,.55);font-size:10px;font-weight:700;padding:3px 4px;}
.gcell .del{position:absolute;top:3px;right:3px;background:rgba(0,0,0,.6);border-radius:8px;font-size:12px;padding:1px 6px;cursor:pointer;}
.gadd{aspect-ratio:1;border:2px dashed rgba(255,255,255,.35);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:30px;cursor:pointer;color:var(--paper);background:transparent;}
.hint{font-size:12px;opacity:.55;margin-top:6px;}
.spin{display:inline-block;width:16px;height:16px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.mini-note{position:fixed;bottom:6px;left:0;right:0;text-align:center;font-size:11px;opacity:.4;}

/* РЕЖИМЫ */
.modes{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:440px;margin-top:16px;}
.mode-btn{background:rgba(255,255,255,.08);border:2px solid rgba(255,255,255,.18);border-radius:20px;
  padding:18px 12px;cursor:pointer;color:var(--paper);font-family:'Fredoka';font-weight:600;font-size:16px;
  text-align:center;transition:transform .08s,background .15s;}
.mode-btn:active{transform:translateY(3px);}
.mode-btn.highlight{background:rgba(255,200,69,.15);border-color:var(--gold);}
.mode-btn .mode-ico{font-size:36px;display:block;margin-bottom:8px;}

/* ДУЭЛЬ */
#duel-lobby{padding:20px;}
.code-display{font-family:'Fredoka';font-weight:700;font-size:clamp(40px,12vw,80px);
  color:var(--gold);letter-spacing:4px;background:rgba(0,0,0,.2);border-radius:20px;padding:16px 30px;margin:16px 0;}
.code-input-wrap{display:flex;gap:10px;margin-top:10px;}
.code-input{text-transform:uppercase;letter-spacing:4px;text-align:center;font-size:24px;width:180px;}
.duel-status{font-size:14px;opacity:.7;margin-top:12px;min-height:20px;}
.duel-scores{display:flex;gap:30px;align-items:center;justify-content:center;margin:10px 0;font-family:'Fredoka';font-size:36px;font-weight:700;}
.duel-scores .vs{font-size:18px;opacity:.5;}

/* УСТАНОВИТЬ КАК ПРИЛОЖЕНИЕ */
.install-bar{position:fixed;bottom:0;left:0;right:0;background:rgba(30,10,60,.95);padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:100;
  border-top:1px solid rgba(255,255,255,.12);}
.install-bar p{font-size:14px;font-weight:700;flex:1;}
