@font-face{font-family:'Fredoka One';src:url('fonts/FredokaOne-Regular.ttf') format('truetype');font-weight:400;}
@font-face{font-family:'Nunito';src:url('fonts/Nunito-Regular.ttf') format('truetype');font-weight:700;}
@font-face{font-family:'Nunito';src:url('fonts/Nunito-Regular.ttf') format('truetype');font-weight:800;}
@font-face{font-family:'Nunito';src:url('fonts/Nunito-Regular.ttf') format('truetype');font-weight:900;}

:root{
  --bg:#FFF8E7;--primary:#FF6B6B;--secondary:#4ECDC4;--accent:#FFE66D;
  --purple:#A855F7;--green:#6BCB77;--blue:#4D96FF;--orange:#FF9F1C;
  --pink:#FF9FDB;--teal:#1ABC9C;--red:#E74C3C;
  --cell-size:clamp(24px,5vmin,38px);
  --font-title:'Fredoka One',cursive;--font-body:'Nunito',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--bg);font-family:var(--font-body);min-height:100vh;display:flex;flex-direction:column;align-items:center;overflow-x:hidden;background-image:radial-gradient(circle at 15% 15%,#FFE0E055 0%,transparent 45%),radial-gradient(circle at 85% 80%,#D4F0FF55 0%,transparent 45%),radial-gradient(circle at 50% 50%,#FFFBE044 0%,transparent 60%);}

/* CLOUDS */
.cloud{position:fixed;border-radius:50px;background:rgba(255,255,255,.65);animation:floatCloud linear infinite;pointer-events:none;z-index:0;}
.cloud::before,.cloud::after{content:'';position:absolute;background:rgba(255,255,255,.65);border-radius:50%;}
.cloud::before{width:60%;height:160%;top:-80%;left:15%;}
.cloud::after{width:40%;height:130%;top:-65%;left:50%;}
@keyframes floatCloud{from{transform:translateX(-250px)}to{transform:translateX(calc(100vw + 250px))}}

.screen{display:none;width:100%;max-width:960px;padding:20px;}
.screen.active{display:flex;flex-direction:column;align-items:center;}

/* ══ LANG SELECT ══ */
#langselect{justify-content:center;align-items:center;min-height:100vh;gap:28px;position:relative;z-index:1;padding-bottom:60px;}
.lang-logo{font-family:var(--font-title);font-size:clamp(48px,11vw,88px);color:var(--primary);text-shadow:5px 5px 0 #FF9E9E,10px 10px 0 rgba(0,0,0,.06);animation:logoFloat 3s ease-in-out infinite;letter-spacing:2px;text-align:center;}
@keyframes logoFloat{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-12px) rotate(1.5deg)}}
.lang-tagline{font-family:var(--font-title);font-size:clamp(13px,3vw,19px);color:var(--secondary);letter-spacing:4px;text-transform:uppercase;text-align:center;}
.lang-pick-label{font-family:var(--font-title);font-size:clamp(16px,4vw,24px);color:#ccc;letter-spacing:2px;}
.menu-stars{font-size:34px;letter-spacing:10px;animation:starBounce 1.4s ease-in-out infinite;}
@keyframes starBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* FLAG GRID — 3 columns of pure flag buttons */
.lang-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  width:100%;max-width:440px;
}
.lang-choice{
  background:white;
  border:4px solid #eee;
  border-radius:28px;
  padding:18px 8px 14px;
  text-align:center;cursor:pointer;
  transition:all .22s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 7px 0 rgba(0,0,0,.09);
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.lang-choice .lc-flag{
  font-size:62px;
  line-height:1;
  filter:drop-shadow(0 3px 6px rgba(0,0,0,.15));
  transition:transform .2s cubic-bezier(.34,1.56,.64,1);
}
.lang-choice .lc-name{
  font-family:var(--font-title);
  font-size:15px;
  color:#bbb;
  letter-spacing:1px;
}
.lang-choice:hover{
  transform:translateY(-10px) scale(1.08);
  box-shadow:0 18px 0 rgba(0,0,0,.08);
  border-color:var(--secondary);
}
.lang-choice:hover .lc-flag{ transform:scale(1.15) rotate(-5deg); }
.lang-choice:active{transform:translateY(0) scale(.97);box-shadow:0 3px 0 rgba(0,0,0,.08);}

/* ══ MENU ══ */
#menu{justify-content:center;min-height:100vh;gap:18px;position:relative;z-index:1;padding-bottom:60px;padding-top:20px;}
.logo{font-family:var(--font-title);font-size:clamp(40px,9vw,78px);color:var(--primary);text-shadow:4px 4px 0 #FF9E9E,8px 8px 0 rgba(0,0,0,.07);animation:logoFloat 3s ease-in-out infinite;letter-spacing:2px;}
.logo-sub{font-family:var(--font-title);font-size:clamp(13px,3vw,19px);color:var(--secondary);letter-spacing:5px;text-transform:uppercase;margin-top:-12px;}
.menu-label{font-weight:800;color:#bbb;font-size:14px;letter-spacing:1px;}

.top-bar{display:flex;justify-content:space-between;width:100%;max-width:640px;align-items:center;}
.icon-btn{background:white;border:2.5px solid #eee;border-radius:50px;padding:7px 16px;font-family:var(--font-body);font-weight:900;font-size:15px;cursor:pointer;transition:all .15s;color:#aaa;display:flex;align-items:center;gap:6px;}
.icon-btn:hover{border-color:var(--secondary);color:var(--secondary);}
.icon-btn.playing{border-color:var(--green);color:var(--green);}

.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;width:100%;max-width:680px;}
.cat-btn{background:white;border:3px solid transparent;border-radius:20px;padding:18px 8px;text-align:center;cursor:pointer;transition:all .18s cubic-bezier(.34,1.56,.64,1);box-shadow:0 5px 0 rgba(0,0,0,.09);font-family:var(--font-body);font-weight:900;font-size:14px;position:relative;overflow:hidden;}
.cat-btn::before{content:'';position:absolute;inset:0;background:currentColor;opacity:0;transition:opacity .15s;border-radius:18px;}
.cat-btn:hover{transform:translateY(-6px);box-shadow:0 10px 0 rgba(0,0,0,.09);}
.cat-btn:hover::before{opacity:.06;}
.cat-btn:active{transform:translateY(0);box-shadow:0 2px 0 rgba(0,0,0,.09);}
.cat-btn .cat-emoji{font-size:34px;display:block;margin-bottom:7px;}
.cat-btn.animals{border-color:var(--green);color:var(--green);}
.cat-btn.food{border-color:var(--orange);color:var(--orange);}
.cat-btn.space{border-color:var(--purple);color:var(--purple);}
.cat-btn.ocean{border-color:var(--blue);color:var(--blue);}
.cat-btn.colors{border-color:var(--primary);color:var(--primary);}
.cat-btn.cartoons{border-color:var(--red);color:var(--red);}
.cat-btn.jobs{border-color:var(--teal);color:var(--teal);}
.cat-btn.countries{border-color:#F39C12;color:#F39C12;}

/* MAPI FOOTER */
.mapi-footer{position:fixed;bottom:10px;left:50%;transform:translateX(-50%);font-family:var(--font-title);font-size:14px;color:var(--red);letter-spacing:3px;text-transform:uppercase;z-index:10;pointer-events:none;opacity:.8;}

/* ══ GAME ══ */
#game{padding:12px;gap:12px;position:relative;z-index:1;padding-bottom:50px;}
.game-header{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:700px;}
.back-btn{background:white;border:3px solid #e8e8e8;border-radius:50px;padding:8px 16px;font-family:var(--font-body);font-weight:800;font-size:13px;cursor:pointer;transition:all .15s;color:#aaa;}
.back-btn:hover{border-color:var(--primary);color:var(--primary);}
.game-title{font-family:var(--font-title);font-size:20px;color:#555;}
.timer-box{background:var(--accent);border-radius:50px;padding:8px 16px;font-family:var(--font-title);font-size:19px;color:#aa8800;box-shadow:0 3px 0 rgba(0,0,0,.09);min-width:70px;text-align:center;}
.progress-wrap{width:100%;max-width:540px;background:#eee;border-radius:50px;height:14px;overflow:hidden;box-shadow:inset 0 2px 4px rgba(0,0,0,.06);}
.progress-bar{height:100%;background:linear-gradient(90deg,var(--secondary),var(--green));border-radius:50px;transition:width .5s cubic-bezier(.34,1.56,.64,1);}

.game-area{display:flex;gap:16px;width:100%;max-width:800px;flex-wrap:wrap;justify-content:center;}
.grid-container{background:white;border-radius:24px;padding:14px;box-shadow:0 7px 0 rgba(0,0,0,.07),0 0 0 3px #f0f0f0;user-select:none;-webkit-user-select:none;touch-action:none;position:relative;}
#grid{display:grid;gap:2px;}
.cell{width:var(--cell-size);height:var(--cell-size);display:flex;align-items:center;justify-content:center;font-family:var(--font-title);font-size:clamp(11px,2.6vmin,17px);color:#777;border-radius:8px;cursor:pointer;transition:background .1s,transform .12s,color .1s;background:#f8f8f8;position:relative;}
.cell.selected{background:var(--accent)!important;color:#554400!important;transform:scale(1.15);z-index:3;}

/* FOUND COLORS */
.cell.found-0{background:#FF8A8A!important;color:white!important}
.cell.found-1{background:#5EC8C3!important;color:white!important}
.cell.found-2{background:#70AFFF!important;color:white!important}
.cell.found-3{background:#B87FFF!important;color:white!important}
.cell.found-4{background:#65D475!important;color:white!important}
.cell.found-5{background:#FF9C50!important;color:white!important}
.cell.found-6{background:#FF80C8!important;color:white!important}
.cell.found-7{background:#40D4D4!important;color:white!important}
.cell.found-8{background:#F0956A!important;color:white!important}
.cell.found-9{background:#90CC90!important;color:white!important}

/* WORD FOUND ANIMATION on cell */
@keyframes cellPop{0%{transform:scale(1)}40%{transform:scale(1.35)}70%{transform:scale(0.92)}100%{transform:scale(1)}}
.cell.pop{animation:cellPop .4s cubic-bezier(.34,1.56,.64,1);}

@keyframes hintPulse{0%,100%{background:#f8f8f8;transform:scale(1)}50%{background:var(--accent);transform:scale(1.2)}}
.cell.hint-flash{animation:hintPulse .55s ease-in-out 4;}

/* WORD FOUND RIBBON */
@keyframes ribbonIn{0%{transform:translateX(-50%) scale(.4) translateY(20px);opacity:0}60%{transform:translateX(-50%) scale(1.1) translateY(-4px);opacity:1}100%{transform:translateX(-50%) scale(1) translateY(0);opacity:1}}
@keyframes ribbonOut{to{transform:translateX(-50%) translateY(-30px);opacity:0}}
.found-ribbon{
  position:fixed;left:50%;bottom:calc(50% - 20px);
  background:white;
  border-radius:50px;padding:10px 28px;
  font-family:var(--font-title);font-size:clamp(18px,5vw,28px);
  box-shadow:0 8px 30px rgba(0,0,0,.12);
  pointer-events:none;z-index:500;
  white-space:nowrap;
  animation:ribbonIn .35s cubic-bezier(.34,1.56,.64,1) forwards;
  border:3px solid transparent;
}
.found-ribbon.out{animation:ribbonOut .4s ease-in forwards;}

/* SCORE POP */
@keyframes scorePop{0%{transform:translateX(-50%) translateY(0) scale(.5);opacity:0}50%{opacity:1;transform:translateX(-50%) translateY(-30px) scale(1.2)}100%{transform:translateX(-50%) translateY(-60px) scale(1);opacity:0}}
.score-pop{position:fixed;font-family:var(--font-title);font-size:26px;pointer-events:none;z-index:600;animation:scorePop .9s ease-out forwards;}

/* WORD LIST */
.word-list{background:white;border-radius:24px;padding:18px;box-shadow:0 7px 0 rgba(0,0,0,.07),0 0 0 3px #f0f0f0;min-width:155px;flex:1;max-width:215px;display:flex;flex-direction:column;gap:3px;}
.word-list h3{font-family:var(--font-title);font-size:15px;color:#ccc;text-align:center;letter-spacing:2px;margin-bottom:8px;}
.word-item{display:flex;align-items:center;gap:9px;padding:7px 11px;border-radius:11px;font-weight:900;font-size:13px;color:#666;transition:all .35s;background:#f8f8f8;}
.word-item .dot{width:9px;height:9px;border-radius:50%;background:#ddd;flex-shrink:0;transition:background .4s,transform .4s;}
.word-item.found{text-decoration:line-through;color:#ccc;background:#f4f4f4;}
.word-item.found .dot{background:var(--green);transform:scale(1.4);}
@keyframes wordItemFound{0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)}}
.word-item.just-found{animation:wordItemFound .5s cubic-bezier(.34,1.56,.64,1);}

.btn-row{display:flex;gap:8px;margin-top:auto;padding-top:12px;}
.btn{background:var(--secondary);color:white;border:none;border-radius:50px;padding:9px 16px;font-family:var(--font-body);font-weight:800;font-size:13px;cursor:pointer;box-shadow:0 4px 0 rgba(0,0,0,.11);transition:all .15s;flex:1;text-align:center;}
.btn:hover{transform:translateY(-2px);box-shadow:0 6px 0 rgba(0,0,0,.11);}
.btn:active{transform:translateY(0);box-shadow:0 2px 0 rgba(0,0,0,.11);}
.btn.hint{background:var(--orange)}.btn.next{background:var(--green)}.btn.menu-btn{background:#bbb}

/* WIN OVERLAY */
#win-overlay{display:none;position:fixed;inset:0;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);z-index:100;flex-direction:column;align-items:center;justify-content:center;gap:18px;}
#win-overlay.show{display:flex;}
.win-emoji{font-size:86px;animation:spinIn .55s cubic-bezier(.34,1.56,.64,1);}
@keyframes spinIn{from{transform:rotate(-200deg) scale(0);opacity:0}to{transform:rotate(0) scale(1);opacity:1}}
.win-title{font-family:var(--font-title);font-size:clamp(44px,10vw,68px);color:var(--primary);text-shadow:4px 4px 0 #FF9E9E;animation:logoFloat 2s ease-in-out infinite;}
.win-stars{font-size:42px;letter-spacing:10px;animation:starBounce 1s ease-in-out infinite;}
.win-stats{font-weight:800;font-size:17px;color:#aaa;background:#f8f8f8;padding:12px 26px;border-radius:16px;}

/* PARTICLES & CONFETTI */
.particle{position:fixed;pointer-events:none;z-index:400;animation:pFly var(--dur,.9s) ease-out forwards;}
@keyframes pFly{0%{transform:translate(0,0) rotate(0deg) scale(1);opacity:1}100%{transform:translate(var(--tx),var(--ty)) rotate(var(--tr)) scale(0);opacity:0}}
.ring-particle{position:fixed;pointer-events:none;z-index:400;border-radius:50%;animation:ringOut .6s ease-out forwards;}
@keyframes ringOut{0%{transform:translate(-50%,-50%) scale(0);opacity:.9}100%{transform:translate(-50%,-50%) scale(1);opacity:0}}

/* ══ PAUSE OVERLAY ══ */
#pause-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(255,248,231,.94);backdrop-filter:blur(14px);
  z-index:300;flex-direction:column;
  align-items:center;justify-content:center;gap:20px;
  cursor:pointer;
}
#pause-overlay.show{display:flex;}
.pause-icon{font-size:80px;animation:starBounce 1.2s ease-in-out infinite;}
.pause-title{font-family:var(--font-title);font-size:clamp(44px,10vw,66px);color:var(--secondary);text-shadow:4px 4px 0 #9EDBD8;}
.pause-sub{font-family:var(--font-title);font-size:18px;color:#bbb;letter-spacing:2px;}
#rotate-overlay{
  display:none;position:fixed;inset:0;
  background:#FFF8E7;z-index:9999;
  flex-direction:column;align-items:center;justify-content:center;gap:18px;
}
#rotate-overlay .rot-icon{font-size:80px;animation:rotAnim 1.8s ease-in-out infinite;}
@keyframes rotAnim{0%,100%{transform:rotate(0deg)}40%{transform:rotate(90deg)}60%{transform:rotate(90deg)}}
#rotate-overlay p{font-family:var(--font-title);font-size:22px;color:#aaa;text-align:center;padding:0 30px;}

/* ══ DIFFICULTY PILLS ══ */
.diff-row{display:flex;gap:10px;align-items:center;}
.diff-label{font-family:var(--font-title);font-size:15px;color:#ccc;letter-spacing:1px;}
.diff-btn{
  background:white;border:3px solid #eee;border-radius:50px;
  padding:8px 22px;font-family:var(--font-title);font-size:15px;
  cursor:pointer;transition:all .18s cubic-bezier(.34,1.56,.64,1);
  color:#bbb;box-shadow:0 4px 0 rgba(0,0,0,.07);
}
.diff-btn:hover{transform:translateY(-3px);box-shadow:0 7px 0 rgba(0,0,0,.07);}
.diff-btn.active-normal{border-color:var(--green);color:var(--green);background:#f0fff4;}
.diff-btn.active-hard{border-color:var(--red);color:var(--red);background:#fff0f0;}

/* ══ TIMER DANGER (countdown < 15s) ══ */
.timer-box.danger{
  background:var(--red);color:white;
  animation:timerShake .15s ease-in-out infinite alternate;
}
@keyframes timerShake{from{transform:translateX(-2px)}to{transform:translateX(2px)}}

/* ══ GAME OVER OVERLAY ══ */
#gameover-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(30,10,10,.88);backdrop-filter:blur(10px);
  z-index:200;flex-direction:column;
  align-items:center;justify-content:center;gap:18px;
}
#gameover-overlay.show{display:flex;}
.go-emoji{font-size:80px;animation:spinIn .5s cubic-bezier(.34,1.56,.64,1);}
.go-title{font-family:var(--font-title);font-size:clamp(44px,10vw,68px);color:var(--red);text-shadow:4px 4px 0 #8B0000;}
.go-sub{font-family:var(--font-title);font-size:20px;color:#eee;}

/* ══ LEADERBOARD SCREEN ══ */
#leaderboard{justify-content:flex-start;min-height:100vh;gap:16px;position:relative;z-index:1;padding-bottom:60px;padding-top:20px;}
.lb-header{display:flex;justify-content:space-between;width:100%;max-width:500px;align-items:center;}
.lb-title{font-family:var(--font-title);font-size:clamp(28px,7vw,44px);color:var(--primary);text-shadow:3px 3px 0 #FF9E9E;}
.lb-cat-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;width:100%;max-width:600px;}
.lb-tab{
  background:white;border:2.5px solid #eee;border-radius:50px;
  padding:6px 14px;font-family:var(--font-body);font-weight:900;font-size:13px;
  cursor:pointer;transition:all .15s;color:#aaa;
}
.lb-tab.active{background:var(--accent);border-color:var(--orange);color:#886600;}
.lb-tab:hover{border-color:var(--secondary);color:var(--secondary);}
.lb-table{
  width:100%;max-width:500px;
  background:white;border-radius:24px;
  padding:20px;box-shadow:0 7px 0 rgba(0,0,0,.07),0 0 0 3px #f0f0f0;
}
.lb-row{
  display:flex;align-items:center;gap:12px;
  padding:10px 8px;border-radius:12px;
  font-family:var(--font-body);font-weight:900;font-size:15px;
  transition:background .2s;
}
.lb-row:nth-child(odd){background:#fafafa;}
.lb-rank{
  font-family:var(--font-title);font-size:22px;
  width:36px;text-align:center;flex-shrink:0;
}
.lb-row.rank-1 .lb-rank{color:gold;}
.lb-row.rank-2 .lb-rank{color:silver;}
.lb-row.rank-3 .lb-rank{color:#cd7f32;}
.lb-time{margin-left:auto;font-family:var(--font-title);font-size:18px;color:var(--secondary);}
.lb-diff-badge{
  font-size:11px;padding:2px 8px;border-radius:20px;font-weight:800;
}
.lb-diff-badge.hard{background:#ffe0e0;color:var(--red);}
.lb-diff-badge.normal{background:#e0fff4;color:var(--green);}
.lb-empty{text-align:center;color:#ccc;font-family:var(--font-title);font-size:18px;padding:30px 0;}
.lb-new-record{
  background:linear-gradient(135deg,var(--accent),#FFD700);
  border-radius:16px;padding:10px 24px;
  font-family:var(--font-title);font-size:18px;color:#886600;
  box-shadow:0 4px 0 rgba(0,0,0,.1);
  animation:starBounce .8s ease-in-out infinite;
}

@media(max-width:620px){
  .game-area{flex-direction:column;align-items:center}
  .word-list{max-width:100%;width:100%}
  .lang-grid{grid-template-columns:repeat(3,1fr);}
}
/* Block landscape ONLY on real mobile touch devices */
@media screen and (max-height:500px) and (orientation:landscape){
  #rotate-overlay.mobile-only{display:flex;}
}
